# CMOS single-chip 8-bit MCU with 12-bit A/D converter and CEC Controller #### **Main features** - 8-bit Microcontroller With High Speed 8051 CPU - Basic MCU Function - 64KB Flash Code Memory - 4,352 bytes SRAM - 2KB Data EEPROM - Built-in Analog Function - Power-On Reset and Low Voltage Detect Reset - Internal 16MHz RC Oscillator (±1.5%, T<sub>A</sub> = 0 ~ +50°C) - Watchdog Timer RC Oscillator (256kHz) #### • Peripheral Features - 12-bit Analog to Digital Converter (10 inputs) - USART 8-bit x 2-ch - SPI 8-bit x 2-ch - I2C 8-bit x 2-ch - Hardware CEC Controller - Hardware IR Receiver #### I/O and Packages - Up to 46 programmable I/O lines with 48-LQFP - 48-LQFP - . Operating Conditions - 2.7V to 5.5V Wide Voltage Range - 40°C to 85°C Temperature Range - Application - Home Appliance # A97C450 User's manual V 1.02 # **Revision History** | Version | Date | Revision list | |---------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1.00 | 2017.08.11 | The First Edition. | | 1.01 | 2017.10.26 | Maximum value of IDD6 (STOP2) is added in "Table 7.9 DC Characteristics". The content of flowchart is changed in "Figure 11.64 Procedure for Reading RTC". Note about the writing to I2CSR is added in "11.12.11" | | 1.02 | 2018.01.31 | Add Device Nomenclature. Awake-up interrupt from power down mode is removed in 11.14. Fix 11.17.9 RTC Register description (YEAR Register bit (Address 0x8FBA)). | #### Version 1.02 #### Published by AE team 2018 ABOV Semiconductor Co. Ltd. all rights reserved. Additional information of this manual may be served by ABOV Semiconductor offices in Korea or distributors. ABOV Semiconductor reserves the right to make changes to any information here in at any time without notice. The information, diagrams and other data in this manual are correct and reliable. However, ABOV Semiconductor is in no way responsible for any violations of patents or other rights of the third party generated by the use of this manual. For more information, please visit ABOV's website (http://www.abov.co.kr). # 1 Overview # 1.1. Description The A97C450 is advanced CMOS 8-bit microcontroller with FLASH (64KB) and EEPROM (2KB). This is powerful microcontroller which provides a highly flexible and cost effective solution to many embedded control applications. This provides the following features: 64KB of FLASH, 2KB of Data EEPROM, 256 bytes of SRAM, 4,096 bytes of XRAM, general purpose I/O, 8/16-bit timer/counter, watchdog timer, watch timer, RTC with calendar, SPI, USART, I2C, on-chip POR and LVI, 12-bit A/D converter, analog comparator, buzzer driving port, 8/16-bit PWM output, on-chip oscillator, CEC, IR receiver and clock circuitry. The A97C450 also supports power saving modes to reduce power consumption. # 1.2 Ordering information | Device Name | Flash | XRAM | IRAM | EEPROM | ADC | I/O PORT | Package | |-------------|-------|-------------|-----------|--------|-----------|----------|---------| | A97C450CLN | 64KB | 4,096 bytes | 256 bytes | 2KB | 10 inputs | 46 | 48-LQFP | Table 1.1Ordering Information of A97C450 Figure 1.1 Device Nomenclature #### 1.3 Features - CPU - 8-bit CISC core (M8051, 2 clocks per cycle) - ROM (FLASH) Capacity - 64KB Flash with self-read and write capability - In-System Programming(ISP) - Endurance: 10,000 times - Retention: 10 years - 2KB On-chip EEPROM - Endurance: 300,000 times - Retention: 10 years - 256 bytes IRAM / 4,096 bytes XRAM - General Purpose I/O (GPIO) - Normal I/O: 46 Ports (P0, P1, P2, P3, P4, P5[5:0]) - Boot Loader Protection with Boot Swap - External stack with stack overflow interrupt - Hardware CEC - Hardware IR Receiver with Noise Filter - Timer/Counter - Basic Interval Timer (BIT) 8-bit × 1-ch - Watch Dog Timer (WDT) 8-bit × 1-ch 256kHz internal RC oscillator for WDT - 8-bit × 2-ch (T0/T1) - 16-bit × 5-ch (T2/T3/T4/T5/T6) - Programmable Pulse Generation - Pulse generation (by T2/T3/T4/T5/T6) - 8-bit PWM (by T0/T1) - Watch Timer (WT) - 3.91ms/0.25s/0.5s/1s /1min interval at 32.768kHz - RTC with 100 Year Calendar - Buzzer - 8-bit × 1-ch - SPI - 8-bit × 2-ch - USART - 8-bit USART × 2-ch - I2C - I2C × 2-ch - 12-bit A/D Converter - 10 Input channels - Analog Comparator - 2 Internal Comparator - Power On Reset - Reset release level (1.4V) - Low Voltage Reset - 1.6V - Low Voltage Indicator - 3 levels detect (2.4V / 2.8V / 3.5V) - Interrupt Sources - External Interrupts (EINT0, EINT1, EINT2~4, EINT5~7) (4) - Timer(0/1/2/3/4~6) (5) - CEC (1) - IR (1) - USART (4), SPI (2), I2C (2) - WDT (1) - WT(1) - RTC (1) - BIT (1) - ADC (1) - EEPROM (1) - LVI (1) - Analog comparator (1) - CRC (1) - Stack OVF (1) - Internal RC Oscillator - Internal RC frequency: 16MHz ±1.5% (T<sub>A</sub>= 0 ~ +50°C) - Power Down Mode - STOP1/2. SLEEP1/2. IDLE mode - Operating Voltage and Frequency - 2.7V~ 5.5V (@ 32 ~ 38kHz with Sub Crystal) - 2.7V~ 5.5V (@ 0.4 ~ 12.0MHz with Crystal) - 2.7V~ 5.5V (@ 1.0 ~ 16.0MHz with Internal RC) - Voltage dropout converter included for core - Minimum Instruction Execution Time - 125ns (@16MHz clock) - Operating Temperature - -40 ~ +85°C - Oscillator Type - 0.4 12MHz Crystal or Ceramic for main clock - 32.768kHz Crystal for sub clock - Package Type - 48-LQFP # 1.4 Development tools #### 1.4.1 Compiler ABOV Semiconductor does not provide compiler. It is recommended that you consult a compiler provider. The A97C450 core is Mentor 8051 and the ROM size is smaller than 64KB. Therefore, developer can use the standard 8051 compiler from other providers. #### 1.4.2 OCD(On-chip debugger) emulator and debugger The OCD (On Chip Debug) emulator supports ABOV Semiconductor's 8051 series MCU emulation. The OCD interface uses two-wire connection between PC and MCU which is attached to user's system. The OCD can read or change the value of MCU internal memory and I/O peripherals. And the OCD also controls MCU internal debugging logic, it means OCD controls emulation, step run, monitoring, etc. The OCD debugger program works on Microsoft-Windows NT, 2000, XP, Vista (32-bit), 7, 8, 10 operating system. If you want to see more details, please refer to OCD debugger manual. You can download debugger S/W and manual from our web-site (http://www.abov.co.kr). #### Connection: - DSCL (A97C450 P36 port) - DSDA (A97C450 P37 port) OCD connector diagram: Connect OCD with user system Figure 1.2 debugger and pin description #### OCD2 (On Chip Debug) Emulator - MCU emulation control via 2pin or 3pin OCD interface. - 2pin interface : OCD2 clock & data. - 1pin option interface - Support device OCD2 mode entry during user S/W is running. - Support exact emulation time measurement. - Higher interface speed than OCD dongle. - Support newly added debugging specifications. - Compact size. - · Cost effective emulator. - Emulation & debugging on the target system directly. - · Real time emulation. - PC interface : USB. #### Debugger - Operates with OCD and OCD2 emulator H/W. - Integrated Development Environment (IDE). Support docking windows and menus. - Support Free run, Step run, auto step run. - Support Symbolic debugging. - Support Source level debugging. Figure 1.3 OCD Debugger #### **Support Devices** - MC94xxxx - MC95xxxx - MC96xxxx - MC97xxxx #### E-PGM + - Support ABOV / ADAM devices - 2~5 times faster than S-PGM+ - Main controller: 32 bit MCU @ 72MHz - Buffer memory : 1 MByte Figure 1.4 component and connector #### **PGMPlusLC** 2 #### Description PGMPlusLC2 is for ISP (In System Programming). It is used to write into the MCU Which is already mounted on target board using 10pin cable. #### **Features** - PGMplusLC2 is low cost writing Tool. - USB interface is supported. - Not need USB driver installation. - Connect the external power adaptor (5v@2A). - Fast 32-bit Cortex-M3 MCU is used. - Supported high voltage Max 18V. - PGMplusLC2 is based on PC environment. - PGMplusLC2 is faster than PGMplusLC. - Transmission speed is 64kbyte/s - 2. Vdd - 4. GND - 6. Serial Clock - 8. Serial Data Figure 1.5 PGMplusLC Writer #### E-PGM+ Gang4/6 • Product name : E-PGM+ GANG 4 • Dimension(x , y, h) : 33.5 x 22.5 x35mm • Weight: 2.0kg Input Voltage : DC Adaptor 15V/2A Operating Temp: -10 ~ 40°C • Storage Temp : -30 ~ 80°C Water Proof : No Product name : E-PGM+ GANG 6 • Dimension(x , y, h): 148.2 x 22.5 x35mm Weight: 2.8kg Input Voltage : DC Adaptor 15V/2A Operating Temp: -10 ~ 40°C Storage Temp : -30 ~ 80°C Water Proof : No Figure 1.6 E-PGM+ Gang4/6 Programmer # 1.5 MTP programming #### 1.5.1 Overview The program memory of A97C450 is MTP Type. This flash is accessed by serial data format. There are four pins(DSCL, DSDA, VDD and VSS) for programming/reading the flash. | Din name | Main chip | | During programming | |----------|-----------|-----|----------------------------------------------------------------------------------------------------------------------------| | Pin name | pin name | I/O | Description | | DSCL | P36 | I | Serial clock pin. Input only pin. | | DSDA | P37 | I/O | Serial data pin. Output port when reading and input port when programming. Can be assigned as input/push-pull output port. | | VDD, VSS | VDD, VSS | - | Logic power supply pin. | Table 1.2 Descriptions of pins which are used to programming/reading the Flash #### 1.5.2 On-Board programming The A97C450 needs only four signal lines including VDD and VSS pins for programming FLASH with serial communication protocol. Therefore the on-board programming is possible if the programming signal lines are ready at the PCB of application board is designed. #### 1.5.2.1 Circuit Design Guide At the FLASH programming, the programming tool needs 4 signal lines that are DSCL, DSDA, VDD and VSS. When you design the PCB circuits, you should consider the usage of these signal lines for the on-board programming. Please be careful to design the related circuit of these signal pins because rising/falling timing of DSCL and DSDA is very important for proper programming. And it will cause some damages to the application circuits connected to DSCL and DSDA. application circuit is designed as high speed response such as relay control circuit. If possible, the I/O configuration of DSDA, DSCL pins had better be set to input mode. The value of R1 and R2 is recommended value and it varies with circuit of system. Figure 1.7 PCB design guide for on board programming # 2 Block diagram Figure 2.1 Block diagram of A97C450 # 3 Pin assignment Figure 3.1 A97C450CLN 48-LQFP pin assignment # 4 Package Diagram Figure 4.1 48 pin LQFP package # 5 Pin Description | PIN<br>Name | I/O | Function | @RESET | Shared with | |-------------|-----|--------------------------------------------------------------------------------------|--------|------------------| | P00 | I/O | Port 0 is a bit-programmable I/O port which can be | Input | MOSI0 | | P01 | | configured as an input, a push-pull output, or an open- | | SDA0/MISO0 | | P02 | | drain output. A pull-up resistor can be specified in 1-bit unit. | | SCL0/SCK0 | | P03 | | 7. Pari ap 100.000 cam 20 apositios in 1 2.1 ami | | EINT2/SS0/RTC1HZ | | P04 | | | | EINT3 | | P05 | | | | EINT6 | | P06 | | | | PWM2 | | P07 | | | | SS1/PWM3/EINT4 | | P10 | I/O | Port 1 is a bit-programmable I/O port which can be | Input | SCK1/PWM4 | | P11 | | configured as an input, a push-pull output, or an open- | | MISO1/(RXD1) | | P12 | | drain output. A pull-up resistor can be specified in 1-bit unit. | | MOSI1/(TXD1) | | P13 | | | | TXD0 | | P14 | | | | RXD0 | | P15 | | | | USS0 | | P16 | | | | XCK0 | | P17 | | | | AN8 | | P20 | I/O | Port 2 is a bit-programmable I/O port which can be | Input | CMP1I/AN0/AVref | | P21 | | configured as a schmitt-trigger input, a push-pull | | CMP2I/AN1 | | P22 | | output, or an open-drain output. A pull-up resistor can be specified in 1-bit unit. | | AN2 | | P23 | | | | AN3 | | P24 | | | | AN4 | | P25 | | | | AN5 | | P26 | | | | AN6 | | P27 | | | | AN7 | | P30 | I/O | Port 3 is a bit-programmable I/O port which can be | Input | USS1 | | P31 | | configured as a schmitt-trigger input, a push-pull output, or an open-drain output. | | RXD1 | | P32 | | A pull-up resistor can be specified in 1-bit unit. | | TXD1/PWM6 | | P33 | | · | | XCK1/PWM5/BUZ | | P34 | | | | AN9 | | P35 | | | | PWM0 | | P36 | | | | DSCL | | P37 | | | | DSDA | | P40 | I/O | Port 4 is a bit-programmable I/O port which can be | Input | SCL1 | | P41 | | configured as an input, a push-pull output, or an open-<br>drain output. | | SDA1 | | P42 | | arain output. A pull-up resistor can be specified in 1-bit unit. | | P42 | | P43 | | · | | P43 | | P44 | | | | EINT5/PWM1 | | P45 | | | | IR-INT/EINT0 | | P46 | | | | CEC/EINT1 | | P47 | | | | | Table 5.1 Normal Pin description | PIN<br>Name | I/O | Function | @RESET | Shared with | |----------------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------------| | P50<br>P51<br>P52<br>P53<br>P54<br>P55 | I/O | Port 5 is a bit-programmable I/O port which can be configured as a schmitt-trigger input, a push-pull output, or an open-drain output. A pull-up resistor can be specified in 1-bit unit. | Input | SXI SXO EINT7 XIN XOUT RESETB | | VDD | _ | Power input pins | _ | _ | | VSS | _ | Power input pins | _ | _ | Table 5.2 Normal Pin Description (Continued) | Port IO Direction<br>Register(PxIO) | Pull_Up Register<br>(PxPU) | Open Drain Register<br>(PxOD) | Port output attribute | |-------------------------------------|----------------------------|-------------------------------|-----------------------| | | OFF (0) | OFF (0) | Push-pull | | ON (1) | OFF (0) | ON (1) | Open drain | | ON (1) | ON (4) | OFF (0) | Push-pull | | | ON (1) | ON (1) | Internal Pull-Up | | Port IO Direction<br>Register | Pull_Up Register | Open Drain Register | Port Input attribute | |-------------------------------|------------------|---------------------|----------------------| | OFF (0) | OFF (0) | X | External condition | | OFF (0) | ON (1) | X | Internal Pull-Up | **Table 5.3** Port attribute setting ( PxIO, PxPU, PxOD, x= Port number (0, 1, 2, 3, 4, 5) # 6 Port Structures # 6.1 General Purpose I/O Port with Analog Input Figure 6.1 General Purpose I/O Port ## 7 Electrical Characteristics # 7.1 Absolute Maximum Ratings | Parameter | Symbol | Rating | Unit | NOTE | |-------------------------|------------------|--------------|------|-----------------------------------------------------------------| | Supply Voltage | VDD | -0.3~+6.5 | V | - | | | Vı | -0.3~VDD+0.3 | V | Voltage on any pin with respect to VSS | | | Vo | -0.3~VDD+0.3 | V | Voltage on any pin with respect to VSS | | Normal Valtage Din | Іон | -15 | mA | Maximum current output sourced by (I <sub>OH</sub> per I/O pin) | | Normal Voltage Pin | Σl <sub>OH</sub> | -80 | mA | Maximum current (∑l <sub>OH</sub> ) | | | I <sub>OL</sub> | 25 | mA | Maximum current sunk by (I <sub>OL</sub> per I/O pin) | | | ΣloL | 160 | mA | Maximum current (∑lo∟) | | Total Power Dissipation | PT | 400 | mW | - | | Storage Temperature | Tstg | -65~+150 | °C | - | Table 7.1 Absolute Maximum Ratings #### NOTE) 1. Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at any other conditions beyond those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. # 7.2 Recommended Operating Conditions $(T_A = -40^{\circ}C \sim +85^{\circ}C)$ | | | | | | | /( | | |-----------------------|--------|------------------------------------|--------------|-----|-----|-----|------| | Parameter | Symbol | Conditions | | MIN | TYP | MAX | Unit | | | | f <sub>X</sub> = 32 ~ 38kHz | Sub Crystal | 2.7 | _ | 5.5 | | | Operating Voltage | VDD | f <sub>X</sub> = 0.4 ~ 12MHz | Main Crystal | 2.7 | _ | 5.5 | V | | | | f <sub>X</sub> = 1, 2, 4, 8, 16MHz | Internal RC | 2.7 | _ | 5.5 | | | Operating Temperature | Topr | VDD=2.7~5.5V | | -40 | _ | 85 | °C | Table 7.2 Recommended Operating Conditions #### 7.3 A/D Converter Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V, VSS = 0V)$ | Parameter | Symbol | Co | Conditions | | TYP | MAX | Unit | |------------------------------|------------------|--------------|--------------------|-----|-----|-------|------| | Resolution | _ | _ | | | 12 | _ | bit | | Integral Non-Linear | INL | | | _ | _ | ±6 | | | Differential Non-Linearity | DNL | AVREF= | AVREF= 2.7V – 5.5V | | _ | ±3 | LSB | | Zero Offset Error | ZOE | ADCCLK= 2MHz | | _ | _ | ±5 | LOD | | Full Scale Error | FSE | | | _ | _ | ±5 | | | Conversion Time | tconv | 12-bit res | solution, 2MHz | _ | 30 | _ | us | | Analog Input Voltage | Vain | | _ | VSS | _ | AVREF | V | | Analog Reference Voltage | AVREF | * | NOTE 3 | 2.2 | _ | VDD | v | | Analog Input Leakage Current | I <sub>AIN</sub> | AVREF=5.12V | | _ | _ | 2 | uA | | ADC Operating Current | lina | Enable | VDD=5.12V | _ | 1 | 2 | mA | | ADC Operating Current | I <sub>ADC</sub> | Disable | Disable VDD-5.12V | _ | _ | 0.1 | uA | Table 7.3 A/D Converter Characteristics #### NOTE) - 1. Zero offset error is the difference between 0x000 and the converted output for zero input voltage (VSS). - Full scale error is the difference between 0xFFF and the converted output for full-scale input voltage (AVREF). - 3. When AVREF is lower than 2.7V, the ADC resolution is worse. # 7.4 Analog Comparator Characteristics | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | |-------------------------------------|------------------------|---------------------------|-----|------|-----|----------------------| | Operating Voltage | AVDD | - | 2.2 | _ | 5.5 | V | | Operating Temperature | TJ | - | -40 | 25 | 125 | $^{\circ}\mathbb{C}$ | | Operating Current | IDD <sub>(RMS)</sub> | - | - | 30 | 50 | uA | | STOP Current | ISTOP <sub>(RMS)</sub> | 0.7uA@105℃,<br>1.5uA@125℃ | - | 0.05 | 1.5 | uA | | Input Offset Voltage | Vos | - | -50 | - | +50 | mV | | Internal VREF stabilization time | twkup | - | 50 | - | - | us | | Propagation Dolay(t) | t <sub>PHL</sub> | @ Overdirve=50mV, | - | 0.5 | 1.0 | 110 | | Propagation Delay(t <sub>PD</sub> ) | t <sub>PLH</sub> | AVDD=3.45V | - | 0.5 | 1.0 | us | Table 7.4 Analog Comparator Characteristics #### 7.5 Power-On Reset Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V, VSS = 0V)$ | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | |-------------------------|------------------|--------------|------|-----|------|------| | RESET Release Level | $V_{POR}$ | _ | ı | 1.4 | - | V | | VDD Voltage Rising Time | t <sub>R</sub> | 0.5V to 2.0V | 0.05 | I | 30.0 | V/ms | | POR Current | I <sub>POR</sub> | _ | _ | 0.2 | _ | uA | Table 7.5 Power-on Reset Characteristics # 7.6 Low Voltage Reset and Low Voltage Indicator Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V, VSS = 0V)$ | Parameter | Symbol | Conditions | | MIN | TYP | MAX | Unit | | | | | | | | | | | | | |---------------------------------------------------|------------------|-----------------------------------------------------------|------------------------------------------|------|------|------|------|--|--|--|--|--|--|--|--|---|------|------|--| | | V <sub>LVR</sub> | | | | | | | | | | | | | | | - | 1.60 | 1.80 | | | Detection Level V <sub>LVR</sub> V <sub>LVI</sub> | | | The LVR level is only fixed to Typ. 1.6V | | 2.40 | 2.60 | V | | | | | | | | | | | | | | | $V_{LVI}$ | but LVI level can be selected to Typ. 2.4V, 2.8V or 3.5V. | | 2.60 | 2.80 | 3.0 | | | | | | | | | | | | | | | | | | | 3.30 | 3.50 | 3.70 | | | | | | | | | | | | | | | Hysteresis | △V | _ | | _ | 50 | 150 | mV | | | | | | | | | | | | | | Minimum Pulse Width | t <sub>LW</sub> | _ | | 100 | 1 | - | us | | | | | | | | | | | | | | LVR and LVI Current | I <sub>BL</sub> | Enable | VDD= 3V,<br>RUN Mode | _ | 30.0 | - | uA | | | | | | | | | | | | | | | .50 | Disable | VDD= 3V | _ | _ | 0.1 | | | | | | | | | | | | | | Table 7.6 LVR and LVI Characteristics #### 7.7 Internal RC Oscillator Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V, VSS = 0V)$ | | | | , | (IA – - <del>-</del> 0 0 | JJ C, VDD - 2 | | V O O - U \ | |------------------------------|-----------------------|-----------------------------------------------|-----------|--------------------------|---------------|-------|-------------| | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | | | Frequency | firc | $V_{DD} = 2.7 - 5.5V$ | | 15.76 | 16 | 16.24 | MHz | | Tolerance – | $T_A = 0$ °C to +50°C | With 0.1uF | | | ±1.5 | | | | | _ | $T_A = -20^{\circ}C \text{ to } +85^{\circ}C$ | Bypass | _ | _ | ±2.5 | % | | | | $T_A = -40^{\circ}C \text{ to } +85^{\circ}C$ | capacitor | | | ±3.5 | | | Clock Duty Ratio | T <sub>OD</sub> | _ | | 40 | 50 | 60 | % | | Stabilization Time | T <sub>HFS</sub> | _ | | _ | - | 100 | us | | IRC Current I <sub>IRC</sub> | line | Enable | | _ | 0.2 | - | mA | | | IIRC | Disable | | _ | _ | 0.1 | uA | Table 7.7 High Internal RC Oscillator Characteristics #### NOTE) 1. A 0.1uF bypass capacitor should be connected to VDD and VSS. # 7.8 Internal Watch-Dog Timer RC Oscillator Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V, VSS = 0V)$ | | | ( | 10 0 | 0, 100 2 | .,, 0.01, 1 | <u> </u> | | |--------------------|--------|------------|------|----------|-------------|----------|--| | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | | | Frequency | fwdtrc | _ | 230 | 256 | 282 | kHz | | | Stabilization Time | twdts | _ | _ | _ | 1 | ms | | | WDTRC Current | l | Enable | _ | 5 | - | | | | | IWDTRC | Disable | _ | _ | 0.1 | uA | | Table 7.8 Internal WDTRC Oscillator Characteristics #### 7.9 DC Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V, VSS = 0V, f_{XIN} = 8MHz)$ | Parameter | Symbol | Cone | ditions | MIN | TYP | MAX | Unit | |-------------------------------|----------------------------|-------------------------------------------------------|-------------|---------|-------|--------|------| | Input High Voltage | V <sub>IH1</sub> | P0, P1, P2, P3, P4 | 4, P5 | 0.7VDD | _ | VDD | V | | Input Low Voltage | V <sub>IL1</sub> | P0, P1, P2, P3, P4 | 4, P5 | _ | _ | 0.3VDD | V | | Output High | V <sub>OH1</sub> | VDD= 3.3V, I <sub>OH</sub> =<br>All output ports; | , | VDD-1.0 | _ | - | ٧ | | Voltage | V <sub>OH2</sub> | VDD= 5.0V, I <sub>OH</sub> =<br>All output ports; | | VDD-1.0 | _ | _ | V | | Output Low Voltage | V <sub>OL1</sub> | VDD=3.3V, I <sub>OL</sub> =<br>All output ports; | 10mA, | _ | _ | 1.0 | V | | Output Low Voltage | V <sub>OL2</sub> | VDD=5.0V, I <sub>OL</sub> =<br>All output ports; | 20mA, | _ | _ | 1.0 | V | | Input High Leakage<br>Current | Іін | All input ports | | - | - | 1 | uA | | Input Low Leakage<br>Current | lıL | All input ports | | -1 | - | _ | uA | | | _ | VI=0V, | VDD=5.0V | 25 | 50 | 100 | | | Pull-Up Resistor | R <sub>PU1</sub> | T <sub>A</sub> = 25°C<br>All Input ports | VDD=3.0V | 50 | 100 | 200 | kΩ | | OSC feedback | R <sub>X1</sub> | XIN= VDD, XOUT= VSS<br>T <sub>A</sub> = 25°C, VDD= 5V | | 700 | 1000 | 2500 | 1.0 | | resistor | R <sub>X2</sub> | SXIN=VDD, SXOU<br>T <sub>A</sub> = 25°C, VDD=5 | | 6700 | 13000 | 29000 | kΩ | | | | f <sub>XIN</sub> = 12MHz | VDD= 5V±10% | _ | 4.5 | 9.0 | | | | I <sub>DD1</sub><br>(RUN) | f <sub>XIN</sub> = 12MHz | VDD= 3V±10% | _ | 3.6 | 6.0 | mA | | | (11011) | f <sub>IRC</sub> = 16MHz | VDD= 5V±10% | _ | 4.4 | 5.5 | | | | | f <sub>XIN</sub> = 12MHz | VDD= 5V±10% | _ | 2.0 | 4.0 | | | | I <sub>DD2</sub><br>(IDLE) | f <sub>XIN</sub> = 12MHz | VDD= 3V±10% | _ | 1.2 | 2.0 | mA | | Supply Current | (IDEL) | f <sub>IRC</sub> = 16MHz | VDD= 5V±10% | _ | 1.2 | 3.0 | | | Supply Current | I <sub>DD3</sub><br>(SLP1) | SLEEP1 MODE<br>WDTRC OSC Ena | able | _ | - | 1.0 | mA | | | I <sub>DD4</sub> (SLP2) | SLEEP2 MODE<br>WDTRC OSC Ena | able | - | - | 300 | uA | | | I <sub>DD5</sub> (STOP1) | STOP1 MODE<br>WDTRC OSC Ena | | - | - | 60 | uA | | | I <sub>DD6</sub> (STOP2) | STOP2 MODE, TA | =25°C | _ | 5 | 10 | uA | Table 7.9 DC Characteristics #### NOTE) 1. Where the $f_{XIN}$ is an external main oscillator, $f_{SUB}$ is an external sub oscillator, the $f_{IRC}$ is an internal RC oscillator and the fx is the selected system clock. All supply current items don't include the current of an internal Watch-dog timer RC (WDTRC) oscillator and a peripheral block. All supply current items include the current of the power-on reset (POR) block. ## 7.10 AC Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V)$ | | | | , | | | | |-------------------------------------------------|------------------------------------------|------------------------|-----|-----|-----|------| | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | | RESETB Input Low Width | t <sub>RST</sub> | Input, VDD= 5V | 10 | - | - | us | | Interrupt Input High, Low Width | t <sub>IWH</sub> ,<br>t <sub>IWL</sub> | All interrupt, VDD= 5V | 200 | _ | _ | | | External Counter Input High,<br>Low Pulse Width | t <sub>ECWH</sub> ,<br>t <sub>ECWL</sub> | ECn, VDD = 5V (n= 0~7) | 200 | _ | _ | ns | | External Counter Transition Time | t <sub>REC</sub> , t <sub>FEC</sub> | ECn, VDD = 5V (n= 0~7) | 20 | _ | _ | | Table 7.10 AC Characteristics Figure 7.1 AC Timing ## 7.11 SPI Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V)$ | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | |------------------------------------|---------------------|------------------------------|-----|-----|-----|------| | Output Clock Pulse Period | | Internal SCK source | 200 | _ | _ | | | Input Clock Pulse Period | tsck | External SCK source | 200 | - | _ | | | Output Clock High, Low Pulse Width | t <sub>scкн</sub> , | Internal SCK source | 70 | - | - | | | Input Clock High, Low Pulse Width | tsckl | External SCK source | 70 | - | 1 | no | | First Output Clock Delay Time | t <sub>FOD</sub> | Internal/External SCK source | 100 | _ | I | ns | | Output Clock Delay Time | t <sub>DS</sub> | _ | _ | _ | 50 | | | Input Setup Time | t <sub>DIS</sub> | _ | 100 | _ | - | | | Input Hold Time | t <sub>DIH</sub> | _ | 150 | _ | _ | | Table 7.11 SPI Characteristics Figure 7.2 SPI Timing # 7.12 USART Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V, f_{XIN} = 8MHz)$ | | | ( | , | <b>—</b> — • • • • • • • • • • • • • • • • • | IIV 0 | |------------------------------------------|-------------------------|-----------------------|-----------------------|----------------------------------------------|-------| | Parameter | Symbol | MIN | TYP | MAX | Unit | | Serial port clock cycle time | tsck | 1800 | t <sub>CPU</sub> × 16 | 2200 | | | Output data setup to clock rising edge | t <sub>S1</sub> | 810 | t <sub>CPU</sub> × 13 | _ | | | Clock rising edge to input data valid | t <sub>S2</sub> | _ | _ | 590 | ,,, | | Output data hold after clock rising edge | t <sub>H1</sub> | t <sub>CPU</sub> - 50 | tcpu | _ | ns | | Input data hold after clock rising edge | t <sub>H2</sub> | 0 | _ | _ | | | Serial port clock High, Low level width | tніgн, t <sub>LOW</sub> | 720 | t <sub>CPU</sub> × 8 | 1280 | | Table 7.12 USART Characteristics Figure 7.3 Waveform for USART Timing Characteristics Figure 7.4 Timing Waveform for the USART Module ## 7.13 I2C Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V)$ | Parameter | Cumbal | Standa | rd Mode | High-Speed Mode | | Unit | |----------------------------|------------------|--------|---------|-----------------|-----|-------| | Farameter | Symbol | MIN | MAX | MIN | MAX | Ullit | | Clock frequency | tscL | 0 | 100 | 0 | 400 | kHz | | Clock High Pulse Width | tsclh | 4.0 | _ | 0.6 | _ | | | Clock Low Pulse Width | tscll | 4.7 | _ | 1.3 | _ | | | Bus Free Time | t <sub>BF</sub> | 4.7 | _ | 1.3 | _ | | | Start Condition Setup Time | tsтsu | 4.7 | _ | 0.6 | _ | | | Start Condition Hold Time | tsтнD | 4.0 | _ | 0.6 | _ | us | | Stop Condition Setup Time | tspsu | 4.0 | _ | 0.6 | _ | | | Stop Condition Hold Time | tsphD | 4.0 | _ | 0.6 | _ | | | Output Valid from Clock | t∨D | 0 | _ | 0 | _ | | | Data Input Hold Time | t <sub>DIH</sub> | 0 | _ | 0 | 1.0 | | | Data Input Setup Time | tois | 250 | _ | 100 | _ | ns | Table 7.13 I2C Characteristics Figure 7.5 I2C Timing(DIS\_SDAH=0) # 7.14 Data Retention Voltage in Stop Mode $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V)$ | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | |-------------------------------|-------------------|---------------------------------------------------|-----|-----|-----|------| | Data retention supply voltage | V <sub>DDDR</sub> | _ | 2.7 | - | 5.5 | V | | Data retention supply current | I <sub>DDDR</sub> | $V_{DDR} = 2.7V(T_A = 25^{\circ}C),$<br>Stop mode | _ | _ | 1 | uA | Table 7.14 Data Retention Voltage in Stop Mode Figure 7.6 Stop Mode Release Timing when Initiated by an Interrupt Figure 7.7 Stop Mode Release Timing when Initiated by RESETB ## 7.15 Internal Flash ROM Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V, VSS = 0V)$ | Parameter | Symbol | Condition | MIN | TYP | MAX | Unit | |-----------------------------|------------------|-----------|-----|-----|--------|--------| | Sector Write Time | t <sub>FSW</sub> | - | _ | 2.5 | 2.7 | | | Sector Erase Time | t <sub>FSE</sub> | - | - | 2.5 | 2.7 | ms | | Code Write Protection Time | t <sub>FHL</sub> | _ | - | 2.5 | 2.7 | | | Page Buffer Reset Time | t <sub>FBR</sub> | _ | - | - | 5 | us | | Flash Programming Frequency | f <sub>PGM</sub> | - | 0.4 | - | - | MHz | | Endurance of Write/Erase | NFwe | _ | _ | _ | 10,000 | cycles | | Flash Data Retention Time | t <sub>RT</sub> | - | 10 | | | years | Table 7.15 Internal Flash Rom Characteristics #### 7.16 Internal EEPROM Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V, VSS = 0V)$ | | | ( - / / | | , | | , | |------------------------------|------------------|-----------|-----|-----|---------|--------| | Parameter | Symbol | Condition | MIN | TYP | MAX | Unit | | Sector/Byte Write Time | t <sub>FSW</sub> | - | - | 2.5 | 2.7 | | | Sector/Byte Erase Time | t <sub>FSE</sub> | - | - | 2.5 | 2.7 | ms | | Data Write Protection Time | t <sub>FHL</sub> | - | _ | 2.5 | 2.7 | | | Page Buffer Reset Time | t <sub>FBR</sub> | - | _ | _ | 5 | us | | EEPROM Programming Frequency | f <sub>PGM</sub> | - | 0.4 | _ | _ | MHz | | Endurance of Write/Erase | NFwe | - | - | _ | 300,000 | cycles | | EEPROM Data Retention Time | t <sub>RT</sub> | - | 10 | | | years | Table 7.16 Internal Flash Rom Characteristics # 7.17 Input/Output Capacitance $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 0V)$ | Parameter | Symbol | Condition | MIN | TYP | MAX | Unit | |--------------------|-----------------|---------------------|-----|-----|-----|------| | Input Capacitance | C <sub>IN</sub> | fx= 1MHz | | | | | | Output Capacitance | Соит | Unmeasured pins are | _ | _ | 10 | pF | | I/O Capacitance | C <sub>IO</sub> | connected to VSS | | | | | Table 7.17 Input/Output Capacitance ## 7.18 Main Clock Oscillator Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V)$ | Oscillator | Parameter | Condition | MIN | TYP | MAX | Unit | | |--------------------|----------------------------|-------------|-----|-----|------|------|--| | Crystal | Main oscillation frequency | 2.7V – 5.5V | 0.4 | - | 12.0 | MHz | | | Ceramic Oscillator | Main oscillation frequency | 2.7V – 5.5V | 0.4 | - | 12.0 | MHz | | | External Clock | XIN input frequency | 2.7V - 5.5V | 0.4 | _ | 12.0 | MHz | | Table 7.18 Main Clock Oscillator Characteristics Figure 7.8 Crystal/Ceramic Oscillator & External Clock Circuit $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.2V \sim 5.5V)$ | Oscillator | Parameter | MIN | TYP | MAX | Unit | |----------------|----------------------------------------------------------------------------|-----|-----|------|------| | Crystal | fx > 4MHz, VDD = 2.7V ~ 5.5V, | | _ | 15 | ms | | | fx > 1MHz, VDD = 2.7V, T <sub>A</sub> =-40°C | _ | | 60 | | | Ceramic | - | - | - | 10 | ms | | External Clock | $f_{XIN} = 0.4$ to 8MHz<br>XIN input high and low width $(t_{XH}, t_{XL})$ | 42 | - | 1250 | ns | Table 7.19 Main Oscillation Stabilization Characteristics Figure 7.9 Clock Timing Measurement at XIN ## 7.19 Sub Clock Oscillator Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.7V \sim 5.5V)$ | Parameter | Symbol | MIN | TYP | MAX | Unit | Condition | |----------------------------------|------------------|------------------------|--------|------------|------|--------------------------------------------------------------------| | Sub oscillation frequency | f <sub>SUB</sub> | 32 | 32.768 | 38 | kHz | Crystal | | SXIN input frequency | f <sub>SUB</sub> | 32 | _ | 100 | kHz | External Clock | | Operating Current | I <sub>DD</sub> | | 3 | 5 | uA | - | | External Load Capacitor | CL | 5 | 15 | 35 | pF | - | | Feedback resistance | R <sub>FB</sub> | 6.7 | 13.7 | 29 | ΜΩ | | | Crystal Input (Low) | VIL | | | 0.2*VDDINT | V | | | Crystal Input (High) | ViH | 0.8*V <sub>DDINT</sub> | | | V | @Max. Current Mode | | Crystal Output (Low) | Vol | | | 0.2*VDDINT | V | @V <sub>DDINT</sub> = Typ. 1.85V<br>(on-chip LDO regulator Output) | | Crystal Output (High) | Vон | 0.8*VDDINT | | | V | | | Output Clock Duty | D | 45 | 50 | 55 | % | - | | Input Swing Level (Peak to Peak) | Vsw | 1 | | | V | - | Table 7.20 Sub Clock Oscillator Characteristics Figure 7.10 Sub Crystal Oscillator & External Clock Cuircit $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.2V \sim 5.5V)$ | Oscillator | Parameter | MIN | TYP | MAX | Unit | |----------------|------------------------------------------|-----|-----|-----|------| | Crystal | - | - | _ | 10 | S | | External Clock | SXIN input high and low width (txH, txL) | 5 | _ | 15 | us | Table 7.1 Sub Oscillation Stabilization Characteristics Figure 7.11 Clock Timing Measurement at SXIN # 7.20 Operating Voltage Range Figure 7.12 Operating Voltage Range # 7.21 Recommended Circuit and Layout Figure 7.13 Recommended Circuit and Layout # 7.22 Recommended Circuit and Layout with SMPS Power Figure 7.14 Recommended Circuit and Layout with SMPS Power # 7.23 Typical Characteristics These graphs and tables provided in this section are only for design guidance and are not tested or guaranteed. In graphs or tables some data are out of specified operating range (e.g. out of specified VDD range). This is only for information and devices are guaranteed to operate properly only within the specified range. The data presented in this section is a statistical summary of data collected on units from different lots over a period of time. "Typical" represents the mean of the distribution while "max" or "min" represents (mean + $3\sigma$ ) and (mean - $3\sigma$ ) respectively where $\sigma$ is standard deviation. Figure 7.15 RUN (IDD1) Current Figure 7.16 IDLE (IDD2) Current Figure 7.17 STOP1 (IDD5) Current Figure 7.18 STOP2 (IDD6) Current # 8 Memory The A97C450 addresses two separate address memory stores: Program memory and Data memory. The logical separation of Program and Data memory allows Data memory to be accessed by 8-bit addresses, which makes the 8-bit CPU access the data memory more rapidly. Nevertheless, 16-bit Data memory addresses can also be generated through the DPTR register. A97C450 provides on-chip 64KB of the ISP type flash program memory, which can be read and written to. Internal data memory (IRAM) is 256 bytes and it includes the stack area. External data memory (XRAM) is 4,096 bytes and it can be used as the extended stack area. # 8.1 Program Memory A 16-bit program counter is capable of addressing up to 64KB, and this device has 64KB as program memory space. Figure 8.1 shows the map of the program memory. After reset, the CPU begins execution from address 0000H. Each interrupt is assigned to a fixed address in program memory. The interrupt causes the CPU to jump to that address, where it commences execution of the service routine. External interrupt 0, for example, is assigned to address 000BH. If external interrupt 0 would be requested, its service routine must begin at location 000BH. When the interrupt is not used, the Rom address is used as general purpose program memory. If an interrupt service routine is short enough (as is often case in S/W), it can reside entirely within that 8 bytes interval. Longer service routines can use a jump instruction to skip over subsequent interrupt locations, if other interrupts are in use. Internal and external data memory is used as program memory which is assigned to address of code bank1. Memory extension registers (MEX1, MEX2, MEX3, MEXSP) are used to access this memory address. Figure 8.1 Program Memory #### NOTE) 1. 64KB Including Interrupt Vector address ## 8.2 Data Memory Figure 8.2 Data Memory Map The internal data memory space is divided into three blocks, which are generally referred to as the lower 128 bytes, upper 128 bytes and SFR space. Internal data memory address is one byte wide, which implies an address space of only 256bytes. However, in fact the addressing modes for internal RAM can accommodate up to 384 bytes by using a simple trick. Direct addresses higher than 7FH access one memory space and indirect addresses higher than 7FH access a different memory space. Thus Figure 8.2 shows the upper 128 bytes and SFR space occupying the same block of addresses, 80H through FFH, although they are physically separate entities. The lower 128 bytes of RAM are present in all 8051 devices as mapped in Figure 8.3. The lowest 32 bytes are grouped into 4 banks of 8 registers. Program instructions call out these registers as R0 through R7. Two bits in the Program Status Word select which register bank is in use. This allows more efficient usage of code space, since register instructions needs less bytes than direct addressing instructions. The next 16 bytes above the register banks form a block of bit-addressable memory space. The 8051 instruction set includes a wide selection of single-bit instructions and the 128 bits in this area can be directly addressed by these instructions. The bit addresses in this area are 00H through 7FH. All of the bytes in the lower 128 bytes can be accessed by either direct or indirect addressing. The upper 128 bytes RAM can only be accessed by indirect addressing. These spaces are used for data RAM and stack. Figure 8.3 Lower 128bytes RAM ### 8.3 External Data Memory A97C450 has 2Kbytes EEPROM data memory and 4,096 bytes XRAM and XSFR. This area has no relation with RAM/FLASH. It can be read and written to through SFR with 8-bit unit. The 2Kbytes data EEPROM is assigned to address from A000H to A7FFH of external memory. For more information about EEPROM data memory, see chapter 15. Figure 8.4 XDATA Memory Area # 8.4 Extended Stack Pointer(XSP) The XSP register is a high of stack pointer when XSPEN bit of the XSPCR register is set. In this case stack is located in XDATA memory and the maximum size of stack is equal to 64KB. If the XSPEN bit is set to '0', the XSP register is ignored and stack is located in internal memory. ## 8.5 Memory Extension Stack The memory extension stack (MXSTAKCK) store code bank address. When executing the LCALL instruction it stores the code bank address, when executing the RET and RETI instructions exports the code bank address. The MXSTACK is capable of stack 128bit of program address. Figure 8.5 Memory extension stack The memory extension stack (MXSTACK) store code bank address. When executing the LCALL instruction it stores the code bank address, when executing the RET and RETI instructions exports the code bank address. The MXSTACK is capable of stack 128bit of program address. According to the following example, stack pointer memory diagram is shown below. Figure 9.1 Stack pointer memory map ### 8.6 Bootloader Swap The A97C450 support Bootloader swap operation for the area selected by write protection selection register (BSIZE). Setting config option enables bootloader swapping. After downloading the bootloader to be changed to the desired boot page and executing boot swap command and resetting, the changed bootloader is seen from address 0000H. Refer to the following example. Step 1: Jump Boot page 0 Step 2: Enter program mode Step 3: Update boot page 1 Step 4: Set the OTP boot page selection bit Step 5: Reset Step 6: During reset boot page 1 is changed to boot page 0 Step 7: Execute code at the updated boot page 0 FUSE\_SWAPEN = 0x5A : Enable bootloader swap. FUSE\_BTSEL = 0xA5 : Select Boot page 1 (default select boot page 0) | Name | Boot page 0 area | Boot page 1 area | Size | |-------------|------------------|------------------|------| | BSIZE = 0x0 | 0x0000~0x01FF | 0x0200~0x03FF | 512B | | BSIZE = 0x1 | 0x0000~0x03FF | 0x0400~0x07FF | 1KB | | BSIZE = 0x2 | 0x0000~0x07FF | 0x0800~0x0FFF | 2KB | | BSIZE = 0x3 | 0x0000~0x0FFF | 0x1000~0x1FFF | 4KB | Table 8.1 Bootloader area Figure 9.2 Bootloader selection # 8.7 SFR Map # 8.7.1 SFR Map Summary - Reserved M8051 compatible | | 0H/8H | 1H/9H | 2H/AH | 3Н/ВН | 4H/CH | 5H/DH | 6H/EH | 7H/FH | |-----|--------|--------|---------|---------|-----------|-----------|-----------|-----------| | F8H | T6BDRL | T6BDRH | UCTRL11 | UCTRL12 | UCTRL13 | USTAT1 | UBAUD1 | UDATA1 | | F0H | В | T6CRL | FEARL | FEARM | FEARH | FEDR | - | T6CRH | | E8H | SPICR1 | SPIDR1 | FEMR | FECR | FESR | FETCR | T6ADRL | T6ADRH | | ЕОН | ACC | SPISR1 | UCTRL01 | UCTRL02 | UCTRL03 | USTAT0 | UBAUD0 | UDATA0 | | D8H | SPICR0 | SPIDR0 | I2CMR00 | I2CSR0 | I2CSCLLR0 | I2CSCLHR0 | I2CSDAHR0 | I2CDR0 | | D0H | PSW | SPISR0 | T5ADRL | T5ADRH | T5BDRL | T5BDRH | I2CSAR01 | I2CSAR00 | | С8Н | T4CRL | T4CRH | T4ADRL | T4ADRH | T4BDRL | T4BDRH | T5CRL | T5CRH | | СОН | T2BDRL | T2BDRH | T3CRL | T3CRH | T3ADRL | T3ADRH | T3BDRL | T3BDRH | | В8Н | VDCMOD | P5IO | T1DR | T1CR | T2CRL | T2CRH | T2ADRL | T2ADRH | | ВОН | P5 | P4IO | TINTCR | T0CNT | T0DR | T0CR | TIFLAG0 | T1CNT | | A8H | IE | IE1 | IE2 | IE3 | IE4 | XSP | XSPCR | AUTHORITY | | A0H | P4 | P3IO | EO | EIENAB | EIFLAG | EIEDGE | EIPOLA | EIBOTH | | 98H | P3 | P2IO | ADCM | ADCRL | ADCRH | WTMR | WTR | BUZCR | | 90H | P2 | P1IO | ADCM2 | OTPADD | MEX1 | MEX2 | MEX3 | MEXSP | | 88H | P1 | POIO | SCCR | BCCR | BITR | WDTMR | WDTR | BUZDR | | 80H | P0 | SP | DPL | DPH | XBANK | RSFR | LVIR | PCON | Table 9.1SFR Map Summary ## NOTE) 1. 00H/8H, These registers are bit-addressable. | 8FF8H </th <th></th> <th>0H/8H</th> <th>1H/9H</th> <th>2H/AH</th> <th>3Н/ВН</th> <th>4H/CH</th> <th>5H/DH</th> <th>6H/EH</th> <th>7H/FH</th> | | 0H/8H | 1H/9H | 2H/AH | 3Н/ВН | 4H/CH | 5H/DH | 6H/EH | 7H/FH | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------------|-------------|------------|------------|------------|------------|------------|------------| | | 8FF8H | - | - | - | - | - | - | - | - | | 8FEBH CRC_CON CRC_DIT CRC_DIT CRC_DIT CRC_DIT CRC_MNT_LIT ALAMAMWA ALAMAWWA ALAM | 8FF0H | - | - | - | - | - | - | - | - | | 8FD8H SPMUSR PADDRIVE PADDROVEH PADDROVEH PADDROVEL STPIRIUM < | 8FE8H | - | | | | | | | - | | 8FDOH SPMUCR PADDR, OVEH PADDR, OVEH STPTR, OVEH STPTR, UPH <th>8FE0H</th> <th>CRC_CON</th> <th>-</th> <th>CRC_H</th> <th>CRC_L</th> <th>CRC_MNT_H</th> <th>CRC_MNT_L</th> <th>-</th> <th>-</th> | 8FE0H | CRC_CON | - | CRC_H | CRC_L | CRC_MNT_H | CRC_MNT_L | - | - | | 8FC8H UCTR104 FPCRI - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | 8FD8H | SPMUSR | PADDRH | PADDRM | PADDRL | STPTRH | STPTRL | XSTPTR | | | 8FCOH UCTRL04 FPCR0 | 8FD0H | SPMUCR | PADDR_OVFH | PADDR_OVFM | PADDR_OVFL | STPTR_OVFH | STPTR_OVFL | STPTR_UDFH | STPTR_UDFL | | SFB8H WEEK | 8FC8H | UCTRL14 | FPCR1 | - | - | - | - | - | - | | 8FBOH - RTCCO RTCCI ERRCOR SEC MIN HOUR DAY 8FA8H IPAL IPAH INT_OFFSET - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -< | 8FC0H | UCTRL04 | FPCR0 | - | - | - | - | - | - | | 8FA8H IP4L IP4H INT_OFFSET | 8FB8H | WEEK | MONTH | YEAR | ALARMWM | ALARMWH | ALARMWW | - | - | | 8FAOH IPOL IPOH IPIL IPIH IP2L IP2H IP3H IP3H IP3H 8F98H - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | 8FB0H | - | RTCC0 | RTCC1 | ERRCOR | SEC | MIN | HOUR | DAY | | 8F98H . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . <th>8FA8H</th> <th>IP4L</th> <th>IP4H</th> <th>INT_OFFSET</th> <th>-</th> <th>-</th> <th>-</th> <th>-</th> <th>-</th> | 8FA8H | IP4L | IP4H | INT_OFFSET | - | - | - | - | - | | 8F90H CEC_RXD_17 CEC_RXD_18 CEC_RXD_19 - - - - - 8F88H CEC_RXD_9 CEC_RXD_10 CEC_RXD_11 CEC_RXD_12 CEC_RXD_13 CEC_RXD_14 CEC_RXD_16 CEC_RXD_16 8F80H CEC_RXD_1 CEC_RXD_2 CEC_RXD_3 CEC_RXD_4 CEC_RXD_5 CEC_RXD_6 CEC_RXD_7 CEC_RXD_8 8F70H CEC_TXD_13 CEC_TXD_14 CEC_TXD_15 CEC_TXD_16 CEC_TXD_17 CEC_TXD_18 CEC_TXD_19 CEC_TXD_19 CEC_RXD_11 CEC_RXD_12 8F70H CEC_TXD_5 CEC_TXD_6 CEC_TXD_7 CEC_TXD_8 CEC_TXD_9 CEC_TXD_10 CEC_TXD_11 CEC_TXD_12 CEC_TXD_12 CEC_TXD_11 CEC_TXD_12 CEC_TXD_12 CEC_TXD_12 CEC_TXD_11 CEC_TXD_12 | 8FA0H | IP0L | IP0H | IP1L | IP1H | IP2L | IP2H | IP3L | IP3H | | 8F88H CEC_RXD_9 CEC_RXD_10 CEC_RXD_11 CEC_RXD_12 CEC_RXD_13 CEC_RXD_14 CEC_RXD_15 CEC_RXD_16 8F80H CEC_RXD_1 CEC_RXD_2 CEC_RXD_3 CEC_RXD_4 CEC_RXD_5 CEC_RXD_6 CEC_RXD_7 CEC_RXD_8 8F78H CEC_TXD_13 CEC_TXD_14 CEC_TXD_15 CEC_TXD_16 CEC_TXD_17 CEC_TXD_18 CEC_TXD_19 CEC_TXD_19 CEC_TXD_19 CEC_TXD_10 CEC_TXD_11 CEC_RXD_12 8F60H CEC_TXD_5 CEC_TXD_6 CEC_TXD_7 CEC_TXD_8 CEC_TXD_9 CEC_TXD_10 CEC_TXD_11 CEC_TXD_12 8F60H CEC_FSTAT CEC_FCLR CEC_TXH CEC_TXD_1 CEC_TXD_2 CEC_TXD_3 CEC_TXD_4 8F60H CEC_PRES1 CEC_PRES0 CEC_CONF1 CEC_CONF0 CEC_GCTRL CEC_TXD_2 CEC_TXD_3 CEC_TXD_4 8F50H - - - - - - - - - - - - - - - - - - - | 8F98H | - | - | - | - | - | - | - | - | | 8F80H CEC_RXD_1 CEC_RXD_2 CEC_RXD_3 CEC_RXD_4 CEC_RXD_5 CEC_RXD_6 CEC_RXD_7 CEC_RXD_8 8F78H CEC_TXD_13 CEC_TXD_14 CEC_TXD_15 CEC_TXD_16 CEC_TXD_17 CEC_TXD_18 CEC_TXD_19 CEC_TXD_19 CEC_RXH 8F70H CEC_TXD_5 CEC_TXD_6 CEC_TXD_7 CEC_TXD_8 CEC_TXD_9 CEC_TXD_10 CEC_TXD_11 CEC_TXD_12 8F68H CEC_FSTAT CEC_ICIR CEC_CTR CEC_TXH CEC_TXD_1 CEC_TXD_2 CEC_TXD_3 CEC_TXD_4 8F60H CEC_PSTAT CEC_ICIR CEC_CONF0 CEC_GCTRL CEC_TXD_2 CEC_TXD_3 CEC_TXD_4 8F50H CCC_PRES1 CEC_PRES0 CEC_CONF1 CEC_CONF0 CEC_GCTRL CEC_ICIR CEC_IXD_1 8F50H CCC_PRES1 IRC_PRES0 IRC_FRMP1 IRC_FRMP0 IRC_CONF IRC_CTRL IRC_EDGE1 IRC_EDGE0 8F48H IRC_PRES1 IRC_PRES0 IRC_FRMP1 IRC_FRMP0 IRC_CONF IRC_CTRL IRC_EDGE1 IRC_EDGE0 | 8F90H | CEC_RXD_17 | CEC_RXD_18 | CEC_RXD_19 | - | - | - | - | - | | 8F78H CEC_TXD_13 CEC_TXD_14 CEC_TXD_15 CEC_TXD_16 CEC_TXD_17 CEC_TXD_18 CEC_TXD_19 CEC_TXD_12 8F70H CEC_TXD_5 CEC_TXD_6 CEC_TXD_7 CEC_TXD_8 CEC_TXD_9 CEC_TXD_10 CEC_TXD_11 CEC_TXD_12 8F68H CEC_FSTAT CEC_ICLR CEC_FCIR CEC_TXH CEC_TXD_1 CEC_TXD_2 CEC_TXD_3 CEC_TXD_4 8F60H CEC_PRES1 CEC_PRES0 CEC_CONF1 CEC_CONF0 CEC_GCTRL CEC_ICTRL CEC_TXD_3 CEC_TXD_4 8F50H - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | 8F88H | CEC_RXD_9 | CEC_RXD_10 | CEC_RXD_11 | CEC_RXD_12 | CEC_RXD_13 | CEC_RXD_14 | CEC_RXD_15 | CEC_RXD_16 | | 8F70H CEC_TXD_5 CEC_TXD_6 CEC_TXD_7 CEC_TXD_8 CEC_TXD_9 CEC_TXD_10 CEC_TXD_11 CEC_TXD_12 8F68H CEC_FSTAT CEC_ICLR CEC_FCLR CEC_TXH CEC_TXD_1 CEC_TXD_2 CEC_TXD_3 CEC_TXD_4 8F60H CEC_PRESI CEC_PRESO CEC_CONF1 CEC_CONF0 CEC_GCTRL CEC_ICTRL CEC_FCTRL CEC_ISTAT 8F58H - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | 8F80H | CEC_RXD_1 | CEC_RXD_2 | CEC_RXD_3 | CEC_RXD_4 | CEC_RXD_5 | CEC_RXD_6 | CEC_RXD_7 | CEC_RXD_8 | | 8F68H CEC_FSTAT CEC_ICLR CEC_FCLR CEC_TXH CEC_TXD_1 CEC_TXD_2 CEC_TXD_3 CEC_TXD_4 8F60H CEC_PRES1 CEC_PRES0 CEC_CONF1 CEC_CONF0 CEC_GCTRL CEC_ICTRL CEC_FCTRL CEC_ISTAT 8F58H - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | 8F78H | CEC_TXD_13 | CEC_TXD_14 | CEC_TXD_15 | CEC_TXD_16 | CEC_TXD_17 | CEC_TXD_18 | CEC_TXD_19 | CEC_RXH | | 8F60H CEC_PRES1 CEC_PRES0 CEC_CONF1 CEC_CONF0 CEC_GCTRL CEC_ICTRL CEC_FCTRL CEC_FCTRL 8F58H - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | 8F70H | CEC_TXD_5 | CEC_TXD_6 | CEC_TXD_7 | CEC_TXD_8 | CEC_TXD_9 | CEC_TXD_10 | CEC_TXD_11 | CEC_TXD_12 | | 8F58H - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - <th>8F68H</th> <th>CEC_FSTAT</th> <th>CEC_ICLR</th> <th>CEC_FCLR</th> <th>CEC_TXH</th> <th>CEC_TXD_1</th> <th>CEC_TXD_2</th> <th>CEC_TXD_3</th> <th>CEC_TXD_4</th> | 8F68H | CEC_FSTAT | CEC_ICLR | CEC_FCLR | CEC_TXH | CEC_TXD_1 | CEC_TXD_2 | CEC_TXD_3 | CEC_TXD_4 | | 8F50H - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - <th>8F60H</th> <th>CEC_PRES1</th> <th>CEC_PRES0</th> <th>CEC_CONF1</th> <th>CEC_CONF0</th> <th>CEC_GCTRL</th> <th>CEC_ICTRL</th> <th>CEC_FCTRL</th> <th>CEC_ISTAT</th> | 8F60H | CEC_PRES1 | CEC_PRES0 | CEC_CONF1 | CEC_CONF0 | CEC_GCTRL | CEC_ICTRL | CEC_FCTRL | CEC_ISTAT | | 8F48H IRC_PRES1 IRC_PRES0 IRC_FRMP1 IRC_FRMP0 IRC_CONF IRC_CTRL IRC_EDGE1 IRC_EDGE0 8F40H PSR1 PSR2 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | 8F58H | - | - | - | - | - | - | - | - | | 8F40H PSR1 PSR2 - - - - - - 8F38H - - - - - - - - 8F30H COMPCON COMPVREFSEL COMPST COMPDBCNT - - - - - 8F28H BISCCON INTCNTH INTCNTL XTLCNTH XTLCNTL - - - - 8F20H I2CMR10 I2CSR1 I2CSCLLR1 I2CSCLHR1 I2CSDAHR1 I2CDR1 I2CMR01 | 8F50H | - | - | - | - | - | - | - | - | | 8F38H - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - <th>8F48H</th> <th>IRC_PRES1</th> <th>IRC_PRES0</th> <th>IRC_FRMP1</th> <th>IRC_FRMP0</th> <th>IRC_CONF</th> <th>IRC_CTRL</th> <th>IRC_EDGE1</th> <th>IRC_EDGE0</th> | 8F48H | IRC_PRES1 | IRC_PRES0 | IRC_FRMP1 | IRC_FRMP0 | IRC_CONF | IRC_CTRL | IRC_EDGE1 | IRC_EDGE0 | | 8F30H COMPCON COMPVREFSEL COMPST COMPDBCNT - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | 8F40H | PSR1 | PSR2 | - | - | - | - | - | - | | 8F28H BISCCON INTCNTH INTCNTL XTLCNTH XTLCNTL - - 8F20H I2CMR10 I2CSR1 I2CSCLLR1 I2CSCLHR1 I2CSDAHR1 I2CDR1 I2CSAR10 I2CSAR11 8F18H P0DB P1DB P2DB P3DB P4DB P5DB I2CMR01 I2CMR11 8F10H P4OD P5OD - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | 8F38H | - | - | - | - | - | - | - | - | | 8F20H I2CMR10 I2CSR1 I2CSCLLR1 I2CSCLHR1 I2CSDAHR1 I2CDR1 I2CSAR10 I2CSAR11 8F18H P0DB P1DB P2DB P3DB P4DB P5DB I2CMR01 I2CMR11 8F10H P4OD P5OD - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -< | 8F30H | COMPCON | COMPVREFSEL | COMPST | COMPDBCNT | - | - | - | - | | 8F18H PODB P1DB P2DB P3DB P4DB P5DB I2CMR01 I2CMR11 8F10H P4OD P5OD - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - </th <th>8F28H</th> <th>BISCCON</th> <th>INTCNTH</th> <th>INTCNTL</th> <th>XTLCNTH</th> <th>XTLCNTL</th> <th></th> <th>-</th> <th>-</th> | 8F28H | BISCCON | INTCNTH | INTCNTL | XTLCNTH | XTLCNTL | | - | - | | 8F10H P40D P50D - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - <th< th=""><th>8F20H</th><th>I2CMR10</th><th>I2CSR1</th><th>I2CSCLLR1</th><th>I2CSCLHR1</th><th>I2CSDAHR1</th><th>I2CDR1</th><th>I2CSAR10</th><th>I2CSAR11</th></th<> | 8F20H | I2CMR10 | I2CSR1 | I2CSCLLR1 | I2CSCLHR1 | I2CSDAHR1 | I2CDR1 | I2CSAR10 | I2CSAR11 | | 8F08H IODBCNT P00D P10D P20D P30D | 8F18H | PODB | P1DB | P2DB | P3DB | P4DB | P5DB | I2CMR01 | I2CMR11 | | | 8F10H | P4OD | P5OD | - | - | - | - | - | - | | <b>8F00H</b> P0PU P1PU P2PU P3PU P4PU P5PU | 8F08H | IODBCNT | - | - | - | P0OD | P1OD | P2OD | P3OD | | | 8F00H | POPU | P1PU | P2PU | P3PU | P4PU | P5PU | | - | Table 9.2XSFR Map Summary ### 8.7.2 SFR Map ACC (Accumulator Register): E0H 5 3 2 1 0 ACC RW RWRW RWRWRW RW RW Initial value: 00H ACC Accumulator B (B Register): F0H 7 6 5 4 3 2 1 0 В RW RW RW RW RW RW RW RW Initial value: 00H B B Register SP (Stack Pointer): 81H 7 6 5 3 2 0 1 SP RW RW RW RW RW RW RW RW Initial value: 07H SP Stack Pointer XSP (Extend Stack Pointer): ADH 7 6 5 4 3 2 1 0 XSP RW RW RW RW RW RW RW RW Initial value: 00H XSP Extended Stack Pointer The XSP is a high of stack pointer when XSPEN bit of the XSPCR register is set. In this case Stack is located in XDATA memory and the maximal size of stack is equal to 64KB. If the XSPEN bit is set to '0', the XSP register is ignored. XSPCR (Extended Stack Pointer Control Register): AEH 7 6 5 4 3 2 1 0 - - - - - - - XSPEN - - - - - RW Initial value: 00H SP Extended Stack Pointer Enable/Disable 0 Disable1 Enable #### DPL (Data Pointer Register Low): 82H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |------------------|-----|---|---|---|---|---|--------------------|--|--|--| | | DPL | | | | | | | | | | | RW RW RW RW RW F | | | | | | | | | | | | | | | | | | | Initial value: 00H | | | | DPL Data Pointer Register Low Byte ### DPH (Data Pointer Register High): 83H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |----|-----|----|----|----|----|----|--------------------|--|--|--|--| | | DPH | | | | | | | | | | | | RW | | | | | | | | | | | | Initial value: 00H | | | | | DPH Data Pointer Register High Byte #### PSW (Program Status Word): D0H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|-----|-----|----|----|----| | CY | AC | F0 | RS1 | RS0 | OV | F1 | Р | | RW Initial value: 00H CY Carry Flag AC Auxiliary Carry Flag F0 General Purpose User-Definable Flag RS1 Register Bank Select bit 1 RS0 Register Bank Select bit 0 OV Overflow Flag F1 User-Definable Flag P Parity Flag. Set/cleared by hardware each instruction cycle to indicate an odd/even number of '1' bits in the accumulator #### EO (Extended Operation Register) : A2H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---------|---|--------|---------|---------| | • | - | • | TRAP_EN | - | DPSEL2 | DPSEL.1 | DPSEL.0 | | R | R | R | RW | R | RW | RW | RW | Initial value: 00H TRAP\_EN Select the instruction 0 Select MOVC @(DPTR++), A 1 Select Software TRAP instruction DPSEL[2:0] Select Banked Data Point Register DPSEL2 DPSEL1 DPSEL0 0 0 0 DPTR0 0 0 1 DPTR1 Reserved - #### XBANK (XRAM Bank Pointer): 8CH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-----|-------|-----|-----|-----|-----|-----|----|--|--| | | XBANK | | | | | | | | | | R/W RW | | | Initial value: 00H **XBANK** XRAM Bank Pointer ### NOTE) 1. This XBANK register holds the [15:8] part of memory address during access to data. 2. Address[15:0]: "XBANK:Ri" (Ri: R0 or R1) 3. Ex) MOVX A,@Ri ; Move external data (XBANK:Ri[15:0]) to A MOVX @Ri,A ; Move A to external data (XBANK:Ri[15:0]) #### **AUTHORITY (AUTHORITY register): AFH** | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---|-----------|---|---|---|---|---|---|--|--| | | AUTHORITY | | | | | | | | | | R | R | R | R | R | R | R | R | | | Initial value: 00H **AUTHORITY** The following registers can be written only when authorized. The registers are SCCR, LVIR, BCCR, RSFR, VDCMOD. 0 Unauthorized 1 Authorized #### MEX1 (Memory Extension register 1): 94H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | CB19 | CB18 | CB17 | CB16 | NB19 | NB18 | NB17 | NB16 | | R | R | R | R | RW | RW | RW | RW | Initial value: 00H This register records the 'current' and 'next' memory bank numbers for Program code CB19-CB16 Current Bank NB19-NB16 Next Bank ### MEX2 (Memory Extension register 2): 95H | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-----|-------|-------|-------|------|------|------|------| | | MCM | MCB18 | MCB17 | MCB16 | IB19 | IB18 | IB17 | IB16 | | Ī | RW Initial value: 00H This register controls the current memory bank numbers for interrupt service routine code and for memory constants MCM Memory Constant Mode. Set to '1' when Memory Bank used. MCB18-MCB16 Memory Constant Bank (with MEX3.7) IB19-IB16 Interrupt Bank #### MEX3 (Memory Extension register 3): 95H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-----|-----|-------|-----|------|------|------| | MCB19 | UB1 | UB0 | MXB19 | MXM | MX18 | MX17 | MX16 | | RW Initial value: 00H This register chiefly controls the current memory bank number for external data memory. MCB19 Memory Constant Bank MSB. See MEX2. UB3, UB4 Bits available to the user. MXM XRAM Bank selector. When set to '1', the MOVX Bank bits MX19- MX16 are used as XRAMA19-16 instead of the Current Bank (CB) MX19-MX16 XRAM Bank ### **MEXSP (Memory Extension Stack Pointer): 97H** | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |---|----|--------------------------------|----|----|----|----|----|--|--|--| | 0 | | Memory Extension Stack Pointer | | | | | | | | | | - | RW | | | Initial value: 7FH This register is the Memory Extension Stack Pointer. It provides for a stack depth of up to 128 bytes (Bit 7 is always 0). It is pre-incremented by call instructions and post-decremented by return instructions. ### 9 I/O Ports #### 9.1 I/O Ports The A97C450 has six groups of I/O ports (P0 ~ P5). Each port can be easily configured by software as I/O pin, internal pull up and open-drain pin to meet various system configurations and design requirements. Also P0 includes function that can generate interrupt according to change of state of the pin. ### 9.2 Port Register ### 9.2.1 Data Register (Px) Data Register is a bidirectional I/O port. If ports are configured as output ports, data can be written to the corresponding bit of the Px. If ports are configured as input ports, the data can be read from the corresponding bit of the Px. #### 9.2.2 Direction Register (PxIO) Each I/O pin can be independently used as an input or an output through the PxIO register. Clearing bits in this register will make the corresponding pin of Px as an input mode. Set bits of this register will make the pin to output mode. Almost bits are cleared by a system reset, but some bits are set by a system reset. ### 9.2.3 Pull-up Resistor Selection Register (PxPU) The on-chip pull-up resistor can be connected to I/O ports individually with a pull-up resistor selection register (PxPU). The pull-up register selection controls the pull-up resister enable/disable of each port. When the corresponding bit is 1, the pull-up resister of the pin is enabled. When 0, the pull-up resister is disabled. All bits are cleared by a system reset. #### 9.2.4 Open-drain Selection Register (PxOD) There are internally open-drain selection registers (PxOD) for P0 $\sim$ P4 and a bit for P5. The open-drain selection register controls the open-drain enable/disable of each port. Almost ports become push-pull by a system reset, but some ports become open-drain by a system reset. #### 9.2.5 De-bounce Enable Register (PxDB) P0 ~ P5 support debounce function. Debounce time of each ports has about 4us. #### 9.2.6 Port Selection Register 1 (PSR1) PSR1 register select ports P2 attribute to analog-to-digital converter (A/D)s or general I/O port. PSR1 registers prevent the input leakage current when ports are connected to analog inputs. If the bit of PSR1 is '1', the dynamic current path of the Schmitt OR gate of the port is cut off and the digital input of the corresponding port is always '0'. ### 9.2.7 Port Selection Register 2 (PSR2) PSR2[1:0] register select ports P17, P34 attribute to analog-to-digital converter (A/D)s or general I/O port. PSR2[1:0] registers prevent the input leakage current when ports are connected to analog inputs. If the bit of PSR2[1:0] is '1', the dynamic current path of the Schmitt OR gate of the port is cut off and the digital input of the corresponding port is always '0'. PSR[2] is ADC input mux enable register. PSR2[4] register selects ports to be used as a USART1. PSR2[6:5] register selects ports debounce clock. ### 9.2.8 Port Debounce Length Selection Register (IODBCNT) IODBCNT register selects debounce length of port input. Clock selected by PSR[6:5] register counts up to IODBCNT. # 9.2.9 Register Map | PO 80H RW 00H PO Data Register POIO 89H RW 00H PO Direction Register POPU 8F00H RW 00H PO Direction Register PODD 8F0CH RW 00H PO Debounce Enable Register PODB 8F18H RW 00H PO Debounce Enable Register P1 88H RW 00H P1 Data Register P110 92H RW 00H P1 Direction Register P110 92H RW 00H P1 Direction Register P1PU 8F01H RW 00H P1 Pull-up Resistor Selection Register P1DD 8F0DH RW 00H P1 Debounce Enable Register P2D 90H RW 00H P1 Debounce Enable Register P2D 90H RW 00H P2 Data Register P2IO 99H RW 00H P2 Direction Register P2IO 99H RW 00H P2 Direction Register P2D </th <th>Name</th> <th>Address</th> <th>Direction</th> <th>Default</th> <th>Description</th> | Name | Address | Direction | Default | Description | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|-----------|---------|-----------------------------------------| | POPU 8F00H R/W 00H P0 Pull-up Resistor Selection Register POOD 8F0CH R/W 00H P0 Open-drain Selection Register PODB 8F18H R/W 00H P0 Debounce Enable Register P1 88H R/W 00H P1 Data Register P1IO 92H R/W 00H P1 Direction Register P1IO 92H R/W 00H P1 Pull-up Resistor Selection Register P1PU 8F0DH R/W 00H P1 Debounce Enable Register P1DB 8F0H R/W 00H P1 Debounce Enable Register P2D 99H R/W 00H P2 Data Register P2PU 8F02H R/W 00H P2 Direction Register P2PU 8F02H R/W 00H P2 P2 Upen-drain Selection Register P2DB 8F04H R/W 00H P2 Debounce Enable Register P2DB 8F1AH R/W 00H P3 Data Register P3IO A1H R/W 00H < | P0 | 80H | R/W | 00H | P0 Data Register | | PODD 8F0CH R/W 00H P0 Open-drain Selection Register PODB 8F18H R/W 00H P0 Debounce Enable Register P1 88H R/W 00H P1 Data Register P110 92H R/W 00H P1 Direction Register P1D0 8F01H R/W 00H P1 Direction Register P1DD 8F01H R/W 00H P1 Open-drain Selection Register P1DB 8F19H R/W 00H P1 Debounce Enable Register P2 90H R/W 00H P2 Detoction Register P2IO 99H R/W 00H P2 Direction Register P2IO 99H R/W 00H P2 Debounce Enable Register P2D 8F02H R/W 00H P2 Debounce Enable Register P2D 8F02H R/W 00H P3 Data Register P3 98H R/W 00H P3 Data Register P3D 8F18H R/W 00H P3 Debounce Enable Register <td>P0IO</td> <td>89H</td> <td>R/W</td> <td>00H</td> <td>P0 Direction Register</td> | P0IO | 89H | R/W | 00H | P0 Direction Register | | PODB 8F18H R/W 00H PO Debounce Enable Register P1 88H R/W 00H P1 Data Register P1IO 92H R/W 00H P1 Direction Register P1PU 8F01H R/W 00H P1 Pull-up Resistor Selection Register P1DD 8F0DH R/W 00H P1 Debounce Enable Register P1DB 8F19H R/W 00H P2 Data Register P2 90H R/W 00H P2 Data Register P2IO 99H R/W 00H P2 Detounce Enable Register P2IO 99H R/W 00H P2 Pull-up Resistor Selection Register P2DD 8F0EH R/W 00H P2 Depon-drain Selection Register P2DB 8F1AH R/W 00H P3 Data Register P3 98H R/W 00H P3 Data Register P3IO A1H R/W 00H P3 Debounce Enable Register P3DD 8F0FH R/W 00H P3 Depon-drain Selection R | P0PU | 8F00H | R/W | 00H | P0 Pull-up Resistor Selection Register | | P1 88H RW 00H P1 Data Register P1IO 92H RW 00H P1 Direction Register P1PU 8F01H RW 00H P1 Direction Register P1DD 8F0H RW 00H P1 Open-drain Selection Register P1DB 8F19H RW 00H P1 Debounce Enable Register P2 90H RW 00H P2 Data Register P2IO 99H RW 00H P2 Direction Register P2IO 99H RW 00H P2 Direction Register P2PU 8F02H RW 00H P2 Debounce Enable Register P2DD 8F0EH RW 00H P2 Debounce Enable Register P3D 8F1AH RW 00H P3 Direction Register P3IO A1H RW 00H P3 Direction Register P3DU 8F03H RW 00H P3 Debounce Enable Register P3DB 8F1BH RW 00H P3 Debounce Enable Register | P0OD | 8F0CH | R/W | 00H | P0 Open-drain Selection Register | | P1IO 92H RW 00H P1 Direction Register P1PU 8F01H RW 00H P1 Pull-up Resistor Selection Register P1DD 8F0DH RW 00H P1 Open-drain Selection Register P1DB 8F19H RW 00H P1 Debounce Enable Register P2 90H RW 00H P2 Data Register P2IO 99H RW 00H P2 Direction Register P2PU 8F02H RW 00H P2 Pull-up Resistor Selection Register P2PD 8F02H RW 00H P2 Debounce Enable Register P2OD 8F0EH RW 00H P2 Debounce Enable Register P3 98H RW 00H P3 Data Register P3IO A1H RW 00H P3 Data Register P3IO A1H RW 00H P3 Debounce Enable Register P3DD 8F0FH RW 00H P3 Debounce Enable Register P3DD 8F1BH RW 00H P3 Debounce Enable Re | P0DB | 8F18H | R/W | 00H | P0 Debounce Enable Register | | P1PU 8F01H RW 00H P1 Pull-up Resistor Selection Register P1OD 8F0DH RW 00H P1 Open-drain Selection Register P1DB 8F19H RW 00H P1 Debounce Enable Register P2 90H RW 00H P2 Data Register P2U 99H RW 00H P2 Direction Register P2U 8F02H RW 00H P2 Pull-up Resistor Selection Register P2DD 8F02H RW 00H P2 Open-drain Selection Register P2DB 8F1AH RW 00H P2 Debounce Enable Register P3DB 8F1AH RW 00H P3 Data Register P3DB 8F1AH RW 00H P3 Direction Register P3DU 8F03H RW 00H P3 Open-drain Selection Register P3DB 8F1BH RW 00H P3 Debounce Enable Register P4U A0H RW 00H P4 Data Register P4PU 8F04H RW 00H P4 Pul | P1 | 88H | R/W | 00H | P1 Data Register | | P1OD 8FODH RW 00H P1 Open-drain Selection Register P1DB 8F19H RW 00H P1 Debounce Enable Register P2 90H RW 00H P2 Data Register P2IO 99H RW 00H P2 Direction Register P2DU 8F02H RW 00H P2 Pull-up Resistor Selection Register P2DD 8F0EH RW 00H P2 Debounce Enable Register P2DB 8F1AH RW 00H P2 Debounce Enable Register P3 98H RW 00H P3 Data Register P3IO A1H RW 00H P3 Data Register P3IO A1H RW 00H P3 Direction Register P3DB 8F03H RW 00H P3 Pull-up Resistor Selection Register P3DB 8F1BH RW 00H P3 Debounce Enable Register P4U A0H RW 00H P4 Data Register P4U 8F04H RW 00H P4 Direction Register <td>P1IO</td> <td>92H</td> <td>R/W</td> <td>00H</td> <td>P1 Direction Register</td> | P1IO | 92H | R/W | 00H | P1 Direction Register | | P1DB 8F19H RW 00H P1 Debounce Enable Register P2 90H RW 00H P2 Data Register P2IO 99H RW 00H P2 Direction Register P2PU 8F02H RW 00H P2 Pull-up Resistor Selection Register P2DD 8F0EH RW 00H P2 Open-drain Selection Register P2DB 8F1AH RW 00H P2 Debounce Enable Register P3 98H RW 00H P3 Data Register P3IO A1H RW 00H P3 Direction Register P3IO A1H RW 00H P3 Debounce Enable Register P3IO 8F0FH RW 00H P3 Debounce Enable Register P3DD 8F0FH RW 00H P3 Debounce Enable Register P4 A0H RW 00H P4 Data Register P4U 8F04H RW 00H P4 Direction Register P4DD 8F10H RW 00H P4 Open-drain Selection Register | P1PU | 8F01H | R/W | 00H | P1 Pull-up Resistor Selection Register | | P2 90H RW 00H P2 Data Register P2IO 99H RW 00H P2 Direction Register P2PU 8F02H RW 00H P2 Pull-up Resistor Selection Register P2OD 8F0EH RW 00H P2 Open-drain Selection Register P2DB 8F1AH RW 00H P3 Data Register P3 98H RW 00H P3 Direction Register P3IO A1H RW 00H P3 Direction Register P3PU 8F03H RW 00H P3 Pall-up Resistor Selection Register P3DD 8F0FH RW 00H P3 Debounce Enable Register P3DB 8F1BH RW 00H P3 Debounce Enable Register P4 A0H RW 00H P4 Data Register P4IO B1H RW 00H P4 Pull-up Resistor Selection Register P4DD 3F10H RW 00H P4 Debounce Enable Register P5 B0H RW 00H P5 Data Register | P1OD | 8F0DH | R/W | 00H | P1 Open-drain Selection Register | | P2IO 99H RW 00H P2 Direction Register P2PU 8F02H RW 00H P2 Pull-up Resistor Selection Register P2DD 8F0EH RW 00H P2 Open-drain Selection Register P2DB 8F1AH RW 00H P3 Data Register P3 98H RW 00H P3 Data Register P3IO A1H RW 00H P3 Direction Register P3PU 8F03H RW 00H P3 Direction Register P3DD 8F0FH RW 00H P3 Debounce Enable Register P3DB 8F1BH RW 00H P3 Debounce Enable Register P4 A0H RW 00H P4 Data Register P4IO B1H RW 00H P4 Direction Register P4DD 8F04H RW 00H P4 P4 Ul-up Resistor Selection Register P4DB 3F1CH RW 00H P4 Debounce Enable Register P5 B0H RW 00H P5 Data Register | P1DB | 8F19H | R/W | 00H | P1 Debounce Enable Register | | P2PU 8F02H R/W 00H P2 Pull-up Resistor Selection Register P2OD 8F0EH R/W 00H P2 Open-drain Selection Register P2DB 8F1AH R/W 00H P2 Debounce Enable Register P3 98H R/W 00H P3 Data Register P3IO A1H R/W 00H P3 Direction Register P3PU 8F03H R/W 00H P3 Pull-up Resistor Selection Register P3OD 8F0FH R/W 00H P3 Open-drain Selection Register P3DB 8F1BH R/W 00H P3 Debounce Enable Register P4 A0H R/W 00H P4 Direction Register P4IO B1H R/W 00H P4 Pull-up Resistor Selection Register P4PU 8F04H R/W 00H P4 Open-drain Selection Register P4DB 8F1CH R/W 00H P4 Debounce Enable Register P5 B0H R/W 00H P5 Data Register P5DIO B9H R/W < | P2 | 90H | R/W | 00H | P2 Data Register | | P2OD 8F0EH R/W 00H P2 Open-drain Selection Register P2DB 8F1AH R/W 00H P2 Debounce Enable Register P3 98H R/W 00H P3 Data Register P3IO A1H R/W 00H P3 Direction Register P3PU 8F03H R/W 00H P3 Pull-up Resistor Selection Register P3OD 8F0FH R/W 00H P3 Debounce Enable Register P3DB 8F1BH R/W 00H P3 Debounce Enable Register P4U A0H R/W 00H P4 Data Register P4IO B1H R/W 00H P4 Direction Register P4DD 8F04H R/W 00H P4 Open-drain Selection Register P4DB 8F10H R/W 00H P4 Debounce Enable Register P5 B0H R/W 00H P5 Data Register P5IO B9H R/W 00H P5 Direction Register P5DU 8F05H R/W 00H P5 Direction Registe | P2IO | 99H | R/W | 00H | P2 Direction Register | | P2DB 8F1AH RW 00H P2 Debounce Enable Register P3 98H RW 00H P3 Data Register P3IO A1H R/W 00H P3 Direction Register P3PU 8F03H RW 00H P3 Pull-up Resistor Selection Register P3OD 8F0FH RW 00H P3 Open-drain Selection Register P3DB 8F1BH RW 00H P3 Debounce Enable Register P4 A0H RW 00H P4 Data Register P4IO B1H RW 00H P4 Direction Register P4PU 8F04H RW 00H P4 Pull-up Resistor Selection Register P4DB 8F10H RW 00H P4 Debounce Enable Register P5 B0H RW 00H P5 Data Register P5IO B9H RW 00H P5 Direction Register P5DD 8F11H RW 00H P5 Open-drain Selection Register P5DB 8F10H RW 00H P5 Debounce Enable Regi | P2PU | 8F02H | R/W | 00H | P2 Pull-up Resistor Selection Register | | P3 98H R/W 00H P3 Data Register P3IO A1H R/W 00H P3 Direction Register P3PU 8F03H R/W 00H P3 Pull-up Resistor Selection Register P3OD 8F0FH R/W 00H P3 Open-drain Selection Register P3DB 8F1BH R/W 00H P3 Debounce Enable Register P4 A0H R/W 00H P4 Data Register P4IO B1H R/W 00H P4 Direction Register P4PU 8F04H R/W 00H P4 Pull-up Resistor Selection Register P4OD 8F10H R/W 00H P4 Debounce Enable Register P5 B0H R/W 00H P5 Data Register P5IO B9H R/W 00H P5 Direction Register P5DU 8F05H R/W 00H P5 Open-drain Selection Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register P5DB 8F1DH R/W 00H P5 Debounc | P2OD | 8F0EH | R/W | 00H | P2 Open-drain Selection Register | | P3IO A1H R/W 00H P3 Direction Register P3PU 8F03H R/W 00H P3 Pull-up Resistor Selection Register P3OD 8F0FH R/W 00H P3 Open-drain Selection Register P3DB 8F1BH R/W 00H P3 Debounce Enable Register P4 A0H R/W 00H P4 Data Register P4IO B1H R/W 00H P4 Direction Register P4PU 8F04H R/W 00H P4 Pull-up Resistor Selection Register P4OD 8F10H R/W 00H P4 Debounce Enable Register P5 B0H R/W 00H P5 Data Register P5IO B9H R/W 00H P5 Direction Register P5PU 8F05H R/W 00H P5 Pull-up Resistor Selection Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register P5DB 8F40H R/W 00H | P2DB | 8F1AH | R/W | 00H | P2 Debounce Enable Register | | P3PU 8F03H RW 00H P3 Pull-up Resistor Selection Register P3OD 8F0FH RW 00H P3 Open-drain Selection Register P3DB 8F1BH RW 00H P3 Debounce Enable Register P4 A0H RW 00H P4 Data Register P4IO B1H RW 00H P4 Direction Register P4PU 8F04H RW 00H P4 Pull-up Resistor Selection Register P4OD 8F10H RW 00H P4 Open-drain Selection Register P4DB 8F1CH RW 00H P4 Debounce Enable Register P5 B0H RW 00H P5 Data Register P5IO B9H RW 00H P5 Direction Register P5DU 8F05H RW 00H P5 Open-drain Selection Register P5DB 8F1DH RW 00H P5 Debounce Enable Register P5DB 8F40H RW 00H Port Selection Register 1 P5R2 8F41H RW 00H <t< td=""><td>P3</td><td>98H</td><td>R/W</td><td>00H</td><td>P3 Data Register</td></t<> | P3 | 98H | R/W | 00H | P3 Data Register | | P3OD 8F0FH R/W 00H P3 Open-drain Selection Register P3DB 8F1BH R/W 00H P3 Debounce Enable Register P4 A0H R/W 00H P4 Data Register P4IO B1H R/W 00H P4 Direction Register P4PU 8F04H R/W 00H P4 Pull-up Resistor Selection Register P4OD 8F10H R/W 00H P4 Open-drain Selection Register P4DB 8F1CH R/W 00H P4 Debounce Enable Register P5 B0H R/W 00H P5 Data Register P5IO B9H R/W 00H P5 Direction Register P5DD 8F11H R/W 00H P5 Pull-up Resistor Selection Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register PSR1 8F40H R/W 00H Port Selection Register 1 PSR2 8F41H R/W 00H Port Selection Register 2 | P3IO | A1H | R/W | 00H | P3 Direction Register | | P3DB 8F1BH R/W 00H P3 Debounce Enable Register P4 A0H R/W 00H P4 Data Register P4IO B1H R/W 00H P4 Direction Register P4PU 8F04H R/W 00H P4 Pull-up Resistor Selection Register P4OD 8F10H R/W 00H P4 Open-drain Selection Register P4DB 8F1CH R/W 00H P4 Debounce Enable Register P5 B0H R/W 00H P5 Data Register P5IO B9H R/W 00H P5 Direction Register P5PU 8F05H R/W 00H P5 Pull-up Resistor Selection Register P5DB 8F11H R/W 00H P5 Open-drain Selection Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register PSR1 8F40H R/W 00H Port Selection Register 1 PSR2 8F41H R/W 00H Port Selection Register 2 | P3PU | 8F03H | R/W | 00H | P3 Pull-up Resistor Selection Register | | P4 A0H R/W 00H P4 Data Register P4IO B1H R/W 00H P4 Direction Register P4PU 8F04H R/W 00H P4 Pull-up Resistor Selection Register P4OD 8F10H R/W 00H P4 Open-drain Selection Register P4DB 8F1CH R/W 00H P4 Debounce Enable Register P5 B0H R/W 00H P5 Data Register P5IO B9H R/W 00H P5 Direction Register P5PU 8F05H R/W 00H P5 Pull-up Resistor Selection Register P5OD 8F11H R/W 00H P5 Open-drain Selection Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register PSR1 8F40H R/W 00H Port Selection Register 1 PSR2 8F41H R/W 00H Port Selection Register 2 | P3OD | 8F0FH | R/W | 00H | P3 Open-drain Selection Register | | P4IO B1H R/W 00H P4 Direction Register P4PU 8F04H R/W 00H P4 Pull-up Resistor Selection Register P4OD 8F10H R/W 00H P4 Open-drain Selection Register P4DB 8F1CH R/W 00H P4 Debounce Enable Register P5 B0H R/W 00H P5 Data Register P5IO B9H R/W 00H P5 Direction Register P5PU 8F05H R/W 00H P5 Pull-up Resistor Selection Register P5OD 8F11H R/W 00H P5 Open-drain Selection Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register PSR1 8F40H R/W 00H Port Selection Register 1 PSR2 8F41H R/W 00H Port Selection Register 2 | P3DB | 8F1BH | R/W | 00H | P3 Debounce Enable Register | | P4PU 8F04H R/W 00H P4 Pull-up Resistor Selection Register P4OD 8F10H R/W 00H P4 Open-drain Selection Register P4DB 8F1CH R/W 00H P4 Debounce Enable Register P5 B0H R/W 00H P5 Data Register P5IO B9H R/W 00H P5 Direction Register P5PU 8F05H R/W 00H P5 Pull-up Resistor Selection Register P5OD 8F11H R/W 00H P5 Open-drain Selection Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register PSR1 8F40H R/W 00H Port Selection Register 1 PSR2 8F41H R/W 00H Port Selection Register 2 | P4 | A0H | R/W | 00H | P4 Data Register | | P4OD 8F10H R/W 00H P4 Open-drain Selection Register P4DB 8F1CH R/W 00H P4 Debounce Enable Register P5 B0H R/W 00H P5 Data Register P5IO B9H R/W 00H P5 Direction Register P5PU 8F05H R/W 00H P5 Pull-up Resistor Selection Register P5OD 8F11H R/W 00H P5 Open-drain Selection Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register PSR1 8F40H R/W 00H Port Selection Register 1 PSR2 8F41H R/W 00H Port Selection Register 2 | P4IO | B1H | R/W | 00H | P4 Direction Register | | P4DB 8F1CH R/W 00H P4 Debounce Enable Register P5 B0H R/W 00H P5 Data Register P5IO B9H R/W 00H P5 Direction Register P5PU 8F05H R/W 00H P5 Pull-up Resistor Selection Register P5OD 8F11H R/W 00H P5 Open-drain Selection Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register PSR1 8F40H R/W 00H Port Selection Register 1 PSR2 8F41H R/W 00H Port Selection Register 2 | P4PU | 8F04H | R/W | 00H | P4 Pull-up Resistor Selection Register | | P5 B0H R/W 00H P5 Data Register P5IO B9H R/W 00H P5 Direction Register P5PU 8F05H R/W 00H P5 Pull-up Resistor Selection Register P5OD 8F11H R/W 00H P5 Open-drain Selection Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register PSR1 8F40H R/W 00H Port Selection Register 1 PSR2 8F41H R/W 00H Port Selection Register 2 | P4OD | 8F10H | R/W | 00H | P4 Open-drain Selection Register | | P5IO B9H R/W 00H P5 Direction Register P5PU 8F05H R/W 00H P5 Pull-up Resistor Selection Register P5OD 8F11H R/W 00H P5 Open-drain Selection Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register PSR1 8F40H R/W 00H Port Selection Register 1 PSR2 8F41H R/W 00H Port Selection Register 2 | P4DB | 8F1CH | R/W | 00H | P4 Debounce Enable Register | | P5PU 8F05H R/W 00H P5 Pull-up Resistor Selection Register P5OD 8F11H R/W 00H P5 Open-drain Selection Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register PSR1 8F40H R/W 00H Port Selection Register 1 PSR2 8F41H R/W 00H Port Selection Register 2 | P5 | ВОН | R/W | 00H | P5 Data Register | | P5OD 8F11H R/W 00H P5 Open-drain Selection Register P5DB 8F1DH R/W 00H P5 Debounce Enable Register PSR1 8F40H R/W 00H Port Selection Register 1 PSR2 8F41H R/W 00H Port Selection Register 2 | P5IO | В9Н | R/W | 00H | P5 Direction Register | | P5DB 8F1DH R/W 00H P5 Debounce Enable Register PSR1 8F40H R/W 00H Port Selection Register 1 PSR2 8F41H R/W 00H Port Selection Register 2 | P5PU | 8F05H | R/W | 00H | P5 Pull-up Resistor Selection Register | | PSR1 8F40H R/W 00H Port Selection Register 1 PSR2 8F41H R/W 00H Port Selection Register 2 | P5OD | 8F11H | R/W | 00H | P5 Open-drain Selection Register | | PSR2 8F41H R/W 00H Port Selection Register 2 | P5DB | 8F1DH | R/W | 00H | P5 Debounce Enable Register | | · · · · · · · · · · · · · · · · · · · | PSR1 | 8F40H | R/W | 00H | Port Selection Register 1 | | IODBCNT 8F08H R/W 00H Port Debounce Length Selection register | PSR2 | 8F41H | R/W | 00H | Port Selection Register 2 | | | IODBCNT | 8F08H | R/W | 00H | Port Debounce Length Selection register | Table 10.1 Port Register Map ### 9.3 P0 Port #### 9.3.1 P0 Port Description P0 is 8-bit I/O port. P0 control registers consist of P0 data register (P0), P0 direction register (P0IO), debounce enable register (P0DB), P0 pull-up resistor selection register (P0PU) and P0 open-drain selection register (P0OD). Refer to the port function selection registers for the P0 function selection. ### 9.3.2 Register description for P0 ### P0 (P0 Data Register): 80H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-----|-----|-----|-----|-----|-----|-----| | P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 | | RW Initial value: 00H P0[7:0] I/O Data ### P0IO (P0 Direction Register): 89H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P071O | P061O | P05IO | P04IO | P031O | P021O | P01IO | P00IO | | RW Initial value: 00H P0IO[7:0] P0 Data I/O Direction. 0 Input1 Output ### P0PU (P0 Pull-up Resistor Selection Register): 8F00H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P07PU | P06PU | P05PU | P04PU | P03PU | P02PU | P01PU | P00PU | | RW Initial value: 00H P0PU[7:0] Configure Pull-up Resistor of P0 Port 0 Disable1 Enable #### P00D (P0 Open-drain Selection Register): 8F0CH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P07OD | P06OD | P05OD | P04OD | P03OD | P02OD | P010D | P000D | | RW Initial value: 00H P0OD[7:0] Configure Open-drain of P0 Port Push-pull outputOpen-drain output ### P0DB (P0 De-bounce Enable Register): 8F18H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P07DB | P06DB | P05DB | P04DB | P03DB | P02DB | P01DB | P00DB | | RW Initial value: 00H P0DB[7:0] Configure debounce of P0 port 0 Disable 1 Enable ### NOTE) 1. If the same level is not detected on enabled pin three or four times in a row at the sampling clock, the signal is eliminated as noise. A pulse level should be input for the duration of 3 clock or more to be actually detected as a valid edge. The port de-bounce is **not** automatically disabled at stop mode. ### 9.4 P1 Port ### 9.4.1 P1 Port Description P1 is 8-bit I/O port. P1 control registers consist of P1 data register (P1), P1 direction register (P1IO), debounce enable register (P1DB), P1 pull-up resistor selection register (P1PU) and P1 open-drain selection register (P1OD). Refer to the port function selection registers for the P1 function selection. ### 9.4.2 Register description for P1 #### P1 (P1 Data Register): 88H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |--------------------|-----|-----|-----|-----|-----|-----|-----|--|--|--| | P17 | P16 | P15 | P14 | P13 | P12 | P11 | P10 | | | | | RW | | | | Initial value: 00H | | | | | | | | | | | P1[7:0] I/O Data ### P1IO (P1 Direction Register): 91H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P171O | P16IO | P151O | P14IO | P13IO | P12IO | P11IO | P101O | | RW Initial value: 00H P1IO[7:0] P1 Data I/O Direction. 0 Input1 Output #### P1PU (P1 Pull-up Resistor Selection Register): 8F01H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P17PU | P16PU | P15PU | P14PU | P13PU | P12PU | P11PU | P10PU | | RW Initial value: 00H P1PU[7:0] Configure Pull-up Resistor of P1 Port 0 Disable1 Enable ### P10D (P1 Open-drain Selection Register): 8F0DH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P170D | P160D | P150D | P140D | P130D | P120D | P110D | P100D | | RW Initial value: 00H P10D[7:0] Configure Open-drain of P1 Port 0 Push-pull output Open-drain output ### P1DB (P1 De-bounce Enable Register): 8F19H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P17DB | P16DB | P15DB | P14DB | P13DB | P12DB | P11DB | P10DB | | RW Initial value: 00H P1DB[7:0] Configure debounce of Px port 0 Disable 1 Enable ### NOTE) 1. If the same level is not detected on enabled pin three or four times in a row at the sampling clock, the signal is eliminated as noise. A pulse level should be input for the duration of 3 clock or more to be actually detected as a valid edge. The port de-bounce is **not** automatically disabled at stop mode. ### 9.5 P2 Port ### 9.5.1 P2 Port Description P2 is 8-bit I/O port. P2 control registers consist of P2 data register (P2), P2 direction register (P2IO), debounce enable register (P2DB), P2 pull-up resistor selection register (P2PU) and P2 open-drain selection register (P2OD). Refer to the port function selection registers for the P2 function selection. ### 9.5.2 Register description for P2 ### P2 (P2 Data Register): 90H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------|-----|-----|-----|-----|-----|-----|-----| | P27 | P26 | P25 | P24 | P23 | P22 | P21 | P20 | | RW | Initial value: 00 | )H | | | | | | | P2[7:0] ### P2IO (P2 Direction Register): 99H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P271O | P261O | P251O | P24IO | P231O | P221O | P211O | P201O | | RW Initial value: 00H P2IO[7:0] P2 Data I/O Direction. I/O Data 0 Input 1 Output #### P2PU (P2 Pull-up Resistor Selection Register): 8F02H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P27PU | P26PU | P25PU | P24PU | P23PU | P22PU | P21PU | P20PU | | RW Initial value: 00H P2PU[7:0] Configure Pull-up Resistor of P2 Port 0 Disable 1 Enable ### P2OD (P2 Open-drain Selection Register): 8F0EH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P270D | P260D | P250D | P240D | P230D | P220D | P210D | P200D | | RW Initial value: 00H P2OD[7:0] Configure Open-drain of P2 Port 0 Push-pull output Open-drain output ### P2DB (P2 De-bounce Enable Register): 8F1AH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P27DB | P26DB | P25DB | P24DB | P23DB | P22DB | P21DB | P20DB | | RW Initial value: 00H P2DB[7:0] Configure debounce of P2 port 0 Disable 1 Enable ### NOTE) 1. If the same level is not detected on enabled pin three or four times in a row at the sampling clock, the signal is eliminated as noise. A pulse level should be input for the duration of 3 clock or more to be actually detected as a valid edge. The port de-bounce is **not** automatically disabled at stop mode. ### 9.6 P3 Port ### 9.6.1 P3 Port Description P3 is 8-bit I/O port. P3 control registers consist of P3 data register (P3), P3 direction register (P3IO), debounce enable register (P3DB), P3 pull-up resistor selection register (P3PU) and P3 open-drain selection register (P3OD). Refer to the port function selection registers for the P3 function selection. ### 9.6.2 Register description for P3 ### P3 (P3 Data Register): 98H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-----|-----|-----|-----|-----|-----|-----| | P37 | P36 | P35 | P34 | P33 | P32 | P31 | P30 | | RW Initial value: 00H P3[7:0] I/O Data ### P3IO (P3 Direction Register): A1H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P37IO | P36IO | P351O | P34IO | P331O | P32IO | P31IO | P30IO | | RW Initial value: 00H P3IO[7:0] P3 Data I/O Direction. 0 Input 1 Output ### P3PU (P3 Pull-up Resistor Selection Register): 8F03H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P37PU | P36PU | P35PU | P34PU | P33PU | P32PU | P31PU | P30PU | | RW Initial value: 00H P3PU[7:0] Configure Pull-up Resistor of P3 Port 0 Disable 1 Enable ### P3OD (P3 Open-drain Selection Register): 8F0FH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P370D | P360D | P350D | P34OD | P33OD | P320D | P310D | P300D | | RW Initial value: 00H P3OD[7:0] Configure Open-drain of P3 Port 0 Push-pull output 1 Open-drain output ### P3DB (P3 De-bounce Enable Register): 8F1BH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P37DB | P36DB | P35DB | P34DB | P33DB | P32DB | P31DB | P30DB | | RW Initial value: 00H P3DB[7:0] Configure debounce of P3 port 0 Disable 1 Enable ### NOTE) If the same level is not detected on enabled pin three or four times in a row at the sampling clock, the signal is eliminated as noise. A pulse level should be input for the duration of 3 clock or more to be actually detected as a valid edge. The port de-bounce is not automatically disabled at stop mode. ### 9.7 P4 Port ### 9.7.1 P4 Port Description P4 is 8-bit I/O port. P4 control registers consist of P4 data register (P4), P4 direction register (P4IO), debounce enable register (P4DB), P4 pull-up resistor selection register (P4PU) and P4 open-drain selection register (P4OD). Refer to the port function selection registers for the P4 function selection. ### 9.7.2 Register description for P4 ### P4 (P4 Data Register): A0H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------|-----|-----|-----|-----|-----|-----|-----| | P47 | P46 | P45 | P44 | P43 | P42 | P41 | P40 | | RW | Initial value: 00 | )H | | | | | | | P4[7:0] I/O Data ### P4IO (P4 Direction Register): B1H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P47IO | P46IO | P451O | P441O | P431O | P42IO | P41IO | P401O | | RW Initial value: 00H P4IO[7:0] P4 Data I/O Direction. 0 Input 1 Output #### P4PU (P4 Pull-up Resistor Selection Register): 8F04H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P47PU | P46PU | P45PU | P44PU | P43PU | P42PU | P41PU | P40PU | | RW Initial value: 00H P4PU[7:0] Configure Pull-up Resistor of P4 Port 0 Disable 1 Enable ### P4OD (P4 Open-drain Selection Register): 8F10H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P47OD | P460D | P450D | P440D | P430D | P420D | P410D | P400D | | RW Initial value: 00H P4OD[7:0] Configure Open-drain of P4 Port 0 Push-pull output 1 Open-drain output ### P4DB (P4 De-bounce Enable Register): 8F1CH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P47DB | P46DB | P45DB | P44DB | P43DB | P42DB | P41DB | P40DB | | RW Initial value: 00H P4DB[7:0] Configure debounce of P4 port 0 Disable 1 Enable ### NOTE) 1. If the same level is not detected on enabled pin three or four times in a row at the sampling clock, the signal is eliminated as noise. A pulse level should be input for the duration of 3 clock or more to be actually detected as a valid edge. The port de-bounce is **not** automatically disabled at stop mode. ### 9.8 **P5 Port** ### 9.8.1 P5 Port Description P5 is 8-bit I/O port. P5 control registers consist of P5 data register (P5), P5 direction register (P5IO), debounce enable register (P5DB), P5 pull-up resistor selection register (P5PU) and P5 open-drain selection register (P5OD). Refer to the port function selection registers for the P5 function selection. ### 9.8.2 Register description for P5 ### P5 (P5 Data Register): B0H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-----|-----|-----|-----|-----|-----| | - | - | P55 | P54 | P53 | P52 | P51 | P50 | | - | - | RW | RW | RW | RW | RW | RW | Initial value: 00H P5[7:0] I/O Data ### P5IO (P5 Direction Register): B9H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | - | - | P551O | P54IO | P531O | P521O | P51IO | P50IO | | - | - | RW | RW | RW | RW | RW | RW | Initial value: 00H P5IO[7:0] P5 Data I/O Direction. 0 Input 1 Output #### P5PU (P5 Pull-up Resistor Selection Register): 8F05H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | ı | - | P55PU | P54PU | P53PU | P52PU | P51PU | P50PU | | - | - | RW | RW | RW | RW | RW | RW | Initial value: 00H P5PU[7:0] Configure Pull-up Resistor of P5 Port 0 Disable 1 Enable ### P5OD (P5 Open-drain Selection Register): 8F11H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | - | - | P55OD | P54OD | P53OD | P520D | P510D | P500D | | - | - | RW | RW | RW | RW | RW | RW | Initial value: 00H P5OD[7:0] Configure Open-drain of P5 Port 0 Push-pull output 1 Open-drain output ### P5DB (P5 De-bounce Enable Register): 8F1DH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | - | - | P55DB | P54DB | P53DB | P52DB | P51DB | P50DB | | - | - | RW | RW | RW | RW | RW | RW | Initial value: 00H P5DB[7:0] Configure debounce of P5 port 0 Disable 1 Enable ### NOTE) If the same level is not detected on enabled pin three or four times in a row at the sampling clock, the signal is eliminated as noise. A pulse level should be input for the duration of 3 clock or more to be actually detected as a valid edge. The port de-bounce is **not** automatically disabled at stop mode. Refer to the configure option for the P55/RESETB. ### PSR1 (Port Selection Register 1): 8F40H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | PSR17 | PSR16 | PSR15 | PSR14 | PSR13 | PSR12 | PSR11 | PSR10 | | RW Initial value: 00H PSR1[7:0] P20~P27port selection register 0 Disable analog channel AN[7:0]. 1 Enable analog channel AN[7:0]. #### PSR2 (Port Selection Register 2): 8F41H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|--------|-------|-------| | PSR27 | PSR26 | PSR25 | PSR24 | PSR23 | AMUXEN | PSR21 | PSR20 | | RW Initial value: 00H PSR2[7] Not used PSR2[6:5] Select port debounce clock 00 Internal 256KHz RCOSC01 F<sub>SCLK</sub> (system clock) 10 F<sub>SCLK</sub> / 211 F<sub>SCLK</sub> / 4 PSR2[4] Select ports to be used as USART1 P31, P32 port is used as a USART1P11, P12 port is used as a USART1 PSR2[3] Not used AMUXEN ADC input mux enable or disable 0 disable1 enable PSR2[1] P34 port selection register 0 Disable analog channel AN[9].1 Enable analog channel AN[9]. PSR2[0] P17 port selection register 0 Disable analog channel AN[8].1 Enable analog channel AN[8]. ### **IODBCNT (Port Debounce Length Selection Register): 8F08H** | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|----|---------|----| | - | - | - | - | - | | IODBCNT | | | - | - | - | - | - | RW | RW | RW | Initial value: 00H IODBCNT[2:0] Port debounce length selection register Deboounce length = IODBCNT x $1/f_{dbclk}$ f<sub>dbclk</sub> is the clock selected by PSR2[6:5] # 10 Interrupt Controller #### 10.1 Overview The A97C450 supports up to 30 interrupt sources. The interrupts have separate enable register bits associated with them, allowing software control. They can also have four levels of priority assigned to them. The non-maskable interrupt source is always enabled with a higher priority than any other interrupt source, and is not controllable by software. The interrupt controller has following features: - Receive the request from 30 interrupt source - Individual priority - 4 priority levels - Multi Interrupt possibility - If the requests of different priority levels are received simultaneously, the request of higher priority level is served first. - Each interrupt source can be controlled by EA bit and each IEx bit - Interrupt latency: 3~9 machine cycles in single interrupt system The non-maskable interrupt is always enabled. The maskable interrupts are enabled through four pair of interrupt enable registers (IE, IE1, IE2, IE3, IE4). Each bit of IE, IE1, IE2, IE3, IE4 register individually enables/disables the corresponding interrupt source. Overall control is provided by bit 7 of IE (EA). When EA is set to '0', all interrupts are disabled: when EA is set to '1', interrupts are individually enabled or disabled through the other bits of the interrupt enable registers. The EA bit is always cleared to '0' jumping to an interrupt service vector and set to '1' executing the [RETI] instruction. The A97C450 supports a four-level priority scheme. Each maskable interrupt is individually assigned to one of four priority levels according to IP0H/L, IP1H/L, IP2H/L, IP3H/L, and IP4H/L. Default external interrupt mode is level-trigger mode basically, but if needed, it is possible to change to edge-trigger mode. Priority of a group is set by two bits of interrupt priority registers (one bit from IP, another one from IP1). Interrupt service routine serves higher priority interrupt first. If two requests of different priority levels are received simultaneously, the request of higher priority level is served prior to the lower one. | _ | | | IP0 | | | | | IP1 | | | | | IP2 | | | | IP3 | | | | | IP4 | | | | | | | | | | |--------|---|-------|------|-------|-------|-------|----------|----------|-------|-------|-------|---------|---------|---------|--------|----------|---------|---------|----------|---------|----------|--------|----------|--------|-------|----------|--------|--------|----------|----------|-----------| | IPxH.x | 1 | | | | | | INT5 | | | | | | INIT11 | | | | | | INT17 | | | | | | INT23 | | | | | | INT29 | | IPxL.x | 1 | | | | | | | | | | | | IINIIII | | | | | | IIN I 17 | | <u> </u> | | <u> </u> | | | L | | | ш | <u> </u> | | | IPxH.x | 1 | | | INT2 | | | | Ī | | INT8 | | | | | | INT14 | | | | | | INT20 | 1 1 | | | 1 | | INT26 | | i | | | IPxL.x | 0 | | | IINIZ | | l | <b>.</b> | <u> </u> | | IIVIO | | | | | | IIN I 14 | | | | | | 111120 | l1 | | L | <u> </u> | | 111120 | <u> </u> | l | <u> </u> | | IPxH.x | 0 | | INT1 | | | | | | INT7 | | | | | | INT13 | | | | | | INT19 | | 1 | | | 1 | INT25 | | | i | | | IPxL.x | 1 | | | | | | | | 11417 | | | | <u></u> | | IIVIII | | | | L | | 1141113 | | | | ļ | | 114123 | | ш | | لـــــــا | | IPxH.x | 0 | INT0 | | | INT3 | INITA | | INT6 | | | INT9 | INIT10 | | INT12 | | | INIT15 | INT16 | | INT18 | | | INT21 | INITOO | | INT24 | | | INT27 | INIT28 | 1 1 | | IPxL.x | 0 | IIVIO | | | IIVIO | 11114 | | 11410 | | | 11413 | 1141110 | | 1141112 | L | | 1141113 | 1141 10 | L | 1141110 | | L | | 111122 | | | | | | 111120 | 1; | ### 10.2 External Interrupt The external interrupt on EINT0 ~ EINT7 pins receive various interrupt request depending on the edge selection register EIEDGE (External Interrupt Edge register) and EIPOLA (External Interrupt Priority register) as shown in Figure 10-1. Also each external interrupt source has control setting bits. The EIFLAG (External interrupt flag register) register provides the status of external interrupts. Figure 10.1 External Interrupt Description ### 10.3 Block Diagram Figure 10.2 Block Diagram of Interrupt ### NOTE) - The release signal may be generated by all interrupt sources which are enabled without reference to a priority level. - 2. An interrupt request is delayed during data are written to IE, IE1, IE2, IE3, IE4, IP0L/H, IP1L/H, IP2L/H, IP3L/H, IP4L/H and PCON register. # 10.4 Interrupt Vector Table The interrupt controller supports 30 interrupt sources as shown in the Table 10-2. When interrupt is served, long call instruction (LCALL) is executed and program counter jumps to the vector address. All interrupt requests have their own priority order. | Interrupt Source | Symbol | Interrupt<br>Enable Bit | Priority | Mask | Vector Address | |--------------------------|--------|-------------------------|----------|--------------|----------------| | Hardware RESET | RESETB | 0 | 0 | Non-Maskable | 0000H | | IR Interrupt | INT0 | IE.0 | 1 | Maskable | 0003H | | External Interrupt 0 | INT1 | IE.1 | 2 | Maskable | 000BH | | I2C1 Interrupt | INT2 | IE.2 | 3 | Maskable | 0013H | | SPI1 Interrupt | INT3 | IE.3 | 4 | Maskable | 001BH | | External Interrupt 1 | INT4 | IE.4 | 5 | Maskable | 0023H | | CEC Interrupt | INT5 | IE.5 | 6 | Maskable | 002BH | | UART0 Rx Interrupt | INT6 | IE1.0 | 7 | Maskable | 0033H | | UART0 Tx Interrupt | INT7 | IE1.1 | 8 | Maskable | 003BH | | SPI0 Interrupt | INT8 | IE1.2 | 9 | Maskable | 0043H | | I2C0 Tx Interrupt | INT9 | IE1.3 | 10 | Maskable | 004BH | | UART1 Rx Interrupt | INT10 | IE1.4 | 11 | Maskable | 0053H | | UART1 Tx Interrupt | INT11 | IE1.5 | 12 | Maskable | 005BH | | External Interrupt 5 – 7 | INT12 | IE2.0 | 13 | Maskable | 0063H | | External Interrupt 2 – 3 | INT13 | IE2.1 | 14 | Maskable | 006BH | | T2 Match Interrupt | INT14 | IE2.2 | 15 | Maskable | 0073H | | T3 Match Interrupt | INT15 | IE2.3 | 16 | Maskable | 007BH | | T4/5/6 Match Interrupt | INT16 | IE2.4 | 17 | Maskable | 0083H | | Reserved | INT17 | IE2.5 | 18 | Maskable | 008BH | | T0/1 Match Interrupt | INT18 | IE3.0 | 19 | Maskable | 0093H | | T0/1 Overflow Interrupt | INT19 | IE3.1 | 20 | Maskable | 009BH | | ADC Interrupt | INT20 | IE3.2 | 21 | Maskable | 00A3H | | EEPROM Interrupt | INT21 | IE3.3 | 22 | Maskable | 00ABH | | WT Interrupt | INT22 | IE3.4 | 23 | Maskable | 00B3H | | WDT Interrupt | INT23 | IE3.5 | 24 | Maskable | 00BBH | | BIT Interrupt | INT24 | IE4.0 | 25 | Maskable | 00C3H | | SP Overflow Interrupt | INT25 | IE4.1 | 26 | Maskable | 00CBH | | Comparator Interrupt | INT26 | IE4.2 | 27 | Maskable | 00D3H | | LVI Interrupt | INT27 | IE4.3 | 28 | Maskable | 00DBH | | RTC Interrupt | INT28 | IE4.4 | 29 | Maskable | 00E3H | | CRC Interrupt | INT29 | IE4.5 | 30 | Maskable | 00EBH | Table 10.2 Interrupt Vector Address Table For maskable interrupt execution, EA bit must set '1' and specific interrupt must be enabled by writing '1' to associated bit in the IEx. If an interrupt request is received, the specific interrupt request flag is set to '1'. And it remains '1' until CPU accepts interrupt. If the interrupt is served, the interrupt request flag will be cleared automatically. ## 10.5 Interrupt Sequence An interrupt request is held until the interrupt is accepted or the interrupt latch is cleared to '0' by a reset or an instruction. Interrupt acceptance always generates at last cycle of the instruction. So instead of fetching the current instruction, CPU executes internally LCALL instruction and saves the PC at stack. For the interrupt service routine, the interrupt controller gives the address of LJMP instruction to CPU. Since the end of the execution of current instruction, it needs 3~9 machine cycles to go to the interrupt service routine. The interrupt service task is terminated by the interrupt return instruction [RETI]. Once an interrupt request is generated, the following process is performed. Figure 10.3 Interrupt Sequence Flow # 10.6 Effective Timing after Controlling Interrupt Bit Case a) Control Interrupt Enable Register (IE, IE1, IE2, IE3, IE4) Figure 10.4 Effective Timing of Interrupt Enable Register ### Case b) Interrupt flag Register Figure 10.5 Effective Timing of Interrupt Flag Register ### 10.7 Multi Interrupt If two requests of different priority levels are received simultaneously, the request of higher priority level is served first. If more than one interrupt request are received, the interrupt polling sequence determines which request is served first by hardware. However, for special features, multi-interrupt processing can be executed by software. Figure 10.6 Effective Timing of Multi-Interrupt Figure 10.6 shows an example of multi-interrupt processing. While INT1 is served, INT0 which has higher priority than INT1 is occurred. Then INT0 is served immediately and then the remain part of INT1 service routine is executed. If the priority level of INT0 is same or lower than INT1, INT0 will be served after the INT1 service has completed. An interrupt service routine may be only interrupted by an interrupt of higher priority and, if two interrupts of different priority occur at the same time, the higher level interrupt will be served first. An interrupt cannot be interrupted by another interrupt of the same or a lower priority level. If two interrupts of the same priority level occur simultaneously, the service order for those interrupts is determined by the scan order. ### 10.8 Interrupt Enable Accept Timing Figure 10.7 Interrupt Response Timing Diagram # 10.9 Interrupt Service Routine Address Figure 10.8 Correspondence between Vector Table Address and the Entry Address of ISR # 10.10 Saving/Restore General-Purpose Registers Figure 10.9 Saving/Restore Process Diagram and Sample Source # 10.11 Interrupt Timing Figure 10.10 Timing Chart of Interrupt Acceptance and Interrupt Return Instruction Interrupt sources are sampled at the last cycle of a command. If an interrupt source is detected the lower 8-bit of interrupt vector (INT\_VEC) is decided. M8051W core makes interrupt acknowledge at the first cycle of a command and executes long call to jump to interrupt service routine. ### NOTE) 1. command cycle CLPx: L=Last cycle, 1=1st cycle or 1st phase, 2=2nd cycle or 2nd phase # 10.12 Interrupt Register Overview #### 10.12.1 Interrupt Enable Register (IE, IE1, IE2, IE3, IE4) Interrupt enable register consists of global interrupt control bit (EA) and peripheral interrupt control bits. Total 24 peripherals are able to control interrupt. ### 10.12.2 10.12.2 Interrupt Priority Register (IP0H/L, IP1H/L, IP2H/L, IP3H/L, IP4H/L) The 30 interrupts are divided into 6 groups which have each 4 interrupt sources. An individual interrupt can be assigned 4 levels interrupt priority using interrupt priority register. Level 3 is the highest priority, while level 0 is the lowest priority. After a reset IP0H/L, IP1H/L, IP2H/L, and IP3H/L, are cleared to '00H'. If interrupts have the same priority level, lower number interrupt is served first. ### 10.12.3 External Interrupt Flag Register (EIFLAG) The external interrupt flag register is set to '1' when the external interrupt generating condition is satisfied. The flag is cleared when the interrupt routine is executed. Alternatively, the flag can be cleared by writing a '0' to it. #### 10.12.4 External Interrupt Edge Register (EIEDGE) The External interrupt edge register determines which type of edge or level sensitive interrupt. Initially, default value is level. For level, write '0' to related bit. For edge, write '1' to related bit. #### 10.12.5 External Interrupt Polarity Register (EIPOLA) According to EIEDGE register, the external interrupt polarity (EIPOLA) register has a different meaning. If EIEDGE is level type, EIPOLA is able to have Low/High level value. If EIEGDE is edge type, EIPOLA is able to have rising/falling edge value. ### 10.12.6 External Interrupt Both Edge Enable Register (EIBOTH) When the external interrupt both edge enable register is written to '1', the corresponding external pin interrupt is enabled by both edges. Initially, default value is disabled. #### 10.12.7 External Interrupt Enable Register (EIENAB) When the external interrupt enable register is written to '1', the corresponding external pin interrupt is enabled. The EIEDGE and EIPOLA register defines whether the external interrupt is activated on rising or falling edge or level sensed. ### 10.12.8 Register Map | Name | Address | Dir | Default | Description | |--------|---------|-----|---------|---------------------------------------| | IE | A8H | R/W | 00H | Interrupt Enable Register | | IE1 | A9H | R/W | 00H | Interrupt Enable Register 1 | | IE2 | AAH | R/W | 00H | Interrupt Enable Register 2 | | IE3 | ABH | R/W | 00H | Interrupt Enable Register 3 | | IE4 | ACH | R/W | 00H | Interrupt Enable Register 4 | | IP0L | 8FA0H | R/W | 00H | Interrupt Priority 0 Low Register | | IP0H | 8FA1H | R/W | 00H | Interrupt Priority 0 High Register | | IP1L | 8FA2H | R/W | 00H | Interrupt Priority 1 Low Register | | IP1H | 8FA3H | R/W | 00H | Interrupt Priority 1 High Register | | IP2L | 8FA4H | R/W | 00H | Interrupt Priority 2 Low Register | | IP2H | 8FA5H | R/W | 00H | Interrupt Priority 2 High Register | | IP3L | 8FA6H | R/W | 00H | Interrupt Priority 3 Low Register | | IP3H | 8FA7H | R/W | 00H | Interrupt Priority 3 High Register | | IP4L | 8FA8H | R/W | 00H | Interrupt Priority 4 Low Register | | IP4H | 8FA9H | R/W | 00H | Interrupt Priority 4 High Register | | EIENAB | АЗН | R/W | 00H | External Interrupt Enable Register | | EIFLAG | A4H | R/W | 00H | External Interrupt Flag Register | | EIEDGE | A5H | R/W | 00H | External Interrupt Edge Register | | EIPOLA | A6H | R/W | 00H | External Interrupt Polarity Register | | EIBOTH | A7H | R/W | 00H | External Interrupt Both Edge Register | Table 10.3 Interrupt Register Map ### 10.12.9 Interrupt Register Description The Interrupt Register is used for controlling interrupt functions. Also it has External interrupt control registers. The interrupt register consists of Interrupt Enable Register (IE), Interrupt Enable Register 1 (IE1), Interrupt Enable Register 2 (IE2), Interrupt Enable Register 3 (IE3) and Interrupt Enable Register 4 (IE4). For external interrupt, it consists of External Interrupt Flag Register (EIFLAG), External Interrupt Edge Register (EIEDGE), External Interrupt Polarity Register (EIPOLA) and External Interrupt Enable Register (EIENAB). # 10.12.10 Register Description for Interrupt # IE (Interrupt Enable Register) : A8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|---|-------|-------|-------|-------|-------|-------| | EA | - | INT5E | INT4E | INT3E | INT2E | INT1E | INTOE | | RW | - | RW | RW | RW | RW | RW | RW | Initial value: 00H Enable or disable all interrupt bits EΑ All Interrupt disable All Interrupt enable INT5E Enable or disable CEC Interrupt Disable Enable Enable or disable External Interrupt 1 INT4E Disable Enable Enable or disable SPI1 Interrupt INT3E 0 Disable 1 Enable Enable or disable I2C1 Interrupt INT2E Disable Enable Enable or disable External Interrupt 0 INT1E Disable Enable Enable or disable IR Interrupt INT0E Disable 0 Enable 1 # IE1 (Interrupt Enable Register 1) : A9H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------|----|--------|--------------|------------------|-------------|-------|-------| | - | - | INT11E | INT10E | INT9E | INT8E | INT7E | INT6E | | - | - | RW | RW | RW | RW | RW | RW | | Initial value: 0 | 0H | | | | | | | | | | INT11E | Enable or di | sable UART1 Tx | Interrupt | | | | | | | 0 Dis | able | | | | | | | | 1 Ena | able | | | | | | | INT10E | Enable or di | sable UART1 R | k Interrupt | | | | | | | 0 Dis | able | | | | | | | | 1 Ena | able | | | | | | | INT9E | Enable or di | sable I2C0 Inter | rupt | | | | | | | 0 Dis | able | | | | | | | | 1 Ena | able | | | | | | | INT8E | Enable or di | sable SPI0 Inter | rupt | | | | | | | 0 Dis | able | | | | | | | | 1 Ena | able | | | | | | | INT7E | Enable or di | sable UART0 Tx | Interrupt | | | | | | | 0 Dis | able | | | | Enable Disable Enable Enable or disable UART0 Rx Interrupt 1 0 1 INT6E # IE2 (Interrupt Enable Register 2) : AAH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------|-----|--------|-----------------------|--------------------------------------------|-------------------|--------|--------| | - | - | - | INT16E | INT15E | INT14E | INT13E | INT12E | | - | - | - | RW | RW | RW | RW | RW | | Initial value : 0 | 00H | | | | | | | | | | INT16E | 0 Dis | isable Timer 4/5,<br>able<br>able | /6 match interrup | ot | | | | | | | | | | | | | | INT14E | 0 Dis | sable Timer 2 m<br>able<br>able | atch Interrupt | | | | | | INT13E | (EINT2 ~ EII<br>0 Dis | isable External ii<br>NT4)<br>able<br>able | nterrupt 2 ~ 4 | | | | | | INT12E | (EINT5 ~ EII<br>0 Dis | isable External ii<br>NT7)<br>able<br>able | nterrupt 5 ~ 7 | | | # IE3 (Interrupt Enable Register 3) : ABH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |------------------|----|--------|---------------------------------|--------|--------|--------|--------|--| | - | - | INT23E | INT22E | INT21E | INT20E | INT19E | INT18E | | | R | R | RW | RW | RW | RW | RW | RW | | | Initial value: 0 | 0H | | | | | | | | | | | INT23E | Enable or disable WDT Interrupt | | | | | | INT23E Enable or disable WD1 Interrupt 0 Disable 1 Enable INT22E Enable or disable WT Interrupt 0 Disable1 Enable INT21E Enable or disable EEPROM Interrupt 0 Disable1 Enable INT20E Enable or disable ADC Interrupt 0 Disable1 Enable INT19E Enable or Disable Timer 0/1 overflow interrupt 0 Disable1 Enable INT18E Enable or Disable Timer 0/1 match interrupt 0 Disable1 Enable # IE4 (Interrupt Enable Register 4): ACH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------------|----|--------|---------------------------------|-------------------|--------------|--------|--------|--| | - | - | INT29E | INT28E | INT27E | INT26E | INT25E | INT24E | | | R | R | RW | RW | RW | RW | RW | RW | | | Initial value : 0 | 0H | | | | | | | | | | | INT29E | Enable or di | sable CRC Inter | rupt | | | | | | | | 0 Dis | able | | | | | | | | | 1 Ena | able | | | | | | | | INT28E | Enable or di | sable RTC Interr | upt | | | | | | | | 0 Dis | able | | | | | | | | | 1 Ena | able | | | | | | | | INT27E | Enable or disable LVI Interrupt | | | | | | | | | | 0 Dis | able | | | | | | | | | 1 Ena | able | | | | | | | | INT26E | Enable or di | sable Comparate | or Interrupt | | | | | | | | 0 Dis | able | | | | | | | | | 1 Ena | able | | | | | | | | INT25E | Enable or di | sable SP overflo | w Interrupt | | | | | | | | 0 Dis | able | | | | | | | | | 1 Ena | able | | | | | | | | INT24E | Enable or di | sable BIT Interru | ıpt | | | | | | | | 0 Dis | able | | | | | | | | | 1 Ena | able | | | | | # IP0L (Interrupt Priority 0 Low Register): 8FA0H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | - | _ | IPOL5 | IPOL4 | IP0L3 | IPOL2 | IPOL1 | IPOLO | | _ | _ | RW | RW | RW | RW | RW | RW | Initial value: 00H # IP0H (Interrupt Priority 0 High Register): 8FA1H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | _ | _ | IP0H5 | IP0H4 | IP0H3 | IP0H2 | IP0H1 | IP0H0 | | _ | _ | RW | RW | RW | RW | RW | RW | Initial value: 00H IP1L (Interrupt Priority 1 Low Register): 8FA2H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | _ | _ | IP1L5 | IP1L4 | IP1L3 | IP1L2 | IP1L1 | IP1L0 | | _ | _ | RW | RW | RW | RW | RW | RW | Initial value: 00H # IP1H (Interrupt Priority 1 High Register): 8FA3H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | - | _ | IP1H5 | IP1H4 | IP1H3 | IP1H2 | IP1H1 | IP1H0 | | _ | _ | RW | RW | RW | RW | RW | RW | Initial value: 00H ### IP2L (Interrupt Priority 2 Low Register): 8FA4H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|-------|-------|-------|-------|-------| | - | _ | _ | IP2L4 | IP2L3 | IP2L2 | IP2L1 | IP2L0 | | - | - | - | RW | RW | RW | RW | RW | Initial value: 00H # IP2H (Interrupt Priority 2 High Register): 8FA5H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|-------|-------|-------|-------|-------| | _ | _ | _ | IP2H4 | IP2H3 | IP2H2 | IP2H1 | IP2H0 | | _ | _ | _ | RW | RW | RW | RW | RW | Initial value: 00H IP2L[5:0], IP2H[5:0]] Select IE2 Interrupt Priority IP2Hx IP2Lx Description 0 0 level 0 (lowest) 0 1 level 1 1 0 level 2 1 1 level 3 (highest) ### IP3L (Interrupt Priority 3 Low Register): 8FA6H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | - | ı | IP3L5 | IP3L4 | IP3L3 | IP3L2 | IP3L1 | IP3L0 | | _ | _ | RW | RW | RW | RW | RW | RW | Initial value: 00H # IP3H (Interrupt Priority 3 High Register): 8FA7H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | _ | _ | IP3H5 | IP3H4 | IP3H3 | IP3H2 | IP3H1 | IP3H0 | | _ | _ | RW | RW | RW | RW | RW | RW | Initial value: 00H IP3L[5:0], IP3H[5:0]] Select IE3 Interrupt Priority IP3Hx IP3Lx Description 0 0 level 0 (lowest) 0 1 level 1 1 0 level 2 level 3 (highest) IP4L (Interrupt Priority 4 Low Register) : 8FA8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | _ | _ | IP4L5 | IP4L4 | IP4L3 | IP4L2 | IP4L1 | IP4L0 | | _ | _ | RW | RW | RW | RW | RW | RW | Initial value: 00H ### IP4H (Interrupt Priority 4 High Register): 8FA9H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | _ | _ | IP4H5 | IP4H4 | IP4H3 | IP4H2 | IP4H1 | IP4H0 | | _ | _ | RW | RW | RW | RW | RW | RW | Initial value: 00H IP4L[5:0], IP4H[5:0]] Select IE4 Interrupt Priority IP4Hx IP4Lx Description 0 0 level 0 (lowest) 0 1 level 1 1 0 level 2 1 1 level 3 (highest) ### EIENAB (External Interrupt Enable Register) : A3H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | ENAB7 | ENAB6 | ENAB5 | ENAB4 | ENAB3 | ENAB2 | ENAB1 | ENAB0 | | RW Initial value: 00H ENAB[7:0] Control External Interrupt for EINTx 0 Disable EINTx (default) 1 Enable EINTx EXT\_INT0 -> ENAB0,, EXT\_INT7->ENAB7 ### EIFLAG (External Interrupt Flag Register): A4H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | FLAG7 | FLAG6 | FLAG5 | FLAG4 | FLAG3 | FLAG2 | FLAG1 | FLAG0 | | RW Initial value: 00H FLAG[7:0] If External Interrupt is occurred, the flag becomes '1'. The flag can be cleared by writing a '0' to bit 0 External Interrupt not occurred 1 External Interrupt occurred EINT0 -> FLAG0,, EINT7->FLAG7 ### EIEDGE (External Interrupt Edge Register): A5H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | EDGE7 | EDGE6 | EDGE5 | EDGE4 | EDGE3 | EDGE2 | EDGE1 | EDGE0 | | RW Initial value: 00H EDGE[7:0] Determines which type of edge or level sensitive interrupt may occur. 0 Level (default) 1 Edge EINT0 -> EDGE0,, EINT7->EDGE7 ### EIPOLA (External Interrupt Polarity Register) : A6H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | POLA7 | POLA6 | POLA5 | POLA4 | POLA3 | POLA2 | POLA1 | POLA0 | | RW Initial value: 00H POLA[7:0] According to EIEDGE, External interrupt polarity register has a different means. If EIEDGE is level type, external interrupt polarity is able to have Low/High level value. If EIEGDE is edge type, external interrupt polarity is able to have rising/ falling edge value. Level case: - 0 When High level, Interrupt occurred (default) - 1 When Low level, Interrupt occurred Edge case: - 0 When Rising edge, Interrupt occurred (default) - 1 When Falling edge, Interrupt occurred EINT0 -> POLA0,, EINT7->POLA7 ### EIBOTH (External Interrupt Both Edge Enable Register): A7H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|--------|-------|-------|-------|-------|-------|--------| | BOTH7 | BOTH 6 | BOTH5 | BOTH4 | BOTH3 | BOTH2 | BOTH1 | BOTH 0 | | RW Initial value: 00H **BOTH[7:0]** Determines which type of interrupt may occur, EIBOTH or EIEDGE+EIPOLA. if EIBOTH is enable, EIEDGE and EIPOLA register value don't matter - 0 Disable (default) - 1 Enable EINT0 -> BOTH0,, EINT7->BOTH7 # 11 Peripheral Hardware # 11.1 Stack Pointer Management Unit # 11.1.1 Overview The SPMU register enables stack pointer interrupt. When stack pointer is larger than or less than the compare register, stack pointer flag is generated. If stack pointer interrupt is enabled and the global interrupt is enabled, program go to the interrupt service routine. Figure 11.1 SPMU block diagram # 11.1.2 Register Map | Name | Address | Direction | Default | Description | |------------|---------|-----------|---------|----------------------------------------------| | SPMUCR | 8FD0H | R/W | 00H | SPMU Control register | | SPMUSR | 8FD8H | R/W | 00H | SPMU Flag register | | PADDR_OVFH | 8FD1H | R/W | 00H | Program Address Overflow Data Register High | | PADDR_OVFH | 8FD2H | R/W | 00H | Program Address Overflow Data Register High | | PADDR_OVFH | 8FD3H | R/W | 00H | Program Address Overflow Data Register High | | STPTR_OVFH | 8FD4H | R/W | 00H | Stack Pointer Overflow Data Register High | | STPTR_OVFL | 8FD5H | R/W | FEH | Stack Pointer Overflow Data Register Low: | | STPTR_UDFH | 8FD6H | R/W | 00H | Stack Pointer Underflow Data Register High | | STPTR_UDFL | 8FD7H | R/W | 07H | Stack Pointer Underflow Data Register Low | | PADDRH | 8FD9H | R | 00H | Program Address Invalid Data Register High | | PADDRM | 8FDAH | R | 00H | Program Address Invalid Data Register Middle | | PADDRL | 8FDBH | R | 00H | Program Address Invalid Data Register Low | | STPTRH | 8FDCH | R | 00H | Stack Pointer Register High | | STPTRL | 8FDDH | R | 07H | Stack Pointer Register Low | | XSTPTR | 8FDEH | R | 7FH | Memory Extension Stack Pointer | Table 11.1 SPMU Register Map # 11.1.3 Register Description for SPMU # SPMUCR (SPMU Control register) : 8FD0H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---------------|---------------|--------------|--------------|--------------| | ı | - | - | XSTPTR_UDF_EN | XSTPTR_OVF_EN | STPTR_UDF_EN | STPTR_OVF_EN | PADDR_MNT_EN | | - | - | - | RW | RW | RW | RW | RW | Initial value : 00H | XSTPTR_UDF_E<br>N | | nory extension stack pointer underflow occurs, this enables the of ${\sf XSTPTR\_UDF\_FLAG}$ | |-------------------|----------------------|--------------------------------------------------------------------------------------------------------------------| | | 0 | Disable | | | 1 | Enable | | XSTPTR_OVF_E<br>N | | nory extension stack pointer overflow occurs, this enables the of XSTPTR_OVF_FLAG | | | 0 | Disable | | | 1 | Enable | | STPTR_UDF_E<br>N | When stac | k pointer underflow occurs, this enables the generation of DF_FLAG | | | 0 | Disable | | | 1 | Enable | | STPTR_OVF_E<br>N | When stac<br>STPTR_O | k pointer overflow occurs, this enables the generation of VF_FLAG | | | 0 | Disable | | | 1 | Enable | | PADDR_MNT_E<br>N | | gram address is larger than the program address overflow data ADDR_OVF), this enables the generation of PADDR_FLAG | | | 0 | Disable | | | 1 | Enable | $\mathsf{R}\!\mathsf{W}$ $\mathsf{R}\!\mathsf{W}$ **SPWRH** ${\sf RW}$ $\mathsf{R}\!\mathsf{W}$ Stack Pointer overflow data register low $\mathsf{R}\!\mathsf{W}$ $\mathsf{R}\!\mathsf{W}$ RW RW Initial value : FEH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------------|-------------------------------------------------|------------------------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------|-----------|---------|---------------------------| | | | | PADDR | _OVFH | | | | | RW | | | | | | | | Initial value : 00H | | | PADDR_O | <b>VFH</b> Program | n address overflo | w data register l | high | | | | | (Program Addre | | | | | , | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | PADDR | _ | | | | | RW | | | | | | | | Initial value : 00H | | | PADDR_O | <b>VFM</b> Program | n address overflo | w data register | middle | | | | | | | | | | | | | R_OVFL ( | Program Addres | se Overflow Da | D! | \ - 0FD011 | | | | | | | SO OVELLION DO | ita Register Low | '): 8FD3H | | | | | 7 | 6 | 5 | ita Register Low<br>4 | 3 | 2 | 1 | 0 | | 7 | _ | | _ | 3 | 2 | 1 | 0 | | <b>7</b> RW | _ | | 4 | 3 | 2<br>RW | 1<br>RW | 0<br>RW | | - | 6 | 5 | 4<br>PADDR | 3<br>COVFL | | | RW | | | 6 | 5<br>RW | A PADDR | 3<br>COVFL<br>RW | RW | | RW | | | 6<br>RW | 5<br>RW | 4<br>PADDR | 3<br>COVFL<br>RW | RW | | RW | | RW | 6 RW PADDR_O | 5<br>RW<br>VFL Program | PADDR<br>RW<br>n address overflo | 3<br>COVFL<br>RW<br>w data register | RW | | RW | | RW | 6<br>RW | 5<br>RW<br>VFL Program | PADDR<br>RW<br>n address overflo | 3<br>COVFL<br>RW<br>w data register | RW | | RW | | RW<br>R_OVFH (S | 6 RW PADDR_O Stack Pointer Ov | 5 RW VFL Program verflow Data Re | PADDR<br>RW<br>address overflo<br>egister High): 8 | 3<br>COVFL<br>RW<br>w data register <br>FD4H<br>3 | RW | RW | RW<br>Initial value : 00H | | RW<br>R_OVFH (S | 6 RW PADDR_O Stack Pointer Ov 6 | 5 RW VFL Program verflow Data Ref | PADDR RW address overflo egister High): 8 4 SIPIR | 3 COVFL RW w data register FD4H 3 _OVFH | RW low | RW<br>1 | RW<br>Initial value : 00H | | RW<br>R_OVFH (S | 6 RW PADDR_O Stack Pointer Ov | 5 RW VFL Program verflow Data Re | PADDR<br>RW<br>address overflo<br>egister High): 8 | 3<br>COVFL<br>RW<br>w data register <br>FD4H<br>3 | RW | RW | RW Initial value : 00H | | RW<br>R_OVFH (\$ | RW PADDR_O Stack Pointer Ov 6 | FW VFL Program verflow Data Ro 5 | PADDR RW address overflo egister High): 8 4 STPTR RW | 3 COVFL RW w data register FD4H 3 COVFH RW | RW 2 RW | RW<br>1 | RW Initial value : 00H | | RW<br>R_OVFH (\$ | 6 RW PADDR_O Stack Pointer Ov 6 | FW VFL Program verflow Data Ro 5 | PADDR RW address overflo egister High): 8 4 SIPIR | 3 COVFL RW w data register FD4H 3 COVFH RW | RW 2 RW | RW<br>1 | RW Initial value : 00H | | RW<br>R_OVFH (\$<br>7 | RW PADDR_O Stack Pointer Ov 6 | FW VFL Program verflow Data Ro 5 RW VFH Stack po | PADDR RW address overflo egister High): 8 4 STPTR RW cinter overflow da | RW w data register l FD4H 3 OVFH RW ata register high | RW 2 RW | RW<br>1 | RW Initial value : 00H | | RW<br>R_OVFH (\$<br>7 | FAM PADDR_O Stack Pointer Ov 6 RW STPTR_OV | FW VFL Program verflow Data Ro 5 RW VFH Stack po | PADDR RW address overflo egister High): 8 4 STPTR RW cinter overflow da | RW w data register l FD4H 3 OVFH RW ata register high | RW 2 RW | RW<br>1 | RW Initial value : 00H | ### STPTR\_UDFH (Stack Pointer Underflow Data Register High): 8FD6H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|-------|-------|----|----|----| | | | | STPTF | RUDFH | | | | | RW Initial value: 00H **STPTR\_UDFH** Stack pointer underflow data register high # STPTR\_UDFL (Stack Pointer Underflow Data Register Low) : 8FD7H | 1 | 0 | ວ | 4 | 3 | 2 | 1 | U | |----|----|-------|----------|-----|-----------------------------------------------------|-------|-------| | | | | SPV | VRH | | | | | RW | | RW | RW RW | RW RW RW | | SPWRH RW RW RW RW | SPWRH | SPWRH | Initial value: 07H STPTR\_UDFL Stack pointer underflow data register low ### SPMUSR (SPMU Flag register): 8FD8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|-----------------|-----------------|----------------|----------------|------------| | ı | - | - | XSTPTR_UDF_FLAG | XSTPTR_OVF_FLAG | STPTR_UDF_FLAG | STPTR_OVF_FLAG | PADDR_FLAG | | - | - | - | RW | RW | RW | RW | RW | Initial value: 00H | XSTPTR_UDF<br>_FLAG | If memory extension stack pointer underflow is occurred, the flag becomes '1'. The flag can be cleared by writing a '0' to bit | | | | | | |---------------------|--------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | | Memory extension stack pointer underflow is not occurred | | | | | | | | 1 Memory extension stack pointer underflow occurred | | | | | | | XSTPTR_OVF<br>_FLAG | If memory extension stack pointer overflow is occurred, the flag becomes '1'. The flag can be cleared by writing a '0' to bit | | | | | | | | 0 Memory extension stack pointer overflow is not occurred | | | | | | | | 1 Memory extension stack pointer overflow occurred | | | | | | | STPTR_UDF_<br>FLAG | If stack pointer underflow is occurred, the flag becomes '1'. The flag can be cleared by writing a '0' to bit | | | | | | | | O Stack pointer underflow is not occurred | | | | | | | | 1 Stack pointer underflow occurred | | | | | | | STPTR_OVF_<br>FLAG | If stack pointer overflow is occurred, the flag becomes '1'. The flag can be cleared by writing a '0' to bit | | | | | | | | O Stack pointer overflow is not occurred | | | | | | | | 1 Stack pointer overflow occurred | | | | | | | PADDR_FLAG | If program address overflow is occurred, the flag becomes '1'. The flag can be cleared by writing a '0' to bit | | | | | | | | O Program address overflow is not occurred | | | | | | | | Program address overflow occurred | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------------------------|--------------------------------------------------------------------|----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|---------------------------------------|-----------|----------|--------------------------------------------| | | | | PAL | DDRH | | | | | R | R | R | R | R | R | R | R | | | | | | | | | Initial value : | | | PADDRI | <b>H</b> Prog | gram address overflo | ow data regist | er high | | | | DDRM (Pr<br>7 | rogram Address I<br>6 | Invalid Data F<br>5 | Register Middle) : 8<br>4 | BFDAH<br>3 | 2 | 1 | 0 | | | | | | DDRM | | <u> </u> | | | <u> </u> | R | R | R | R | R | R | R | | | IX | K | IX | IX. | IX | K | Initial value : | | | DADDD | M 5 | | | | | ililiai value . | | | PADDRI | M Pro | gram address overflo | ow data regist | er middle | | | | | | | | | | | | | | | | egister Low) : 8FD | | _ | _ | _ | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | DDRL | | | | | | | | _ | | R | R | R | | | R | R | R | R | ĸ | 1 | ĸ | | | PADDRI | L Prog | gram address overflo | | | K | | | | | L Prog | gram address overflo | | | 1 | | | PTRH (Sta | PADDRI<br>ack Pointer Regis | L Prog<br>ster High) : 8F | gram address overflo<br>FDCH<br>4 | ow data regist | er low | | Initial value : | | PTRH (Sta | PADDRI<br>ack Pointer Regis | L Prog<br>ster High) : 8F | gram address overflo<br>FDCH<br>4 | ow data regist | er low | | Initial value : | | PTRH (Sta | PADDRI<br>ack Pointer Regis<br>6 | L Prog<br>ster High) : 8F<br>5 | gram address overflo<br>FDCH<br>4 | ow data regist 3 PTRH | er low | 1 | Initial value : | | PTRH (Sta | PADDRI<br>ack Pointer Regis<br>6 | L Prog<br>ster High) : 8F<br>5 | gram address overflo<br>FDCH<br>4 | ow data regist 3 PTRH R | er low | 1 | Initial value : | | PTRH (Sta | PADDRI<br>ack Pointer Regis<br>6 | L Prog<br>ster High) : 8F<br>5 | gram address overflor FDCH 4 STF R ck pointer register hi | ow data regist 3 PTRH R | er low | 1 | Initial value : | | PTRH (Sta | PADDRI<br>ack Pointer Regis<br>6 | L Prog<br>ster High) : 8F<br>5 | gram address overflor FDCH 4 STF R ck pointer register hi | ow data regist 3 PTRH R | er low | 1 | Initial value : | | PTRH (Sta | PADDRI ack Pointer Regis 6 R SPWRH ack Pointer Regis | L Prog<br>ster High) : 8F<br>5<br>R Stac<br>ster Low) : 8F | gram address overflor FDCH 4 STF R ck pointer register hi | ow data regist 3 PTRH R | z R | 1<br>R | O R Initial value : | | PTRH (Sta | PADDRI ack Pointer Regis 6 R SPWRH ack Pointer Regis | L Prog<br>ster High) : 8F<br>5<br>R Stac<br>ster Low) : 8F | gram address overflor FDCH 4 STF R ck pointer register hi | ow data regist 3 PTRH R | z R | 1<br>R | O R Initial value : | | PTRH (Sta<br>7<br>PTRL (Sta<br>7 | PADDRI ack Pointer Regis 6 R SPWRH ack Pointer Regis 6 | Prog<br>ster High) : 8F<br>5<br>R<br>Stac<br>ster Low) : 8F | Gram address overflow TOCH 4 STE R Ck pointer register his DDH 4 STE | ow data regist 3 PTRH R igh | z R | 1 R | O R Initial value : | | PTRH (Sta<br>7<br>PTRL (Sta<br>7 | PADDRI ack Pointer Regis 6 R SPWRH ack Pointer Regis 6 | Prog<br>ster High): 8F<br>5<br>R<br>Stac<br>ster Low): 8F<br>5 | gram address overflor FDCH 4 STF R ck pointer register hi DDH 4 STF | ow data regist 3 PTRH R igh 3 PTRL R | z R | 1 R | O R Initial value : | | PTRH (Sta<br>7<br>PTRL (Sta<br>7 | PADDRI ack Pointer Regis 6 R SPWRH ack Pointer Regis 6 | Prog<br>ster High): 8F<br>5<br>R<br>Stac<br>ster Low): 8F<br>5 | Gram address overflow TOCH 4 STE R Ck pointer register his DDH 4 STE | ow data regist 3 PTRH R igh 3 PTRL R | z R | 1 R | O R Initial value : | | PTRH (Sta | PADDRI ack Pointer Regis 6 R SPWRH ack Pointer Regis 6 | R Staceter Low): 8F | gram address overflor FDCH 4 STF R ck pointer register hi DDH 4 STF R | ow data regist 3 PTRH R igh 3 PTRL R | z R | 1 R | O R Initial value : | | PTRH (Sta | PADDRI ack Pointer Regis 6 R SPWRH ack Pointer Regis 6 R SPWRL | R Stack Pointer | gram address overflor 4 STF R ck pointer register hi DDH 4 STF R ck pointer register lock c): 8FDEH | ow data regist 3 PTRH R igh 3 PTRL R | z R | R 1 | O R Initial value : O R Initial value : | | PTRH (Sta | PADDRI ack Pointer Regis 6 R SPWRH ack Pointer Regis 6 | R Staceter Low): 8F | gram address overflor FDCH 4 STF R ck pointer register hi DDH 4 STF R ck pointer register look | ow data regist 3 PTRH R igh 3 PTRL R | z R | 1 R | O R Initial value : | | PTRH (Sta | PADDRI ack Pointer Regis 6 R SPWRH ack Pointer Regis 6 R SPWRL | R Stack Pointer | gram address overflor FDCH 4 STF R ck pointer register hi DDH 4 STF R ck pointer register look | ow data regist 3 PTRH R igh 3 PTRL R | z R | R 1 | O R Initial value : O R Initial value : | #### 11.2 Clock Generator #### 11.2.1 Overview As shown in Figure 11.2Table 11.2, the clock generator produces the basic clock pulses which provide the system clock to be supplied to the CPU and the peripheral hardware. The system colock source get from three kinds of resources - Internal RC OSC (16MHz) - INT-RC OSC/1 (16MHz) - INT-RC OSC/2 (8MHz, Default system clock) - INT-RC OSC/4 (4MHz) - INT-RC OSC/8 (2MHz) - INT-RC OSC/16 (1MHz) - Internal WDT RING OSC (256kHz) - External crystal at Xin and Xout pin (1~ 16MHz) - Sub crystal at SUBxin and SUBxout pins (32.768kHz, the resource of real time clock especially) The default system clock after power on is RC OSC Oscillator(8Mhz). It is clock resource to have quickly stable oscillation at POR or RESET active and provide system clock source to CPU and an other peripheral block. It is also clock source of BIT, WDT and ports de-bounce that control system stabilization. After the system operation start with RC OSC, an application software change system clock source to Main or SUB OSC with clock control registers. #### 11.2.2 Block Diagram Figure 11.2 Clock Generator Block Diagram # 11.2.3 CPU clock and Peripherals Clock Almost A97C450 blocks (CPU and Peripherals) are operating by System clock but a few of Peripherals block source are directly supplied from clock source. Figure 11.3 Clock source for operating block The peripheral block that is not operated by system clock source(Fsclk) - WDT RING OSC ( 256kHz internal ) - Bit counter block - Watch Dog Timer block - SUB clock (32.768Khz ) - Watch Timer and RTC block - CEC block (optional SUBCLK\_EN bit on CEC\_CONF1 register ( XSFR address : 8F62h) - H/W IR clock (optional SUBCLK\_EN bit on IRC\_CONF register ( XSFR address : 8F4Ch) - (In case of Power down mode (STOP mode), wake up source) - XTAL (only power Stop mode, and enable Main OSC block(XSTOP = '0') - Watch Timer and RTC block - CEC block - H/W IR clock ### 11.2.4 Register Map | Name | Address | Direction | Default | Description | |------|---------|-----------|---------|-----------------------------------| | SCCR | 8AH | R/W | 41H | System and Clock Control Register | Table 11.2 Clock Generator Register Map # 11.2.5 Clock Generator Register Description The Clock Control Register selects clock source for system operation. This register operation depends on oscillation resource and system configure option register(FUSE\_CONFIG). #### NOTE) It should to set SXINEN bit or XINENA bit on FUSE\_CONFIG register to use External clock source( Crystal Oscillator (1~16MHz) or/and Sub-Clock Crystal Oscillator (32.768 KHz)). Especially for Main Crystal Oscillator application, the bit (XOFF) on SCCR has to be "0" (X-Tal Oscillation enable) before changing clock souce. #### NOTE) Before changing system clock source with the bits (CS[1:0]), please check SXINEN, XINENA [ bit 4, 5] on FUSE\_CONFIG and XOFF [bit 2] on SCCR. # 11.2.6 Register Description for Clock Generator # SCCR (System and Clock Control Register): 8AH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------------|---------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|------------------|----------------|-----|--|--| | STOP1 | IRCEN | CBYS | XSTOP | SSTOP | CS2 | CS1 | CS0 | | | | RW | | | Initial value: 41 | ΙΗ | | | | | | | | | | | STOP1 | The o<br>0<br>1 | Rir | RING Oscillation at s<br>g-Oscillator is disab<br>g-Oscillator is enabl | led at stop mode | , | | | | | | IRCEN | Enabl | le IRC 16MI | Ηz | | | | | | | | | 0 | Dis | able IRC 16MHz | | | | | | | | | 1 | En | able IRC 16MHz | | | | | | | | CBYS | It con | trol method | s of system clock cha | ange. | | | | | | | 52.5 | this b | If this bit is '0', clock change occure on BIT interrupt generation on STOP condition this bit is '1', the clock change take place on setting CS[1:0] <b>NOTE)</b> when clear this bit, keep other bits in SCCR. | | | | | | | | | | 0 | • | ock changed by hard | | mode (default) | | | | | | | 1 | | ock changed by softw | | mode (deladit) | | | | | | XSTOP | Stop | main x-tal. | J | | | | | | | | 7.0.0. | 0 | | not stop main x-tal. | | | | | | | | | 1 | Sto | p main x-tal. | | | | | | | | SSTOP | Stop : | sub-xtal. | | | | | | | | | | 0 | Do | not stop sub-xtal. | | | | | | | | | 1 | | p sub-xtal. | | | | | | | | CS[2:0] | | ect system o | | | | | | | | | | | • | S bit, reflection poin | t is decided | | | | | | | | | CS1 CS | • | | | | | | | | | 0 | 0 0 0 | fIRC (16 MHz)<br>fIRC/2 (8 MHz) | | | | | | | | | 0 | 1 0 | fIRC/4 (4 MHz) | | | | | | | | | 0 | 1 1 | fIRC/8 (2 MHz) | | | | | | | | | 1 | 0 0 | fIRC/16 (1 MHz) | ) | | | | | | | | 1 | 0 1 | fXIN Main Clock | | | | | | | | | 1 | 1 0 | fSUB clock(32.7 | • | | | | | | | | | _ | · · | OOKI IZ) | | | | | | | | 1 | 1 1 | fRING(256kHz) | | | | | | Note 1. If XINENA bit in FUSE\_CONF is to '0', XOFF fixed to '1' Note 2. By writing 'A5h' to AUTHORITY register, SCCR changing is possible. ### 11.3 Basic Interval Timer #### 11.3.1 Overview The A97C450 has one 8-bit basic interval timer that is free-run and can't stop. Block diagram is shown in Figure 11.4. In addition, the basic interval timer generates the time base for watchdog timer counting. It also provides a basic interval timer interrupt (BITF). The A97C450 has these basic interval timer (BIT) features: - During Power On, BIT gives a stable clock generation time - On exiting Stop mode, BIT gives a stable clock generation time - As timer function, timer interrupt occurrence ### 11.3.2 Block Diagram Figure 11.4 Basic Interval Timer Block Diagram ### 11.3.3 Register Map | Name | Address | Direction | Default | Description | |------|---------|-----------|---------|-------------------------------| | BCCR | 8BH | R/W | 03H | BIT Clock Control Register | | BITR | 8CH | R | 00H | Basic Interval Timer Register | Table 11.3 Basic Interval Timer Register Map # 11.3.4 Basic Interval Timer Register Description The Bit Interval Timer Register consists of BIT Clock control register (BCCR) and Basic Interval Timer register (BITR). If BCLR bit set to '1', BITR becomes '0' and then counts up. After 1 machine cycle, BCLR bit is cleared as '0' automatically. # 11.3.5 Register Description for Basic Interval Timer # **BCCR (BIT Clock Control Register): 8BH** | 7 | 6 | 5 | 4 | | 3 | 2 | 1 | 0 | |-------------------|---------|--------|-------------|----------|-------------------|--------------------|---------------------|-----------------| | BITF | - | - | втск | | BCLR | BCK2 | BCK1 | BCK0 | | RW | R | R | RW | | RW | RW | RW | RW | | Initial value: 03 | ВН | | | | | | | | | | BITF | When | BIT Interru | pt occur | s, this bit beco | omes '1'. For cle | aring bit, write '0 | o' to this bit. | | | | 0 | no gener | ation | | | | | | | | 1 | generation | on | | | | | | | BITCK | Select | BIT clock | source | | | | | | | | 0 | fwdtrc / 2 | | | | | | | | | 1 | fwdtrc/ | | | | | | | | BCLR | | | | ', BIT Counte | r is cleared as 'C | )' | | | | | 0 | Free Rur | • | | | | | | | | 1 | Clear Co | | . (DIT OL. 1 | | | | | | BCK[2:0 | | | - | d (BIT Clock | ≒ 1 KHz) | | | | | | BCK2 | | | o (DIT | 5 OL 1 ± O\ | | | | | | 0 | - | 0 | 2msec (BIT | Clock * 2) | | | | | | 0 | 0 | 1 | 4msec | | | | | | | 0 | - | 0<br>1 | 8msec | ofoult) | | | | | | 1 | = | 0 | 16msec (de 32msec | erauri) | | | | | | 1 | 0 | 1 | 64msec | | | | | | | 1 | | 0 | 128msec | | | | | | | 1 | | 1 | 256msec | | | | | | | i | ' | | 200111000 | | | | ### Note 1. By writing 'A5h' to AUTHORITY register, BCCR changing is possible. # BITR (Basic Interval Timer Register): 8CH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|------|------|-----|------|------|------|------| | BIT7 | ВП6 | BIT5 | ВП4 | BIT3 | BIT2 | BIT1 | BITO | | R | R | R | R | R | R | R | R | | 1 '0' 1 1 0 | 01.1 | | | | | | | Initial value : 00H BIT[7:0] BIT Counter # 11.4 Watch Dog Timer #### 11.4.1 Overview The watchdog timer rapidly detects the CPU malfunction such as endless looping caused by noise or the like, and resumes the CPU to the normal state. The watchdog timer signal for detecting malfunction can be selected either a reset CPU or an interrupt request. When the watchdog timer is not being used for malfunction detection, it can be used as a timer to generate an interrupt at fixed intervals. It is possible to use free running 8-bit timer mode (WDTRSON='0') or watch dog timer mode (WDTRSON='1') as setting WDTMR[6] bit. If writing WDTMR[5] to '1', WDT counter value is cleared and counts up. After 1 machine cycle, this bit has '0' automatically. The watchdog timer consists of 8-bit binary counter and the watchdog timer data register. When the value of 8-bit binary counter is equal to the 8 bits of WDTR, the interrupt request flag is generated. This can be used as Watchdog timer interrupt or reset the CPU in accordance with the bit WDTRSON. The clock source of Watch Dog Timer is BIT overflow output. The interval of watchdog timer interrupt is decided by BIT overflow period and WDTR set value. The equation is as below WDT Interrupt Interval = (BIT Interrupt Interval) X (WDTR Value+1) #### 11.4.2 WDT Interrupt Timing Waveform Figure 11.5 Watch Dog Timer Interrupt Timing Waveform # 11.4.3 Block Diagram Figure 11.6 Watch Dog Timer Block Diagram # 11.4.4 Register Map | Name | Address | Direction | Default | Description | |-------|---------|-----------|---------|----------------------------------| | WDTR | 8EH | W | FFH | Watch Dog Timer Register | | WDTCR | 8EH | R | 00H | Watch Dog Timer Counter Register | | WDTMR | 8DH | R/W | 00H | Watch Dog Timer Mode Register | Table 11.4 Watch Dog Timer Register Map # 11.4.5 Watch Dog Timer Register Description The Watch dog timer (WDT) Register consists of Watch Dog Timer Register (WDTR), Watch Dog Timer Counter Register (WDTCR) and Watch Dog Timer Mode Register (WDTMR). ### 11.4.6 Register Description for Watch Dog Timer #### WDTR (Watch Dog Timer Register: Write Case): 8EH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | WDTR7 | WDTR6 | WDTR5 | WDTR4 | WDTR3 | WDTR2 | WDTR1 | WDTR0 | | W | W | W | W | W | W | W | W | Initial value: FFH WDTR[7:0] Set a period WDT Interrupt Interval=(BIT Interrupt Interval) x(WDTR Value+1) NOTE) To guarantee proper operation, the data should be greater than 01H. #### WDTCR (Watch Dog Timer Counter Register: Read Case): 8EH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | WDTCR7 | WDTCR6 | WDTCR5 | WDTCR4 | WDTCR3 | WDTCR2 | WDTCR1 | WDTCR0 | | R | R | R | R | R | R | R | R | Initial value: 00H WDTCR[7:0] WDT Counter ### WDTMR (Watch Dog Timer Mode Register): 8DH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|---------|-------|---|---|---|-------|--------| | WDTEN | WDTRSON | WDTCL | - | - | - | WDTCK | WDTIFR | | RW | RW | RW | - | - | - | RW | RW | Initial value: 00H WDTEN Control WDT operation 0 disable 1 enable WDTRSON Control WDT Reset operation 0 Free Running 8-bit timer 1 Watch Dog Timer Reset ON WDTCL Clear WDT Counter 0 Free Run 1 Clear WDT Counter (auto clear after 1 Cycle) WDTCK Control WDT Clock Selection Bit 0 BIT overflow for WDT clock 1 WDTRC / 16384 for WDT clock WDTIFR When WDT Interrupt occurs, this bit becomes '1'. For clearing bit, write '0' to this bit or auto clear by INT\_ACK signal. 0 WDT Interrupt no generation 1 WDT Interrupt generation #### 11.5 Watch Timer #### 11.5.1 Overview The watch timer has the function for RTC (Real Time Clock) operation. It is generally used for RTC design. The internal structure of the watch timer consists of the clock source select circuit, timer counter circuit, output select circuit and watch timer mode register. To operate the watch timer, determine the input clock source, output interval and set WTEN to '1' in watch timer mode register (WTMR). It is able to execute simultaneously or individually. To stop or reset WT, clear the WTEN bit in WTMR register. Even if CPU is STOP mode, sub clock is able to be alive so WT can continue the operation. The watch timer counter circuits may be composed of 21-bit counter which is low 14-bit with binary counter and high 7-bit with auto reload counter in order to raise resolution. In WTR, it can control WT clear and set Interval value at write time, and it can read 7-bit WT counter value at read time. #### 11.5.2 Block Diagram Figure 11.7 Watch Timer Block Diagram ### 11.5.3 Register Map | Name Address Direction | | Direction | Default | Description | | | |------------------------|-----|-----------|---------|------------------------------|--|--| | WTMR | 9DH | R/W | 00H | Watch Timer Mode Register | | | | WTR | 9EH | W | 7FH | Watch Timer Register | | | | WTCR | 9EH | R | 00H | Watch Timer Counter Register | | | Table 11.5 Watch Timer Register Map ### 11.5.4 Watch Timer Register Description The watch timer register (WT) consists of Watch Timer Mode Register (WTMR), Watch Timer Counter Register (WTCR) and Watch Timer Register (WTR). As WTMR is 6-bit writable/readable register, WTMR can control the clock source (WTCK), interrupt interval (WTIN) and function enable/disable (WTEN). Also there is WT interrupt flag bit (WTIFR). # 11.5.5 Register Description for Watch Timer #### WTMR (Watch Timer Mode Register): 9DH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---------------------|---------|-----------|-------------------------------------------------------------------------------------------------------------------|------------------|---------------|-------|-------|--|--| | WIEN | - | - | WTIFR | WTIN1 | WTINO | WTCK1 | WTCK0 | | | | RW | - | - | RW | RW | RW | RW | RW | | | | Initial value : 00H | | | | | | | | | | | | WTEN | Contro | l Watch Timer | | | | | | | | | | 0 | disable | | | | | | | | | | 1 | enable | | | | | | | | | WTIFR | | When WT Interrupt occurs, this bit becomes '1'. For clearing bit, write '0' to this auto clear by INT_ACK signal. | | | | | | | | | | 0 | 0 WT Interrupt no generation | | | | | | | | | | 1 | WT Interrupt | generation | | | | | | | | WTIN[1: | 0] Deter | mine interrupt ir | nterval | | | | | | | | | WTIN | 1 WTIN0 | description | | | | | | | | | 0 | | fwck/2048 | | | | | | | | | 0 | 1 | fwck/8192 | | | | | | | | | 1 | 0 | fwck/16384 | | | | | | | | | 1 | 1 | fwck/16384 x (7b | oit WT Value) | | | | | | | WTCK[1 | :01 Deter | mine Source Cl | ock | | | | | | | | • | WTC | K1 WTCK0 | description | | | | | | | | | 0 | 0 | fsub | | | | | | | | | 0 | 1 | fxin/256 | | | | | | | | | 1 | 0 | fxin/128 | | | | | | | | | 1 | 1 | fvm/6/ | | | | | | Remark: fxIN- Main clock oscillation frequency fsub- Sub clock oscillation frequency fwck- selected Watch Timer clock # WTR (Watch Timer Register: Write Case): 9EH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | WTCL | WTR6 | WTR5 | WTR4 | WTR3 | WTR2 | WTR1 | WTR0 | | W | W | W | W | W | W | W | W | Initial value: 7FH WTCL Clear WT Counter 0 Free Run 1 Clear WT Counter (auto clear after 1 Cycle) WTR[6:0] Set WT period WT Interrupt Interval=(fwck/2^14) x(7bit WT Value+1) NOTE) To guarantee proper operation, it is greater than 01H to write WTR. # WTCR (Watch Timer Counter Register: Read Case): 9EH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-------|-------|-------|-------|-------|-------|-------| | | WTCR6 | WTCR5 | WTCR4 | WTCR3 | WTCR2 | WTCR1 | WTCR0 | | - | R | R | R | R | R | R | R | Initial value: 00H WTCR[6:0] WT Counter ### 11.6 Timer 0/1 #### 11.6.1 Overview The 8-bit timer 0/1 consists of multiplexer, timer 0/1 counter register, timer 0/1 data register, timer 0/1 capture data register and timer 0/1 control register (TnCNT, TnDR, TnCDR, TnCR). It has three operating modes: - 8-bit timer/counter mode - 8-bit PWM output mode - 8-bit capture mode The timer/counter 0/1 can be clocked by an internal or an external clock source (ECn). The clock source is selected by clock selection logic which is controlled by the clock selection bits (TnCK[2:0]). TIMER 0/1 clock source: fx/2, 4, 8, 32, 128, 512, 2048 and ECn In the capture mode, by EINT0/1, the data is captured into input capture data register (TnCDR). In timer/counter mode, whenever counter value is equal to TnDR, TnO port toggles. Also the timer 0/1 outputs PWM waveform through PWMnO port in the PWM mode. | TnEN | TnMS[1:0] TnCK[2:0] | | Timer n | | | |------|---------------------|--------------------|--------------------------|--|--| | 1 | 00 | XXX | 8 Bit Timer/Counter Mode | | | | 1 | 01 | XXX 8 Bit PWM Mode | | | | | 1 | 1X | XXX | 8 Bit Capture Mode | | | Table 11.6 Timer 0/1 Operating Modes #### 11.6.2 8-Bit Timer/Counter Mode The 8-bit timer/counter mode is selected by control register as shown in Figure 11.8. The 8-bit timer have counter and data register. The counter register is increased by internal or external clock input. Timer 0/1 can use the input clock with one of 2, 4, 8, 32, 128, 512 and 2048 prescaler division rates (TnCK[2:0]). When the value of TnCNT and TnDR is identical in timer 0/1, a match signal is generated and the interrupt of Timer n occurs. TnCNT value is automatically cleared by match signal. It can be also cleared by software (TnCC). The external clock (ECn) counts up the timer at the rising edge. If the ECn is selected as a clock source by TnCK[2:0], EC0/EC1 port is automatically set to the input port. Figure 11.8 8-Bit Timer/Counter Mode for Timer 0/1 (Where n = 0 and 1) Figure 11.9 8-Bit Timer/Counter 0/1 Example (Where n = 0 and 1) #### 11.6.3 8-Bit PWM Mode The timer 0/1 has a high speed PWM (Pulse Width Modulation) function. In PWM mode, TnO/PWMnO pin outputs up to 8-bit resolution PWM output. The PWM output pin is configured by setting the TnPE bit to 1. In the 8-bit timer/counter mode, a match signal is generated when the counter value is identical to the value of TnDR. When the value of TnCNT and TnDR is identical in timer n, a match signal is generated and the interrupt of timer 0/1 occurs. In PWM mode, the match signal does not clear the counter. Instead, it runs continuously, overflowing at "FFH" and then continues incrementing from "00H". The timer 0/1 overflow interrupt is generated whenever a counter overflow occurs. TnCNT value is cleared by software (TnCC) bit. Figure 11.10 8-Bit PWM Mode for Timer 0/1 (Where n = 0 and 1) Figure 11.11 PWM Output Waveforms in PWM Mode for Timer 0/1 (Where n = 0 and 1) #### 11.6.4 8-Bit Capture Mode The timer 0/1 capture mode is set by TnMS[1:0] as '1x'. The clock source can use the internal/external clock. Basically, it has the same function as the 8-bit timer/counter mode and the interrupt occurs when TnCNT is equal to TnDR. TnCNT value is automatically cleared by match signal and it can be also cleared by software (TnCC). This timer interrupt in capture mode is very useful when the pulse width of captured signal is wider than the maximum period of timer. The capture result is loaded into TnCDR. In the timer n capture mode, timer n output (TnO) waveform is not available. According to EIEDGE, EIPOLA registers setting, the external interrupt EINTn function is chosen. Of course, the EINTn pin must be set to an input port. TnCDR and TnDR are in the same address. In the capture mode, reading operation reads TnCDR, not TnDR and writing operation will update TnDR. Figure 11.12 8-Bit Capture Mode for Timer 0/1 (Where n = 0 and 1) Figure 11.13 Input Capture Mode Operation for Timer 0/1/2 (Where n = 0, 1 and 2) Figure 11.14 Express Timer Overflow in Capture Mode (Where n = 0 and 1) ### 11.6.5 Block Diagram Figure 11.15 8-Bit Timer 0/1/2 Block Diagram (Where n = 0 and 1) # 11.6.6 Register Map | Name | Address | Direction | Default | Description | |---------|---------|-----------|---------|----------------------------------| | TnCNT | B3H/B7H | R | 00H | Timer n Counter Register | | TnDR | B4H/BAH | R/W | FFH | Timer n Data Register | | TnCDR | B4H/BAH | R | 00H | Timer n Capture Data Register | | TnCR | B5H/BBH | R/W | 00H | Timer n Control Register | | TINTCR | B2H | R/W | 00H | Timer Interrupt Control Register | | TIFLAG0 | В6Н | R/W | 00H | Timer Interrupt Flag Register | Table 11.7 Timer 0/1 Register Map # 11.6.7 Timer/Counter 0 Register Description The timer/counter 0/1 register consists of timer 0/1 counter register (TnCNT), timer 0/1 data register (TnDR), timer 0/1 capture data register (TnCDR), timer 0/1 control register (TnCR), timer interrupt control register(TINTCR), and timer interrupt flag register(TIFLAG0). # 11.6.8 Register Description for Timer/Counter 0/1 TnCNT (Timer n Counter Register): B3H/B7H, n= 0 and 1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | TnCNT7 | TnCNT6 | TnCNT5 | TnCNT4 | TnCNT3 | TnCNT2 | TnCNT1 | TnCNT0 | | R | R | R | R | R | R | R | R | Initial value: 00H TnCNT[7:0] Tn Counter TnDR (Timer n Data Register: Write only when it is capture mode): B4H/BAH, n= 0 and 1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | TnDR7 | TnDR6 | TnDR5 | TnDR4 | TnDR3 | TnDR2 | TnDR1 | TnDR0 | | RW Initial value: FFH TnDR[7:0] Tn Data TnCDR (Timer n Capture Data Register : Capture mode only) : B4H/BAH, n= 0 and 1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | TnCDR7 | TnCDR6 | TnCDR5 | TnCDR4 | TnCDR3 | TnCDR2 | TnCDR1 | TnCDR0 | | R | R | R | R | R | R | R | R | Initial value: 00H TnCDR[7:0] Tn Capture Data TnCR (Timer n Control Register): B5H/BBH, n= 0 and 1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|-------|-------|-------|-------|-------|------| | TnEN | TnPE | TnMS1 | TnMS0 | TnCK2 | TnCK1 | TnCK0 | TnCC | | RW Initial value: 00H | TnEN | Control | Timer n | | | | | | |-----------|--------------------------------------------------------------|------------------------------------------------------|--------------------|----------------------|--|--|--| | | 0 | Timer n disable | | | | | | | | 1 | Timer n enable | | | | | | | TnPE | Configu | ure Timer n PWM output port. | | | | | | | | 0 | GPIO | | | | | | | | 1 | PWM output | | | | | | | TnMS[1:0] | Control | Control Timer n Operation Mode | | | | | | | | TnMS1 | TnMS0 | Descrip | tion | | | | | | 0 | 0 | Timer/counter mode | | | | | | | 0 | 1 | PWM mode | | | | | | | 1 | х | Capture mode | | | | | | TnCK[2:0] | Select 7 | Timer n clock source. fx is a system clock frequency | | | | | | | | TnCK2 | TnCK1 | TnCK0 | Description | | | | | | 0 | 0 | 0 | fx/2 | | | | | | 0 | 0 | 1 | fx/4 | | | | | | 0 | 1 | 0 | fx/8 | | | | | | 0 | 1 | 1 | fx/32 | | | | | | 1 | 0 | 0 | fx/128 | | | | | | 1 | 0 | 1 | fx/512 | | | | | | 1 | 1 | 0 | fx/2048 | | | | | | 1 | 1 | 1 | External Clock (ECn) | | | | | TnCC | Clear tir | Clear timer n Counter | | | | | | | | 0 | No effe | | | | | | | | n counter (When write, automatically cleared "0" after being | | | | | | | **NOTE)** 1. Match Interrupt is generated in Capture mode. 2. Refer to the timer interrupt flag register (TIFLAG0) for the T0/1 interrupt flags. # TINTCR(Timer Interrupt Control Register): B2H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|---|---|--------|--------| | - | - | T1MIE | TOMIE | - | - | T10VIE | T00VIE | | - | - | RW | RW | - | - | RW | RW | Initial value: 00H T1MIE Enable or Disable Timer 1 Match Interrupt 0 Disable1 Enable **TOMIE** Enable or Disable Timer 0 Match Interrupt 0 Disable1 Enable **T10VIE** Enable or Disable Timer 1 Overflow Interrupt 0 Disable1 Enable **T00VIE** Enable or Disable Timer 0 Overflow Interrupt 0 Disable1 Enable #### TIFLAG0(Timer Interrupt Flag Register): B6H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-------|-------|-------|---------|-------|---------|-------| | - | T4IFR | T4IFR | T4IFR | T10VIFR | T1IFR | T00VIFR | T0IFR | | - | RW Initial value: 00H T6IFR When Timer 6 match interrupt occurs, this bit becomes '1'. The flag is cleared only by writing a '0' to the bit. So, the flag should be cleared by software. Writing "1" has no effect. O Timer 6 match interrupt no generation 1 Timer 6 match interrupt generation T5IFR When Timer 5 match interrupt occurs, this bit becomes '1'. The flag is cleared only by writing a '0' to the bit. So, the flag should be cleared by software. Writing "1" has no effect. 0 Timer 5 match interrupt no generation 1 Timer 5 match interrupt generation T4IFR When Timer 4 match interrupt occurs, this bit becomes '1'. The flag is cleared only by writing a '0' to the bit. So, the flag should be cleared by software. Writing "1" has no effect O Timer 4 match interrupt no generation 1 Timer 4 match interrupt generation T10VIFR When Timer 1 overflow interrupt occurs, this bit becomes '1'. The flag is cleared only by writing a '0' to the bit. So, the flag should be cleared by software. Writing "1" has no effect. 0 Timer 1 overflow interrupt no generation 1 Timer 1 overflow interrupt generation T1IFR When Timer 1 match interrupt occurs, this bit becomes '1'. The flag is cleared only by writing a '0' to the bit. So, the flag should be cleared by software. Writing "1" has no effect. O Timer 1 match interrupt no generation 1 Timer 1 match interrupt generation **T00VIFR** When Timer 0 overflow interrupt occurs, this bit becomes '1'. The flag is cleared only by writing a '0' to the bit. So, the flag should be cleared by software. Writing "1" has no effect. O Timer 0 overflow interrupt no generation 1 Timer 0 overflow interrupt generation T0IFR When Timer 0 match interrupt occurs, this bit becomes '1'. The flag is cleared only by writing a '0' to the bit. So, the flag should be cleared by software. Writing "1" has no effect. 0 Timer 0 match interrupt no generation 1 Timer 0 match interrupt generation ### 11.7 Timer 2/3 #### 11.7.1 Overview The 16-bit timer 2/3 consists of multiplexer, timer 2/3 A data register high/low, timer 2/3 B data register high/low and timer 2/3 control register high/low (TnADRH, TnBDRH, TnBDRH, TnCRH). It has four operating modes: - 16-bit timer/counter mode - 16-bit capture mode - 16-bit PPG output mode (one-shot mode) - 16-bit PPG output mode (repeat mode) The timer/counter 2/3 can be clocked by an internal or an external clock source (ECn). The clock source is selected by clock selection logic which is controlled by the clock selection bits (TnCK[2:0]). - TIMER n clock source: fX/1, 2, 4, 8, 64, 512, 2048 and ECn In the capture mode, by EINT1n, the data is captured into input capture data register (TnBDRH/TnBDRL). Timer 2/3 outputs the comparison result between counter and data register through TnO port in timer/counter mode. Also Timer 2/3 outputs PWM wave form through PWMnO port in the PPG mode. | TnEN | TnMS[1:0] | TnCK[2:0] | Timer 2/3 | |------|-----------|-----------|------------------------------------| | 1 | 00 | XXX | 16 Bit Timer/Counter Mode | | 1 | 01 | XXX | 16 Bit Capture Mode | | 1 | 10 | xxx | 16 Bit PPG Mode<br>(one-shot mode) | | 1 | 11 | xxx | 16 Bit PPG Mode<br>(repeat mode) | Table 11.8 Timer 2/3 Operating Modes #### 11.7.2 16-bit Timer/Counter Mode The 16-bit timer/counter mode is selected by control register as shown in Figure 11.14. The 16-bit timer have counter and data register. The counter register is increased by internal or external clock input. Timer 2/3 can use the input clock with one of 1, 2, 4, 8, 64, 512 and 2048 prescaler division rates (TnCK[2:0]). When the value of TnCNTH, TnCNTL and the value of TnADRH, TnADRL are identical in Timer 2/3 respectively, a match signal is generated and the interrupt of Timer 2/3 occurs. The TnCNTH, TnCNTL value is automatically cleared by match signal. It can be also cleared by software (TnCC). The external clock (ECn) counts up the timer at the rising edge. If the ECn is selected as a clock source by TnCK[2:0], ECn port is automatically set to the input port. Figure 11.16 16-bit Timer/Counter Mode for Timer 2/3 ( where n= 2 and 3) Figure 11.17 16-bit Timer/Counter 2/3 Example (where n= 2 and 3) ## 11.7.3 16-bit Capture Mode The 16-bit timer 2/3 capture mode is set by TnMS[1:0] as '01'. The clock source can use the internal/external clock. Basically, it has the same function as the 16-bit timer/counter mode and the interrupt occurs when TnCNTH/TnCNTL is equal to TnADRH/TnADRL. The TnCNTH, TnCNTL values are automatically cleared by match signal. It can be also cleared by software (TnCC). This timer interrupt in capture mode is very useful when the pulse width of captured signal is wider than the maximum period of timer. The capture result is loaded into TnBDRH/TnBDRL. According to EIEDGE, EIPOLA registers setting, the external interrupt EINTn function is chosen. Of course, the EINTn pin must be set as an input port. Figure 11.18 16-bit Capture Mode for Timer 2/3 (where n= 2 and 3) Figure 11.19 Input Capture Mode Operation for Timer 2/3 (where n= 2 and 3) Figure 11.20 Express Timer Overflow in Capture Mode ( where n= 2 and 3) ### 11.7.4 16-bit PPG Mode The timer 2/3 has a PPG (Programmable Pulse Generation) function. In PPG mode, TnO/PWMnO pin outputs up to 16-bit resolution PWM output. This pin should be configured as a PWM output by setting TnPE bit to '1'. The period of the PWM output is determined by the TnADRH/TnADRL. And the duty of the PWM output is determined by the TnBDRH/TnBDRL. Figure 11.21 16-bit PPG Mode for Timer 2/3 (where n= 2 and 3) Figure 11.22 16-bit PPG Mode Timming chart for Timer 2/3 ( where n= 2 and 3) ## 11.7.5 Block Diagram Figure 11.23 16-bit Timer 2/3 Block Diagram (where n= 2 and 3) # 11.7.6 Register Map | Name | Address | Direction | Default | Description | |--------|---------|-----------|---------|-------------------------------| | TnADRH | BFH/C5H | R/W | FFH | Timer n A Data High Register | | TnADRL | BEH/C4H | R/W | FFH | Timer n A Data Low Register | | TnBDRH | C1H/C7H | R/W | FFH | Timer n B Data High Register | | TnBDRL | C0H/C6H | R/W | FFH | Timer n B Data Low Register | | TnCRH | BDH/C3H | R/W | 00H | Timer n Control High Register | | TnCRL | BCH/C2H | R/W | 00H | Timer n Control Low Register | Table 11.9 Timer 2/3 Register Map ## 11.7.7 Timer/Counter 2/3 Register Description The timer/counter 2/3 register consists of timer 2/3 A data high register (TnADRH), timer 2/3 A data low register (TnADRL), timer 2/3 B data high register (TnBDRH), timer 2/3 B data low register (TnBDRL), timer 2/3 control high register (TnCRH) and timer 2/3 control low register (TnCRL). ### 11.7.8 Register Description for Timer/Counter 2/3 ## TnADRH (Timer n A data High Register): BFH/C5H, n= 2 and 3 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | TnADRH7 | TnADRH6 | TnADRH5 | TnADRH4 | TnADRH3 | TnADRH2 | TnADRH1 | TnADRH0 | | R/W Initial value : FFH TnADRH[7:0] Tn A Data High Byte ## TnADRL (Timer n A Data Low Register): BEH/C4H, n= 2 and 3 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | TnADRL7 | TnADRL6 | TnADRL5 | TnADRL4 | TnADRL3 | TnADRL2 | TnADRL1 | TnADRL0 | | R/W Initial value: FFH TnADRL[7:0] Tn A Data Low Byte NOTE) Do not write "0000H" in the TnADRH/TnADRL register when PPG mode ## TnBDRH (Timer n B Data High Register): C1H/C7H, n= 2 and 3 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | TnBDRH7 | TnBDRH6 | TnBDRH5 | TnBDRH4 | TnBDRH3 | TnBDRH2 | TnBDRH1 | TnBDRH0 | | R/W Initial value: FFH TnBDRH[7:0] Tn B Data High Byte ## TnBDRL (Timer n B Data Low Register): C0H/C6H, n= 2 and 3 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | TnBDRL7 | TnBDRL6 | TnBDRL5 | TnBDRL4 | TnBDRL3 | TnBDRL2 | TnBDRL1 | TnBDRL0 | | R/W Initial value: FFH TnBDRL[7:0] Tn B Data Low Byte # TnCRH (Timer n Control High Register) : BDH/C3H, n= 2 and 3 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|-------|-------|---|---|------|------| | TnEN | _ | TnMS1 | TnMS0 | _ | _ | TnPE | TnCC | | RW | _ | R/W | RW | _ | _ | R/W | RW | Initial value: 00H | TnEN | Control | Timer n | | |-----------|----------|------------|--------------------------------------------------------------------------------| | | 0 | | disable | | | 1 | | enable (Counter clear and start) | | TnMS[1:0] | Control | Timer n C | Operation Mode | | | TnMS1 | TnMS0 | Description | | | 0 | 0 | Timer/counter mode (TnO: toggle at A match) | | | 0 | 1 | Capture mode (The A match interrupt can occur) | | | 1 | 0 | PPG one-shot mode (PWMnO) | | | 1 | 1 | PPG repeat mode (PWMnO) | | TnPE | Configu | re Timer ı | n PWM output port. | | | 0 | GPIO | | | | 1 | PWM o | utput | | TnCC | Clear Ti | mer n Co | unter | | | 0 | No effe | ct | | | 1 | | ne Timer n counter (When write, automatically cleared "0" after being counter) | TnCRL (Timer n Control Low Register) : BCH/C2H, n= 2 and 3 | _ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-------|-------|-------|-------|---|-------|-------|--------| | | TnCK2 | TnCK1 | TnCK0 | TnIFR | _ | TnPOL | TnECE | TnCNTR | | Ī | R/W | R/W | R/W | R/W | _ | RW | RW | RW | Initial value: 00H | | | | | | iidi valdo . ooi | | |-----------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------|------------------|--| | TnCK[2:0] | Select Ti | imer n clo | ck sourc | e. fx is main system clock frequency | | | | | TnCK2 | TnCK1 | TnCK0 | Description | | | | | 0 | 0 | 0 | fx/2048 | | | | | 0 | 0 | 1 | fx/512 | | | | | 0 | 1 | 0 | fx/64 | | | | | 0 | 1 | 1 | fx/8 | | | | | 1 | 0 | 0 | fx/4 | | | | | 1 | 0 | 1 | fx/2 | | | | | 1 | 1 | 0 | fx/1 | | | | | 1 | 1 | 1 | External clock (ECn) | | | | TnIFR | | When Tn Interrupt occurs, this bit becomes '1'. For clearing bit, write '0' to this bauto clear by INT_ACK signal. Writing "1" has no effect. | | | | | | | 0 | Tn Inter | rupt no g | eneration | | | | | 1 | Tn Inter | rupt gene | eration | | | | TnPOL | TnO/PW | MnO Pol | arity Sele | ection | | | | | 0 | Start Hi | gh (TnO/ | PWMnO is low level at disable) | | | | | 1 | Start Lo | w (TnO/F | PWMnO is high level at disable) | | | | TnECE | Timer n | External ( | Clock Ed | ge Selection | | | | | 0 | Externa | l clock fa | ılling edge | | | | | 1 | Externa | I clock ris | sing edge | | | | TnCNTR | Timer n | Counter F | Read Cor | ntrol | | | | | 0 | No effec | ct | | | | | | 1 | | | er value to the B data register (When write, being loaded) | automatically | | | | | | | | | | #### 11.8 Timer 4/5/6 #### 11.8.1 Overview The 16-bit timer 4/5/6 consists of multiplexer, timer 4/5/6 A data register high/low, timer 4/5/6 B data register high/low and timer 4/5/6 control register high/low (TnADRH, TnBDRH, TnBDRH, TnBDRH, TnCRH, TnCRL). It has four operating modes: - 16-bit timer/counter mode - 16-bit capture mode - 16-bit PPG output mode (one-shot mode) - 16-bit PPG output mode (repeat mode) The timer/counter 4/5/6 can be clocked by an internal or an external clock source (ECn). The clock source is selected by clock selection logic which is controlled by the clock selection bits (TnCK[2:0]). - TIMER n clock source: fX/1, 2, 4, 8, 64, 512, 2048 and ECn In the capture mode, by EINT1n, the data is captured into input capture data register (TnBDRH/TnBDRL). Timer 4/5/6 outputs the comparison result between counter and data register through TnO port in timer/counter mode. Also Timer 4/5/6 outputs PWM wave form through PWMnO port in the PPG mode. | TnEN | TnMS[1:0] | TnCK[2:0] | Timer 4/5/6 | |------|-----------|-----------|------------------------------------| | 1 | 00 | XXX | 16 Bit Timer/Counter Mode | | 1 | 01 | XXX | 16 Bit Capture Mode | | 1 | 10 | xxx | 16 Bit PPG Mode<br>(one-shot mode) | | 1 | 11 | xxx | 16 Bit PPG Mode<br>(repeat mode) | Table 11.10 Timer 4/5/6 Operating Modes #### 11.8.2 16-bit Timer/Counter Mode The 16-bit timer/counter mode is selected by control register as shown in Figure 11.22. The 16-bit timer have counter and data register. The counter register is increased by internal or external clock input. Timer 4/5/6 can use the input clock with one of 1, 2, 4, 8, 64, 512 and 2048 prescaler division rates (TnCK[2:0]). When the value of TnCNTH, TnCNTL and the value of TnADRH, TnADRL are identical in Timer 4/5/6 respectively, a match signal is generated and the interrupt of Timer 4/5/6 occurs. The TnCNTH, TnCNTL value is automatically cleared by match signal. It can be also cleared by software (TnCC). The external clock (ECn) counts up the timer at the rising edge. If the ECn is selected as a clock source by TnCK[2:0], ECn port is automatically set to the input port. Figure 11.24 16-bit Timer/Counter Mode for Timer 4/5/6 ( where n= 4, 5 and 6) Figure 11.25 16-bit Timer/Counter 4/5/6 Example ( where n= 4, 5 and 6) ## 11.8.3 16-bit Capture Mode The 16-bit timer 4/5/6 capture mode is set by TnMS[1:0] as '01'. The clock source can use the internal/external clock. Basically, it has the same function as the 16-bit timer/counter mode and the interrupt occurs when TnCNTH/TnCNTL is equal to TnADRH/TnADRL. The TnCNTH, TnCNTL values are automatically cleared by match signal. It can be also cleared by software (TnCC). This timer interrupt in capture mode is very useful when the pulse width of captured signal is wider than the maximum period of timer. The capture result is loaded into TnBDRH/TnBDRL. According to EIEDGE, EIPOLA registers setting, the external interrupt EINTn function is chosen. Of course, the EINTn pin must be set as an input port. Figure 11.26 16-bit Capture Mode for Timer 4/5/6 (where n= 4, 5 and 6) Figure 11.27 Input Capture Mode Operation for Timer 4/5/6 (where n= 4, 5 and 6) Figure 11.28 Express Timer Overflow in Capture Mode ( where n= 4, 5 and 6) #### 11.8.4 16-bit PPG Mode The timer 4/5/6 has a PPG (Programmable Pulse Generation) function. In PPG mode, TnO/PWMnO pin outputs up to 16-bit resolution PWM output. This pin should be configured as a PWM output by setting TnPE bit to '1'. The period of the PWM output is determined by the TnADRH/TnADRL. And the duty of the PWM output is determined by the TnBDRH/TnBDRL. Figure 11.29 16-bit PPG Mode for Timer 4/5/6 ( where n= 4, 5 and 6) Figure 11.30 16-bit PPG Mode Timming chart for Timer 4/5/6 ( where n= 4, 5 and 6) ## 11.8.5 Block Diagram **Figure 11.31** 16-bit Timer 4/5/6 Block Diagram ( where n= 4, 5 and 6) ## 11.8.6 Register Map | Name | Address | Direction | Default | Description | |--------|-------------|-----------|---------|-------------------------------| | TnADRH | CBH/D3H/EFH | R/W | FFH | Timer n A Data High Register | | TnADRL | CAH/D2H/EEH | R/W | FFH | Timer n A Data Low Register | | TnBDRH | CDH/D5H/F9H | R/W | FFH | Timer n B Data High Register | | TnBDRL | CCH/D4H/F8H | R/W | FFH | Timer n B Data Low Register | | TnCRH | C9H/CFH/F7H | R/W | 00H | Timer n Control High Register | | TnCRL | C8H/CEH/F1H | R/W | 00H | Timer n Control Low Register | | TIFLAG | В6Н | R/W | 00H | Timer Interrupt Flag Register | Table 11.11 Timer 4/5/6 Register Map ## 11.8.7 Timer/Counter 4/5/6 Register Description The timer/counter 4/5/6 register consists of timer 4/5/6 A data high register (TnADRH), timer 4/5/6 A data low register (TnADRL), timer 4/5/6 B data high register (TnBDRH), timer 4/5/6 B data low register (TnBDRL), timer 4/5/6 control high register (TnCRH), timer 4/5/6 control low register (TnCRL), and timer interrupt flag register(TIFLAG1). ### 11.8.8 Register Description for Timer/Counter 4/5/6 ## TnADRH (Timer n A data High Register): DDH/E5H/EDH/105BH (SFR/SFR/XSFR), n= 4, 5 and 6 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | TnADRH7 | TnADRH6 | TnADRH5 | TnADRH4 | TnADRH3 | TnADRH2 | TnADRH1 | TnADRH0 | | R/W Initial value: FFH TnADRH[7:0] Tn A Data High Byte ## TnADRL (Timer n A Data Low Register): DCH/E4H/ECH/105AH (SFR/SFR/XSFR), n= 4, 5 and 6 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | TnADRL7 | TnADRL6 | TnADRL5 | TnADRL4 | TnADRL3 | TnADRL2 | TnADRL1 | TnADRL0 | | R/W Initial value : FFH TnADRL[7:0] Tn A Data Low Byte NOTE) Do not write "0000H" in the TnADRH/TnADRL register when PPG mode ## TnBDRH (Timer n B Data High Register): DFH/E7H/EFH/105DH (SFR/SFR/XSFR), n= 4, 5 and 6 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | TnBDRH7 | TnBDRH6 | TnBDRH5 | TnBDRH4 | TnBDRH3 | TnBDRH2 | TnBDRH1 | TnBDRH0 | | R/W Initial value: FFH TnBDRH[7:0] Tn B Data High Byte ## TnBDRL (Timer n B Data Low Register): DEH/E6H/EEH/105CH (SFR/SFR/XSFR), n= 4, 5 and 6 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | TnBDRL7 | TnBDRL6 | TnBDRL5 | TnBDRL4 | TnBDRL3 | TnBDRL2 | TnBDRL1 | TnBDRL0 | | R/W Initial value: FFH TnBDRL[7:0] Tn B Data Low Byte ## TnCRH (Timer n Control High Register): DBH/E3H/EBH/1059H (SFR/SFR/XSFR), n= 4, 5 and 6 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|-------|-------|-------|---|---|------|------| | TnEN | TnMIE | TnMS1 | TnMS0 | _ | _ | TnPE | TnCC | | RW | R/W | R/W | RW | _ | _ | R/W | RW | Initial value: 00H | TnEN | Control | Timer n | | |-----------|----------|------------|--------------------------------------------------------------------------------| | | 0 | Timer n | disable | | | 1 | Timer n | enable (Counter clear and start) | | TnMIE | Enable | or Disable | e Timer n Match Interrupt | | | 0 | Disable | | | | 1 | Enable | | | TnMS[1:0] | Control | Timer n C | Operation Mode | | | TnMS1 | TnMS0 | Description | | | 0 | 0 | Timer/counter mode (TnO: toggle at A match) | | | 0 | 1 | Capture mode (The A match interrupt can occur) | | | 1 | 0 | PPG one-shot mode (PWMnO) | | | 1 | 1 | PPG repeat mode (PWMnO) | | TnPE | Configu | re Timer r | n PWM output port. | | | 0 | GPIO | | | | 1 | PWM o | utput | | TnCC | Clear Ti | mer n Co | unter | | | 0 | No effe | ct | | | 1 | | ne Timer n counter (When write, automatically "0" after being cleared counter) | NOTE) Refer to the timer interrupt flag register (TIFLAG) for the T4/T5/T6 interrupt flags. # TnCRL (Timer n Control Low Register): DAH/E2H/EAH/1058H (SFR/SFR/XSFR), n= 4, 5 and 6 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|---|---|-------|-------|--------| | TnCK2 | TnCK1 | TnCK0 | _ | _ | TnPOL | TnECE | TnCNTR | | R/W | R/W | R/W | _ | _ | RW | RW | RW | Initial value: 00H | TnCK[2:0] | Select 7 | Timer n cl | ock sourc | ce. fx is main system clock frequency | |-----------|----------|------------|--------------|--------------------------------------------------------------------------| | | TnCK2 | TnCK1 | TnCK0 | Description | | | 0 | 0 | 0 | fx/2048 | | | 0 | 0 | 1 | fx/512 | | | 0 | 1 | 0 | fx/64 | | | 0 | 1 | 1 | fx/8 | | | 1 | 0 | 0 | fx/4 | | | 1 | 0 | 1 | fx/2 | | | 1 | 1 | 0 | fx/1 | | | 1 | 1 | 1 | External clock (ECn) | | TnPOL | TnO/PV | VMnO Po | larity Sele | ection | | | 0 | Start H | igh (TnO/ | /PWMnO is low level at disable) | | | 1 | Start Lo | ow (TnO/ | PWMnO is high level at disable) | | TnECE | Timer n | External | Clock Ed | ge Selection | | | 0 | Externa | al clock fa | alling edge | | | 1 | Externa | al clock ris | sing edge | | TnCNTR | Timer n | Counter | Read Co | ntrol | | | 0 | No effe | ct | | | | 1 | | | er value to the B data register (When write, automatically being loaded) | ## 11.9 Buzzer Driver ## 11.9.1 Overview The Buzzer consists of 8 Bit Counter and BUZDR (Buzzer Data Register), BUZCR (Buzzer Control Register). The Square Wave (122.07Hz~250 KHz, @16MHz) gets out of P33/BUZ pin. BUZDR (Buzzer Data Register) controls the Buzzer frequency (look at the following expression). In the BUZCR (Buzzer Control Register), BUCK[1:0] selects source clock divided from prescaler. $$f_{BUZ}(Hz) = \frac{Oscillator\ Frequency}{2 \times Prescaler\ Ratio \times (BUZDR\ +1)}$$ | DUZDDIZ:01 | Buzzer Frequency (kHz) | | | | | | | | | |------------|------------------------|---------------|---------------|---------------|--|--|--|--|--| | BUZDR[7:0] | BUZCR[2:1]=00 | BUZCR[2:1]=01 | BUZCR[2:1]=10 | BUZCR[2:1]=11 | | | | | | | 0000_0000 | 250kHz | 125kHz | 62.5kHz | 31.25kHz | | | | | | | 0000_0001 | 125kHz | 62.5kHz | 31.25kHz | 15.624kHz | | | | | | | | | | | | | | | | | | 1111_1101 | 984.252Hz | 492.126Hz | 246.062Hz | 123.03Hz | | | | | | | 1111_1110 | 980.392Hz | 490.196Hz | 245.098Hz | 122.548Hz | | | | | | | 1111_1111 | 976.562Hz | 488.282Hz | 244.140Hz | 122.07Hz | | | | | | Table 11.12 Buzzer Frequency at 16 MHz ## 11.9.2 Block Diagram Figure 11.32 Buzzer Driver Block Diagram ## 11.9.3 Register Map | Name | Address | Direction Default | | Description | |-------|---------|-------------------|-----|-------------------------| | BUZDR | 8FH | R/W | FFH | Buzzer Data Register | | BUZCR | 9FH | R/W | 00H | Buzzer Control Register | Table 11.13 Buzzer Driver Register Map ## 11.9.4 Buzzer Driver Register Description Buzzer driver consists of buzzer data register (BUZDR) and buzzer control register (BUZCR). ## 11.9.5 Register Description for Buzzer Driver ## BUZDR (Buzzer Data Register): 8FH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | BUZDR7 | BUZDR6 | BUZDR5 | BUZDR4 | BUZDR3 | BUZDR2 | BUZDR1 | BUZDR0 | | RW Initial value: FFH BUZDR[7:0] This bits control the Buzzer frequency Its resolution is 00H ~ FFH ## **BUZCR (Buzzer Control Register): 97H** | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|-------|--------|-------| | - | _ | _ | _ | _ | BUCK1 | BUCK() | BUZEN | | _ | _ | - | _ | - | RW | RW | RW | Initial value: 00H **Buzzer Driver Source Clock Selection** BUCK[1:0] BUCK1 BUCK0 Description 0 0 fx/32 0 fx/64 1 1 0 fx/128 fx/256 **Buzzer Driver Operation Control** BUZEN 0 Buzzer Driver disable Buzzer Driver enable ## NOTE) 1. fx: System clock oscillation frequency. ### 11.10 **USART** #### 11.10.1 Overview The Universal Synchronous and Asynchronous serial Receiver and Transmitter (USART) is a highly flexible serial communication device. The main features are listed below. - Full Duplex Operation (Independent Serial Receive and Transmit Registers) - Asynchronous or Synchronous Operation - Master or Slave Clocked Synchronous and SPI Operation - Supports all four SPI Modes of Operation (Mode 0, 1, 2, 3) - LSB First or MSB First Data Transfer @SPI mode - High Resolution Baud Rate Generator - Supports Serial Frames with 5,6,7,8, or 9 Data bits and 1 or 2 Stop bits - Odd or Even Parity Generation and Parity Check Supported by Hardware - Data OverRun Detection - Framing Error Detection - Digital Low Pass Filter - Three Separate Interrupts on TX Complete, TX Data Register Empty and RX Complete - Double Speed Asynchronous Communication Mode USART has three main parts of Clock Generator, Transmitter and Receiver. The Clock Generation logic consists of synchronization logic for external clock input used by synchronous or SPI slave operation, and the baud rate generator for asynchronous or master (synchronous or SPI) operation. The Transmitter consists of a single write buffer, a serial shift register, parity generator and control logic for handling different serial frame formats. The write buffer allows a continuous transfer of data without any delay between frames. The receiver is the most complex part of the USART module due to its clock and data recovery units. The recovery unit is used for asynchronous data reception. In addition to the recovery unit, the Receiver includes a parity checker, a shift register, a two level receive FIFO (UDATAx) and control logic. The Receiver supports the same frame formats as the Transmitter and can detect Frame Error, Data OverRun and Parity Errors. ## 11.10.2 Block Diagram Figure 11.33 USART Block Diagram ### 11.10.3 Clock Generation Figure 11.34 Clock Generation Block Diagram The Clock generation logic generates the base clock for the Transmitter and Receiver. The USART supports four modes of clock operation and those are Normal Asynchronous, Double Speed Asynchronous, Master Synchronous and Slave Synchronous. The clock generation scheme for Master SPI and Slave SPI mode is the same as Master Synchronous and Slave Synchronous operation mode. The UMSELn bit in UCTRLx1 register selects between asynchronous and synchronous operation. Asynchronous Double Speed mode is controlled by the U2X bit in the UCTRLx2 register. The MASTER bit in UCTRLx2 register controls whether the clock source is internal (Master mode, output port) or external (Slave mode, input port). The XCK pin is only active when the USART operates in Synchronous or SPI mode. Table below contains equations for calculating the baud rate (in bps). | Operating Mode | Equation for Calculating Baud Rate | |----------------------------------------|----------------------------------------------------------| | Asynchronous Normal Mode (U2X=0) | Baud Rate = $\frac{\text{fSCLK}}{16(\text{UBAUDx} + 1)}$ | | Asynchronous Double Speed Mode (U2X=1) | Baud Rate = $\frac{\text{fSCLK}}{8(\text{UBAUDx} + 1)}$ | | Synchronous or SPI Master Mode | Baud Rate = $\frac{\text{fSCLK}}{2(\text{UBAUDx} + 1)}$ | Table 11.14 Equations for Calculating Baud Rate Register Setting ## 11.10.4 External Clock (XCK) External clocking is used by the synchronous or SPI slave modes of operation. External clock input from the XCK pin is sampled by a synchronization logic to remove meta-stability. The output from the synchronization logic must then pass through an edge detector before it can be used by the Transmitter and Receiver. This process introduces a two CPU clock period delay and the maximum frequency of the external XCK pin is limited by the following equation. $$fXCK = \frac{fSCLK}{4}$$ Where fXCK is the frequency of XCK and fSCLK is the frequency of main system clock (SCLK). ## 11.10.5 Synchronous mode Operation When synchronous or SPI mode is used, the XCK pin will be used as either clock input (slave) or clock output (master). The dependency between the clock edges and data sampling or data change is the same. The basic principle is that data input on RXD (MISO in SPI mode) pin is sampled at the opposite XCK clock edge of the edge in the data output on TXD (MOSI in SPI mode) pin is changed. The UCPOL bit in UCTRLx1 register selects which XCK clock edge is used for data sampling and which is used for data change. As shown in the figure below, when UCPOL is zero the data will be changed at XCK rising edge and sampled at XCK falling edge. Figure 11.35 Synchronous Mode XCKn Timing #### 11.10.6 Data format A serial frame is defined to be one character of data bits with synchronization bits (start and stop bits), and optionally a parity bit for error checking. The USART supports all 30 combinations of the following as valid frame formats. - 1 start bit - 5, 6, 7, 8 or 9 data bits - no, even or odd parity bit - 1 or 2 stop bits A frame starts with the start bit followed by the least significant data bit (LSB). Then the next data bits, up to a total of nine, are succeeding, ending with the most significant bit (MSB). If enabled the parity bit is inserted after the data bits, before the stop bits. A high to low transition on data pin is considered as start bit. When a complete frame is transmitted, it can be directly followed by a new frame, or the communication line can be set to an idle state. The idle means high state of data pin. The next figure shows the possible combinations of the frame formats. Bits inside brackets are optional. Figure 11.36 frame format 1 data frame consists of the following bits - Idle No communication on communication line (TxD/RxD) - St Start bit (Low) - Dn Data bits (0~8) - Parity bit ----- Even parity, Odd parity, No parity - Stop bit(s) ----- 1 bit or 2 bits The frame format used by the USART is set by the USIZE[2:0], UPM[1:0] and USBS bits in UCTRLx1 register. The Transmitter and Receiver use the same setting. ## 11.10.7 Parity bit The parity bit is calculated by doing an exclusive-or of all the data bits. If odd parity is used, the result of the exclusive-or is inverted. The parity bit is located between St + bits and first stop bit of a serial frame. Peven = Dn-1 ^ ... ^ D3 ^ D2 ^ D1 ^ D0 ^ 0 Podd = Dn-1 ^ ... ^ D3 ^ D2 ^ D1 ^ D0 ^ 1 Peven : Parity bit using even parity Podd : Parity bit using odd parity Dn : Data bit n of the character #### 11.10.8 USART Transmitter The USART Transmitter is enabled by setting the TXE bit in UCTRLx1 register. When the Transmitter is enabled, the normal port operation of the TXD pin is overridden by the serial output pin of USART. The baud-rate, operation mode and frame format must be setup once before doing any transmissions. If synchronous or SPI operation is used, the clock on the XCK pin will be overridden and used as transmission clock. If USART operates in SPI mode, SS pin is used as SS input pin in slave mode or can be configured as SS output pin in master mode. This can be done by setting SPISS bit in UCTRLx3 register. #### 11.10.8.1 Sending Tx data A data transmission is initiated by loading the transmit buffer (UDATAx register I/O location) with the data to be transmitted. The data written in transmit buffer is moved to the shift register when the shift register is ready to send a new frame. The shift register is loaded with the new data if it is in idle state or immediately after the last stop bit of the previous frame is transmitted. When the shift register is loaded with new data, it will transfer one complete frame at the settings of control registers. If the 9-bit characters are used in asynchronous or synchronous operation mode (USIZE[2:0]=7), the ninth bit must be written to the TX8 bit in UCTRLx3 register before loading transmit buffer (UDATA register). ## 11.10.8.2 Transmitter flag and interrupt The USART Transmitter has 2 flags which indicate its state. One is USART Data Register Empty (UDRE) and the other is Transmit Complete (TXC). Both flags can be used as interrupt sources. UDRE flag indicates whether the transmit buffer is ready to be loaded with new data. This bit is set when the transmit buffer is empty and cleared when the transmit buffer contains transmittion data which has not yet been moved into the shift register. And also this flag can be cleared by writing '0' to this bit position. Writing '1' to this bit position is not valid. When the Data Register Empty Interrupt Enable (UDRIE) bit in UCTRL2 register is set and the Global Interrupt is enabled, USART Data Register Empty Interrupt is generated while UDRE flag is set. The Transmit Complete (TXC) flag bit is set when the entire frame in the transmit shift register has been shifted out and there are no more data in the transmit buffer. The TXC flag is automatically cleared when the Transmit Complete Interrupt service routine is executed, or it can be cleared by writing '0' to TXC bit in USTAT register. When the Transmit Complete Interrupt Enable (TXCIE) bit in UCTRL2 register is set and the Global Interrupt is enabled, USART Transmit Complete Interrupt is generated while TXC flag is set. #### 11.10.8.3 Parity Generator The Parity Generator calculates the parity bit for the sending serial frame data. When parity bit is enabled (UPM[1]=1), the transmitter control logic inserts the parity bit between the bits and the first stop bit of the sending frame. ## 11.10.8.4 Disabling Transmitter Disabling the Transmitter by clearing the TXE bit will not become effective until ongoing transmission is completed. When the Transmitter is disabled, the TXD pin is used as normal General Purpose I/O (GPIO) or primary function pin. #### 11.10.9 USART Receiver The USART Receiver is enabled by setting the RXE bit in the UCTRLx1 register. When the Receiver is enabled, the normal pin operation of the RXD pin is overridden by the USART as the serial input pin of the Receiver. The baud-rate, mode of operation and frame format must be set before serial reception. If synchronous or SPI operation is used, the clock on the XCK pin will be used as transfer clock. If USART operates in SPI mode, SS pin is used as SS input pin in slave mode or can be configured as SS output pin in master mode. This can be done by setting SPISS bit in UCTRLx3 register. ## 11.10.9.1 Receiving Rx data When USART is in synchronous or asynchronous operation mode, the Receiver starts data reception when it detects a valid start bit (LOW) on RXD pin. Each bit after start bit is sampled at pre-defined baud-rate (asynchronous) or sampling edge of XCK (synchronous), and shifted into the receive shift register until the first stop bit of a frame is received. Even if there's 2nd stop bit in the frame, the 2nd stop bit is ignored by the Receiver. That is, receiving the first stop bit means that a complete serial frame is present in the receiver shift register and contents of the shift register are to be moved into the receive buffer. The receive buffer is read by reading the UDATAx register. If 9-bit characters are used (USIZE[2:0] = 7), the ninth bit is stored in the RX8 bit position in the UCTRLx3 register. The 9th bit must be read from the RX8 bit before reading the low 8 bits from the UDATAx register. Likewise, the error flags FE, DOR, PE must be read before reading the data from UDATAx register. This is because the error flags are stored in the same FIFO position of the receive buffer. ### 11.10.9.2 Receiver flag and interrupt The USART Receiver has one flag that indicates the Receiver state. The Receive Complete (RXC) flag indicates whether there are unread data present in the receive buffer. This flag is set when there are unread data in the receive buffer and cleared when the receive buffer is empty. If the Receiver is disabled (RXE=0), the receiver buffer is flushed and the RXC flag is cleared. When the Receive Complete Interrupt Enable (RXCIE) bit in the UCTRLx2 register is set and Global Interrupt is enabled, the USART Receiver Complete Interrupt is generated while RXC flag is set. The USART Receiver has three error flags which are Frame Error (FE), Data OverRun (DOR) and Parity Error (PE). These error flags can be read from the USTATx register. As data received are stored in the 2-level receive buffer, these error flags are also stored in the same position of receive buffer. So, before reading received data from UDATAX register, read the USTATx register first which contains error flags. The Frame Error (FE) flag indicates the state of the first stop bit. The FE flag is set when the stop bit was correctly detected as "1", and the FE flag is cleared when the stop bit was incorrect, ie detected as "0". This flag can be used for detecting out-of-sync conditions between data frames. The Data OverRun (DOR) flag indicates data loss due to a receive buffer full condition. A DOR occurs when the receive buffer is full, and another new data is present in the receive shift register which are to be stored into the receive buffer. After the DOR flag is set, all the incoming data are lost. To prevent data loss or clear this flag, read the receive buffer. The Parity Error (PE) flag indicates that the frame in the receive buffer had a Parity Error when received. If Parity Check function is not enabled (UPM[1]=0), the PE bit is always read "0". NOTE) The error flags related to receive operation are not used when USART is in SPI mode. ## 11.10.9.3 Parity Checker If Parity bit is enabled (UPM[1]=1), the Parity Checker calculates the parity of the data bits in incoming frame and compares the result with the parity bit from the received serial frame. ### 11.10.9.4 Disabling Receiver In contrast to Transmitter, disabling the Receiver by clearing RXE bit makes the Receiver inactive immediately. When the Receiver is disabled the Receiver flushes the receive buffer and the remaining data in the buffer is all reset. The RXD pin is not overridden the function of USART, so RXD pin becomes normal GPIO or primary function pin. #### 11.10.9.5 Asynchronous Data Reception To receive asynchronous data frame, the USART includes a clock and data recovery unit. The Clock Recovery logic is used for synchronizing the internally generated baud-rate clock to the incoming asynchronous serial frame on the RXD pin. The Data recovery logic samples incoming bits and low pass filters them, and this removes the noise of RXD pin. The next figure illustrates the sampling process of the start bit of an incoming frame. The sampling rate is 16 times the baud-rate for normal mode, and 8 times the baud rate for Double Speed mode (U2X=1). The horizontal arrows show the synchronization variation due to the asynchronous sampling process. Note that larger time variation is shown when using the Double Speed mode. Figure 11.37 Start bit Sampling When the Receiver is enabled (RXE=1), the clock recovery logic tries to find a high to low transition on the RXD line, the start bit condition. After detecting high to low transition on RXD line, the clock recovery logic uses samples 8,9, and 10 for Normal mode, and samples 4, 5, and 6 for Double Speed mode to decide if a valid start bit is received. If more than 2 samples have logical low level, it is considered that a valid start bit is detected and the internally generated clock is synchronized to the incoming data frame. And the data recovery can begin. The synchronization process is repeated for each start bit. As described above, when the Receiver clock is synchronized to the start bit, the data recovery can begin. Data recovery process is almost similar to the clock recovery process. The data recovery logic samples 16 times for each incoming bits for Normal mode and 8 times for Double Speed mode. And uses sample 8, 9, and 10 to decide data value for Normal mode, samples 4, 5, and 6 for Double Speed mode. If more than 2 samples have low levels, the received bit is considered to a logic 0 and more than 2 samples have high levels, the received bit is considered to a logic 1. The data recovery process is then repeated until a complete frame is received including the first stop bit. The decided bit value is stored in the receive shift register in order. Note that the Receiver only uses the first stop bit of a frame. Internally, after receiving the first stop bit, the Receiver is in idle state and waiting to find start bit. Figure 11.38 Sampling of Data and Parity bit The process for detecting stop bit is like clock and data recovery process. That is, if 2 or more samples of 3 center values have high level, correct stop bit is detected, else a Frame Error flag is set. After deciding first stop bit whether a valid stop bit is received or not, the Receiver enters into idle state and monitors the RXD line to check a valid high to low transition is detected (start bit detection). Figure 11.39 Stop bit Sampling and Next Start bit Sampling ### 11.10.10 SPI Mode The USART can be set to operate in industrial standard SPI compliant mode. The SPI mode has the following features. - Full duplex, three-wire synchronous data transfer - Master or Slave operation - Supports all four SPI modes of operation (mode0, 1, 2, and 3) - Selectable LSB first or MSB first data transfer - Double buffered transmit and receive - Programmable transmit bit rate When SPI mode is enabled (UMSEL[1:0]=3), the Slave Select (SS) pin becomes active low input in slave mode operation, or can be output in master mode operation if SPISS bit is set. Note that during SPI mode of operation, the pin RXD is renamed as MISO and TXD is renamed as MOSI for compatibility to other SPI devices. ### 11.10.10.1 SPI Clock formats and timing To accommodate a wide variety of synchronous serial peripherals from different manufacturers, the USART has a clock polarity bit (UCPOL) and a clock phase control bit (UCPHA) to select one of four clock formats for data transfers. UCPOL selectively insert an inverter in series with the clock. UCPHA selects one of two different clock phase relationships between the clock and data. Note that UCPHA and UCPOL bits in UCTRLx1 register have different meanings according to the UMSEL[1:0] bits which decides the operating mode of USART. Table below shows four combinations of UCPOL and UCPHA for SPI mode 0, 1, 2, and 3. | SPI Mode | UCPOL | UCPHA | Leading Edge | Trailing Edge | |----------|-------|-------|------------------|------------------| | 0 | 0 | 0 | Sample (Rising) | Setup (Falling) | | 1 | 0 | 1 | Setup (Rising) | Sample (Falling) | | 2 | 1 | 0 | Sample (Falling) | Setup (Rising) | | 3 | 1 | 1 | Setup (Falling) | Sample (Rising) | Table 11.15 CPOL Functionality Figure 11.40 SPI Clock Formats when UCPHA=0 When UCPHA=0, the slave begins to drive its MISO output with the first data bit value when SS goes to active low. The first XCK edge causes both the master and the slave to sample the data bit value on their MISO and MOSI inputs, respectively. At the second XCK edge, the USART shifts the second data bit value out to the MOSI and MISO outputs of the master and slave, respectively. Unlike the case of UCPHA=1, when UCPHA=0, the slave's SS input must go to its inactive high level between transfers. This is because the slave can prepare the first data bit when it detects falling edge of SS input. Figure 11.41 SPI Clock Formats when UCPHA=1 When UCPHA=1, the slave begins to drive its MISO output when SS goes active low, but the data is not defined until the first XCK edge. The first XCK edge shifts the first bit of data from the shifter onto the MOSI output of the master and the MISO output of the slave. The next XCK edge causes both the master and slave to sample the data bit value on their MISO and MOSI inputs, respectively. At the third XCK edge, the USART shifts the second data bit value out to the MOSI and MISO output of the master and slave respectively. When UCPHA=1, the slave's SS input is not required to go to its inactive high level between transfers. Because the SPI logic reuses the USART resources, SPI mode of operation is similar to that of synchronous or asynchronous operation. An SPI transfer is initiated by checking for the USART Data Register Empty flag (UDRE=1) and then writing a byte of data to the UDATA Register. In master mode of operation, even if transmission is not enabled (TXE=0), writing data to the UDATA register is necessary because the clock XCK is generated from transmitter block. ## 11.10.11 Register Map | Name | Address | Direction | Default | Description | |---------|---------|-----------|---------|---------------------------------------| | UCTRL01 | E2H | R/W | 00H | USART 0 Control 1 Register 0 | | UCTRL02 | E3H | R/W | 00H | USART 0 Control 2 Register 0 | | UCTRL03 | E4H | R/W | 00H | USART 0 Control 3 Register 0 | | UCTRL04 | 8FC0H | R/W | 00H | USART 0 Control 4 Register 0 | | FPCR0 | 8FC1H | R/W | 00H | USART 0 Floating Point Counter | | USTAT0 | E5H | R | 80H | USART Status Register 0 | | UBAUD0 | E6H | R/W | FFH | USART Baud Rate Generation Register 0 | | UDATA0 | E7H | R/W | FFH | USART Data Register 0 | | UCTRL11 | FAH | R/W | 00H | USART 1 Control 1 Register 1 | | UCTRL12 | FBH | R/W | 00H | USART 1 Control 2 Register 1 | | UCTRL13 | FCH | R/W | 00H | USART 1 Control 3 Register 1 | | UCTRL14 | 8FC8H | R/W | 00H | USART 1 Control 4 Register 0 | | FPCR1 | 8FC9H | R/W | 00H | USART 1 Floating Point Counter | | USTAT1 | FDH | R | 80H | USART Status Register 1 | | UBAUD1 | FEH | R/W | FFH | USART Baud Rate Generation Register 1 | | UDATA1 | FFH | R/W | FFH | USART Data Register 1 | Table 11.16 USART Register Map ## 11.10.12 USART Register Description USART module consists of USART Control 1 Register (UCTRLx1), USART Control 2 Register (UCTRLx2), USART Control 3 Register (UCTRLx3), USART Control 4 Register (UCTRLx4), USART Floating Point Counter (FPCRx), USART Status Register (USTATx), USART Data Register (UDATAx), and USART Baud Rate Generation Register (UBAUDx). #### 11.10.13 **Register Description for USART** ## UCTRLx1 (USART Control 1 Register) E2H, FAH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|------|------|--------|-----------------|-----------------|-------| | UMSEL1 | UMSEL0 | UPM1 | UPMO | USIZE2 | USIZE1<br>UDORD | USIZEO<br>UCPHA | UCPOL | | RW Initial value: 00H | 1 4 4 4 | | 1 4 4 4 | 1 4 4 4 | | 1 4 4 4 | 1444 | 1444 | 1444 | |---------|------------|-----------------------------|----------------------------------------|-------------------------------------|---------------------------------------------|-------------------------------------------------------|-----------------------------------------------------------------|----------------------------------------------------------------------| | | | | | | | | | | | UN | /ISEL[1:0] | Selects | operation n | node of L | JSART | | | | | | | UMSEL <sup>*</sup> | 1 UN | MSEL0 | Operating I | Mode | | | | | | 0 | 0 | | Asynchron | ous Mode (Nor | mal Uart) | | | | | 0 | 1 | | Synchrono | us Mode (Sync | hronous Uart) | | | | | 1 | 0 | | Reserved | | | | | | | 1 | 1 | | SPI Mode | | | | | UF | PM[1:0] | Selects | Parity Gene | eration a | nd Check m | ethods | | | | | | UPM1 | UPM0 | Parity | / mode | | | | | | | 0 | 0 | No Pa | arity | | | | | | | 0 | 1 | Rese | rved | | | | | | | 1 | 0 | Even | Parity | | | | | | | 1 | 1 | Odd I | Parity | | | | | US | SIZE[2:0] | When in bits in fra | | nous or s | synchronous | mode of oper | ation, selects th | e length of data | | | | USIZE<br>2 | USIZE<br>1 | USIZE | Data le | ngth | | | | | | 0 | 0 | 0 | 5-bit | | | | | | | 0 | 0 | 1 | 6-bit | | | | | | | 0 | 1 | 0 | 7-bit | | | | | | | 0 | 1 | 1 | 8-bit | | | | | | | 1 | 0 | 0 | Reserv | ed | | | | | | 1 | 0 | 1 | Reserv | ed | | | | | | 1 | 1 | 0 | Reserv | ed | | | | | | 1 | 1 | 1 | 9-bit | | | | | UE | OORD | of the o<br>transmit<br>0 L | lata byte is | | | | | to one the MSB<br>he data byte is | | UC | CPOL | Selects | polarity of ) | CK in sy | nchronous ( | or SPI mode | | | | | ) | | - | - | | O change @Fal | ling Edge | | | | | | - | | | D change @ R | | | | UC | CPHA | This bit selects Leading | is in the sa<br>one of two<br>edge mea | ame bit p<br>clock fo<br>ns first X | cosition with<br>rmats for di<br>CK edge ar | USIZE0. In SI<br>fferent kinds of<br>nd trailing edge | PI mode, along<br>synchronous se<br>means 2 <sup>nd</sup> or la | with UCPOL bit, erial peripherals. st clock edge of ceive bit, Setup | XCK in one XCK pulse. And Sample means detecting of incoming receive bit, Setup means preparing transmit data. | UCPOL | UCPHA | Leading Edge | Trailing Edge | |-------|-------|------------------|------------------| | 0 | 0 | Sample (Rising) | Setup (Falling) | | 0 | 1 | Setup (Rising) | Sample (Falling) | | 1 | 0 | Sample (Falling) | Setup (Rising) | | 1 | 1 | Setup (Falling) | Sample (Rising) | # UCTRLx2 (USART Control 2 Register) E3H, FBH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------------|---------|------------------|-------------------|--------------------|-----------------|------------------|-----------------| | UDRIE | TXCIE | RXCIE | WAKEIE | TXE | RXE | USARTEN | U2X | | RW | Initial value: 00H | I | | | | | | | | | UDRIE | Interru | pt enable bit for | USART Data Re | gister Empty. | | | | | | 0 | Interrupt from | UDRE is inhibite | d (use polling) | | | | | | 1 | When UDRE is | s set, request an | interrupt | | | | | TXCIE | Interru | pt enable bit for | Transmit Comple | ete. | | | | | | 0 | Interrupt from | TXC is inhibited | (use polling) | | | | | | 1 | When TXC is | set, request an ir | nterrupt | | | | | RXCIE | Interru | pt enable bit for | Receive Comple | te | | | | | | 0 | Interrupt from | RXC is inhibited | (use polling) | | | | | | 1 | When RXC is | set, request an ir | nterrupt | | | | | WAKEIE | | | | | mode. When de | | | | | | • | | • | quested to wake- | up system. | | | | 0 | • | Wake is inhibited | | | | | | | 1 | | s set, request an | interrupt | | | | | TXE | | es the transmitte | | | | | | | | 0 | Transmitter is | | | | | | | | 1 | Transmitter is | | | | | | | RXE | | es the receiver u | | | | | | | | 0 | Receiver is dis | | | | | | | | 1 | Receiver is en | | | | | | | USARTEN | | | le by supplying c | | | | | | | 0 | | abled (clock is ha | lted) | | | | | | 1 | USART is ena | | | | | | | U2X | This bi<br>rate. | t only has effec | t for the asynchi | ronous operatio | n and selects re | ceiver sampling | | | | 0 | Normal asynch | nronous operatio | n | | | | | | 1 | Double Speed | asynchronous o | peration | | | | | | | | | | | | #### UCTRLx3 (USART Control 3 Register) E4H, FCH DISXCK | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|--------|-------|---|------|-----|-----| | MASTER | LOOPS | DISXCK | SPISS | - | USBS | TX8 | RX8 | | RW | RW | RW | RW | - | RW | RW | RW | Initial value: 00H MASTER Selects master or slave in SPI or Synchronous mode operation and controls the direction of XCK pin. O Slave mode operation and XCK is input pin. 1 Master mode operation and XCK is output pin LOOPS Controls the Loop Back mode of USART, for test mode Normal operationLoop Back mode In Synchronous mode of operation, selects the waveform of XCK output. 0 XCK is free-running while USART is enabled in synchronous master mode. 1 XCK is active while any frame is on transferring. SPISS Controls the functionality of SS pin in master SPI mode. 0 SS pin is normal GPIO or other primary function 1 SS output to other slave device USBS Selects the length of stop bit in Asynchronous or Synchronous mode of operation. 0 1 Stop bit1 2 Stop bit TX8 The ninth bit of data frame in Asynchronous or Synchronous mode of operation. Write this bit first before loading the UDATA register. MSB (9<sup>th</sup> bit) to be transmitted is '0' 1 MSB (9<sup>th</sup> bit) to be transmitted is '1' RX8 The ninth bit of data frame in Asynchronous or Synchronous mode of operation. Read this bit first before reading the receive buffer. 0 MSB (9<sup>th</sup> bit) received is '0' 1 MSB (9th bit) received is '1' #### UCTRLx4 (USART Control 4 Register) 8FC0H, 8FC8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|--------|---------|--------| | ı | - | - | - | - | FPCREN | AOVSSEL | AOVSEN | | - | - | - | - | - | RW | RW | RW | Initial value: 00H FPCREN Enable baudrate compensation 0 Disable1 Enable AOVSSEL Select additional oversampling rates 0 Select X131 Select X4 AOVSEN Enable additional oversampling rates selection 0 Disable1 Enable ## FPCRx (USART Floating Point Counter) 8FC1H, 8FC9H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | FPCR0 | RW | RW | RW | RW | RW- | RW | RW | RW | Initial value: 00H FPCR[7:0] USART Floating Point Counter 8-bit floating point counter ### **USTATx (USART Status Register) E5H** | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|-----|-----|------|---------|-----|----|----| | UDRE | TXC | RXC | WAKE | SOFTRST | DOR | FE | PE | | RW | RW | RW | RW | RW | R | R | R | Initial value: 80H **UDRE** The UDRE flag indicates if the transmit buffer (UDATA) is ready to be loaded with new data. If UDRE is '1', it means the transmit buffer is empty and can hold one or two new data. This flag can generate an UDRE interrupt. Writing '0' to this bit position will clear UDRE flag. - 0 Transmit buffer is not empty. - 1 Transmit buffer is empty. TXC This flag is set when the entire frame in the transmit shift register has been shifted out and there is no new data currently present in the transmit buffer. This flag is automatically cleared when the interrupt service routine of a TXC interrupt is executed. It is also cleared by writing '0' to this bit position. This flag can generate a TXC interrupt. - 0 Transmission is ongoing. - 1 Transmit buffer is empty and the data in transmit shift register are shifted out completely. **RXC** This flag is set when there are unread data in the receive buffer and cleared when all the data in the receive buffer are read. The RXC flag can be used to generate a RXC interrupt. - 0 There is no data unread in the receive buffer - 1 There are more than 1 data in the receive buffer WAKE This flag is set when the RX pin is detected low while the CPU is in stop mode. This flag can be used to generate a WAKE interrupt. This bit is set only when in asynchronous mode of operation. $^{\mathsf{NOTE}}$ - No WAKE interrupt is generated. - 1 WAKE interrupt is generated. **SOFTRST** This is an internal reset and only has effect on USART. Writing '1' to this bit initializes the internal logic of USART and is auto cleared. - 0 No operation - 1 Reset USART DOR This bit is set if a Data OverRun occurs. While this bit is set, the incoming data frame is ignored. This flag is valid until the receive buffer is read. - 0 No Data OverRun - 1 Data OverRun detected FΕ This bit is set if the first stop bit of next character in the receive buffer is detected as '0'. This bit is valid until the receive buffer is read. - 0 No Frame Error - 1 Frame Error detected PΕ This bit is set if the next character in the receive buffer has a Parity Error when received while Parity Checking is enabled. This bit is valid until the receive buffer is read. - 0 No Parity Error - 1 Parity Error detected #### NOTE) 2. When the WAKE function of USART is used as a release source from STOP mode, it is required to clear this bit in the RX interrupt service routine. Else the device will not wake-up from STOP mode again by the change of RX pin. ## UBAUDx (USART Baud-Rate Generation Register) E6H, FEH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | UBAUD7 | UBAUD6 | UBAUD5 | UBAUD4 | UBAUD3 | UBAUD2 | UBAUD1 | UBAUD0 | | RW UBAUD [7:0] The value in this register is used to generate internal baud rate in asynchronous mode or to generate XCK clock in synchronous or SPI mode. To prevent malfunction, do not write '0' in asynchronous mode, and do not write '0' or '1' in synchronous or SPI mode. ## UDATAx (USART Data Register) E7H, FFH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|---------|---------| | UDATA7 | UDATA6 | UDATA5 | UDATA4 | UDATA3 | UDATA2 | UDATA 1 | UDATA 0 | | RW Initial value: FFH Initial value: FFH UDATA [7:0] The USART Transmit Buffer and Receive Buffer share the same I/O address with this DATA register. The Transmit Data Buffer is the destination for data written to the UDATA register. Reading the UDATA register returns the contents of the Receive Buffer. Write this register only when the UDRE flag is set. In SPI or synchronous master mode, write this register even if TX is not enabled to generate clock, XCK. ## 11.10.14 Baud Rate setting (example) | | | fOSC=1 | .00MHz | | | fOSC=1. | 8432MHz | | | fOSC=2.00MHz | | | | |--------------|-------|---------|---------|--------|-------|---------|----------|-------|-------|--------------|---------|-------|--| | Baud<br>Rate | U2 | X=0 | U2 | X=1 | U2 | X=0 | U2 | X=1 | U2X | X=0 | U2X=1 | | | | Nate | UBAUD | ERROR | UBAUD | ERROR | UBAUD | ERROR | UBAUD | ERROR | UBAUD | ERROR | UBAUD | ERROR | | | 2400 | 25 | 0.2% | 51 | 0.2% | 47 | 0.0% | 95 | 0.0% | 51 | 0.2% | 103 | 0.2% | | | 4800 | 12 | 0.2% | 25 | 0.2% | 23 | 0.0% | 47 | 0.0% | 25 | 0.2% | 51 | 0.2% | | | 9600 | 6 | -7.0% | 12 | 0.2% | 11 | 0.0% | 23 | 0.0% | 12 | 0.2% | 25 | 0.2% | | | 14.4K | 3 | 8.5% | 8 | -3.5% | 7 | 0.0% | 15 | 0.0% | 8 | -3.5% | 16 | 2.1% | | | 19.2K | 2 | 8.5% | 6 | -7.0% | 5 | 0.0% | 11 | 0.0% | 6 | -7.0% | 12 | 0.2% | | | 28.8K | 1 | 8.5% | 3 | 8.5% | 3 | 0.0% | 7 | 0.0% | 3 | 8.5% | 8 | -3.5% | | | 38.4K | 1 | -18.6% | 2 | 8.5% | 2 | 0.0% | 5 | 0.0% | 2 | 8.5% | 6 | -7.0% | | | 57.6K | - | - | 1 | 8.5% | 1 | -25.0% | 3 | 0.0% | 1 | 8.5% | 3 | 8.5% | | | 76.8K | - | - | 1 | -18.6% | 1 | 0.0% | 2 | 0.0% | 1 | -18.6% | 2 | 8.5% | | | 115.2K | - | - | - | - | - | - | 1 | 0.0% | - | - | 1 | 8.5% | | | 230.4K | - | - | - | - | - | - | - | - | - | - | - | - | | | | | fOSC=3. | 6864MHz | | | fOSC=4 | 1.00MHz | | | fOSC=7.3 | 3728MHz | | | | Baud<br>Rate | U2 | X=0 | U2 | X=1 | U2 | X=0 | U2 | X=1 | U2 | X=0 | U2 | X=1 | | | | UBAUD | ERROR | UBAUD | ERROR | UBAUD | ERROR | UBAUD | ERROR | UBAUD | ERROR | UBAUD | ERROR | | | 2400 | 95 | 0.0% | 191 | 0.0% | 103 | 0.2% | 207 | 0.2% | 191 | 0.0% | - | - | | | 4800 | 47 | 0.0% | 95 | 0.0% | 51 | 0.2% | 103 | 0.2% | 95 | 0.0% | 191 | 0.0% | | | 9600 | 23 | 0.0% | 47 | 0.0% | 25 | 0.2% | 51 | 0.2% | 47 | 0.0% | 95 | 0.0% | | | 14.4K | 15 | 0.0% | 31 | 0.0% | 16 | 2.1% | 34 | -0.8% | 31 | 0.0% | 63 | 0.0% | | | 19.2K | 11 | 0.0% | 23 | 0.0% | 12 | 0.2% | 25 | 0.2% | 23 | 0.0% | 47 | 0.0% | | | 28.8K | 7 | 0.0% | 15 | 0.0% | 8 | -3.5% | 16 | 2.1% | 15 | 0.0% | 31 | 0.0% | | | 38.4K | 5 | 0.0% | 11 | 0.0% | 6 | -7.0% | 12 | 0.2% | 11 | 0.0% | 23 | 0.0% | | | 57.6K | 3 | 0.0% | 7 | 0.0% | 3 | 8.5% | 8 | -3.5% | 7 | 0.0% | 15 | 0.0% | | | 76.8K | 2 | 0.0% | 5 | 0.0% | 2 | 8.5% | 6 | -7.0% | 5 | 0.0% | 11 | 0.0% | | | 115.2K | 1 | 0.0% | 3 | 0.0% | 1 | 8.5% | 3 | 8.5% | 3 | 0.0% | 7 | 0.0% | | | 230.4K | - | - | 1 | 0.0% | - | - | 1 | 8.5% | 1 | 0.0% | 3 | 0.0% | | | 250K | - | - | 1 | -7.8% | - | - | 1 | 0.0% | 1 | -7.8% | 3 | -7.8% | | | 0.5M | - | - | - | - | - | - | - | - | - | - | 1 | -7.8% | | | | | fOSC=8 | 3.00MHz | | | fOSC=11 | .0592MHz | | | fOSC=14. | 7456MHz | | | | Baud<br>Rate | U2 | X=0 | U2 | X=1 | U2 | X=0 | U2 | X=1 | U2 | X=0 | U2 | X=1 | | | rate | UBAUD | ERROR | UBAUD | ERROR | UBAUD | ERROR | UBAUD | ERROR | UBAUD | ERROR | UBAUD | ERROR | | | 2400 | 207 | 0.2% | - | - | - | - | - | - | - | - | - | - | | | 4800 | 103 | 0.2% | 207 | 0.2% | 143 | 0.0% | - | - | 191 | 0.0% | n) | - | | | 9600 | 51 | 0.2% | 103 | 0.2% | 71 | 0.0% | 143 | 0.0% | 95 | 0.0% | 191 | 0.0% | | | 14.4K | 34 | -0.8% | 68 | 0.6% | 47 | 0.0% | 95 | 0.0% | 63 | 0.0% | 127 | 0.0% | | | 19.2K | 25 | 0.2% | 51 | 0.2% | 35 | 0.0% | 71 | 0.0% | 47 | 0.0% | 95 | 0.0% | | | 28.8K | 16 | 2.1% | 34 | -0.8% | 23 | 0.0% | 47 | 0.0% | 31 | 0.0% | 63 | 0.0% | | | 38.4K | 12 | 0.2% | 25 | 0.2% | 17 | 0.0% | 35 | 0.0% | 23 | 0.0% | 47 | 0.0% | | | 57.6K | 8 | -3.5% | 16 | 2.1% | 11 | 0.0% | 23 | 0.0% | 15 | 0.0% | 31 | 0.0% | | | 76.8K | 6 | -7.0% | 12 | 0.2% | 8 | 0.0% | 17 | 0.0% | 11 | 0.0% | 23 | 0.0% | | | 115.2K | 3 | 8.5% | 8 | -3.5% | 5 | 0.0% | 11 | 0.0% | 7 | 0.0% | 15 | 0.0% | | | 230.4K | 1 | 8.5% | 3 | 8.5% | 2 | 0.0% | 5 | 0.0% | 3 | 0.0% | 7 | 0.0% | | | 250K | 1 | 0.0% | 3 | 0.0% | 2 | -7.8% | 5 | -7.8% | 3 | -7.8% | 6 | 5.3% | | | 0.5M | - | - | 1 | 0.0% | - | - | 2 | -7.8% | 1 | -7.8% | 3 | -7.8% | | | 1M | 1 | - | - | - | - | - | - | - | - | I . | 1 | -7.8% | | Table 11.17 Examples of UBAUD Settings for Commonly Used Oscillator Frequencies #### 11.10.15 **0% Error Baud Rate** This USART system supports the floating point counter logic for the 0% error of baud rate. By using the 8bits floating point counter logic, the cumulative error to below the decimal point can be removed. The floating point counter value is defined by baud rate error. In the baud rate formula, BAUD is presented the integer count value. For example, If you want to use the 57600 baud rate (fXIN = 16MHz), a calculated integer count value must be 16.36 value (BAUD+1 = $16000000/(16 \times 57600) = 17.36$ ). Here, BAUD which can be set is the nearest big integer number 17. To realize 0% error of baud rate, floating point counter value must be 164 ((17-16.36) x 256 = 164). Namely you have to write the 164(decimal number) in USART\_FPCR and 17(decimal number) in USART\_BAUD. ## 11.11 SPI #### **11.11.1 Overview** There is Serial Peripheral Interface (SPI) one channel in A97C450. The SPI allows synchronous serial data transfer between the external serial devices. It can do Full-duplex communication by 4-wire (MOSI, MISO, SCK, SS), support Master/Slave mode, can select serial clock (SCK) polarity, phase and whether LSB first data transfer or MSB first data transfer. ## 11.11.2 Block Diagram Figure 11.42 SPI Block Diagram ## 11.11.3 Data Transmit / Receive Operation User can use SPI for serial data communication by following step - 1. Select SPI operation mode(master/slave, polarity, phase) by control register SPICR. - 2. When the SPI is configured as a Master, it selects a Slave by SS signal (active low). When the SPI is configured as a Slave, it is selected by SS signal incoming from Master - 3. When the user writes a byte to the data register SPIDR, SPI will start an operation. - 4. In this time, if the SPI is configured as a Master, serial clock will come out of SCK pin. And Master shifts the eight bits into the Slave (transmit), Slave shifts the eight bits into the Master at the same time (receive). If the SPI is configured as a Slave, serial clock will come into SCK pin. And Slave shifts the eight bits into the Master (transmit), Master shifts the eight bits into the Slave at the same time (receive). - 5. When transmit/receive is done, TCIR (Transmit Complete or Interrupt Request) bit will be set. If the SPI interrupt is enabled, an interrupt is requested. And TCIR bit is cleared by hardware when executing the corresponding interrupt. If SPI interrupt is disable, TCIR bit is cleared when user read the status register SPISR, and then access (read/write) the data register SPIDR. #### NOTE) If you want to use both transmit and receive, set the TXENA, RXENA bit of SPISR, and if user want to use only either transmit or receive, clear the TXENA or RXENA. In this case, user can use disabled pin by GPIO freely. ### 11.11.4 SS pin function - When the SPI is configured as a Slave, the SS pin is always input. If LOW signal comes into SS pin, the SPI logic is active. And if 'HIGH' signal comes into SS pin, the SPI logic is stop. In this time, SPI logic will be reset, and invalidated any received data. - 2. When the SPI is configured as a Master, the user can select the direction of the SS pin by port direction register (PxIO[x]). If the SS pin is configured as an output, user can use general GPIO output mode. If the SS pin is configured as an input, 'HIGH' signal must come into SS pin to guarantee Master operation. If 'LOW' signal comes into SS pin, the SPI logic interprets this as another master selecting the SPI as a slave and starting to send data to it. To avoid bus contention, MS bit of SPICR will be cleared and the SPI becomes a Slave and then, TCIR bit of SPISR will be set, and if the SPI interrupt is enabled, an interrupt is requested. #### NOTE) - When the SS pin is configured as an output at Master mode, SS pin's output value is defined by user's software (PxDA[x]). Before SPICR setting, the direction of SS pin must be defined - If you don't need to use SS pin, clear the SSENA bit of SPISR. So, you can use disabled pin by GPIO freely. In this case, SS signal is driven by 'HIGH' or 'LOW' internally. In other words, master is 'HIGH', salve is 'LOW' - When SS pin is configured as input(master or slave), if 'HIGH' signal come into SS pin, this flag bit will be set at the SS rising time. And you can clear it by writing '0'. ## 11.11.5 Timing Waveform Figure 11.43 SPI Transmit/Receive Timing Diagram at CPHA = 0 Figure 11.44 SPI Transmit/Receive Timing Diagram at CPHA = 1 ## 11.11.6 Register Map | Name | Address | Direction | Default | Description | |--------|---------|-----------|---------|------------------------| | SPICR0 | D8H | R/W | 0H | SPI Control Register 0 | | SPIDR0 | D9H | R/W | 0H | SPI Data Register 0 | | SPISR0 | D1H | - | 0H | SPI Status Register 0 | | SPICR1 | E8H | R/W | 0H | SPI Control Register 1 | | SPIDR1 | E9H | R/W | 0H | SPI Data Register 1 | | SPISR1 | E1H | - | 0H | SPI Status Register 1 | Table 11.18 SPI Register Map ## 11.11.7 SPI Register description The SPI Register consists of SPI Control Register (SPICR), SPI Status Register (SPISR) and SPI Data Register (SPIDR) ## 11.11.8 Register Description for SPI ## SPICRn (SPI Control Register): D8H/E8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------|---------|---------|-------------------|------------------|---------------------|------------------|---------------------| | SPIEN | FLSB | MS | CPOL | CPHA | DSCR | SCR1 | SCR0 | | RW | Initial value: 00 | DH | | | | | | | | | SPIEN | This bi | t controls the SI | PI operation | | | | | | SITEN | 0 | SPI Disable | . 000.0 | | | | | | | 1 | SPI Enable | | | | | | | FLSB | This bi | t selects the dat | ta transmission | sequence | | | | | 1 200 | 0 | MSB First | | • | | | | | | 1 | LSB First | | | | | | | MS | This bi | t selects whether | er Master or Sla | ave mode | | | | | | 0 | Slave mode | | | | | | | | 1 | Master mode | | | | | | | CPOL | These | two bits control | the serial clock | (SCK) mode | | | | | CPHA | Clock I | Polarity (CPOL) | bit determine S | SCK's value at idle | e mode | | | | | Clock | Phase (CPHA) | bit determine if | data is sampled | on the leading o | or trailing edge of | | | | | Refer to Figure ( | 0-32, Figure 0-3 | 33 | | | | | | CPOL | CPHA | Leading E | - | g Edge | | | | | 0 | 0 | Sample (R | | (Falling) | | | | | 0 | 1 | Setup (Ris | • | e (Falling) | | | | | 1 | 0 | Sample (F | • | (Rising) | | | | | 1 | 1 | Setup (Fal | • | e (Rising) | | | | DSCR | | | | | | a Master. When | | | SCR[2:0 | 4 | | | doubled in Master | mode. | | | | | | in system clock | - | - | | | | | | DSCR | | | CK frequency | | | | | | 0 | 0 | 0 fx | | | | | | | 0 | 0 | | /16 | | | | | | 0 | 1 | _ | /64<br>/4.28 | | | | | | 0<br>1 | 1 | 1 fx<br>0 fx | /128 | | | | | | 1 | 0<br>0 | | | | | | | | 1 | _ | 1 fx | /8<br>/32 | | | | | | 1 | 1<br>1 | | /32<br>/64 | | | | | | 1 | ı | ı TX | /0 <del>4</del> | | | ### SPIDRn (SPI Data Register): D9H/E9H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | SPIDR7 | SPIDR6 | SPIDR5 | SPIDR4 | SPIDR3 | SPIDR2 | SPIDR1 | SPIDR0 | | RW Initial value: 00H SPIDR [7:0] SPI data register. Although you only use reception, user must write any data in here to start the SPI operation. ## SPISRn (SPI Status Register): D1H/E1H SS\_HIGH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------|--------|-------------------------------|-------------------------------|-------------------------------------------------------------------------------|------------------|-------------------|-------------------| | TCIR | WCOL | SS_HIGH | - | TWOPIN | SSENA | TXENA | RXENA | | R | R | RW | - | RW | RW | RW | RW | | Initial value : 0 | 0H | | | | | | | | | TCIR | And TCIR bit If SPI interrupt | is cleared by is disable, TCl | e SPI interrupt is<br>hardware when<br>IR bit is cleared<br>I/write) the data | | | | | | | 0 | Interrupt clear | ed | | | | | | | 1 | Transmission | Complete and In | terrupt Request | ed | | | | 14/001 | This hi | it is set if the da | ata register SPIF | ORO is written d | uring a data trai | nefer This hit is | WCOL This bit is set if the data register SPIDR0 is written during a data transfer. This bit is cleared when user read the status register SPISR0, and then access (read/write) the data register SPIDR0. No collisionWrite Collision When SS pin is configured as input(master or slave), if 'HIGH' signal come into SS pin, this flag bit will be set at the SS rising time. And you can clear it by writing '0'. You can write only zero. Flag is cleared Flag is set TWOPIN This bit controls the 2 pin operation. 0 Disable1 Enable SSENA This bit controls the SS pin operation 0 Disable1 Enable TXENA This bit controls a data transfer operation 0 Disable1 Enable RXENA This bit controls a data reception operation 0 Disable1 Enable Note that if the MS is set to '0', when TWOPIN is set to '0', port 03 is set to MISO and if the MS is set to '0', when TWOPIN is set to '1', port 02 is set to MOSI. But if the MS is set to '1', when TWOPIN is set to '0', port 03 is set to MOSI and if the MS is set to '1', when TWOPIN is set to '1', port 02 is set to MISO. ## 11.12 I2C #### 11.12.1 Overview The I2C is one of industrial standard serial communication protocols, and which uses 2 bus lines Serial Data Line (SDA) and Serial Clock Line (SCL) to exchange data. Because both SDA and SCL lines are open-drain output, each line needs pull-up resistor. The features are as shown below. - Compatible with I2C bus standard - Multi-master operation - Up to 400kHz data transfer speed - 7-bit address - Support two slave addresses - Both master and slave operation - Bus busy detection ## 11.12.2 Block Diagram Figure 11.45 I2C Block Diagram #### 11.12.3 I2C bit Transfer The data on the SDA line must be stable during HIGH period of the clock, SCL. The HIGH or LOW state of the data line can only change when the clock signal on the SCL line is LOW. The exceptions are START(S), repeated START(Sr) and STOP(P) condition where data line changes when clock line is high. Figure 11.46 Bit Transfer on the I2C-Bus #### 11.12.4 Start / Repeated Start / Stop One master can issue a START (S) condition to notice other devices connected to the SCL, SDA lines that it will use the bus. A STOP (P) condition is generated by the master to release the bus lines so that other devices can use it. A high to low transition on the SDA line while SCL is high defines a START (S) condition. A low to high transition on the SDA line while SCL is high defines a STOP (P) condition. START and STOP conditions are always generated by the master. The bus is considered to be busy after START condition. The bus is considered to be free again after STOP condition, ie, the bus is busy between START and STOP condition. If a repeated START condition (Sr) is generated instead of STOP condition, the bus stays busy. So, the START and repeated START conditions are functionally identical. Figure 11.47 START and STOP Condition #### 11.12.5 Data Transfer Every byte put on the SDA line must be 8-bit long. The number of bytes that can be transmitted per transfer is unlimited. Each byte has to be followed by an acknowledge bit. Data is transferred with the most significant bit (MSB) first. If a slave can't receive or transmit another complete byte of data until it has performed some other function, it can hold the clock line SCL LOW to force the master into a wait state. Data transfer then continues when the slave is ready for another byte of data and releases clock line SCL. Figure 11.48 STOP or Repeated START Condition ## 11.12.6 Acknowledge The acknowledge related clock pulse is generated by the master. The transmitter releases the SDA line (HIGH) during the acknowledge clock pulse. The receiver must pull down the SDA line during the acknowledge clock pulse so that it remains stable LOW during the HIGH period of this clock pulse. When a slave is addressed by a master (Address Packet), and if it is unable to receive or transmit because it's performing some real time function, the data line must be left HIGH by the slave. And also, when a slave addressed by a master is unable to receive more data bits, the slave receiver must release the SDA line (Data Packet). The master can then generate either a STOP condition to abort the transfer, or a repeated START condition to start a new transfer. If a master receiver is involved in a transfer, it must signal the end of data to the slave transmitter by not generating an acknowledge on the last byte that was clocked out of the slave. The slave transmitter must release the data line to allow the master to generate a STOP or repeated START condition. Figure 11.49 Acknowledge on the I2C-Bus ## 11.12.7 Synchronization / Arbitration Clock synchronization is performed by using the wired-AND connection of I2C interfaces to the SCL line. This means that a HIGH to LOW transition on the SCL line will cause the devices concerned to start counting off their LOW period and it will hold the SCL line in that state until the clock HIGH state is reached. However the LOW to HIGH transition of this clock may not change the state of the SCL line if another clock is still within its LOW period. In this way, a synchronized SCL clock is generated with its LOW period determined by the device with the longest clock LOW period, and its HIGH period determined by the one with the shortest clock HIGH period. A master may start a transfer only if the bus is free. Two or more masters may generate a START condition. Arbitration takes place on the SDA line, while the SCL line is at the HIGH level, in such a way that the master which transmits a HIGH level, while another master is transmitting a LOW level will switch off its DATA output state because the level on the bus doesn't correspond to its own level. Arbitration continues for many bits until a winning master gets the ownership of I2C bus. Its first stage is comparison of the address bits. Figure 11.50 Clock Synchronization during Arbitration Procedure Figure 11.51 Arbitration Procedure of Two Masters ### 11.12.8 Operation The I2C is byte-oriented and interrupt based. Interrupts are issued after all bus events except for a transmission of a START condition. Because the I2C is interrupt based, the application software is free to execute other operations during a I2C byte transfer. Note that when a I2C interrupt is generated, IIF flag in I2CMR register is set, it is cleared by writing an arbitrary value to I2CSR. When I2C interrupt occurs, the SCL line is hold LOW until writing any value to I2CSR. When the IIF flag is set, the I2CSR contains a value indicating the current state of the I2C bus. According to the value in I2CSR, software can decide what to do next. I2C can operate in 4 modes by configuring master/slave, transmitter/receiver. The operating mode is configured by a winning master. A more detailed explanation follows below. #### 11.12.8.1 Master Transmitter To operate I2C in master transmitter, follow the recommended steps below. - 1. Enable I2C by setting IICEN bit in I2CMR. This provides main clock to the peripheral. - 2. Load SLA+W into the I2CDR where SLA is address of slave device and W is transfer direction from the viewpoint of the master. For master transmitter, W is '0'. Note that I2CDR is used for both address and data. - 3. Configure baud rate by writing desired value to both I2CSCLLR and I2CSCLHR for the Low and High period of SCL line. - Configure the I2CSDAHR to decide when SDA changes value from falling edge of SCL. If SDA should change in the middle of SCL LOW period, load half the value of I2CSCLLR to the I2CSDAHR. - 5. Set the START bit in I2CMR. This transmits a START condition. And also configure how to handle interrupt and ACK signal. When the START bit is set, 8-bit data in I2CDR is transmitted out according to the baud-rate. - 6. This is ACK signal processing stage for address packet transmitted by master. When 7-bit address and 1-bit transfer direction is transmitted to target slave device, the master can know whether the slave acknowledged or not in the 9th high period of SCL. If the master gains bus mastership, I2C generates GCALL interrupt regardless of the reception of ACK from the slave device. When I2C loses bus mastership during arbitration process, the MLOST bit in I2CSR is set, and I2C waits in idle state or can be operate as an addressed slave. To operate as a slave when the MLSOT bit in I2CSR is set, the ACKEN bit in I2CMR must be set and the received 7-bit address must equal to the SLA bits in I2CSAR. In this case I2C operates as a slave transmitter or a slave receiver (go to appropriate section). In this stage, I2C holds the SCL LOW. This is because to decide whether I2C continues serial transfer or stops communication. The following steps continue assuming that I2C does not lose mastership during first data transfer. I2C (Master) can choose one of the following cases regardless of the reception of ACK signal from slave. 1) Master receives ACK signal from slave, so continues data transfer because slave can receive more data from master. In this case, load data to transmit to I2CDR. - 2) Master stops data transfer even if it receives ACK signal from slave. In this case, set the STOP bit in I2CMR. - 3) Master transmits repeated START condition with not checking ACK signal. In this case, load SLA+R/W into the I2CDR and set START bit in I2CMR. After doing one of the actions above, write arbitrary value to I2CSR to release SCL line. In case of 1), move to step 7. In case of 2), move to step 9 to handle STOP interrupt. In case of 3), move to step 6 after transmitting the data in I2CDR and if transfer direction bit is '1' go to master receiver section. - 7. 1-byte of data is being transmitted. During data transfer, bus arbitration continues. - 8. This is ACK signal processing stage for data packet transmitted by master. I2C holds the SCL as Low. When I2C loses bus mastership while transmitting data arbitrating other masters, the MLOST bit in I2CSR is set. If then, I2C waits in idle state. When the data in I2CDR is transmitted completely, I2C generates TEND interrupt. I2C can choose one of the following cases regardless of the reception of ACK signal from slave. - 1) Master receives ACK signal from slave, so continues data transfer because slave can receive more data from master. In this case, load data to transmit to I2CDR. - 2) Master stops data transfer even if it receives ACK signal from slave. In this case, set the STOP bit in I2CMR. - 3) Master transmits repeated START condition with not checking ACK signal. In this case, load SLA+R/W into the I2CDR and set the START bit in I2CMR. After doing one of the actions above, write arbitrary value to I2CSR to release SCL line. In case of 1), move to step 7. In case of 2), move to step 9 to handle STOP interrupt. In case of 3), move to step 6 after transmitting the data in I2CDR, and if transfer direction bit is '1' go to master receiver section. 9. This is the final step for master transmitter function of I2C, handling STOP interrupt. The STOP bit indicates that data transfer between master and slave is over. To clear I2CSR, write arbitrary value to I2CSR. After this, I2C enters idle state. #### 11.12.8.2 Master Receiver To operate I2C in master receiver, follow the recommended steps below. - 1. Enable I2C by setting IICEN bit in I2CMR. This provides main clock to the peripheral. - 2. Load SLA+R into the I2CDR where SLA is address of slave device and R is transfer direction from the viewpoint of the master. For master receiver, R is '1'. Note that I2CDR is used for both address and data. - 3. Configure baud rate by writing desired value to both I2CSCLLR and I2CSCLHR for the Low and High period of SCL line. - 4. Configure the I2CSDAHR to decide when SDA changes value from falling edge of SCL. If SDA should change in the middle of SCL LOW period, load half the value of I2CSCLLR to the I2CSDAHR. - 5. Set the START bit in I2CMR. This transmits a START condition. And also configure how to handle interrupt and ACK signal. When the START bit is set, 8-bit data in I2CDR is transmitted out according to the baud-rate. - 6. This is ACK signal processing stage for address packet transmitted by master. When 7-bit address and 1-bit transfer direction is transmitted to target slave device, the master can know whether the slave acknowledged or not in the 9th high period of SCL. If the master gains bus mastership, I2C generates GCALL interrupt regardless of the reception of ACK from the slave device. When I2C loses bus mastership during arbitration process, the MLOST bit in I2CSR is set, and I2C waits in idle state or can be operate as an addressed slave. To operate as a slave when the MLSOT bit in I2CSR is set, the ACKEN bit in I2CMR must be set and the received 7-bit address must equal to the SLA bits in I2CSAR. In this case I2C operates as a slave transmitter or a slave receiver (go to appropriate section). In this stage, I2C holds the SCL LOW. This is because to decide whether I2C continues serial transfer or stops communication. The following steps continue assuming that I2C does not lose mastership during first data transfer. I2C (Master) can choose one of the following cases according to the reception of ACK signal from slave. - 1) Master receives ACK signal from slave, so continues data transfer because slave can prepare and transmit more data to master. Configure ACKEN bit in I2CMR to decide whether I2C ACKnowledges the next data to be received or not. - 2) Master stops data transfer because it receives no ACK signal from slave. In this case, set the STOP bit in I2CMR. - 3) Master transmits repeated START condition due to no ACK signal from slave. In this case, load SLA+R/W into the I2CDR and set START bit in I2CMR. After doing one of the actions above, write arbitrary value to I2CSR to release SCL line. In case of 1), move to step 7. In case of 2), move to step 9 to handle STOP interrupt. In case of 3), move to step 6 after transmitting the data in I2CDR and if transfer direction bit is '0' go to master transmitter section. - 7. 1-byte of data is being received. - This is ACK signal processing stage for data packet transmitted by slave. I2C holds the SCL LOW. When 1-byte of data is received completely, I2C generates TEND interrupt. I2C can choose one of the following cases according to the RXACK flag in I2CSR. - Master continues receiving data from slave. To do this, set ACKEN bit in I2CMR to ACK and the next data to be received. - 2) Master wants to terminate data transfer when it receives next data by not generating ACK signal. This can be done by clearing ACKEN bit in I2CMR. - 3) Because no ACK signal is detected, master terminates data transfer. In this case, set the STOP bit in I2CMR. - 4) No ACK signal is detected, and master transmits repeated START condition. In this case, load SLA+R/W into the I2CDR and set the START bit in I2CMR. After doing one of the actions above, write arbitrary value to I2CSR to release SCL line. In case of 1) and 2), move to step 7. In case of 3), move to step 9 to handle STOP interrupt. In case of 4), move to step 6 after transmitting the data in I2CDR, and if transfer direction bit is '0' go to master transmitter section. 9. This is the final step for master receiver function of I2C, handling STOP interrupt. The STOP bit indicates that data transfer between master and slave is over. To clear I2CSR, write arbitrary value to I2CSR. After this, I2C enters idle state. #### 11.12.8.3 Slave Transmitter To operate I2C in slave transmitter, follow the recommended steps below. - 1. If the main operating clock (SCLK) of the system is slower than that of SCL, load value 0x00 into I2CSDAHR to make SDA change within one system clock period from the falling edge of SCL. Note that the hold time of SDA is calculated by SDAH x period of SCLK where SDAH is multiple of number of SCLK coming from I2CSDAHR. When the hold time of SDA is longer than the period of SCLK, I2C (slave) cannot transmit serial data properly. - 2. Enable I2C by setting IICEN bit and INTEN bit in I2CMR. This provides main clock to the peripheral. - When a START condition is detected, I2C receives one byte of data and compares it with SLA bits in I2CSAR. If the GCALLEN bit in I2CSAR is enabled, I2C compares the received data with value 0x00, the general call address. - 4. If the received address does not equal to SLA bits in I2CSAR, I2C enters idle state ie, waits for another START condition. Else if the address equals to SLA bits and the ACKEN bit is enabled, I2C generates SSEL interrupt and the SCL line is held LOW. Note that even if the address equals to SLA bits, when the ACKEN bit is disabled, I2C enters idle state. When SSEL interrupt occurs, load transmit data to I2CDR and write arbitrary value to I2CSR to release SCL line. - 5. 1-byte of data is being transmitted. - 6. In this step, I2C generates TEND interrupt and holds the SCL line as Low regardless of the reception of ACK signal from master. Slave can select one of the following cases. - 1) No ACK signal is detected and I2C waits STOP or repeated START condition. - 2) ACK signal from master is detected. Load data to transmit into I2CDR. - After doing one of the actions above, write arbitrary value to I2CSR to release SCL line. In case of 1) move to step 7 to terminate communication. In case of 2) move to step 5. In either case, a repeated START condition can be detected. For that case, move step 4. - 7. This is the final step for slave transmitter function of I2C, handling STOP interrupt. The STOP bit indicates that data transfer between master and slave is over. To clear I2CSR, write arbitrary value to I2CSR. After this, I2C enters idle state. #### 11.12.8.4 Slave Receiver To operate I2C in slave receiver, follow the recommended steps below. - 1. If the main operating clock (SCLK) of the system is slower than that of SCL, load value 0x00 into I2CSDAHR to make SDA change within one system clock period from the falling edge of SCL. Note that the hold time of SDA is calculated by SDAH x period of SCLK where SDAH is multiple of number of SCLK coming from I2CSDAHR. When the hold time of SDA is longer than the period of SCLK, I2C (slave) cannot transmit serial data properly. - 2. Enable I2C by setting IICEN bit and INTEN bit in I2CMR. This provides main clock to the peripheral. - When a START condition is detected, I2C receives one byte of data and compares it with SLA bits in I2CSAR. If the GCALLEN bit in I2CSAR is enabled, I2C compares the received data with value 0x00, the general call address. - 4. If the received address does not equal to SLA bits in I2CSAR, I2C enters idle state ie, waits for another START condition. Else if the address equals to SLA bits and the ACKEN bit is enabled, I2C generates SSEL interrupt and the SCL line is held LOW. Note that even if the address equals to SLA bits, when the ACKEN bit is disabled, I2C enters idle state. When SSEL interrupt occurs and I2C is ready to receive data, write arbitrary value to I2CSR to release SCL line. - 5. 1-byte of data is being received. - 6. In this step, I2C generates TEND interrupt and holds the SCL line LOW regardless of the reception of ACK signal from master. Slave can select one of the following cases. - 1) No ACK signal is detected (ACKEN=0) and I2C waits STOP or repeated START condition. - 2) ACK signal is detected (ACKEN=1) and I2C can continue to receive data from master. - After doing one of the actions above, write arbitrary value to I2CSR to release SCL line. In case of 1) move to step 7 to terminate communication. In case of 2) move to step 5. In either case, a repeated START condition can be detected. For that case, move step 4. - 7. This is the final step for slave receiver function of I2C, handling STOP interrupt. The STOP bit indicates that data transfer between master and slave is over. To clear I2CSR, write arbitrary value to I2CSR. After this, I2C enters idle state. ## 11.12.9 Register Map | Name | Address | Dir | Default | Description | |-----------|---------|-----|---------|-------------------------------| | I2CMR00 | DAH | R/W | 00H | I2C0 Mode Control Register 0 | | I2CSR0 | DBH | R | 00H | I2C0 Status Register | | I2CSCLLR0 | DCH | R/W | 3FH | I2C0 SCL Low Period Register | | I2CSCLHR0 | DDH | R/W | 3FH | I2C0 SCL High Period Register | | I2CSDAHR0 | DEH | R/W | 01H | I2C0 SDA Hold Time Register | | I2CDR0 | DFH | R/W | FFH | I2C0 Data Register | | I2CSAR00 | D7H | R/W | 00H | I2C0 Slave Address 0 Register | | I2CSAR01 | D6H | R/W | 00H | I2C0 Slave Address 1 Register | | I2CMR01 | 8F1EH | R/W | 00H | I2C0 Mode Control Register 1 | | I2CMR10 | 8F20H | R/W | 00H | I2C1 Mode Control Register 0 | | I2CSR1 | 8F21H | R | 00H | I2C1 Status Register | | I2CSCLLR1 | 8F22H | R/W | 3FH | I2C1 SCL Low Period Register | | I2CSCLHR1 | 8F23H | R/W | 3FH | I2C1 SCL High Period Register | | I2CSDAHR1 | 8F24H | R/W | 01H | I2C1 SDA Hold Time Register | | I2CDR1 | 8F25H | R/W | FFH | I2C1 Data Register | | I2CSAR10 | 8F26H | R/W | 00H | I2C1 Slave Address 1 Register | | I2CSAR11 | 8F27H | R/W | 00H | I2C1 Slave Address Register | | I2CMR11 | 8F1FH | R/W | 00H | I2C1 Mode Control Register 1 | Table 11.19 I2C Register Map ## 11.12.10 I2C Register Description I2C Registers are composed of I2C Mode Control Register 0 (I2CMRn0), I2C Mode Control Register 1 (I2CMRn1), I2C Status Register (I2CSRn), SCL Low Period Register (I2CSCLLRn), SCL High Period Register (I2CSCLHRn), SDA Hold Time Register (I2CSDAHRn), I2C Data Register (I2CDRn), I2C Slave Address 0 Register (I2CSARn1) and I2C Slave Address 1 Register (I2CSARn1). ## 11.12.11 Register Description for I2C #### I2CMRn0 (I<sup>2</sup>C Mode Control Register 0): DAH, 8F20H INTEN | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-------|-------|-------|-------|--------|------|-------| | IIF | IICEN | RESET | INTEN | ACKEN | MASTER | STOP | START | | RW | RW | RW | RW | RW | R | RW | RW | Initial value: 00H IIF This is interrupt flag bit. 0 No interrupt is generated or interrupt is cleared 1 An interrupt is generated IICEN Enable I<sup>2</sup>C Function Block (by providing clock) 0 I<sup>2</sup>C is inactive 1 I<sup>2</sup>C is active RESET Initialize internal registers of I<sup>2</sup>C. 0 No operation 1 Initialize I<sup>2</sup>C, auto cleared Enable interrupt generation of I<sup>2</sup>C. 0 Disable interrupt, operates in polling mode 1 Enable interrupt ACKEN Controls ACK signal generation at ninth SCL period. NOTE) ACK signal is output (SDA=0) for the following 3 cases. When received address packet equals to SLA bits in I2CSAR When received address packet equals to value 0x00 with GCALL enabled When I<sup>2</sup>C operates as a receiver (master or slave) No ACK signal is generated (SDA=1) ACK signal is generated (SDA=0) MASTER Represent operating mode of I<sup>2</sup>C 0 I<sup>2</sup>C is in slave mode 1 I<sup>2</sup>C is in master mode STOP When I<sup>2</sup>C is master, generates STOP condition. 0 No operation 1 STOP condition is to be generated START When I<sup>2</sup>C is master, generates START condition. 0 No operation 1 START or repeated START condition is to be generated 0 1 ## I2CSRn (I<sup>2</sup>C Status Register): DBH, 8F21H **TMODE** **RXACK** 1 5 | | _ | _ | | , | _ | _ | | | | | |--------------------|-------|---------|-----------------------------------------------------------------------------------------------|---------------------|-------------------|-------------------|--------------|--|--|--| | GCALL | TEND | STOP | SSEL | MLOST | BUSY | TMODE | RXACK | | | | | R | R | R | R | R | R | R | R | | | | | Initial value : 00 | OH | | | | | | | | | | | | GCALL | This bi | t has different m | eaning dependir | ng on whether I2 | C is master or sl | ave. NOTE 1) | | | | | | 00/ | | When I <sup>2</sup> C is a master, this bit represents whether it received AACK (Address ACK) | | | | | | | | | | | | from slave. | | | | | | | | | | | When | When I2C is a slave, this bit is used to indicate general call. | | | | | | | | | | | 0 | 0 No AACK is received (Master mode) | | | | | | | | | | | 1 | AACK is recei | ved (Master mod | le) | | | | | | | | | 0 | Received add | ress is not gener | al call address | (Slave mode) | | | | | | | | 1 | 1 General call address is detected (Slave mode) | | | | | | | | | | TEND | This b | t is set when 1-E | Byte of data is tra | ansferred comple | etely. NOTE 1) | | | | | | | | 0 | 1 byte of data | is not completely | y transferred | | | | | | | | | 1 | 1 byte of data | is completely tra | nsferred | | | | | | | | STOP | This b | t is set when ST | OP condition is | detected. NOTE | 1) | | | | | | | | 0 | 0 No STOP condition is detected | | | | | | | | | | | 1 | STOP condition | | | | | | | | | | SSEL | This b | | is addressed by | other master. N | IOTE 1) | | | | | | | | 0 | I <sup>2</sup> C is not sele | | | | | | | | | | | 1 | | ed by other mast | | | | | | | | | MLOST | This bi | | result of bus arb | itration in maste | r mode. NOTE 1 | 1) | | | | | | | 0 | | bus mastership | | | | | | | | | | 1 | 1 I <sup>2</sup> C has lost bus mastership during arbitration process | | | | | | | | | | BUSY | This b | t reflects bus sta | atus. | | | | | | | | | | 0 | I <sup>2</sup> C bus is idle, | so any master o | can issue a STA | RT condition | | | | | | | | | | | | | | | | | 3 2 NOTE 1) These bits can be sources of interrupt. When an I<sup>2</sup>C interrupt occurs except for STOP interrupt, the SCL line is held LOW. To release SCL, write arbitrary value to I2CSR. When I2CSR is written, the TEND, STOP, SSEL, LOST and RXACK bits are cleared. ACK is generated at ninth SCL period This bit is used to indicate whether I2C is transmitter or receiver. I<sup>2</sup>C bus is busy O I<sup>2</sup>C is a receiver I I<sup>2</sup>C is a transmitter This bit shows the state of ACK signal. No ACK is received NOTE 2) The writing to I2CSR can be done in software regardless of the state of I<sup>2</sup>C. It should not be written to the I2CSR during transmit or receive sequence in order to ensure correct I<sup>2</sup>C operation. ## I2CSCLLRn (SCL Low Period Register): DCH, 8F22H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | SCL17 | SCIL6 | SCLL5 | SCLL4 | SCIT3 | SCLL2 | SCLL1 | SCIT0 | | RW Initial value: 3FH SCLL[7:0] This register defines the LOW period of SCL when $I^2C$ operates in master mode. The base clock is SCLK, the system clock, and the period is calculated by the formula : $t_{SCLK} \times (4 \times SCLL + 1)$ where $t_{SCLK}$ is the period of SCLK. #### I2CSCLHRn (SCL High Period Register): DDH, 8F23H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | SCLH7 | SCLH6 | SCLH5 | SCLH4 | SCLH3 | SCLH2 | SCLH1 | SCLH0 | | RW Initial value: 3FH SCLH[7:0] This register defines the HIGH period of SCL when I $^2$ C operates in master mode. The base clock is SCLK, the system clock, and the period is calculated by the formula : $t_{SCLK} \times (4 \times SCLH + 3)$ where $t_{SCLK}$ is the period of SCLK. So, the operating frequency of I<sup>2</sup>C in master mode (fI2C) is calculated by the following equation. $$f12C = \frac{1}{tSCLK \times (4 (SCLL + SCLH) + 4)}$$ ## I2CSDAHRn (SDA Hold Time Register): DEH, 8F24H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | SDAH7 | SDAH6 | SDAH5 | SDAH4 | SDAH3 | SDAH2 | SDAH1 | SDAH0 | | RW Initial value: 01H SDAH[7:0] This register is used to control SDA output timing from the falling edge of SCL. Note that SDA is changed after $t_{SCLK} \times SDAH$ . In master mode, load half the value of SCLL to this register to make SDA change in the middle of SCL. In slave mode, configure this register regarding the frequency of SCL from master. The SDA is changed after $t_{SCLK} \times (SDAH + 1)$ . So, to insure normal operation in slave mode, the value $t_{SCLK} \times (SDAH + 1)$ must be smaller than the period of SCL. #### I2CDRn (I<sup>2</sup>C Data Register): DFH, 8F25H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | ICD7 | ICD6 | ICD5 | ICD4 | ICD3 | ICD2 | ICD1 | ICD0 | | RW Initial value: FFH ICD[7:0] When I<sup>2</sup>C is configured as a transmitter, load this register with data to be transmitted. When I<sup>2</sup>C is a receiver, the received data is stored into this register. ## I2CSARn0 (I<sup>2</sup>C Slave Address Register 0): D7H. 8F26H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|---------| | SLA7 | SLA6 | SLA5 | SLA4 | SLA3 | SLA2 | SLA1 | GCALLEN | | RW Initial value: 00H SLA[7:1] These bits configure the slave address of this I<sup>2</sup>C module when I2C operates in slave mou GCALLEN This bit decides whether I<sup>2</sup>C allows general call address or not when I<sup>2</sup>C operates in slave mode. 0 Ignore general call address 1 Allow general call address #### I2CSARn1 (I2C Slave Address Register 1): D6H, 8F27H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|---------| | SLA7 | SLA6 | SLA5 | SLA4 | SLA3 | SLA2 | SLA1 | GCALLEN | | RW Initial value: 00H SLA[7:1] These bits configure the slave address of this I2C module when I2C operates in slave node. GCALLEN This bit decides whether I2C allows general call address or not when I2C operates in slave mode. 0 Ignore general call address 1 Allow general call address ## I2CMRn1 (I2C Mode Control Register 1): 8F1EH, 8F1FH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|----------| | - | - | - | - | - | - | - | DIS_SDAH | | - | - | - | - | - | - | - | RW | Initial value: 00H DIS\_SDAH Disable SDA hold time 0 Enable SDA hold time. When I2CSR is written, the MSB of the transmitted data of I2CDR is on the output to SDA port before three system clocks from the rising edge of SCL. The other bits after the MSB bit are outputted to SDA port in the timing controlled by I2CSDAHR from the falling edge of SCL. 1 Disable SDA hold time. When I2CDR is written, the MSB of the transmitted data of I2CDR is on the output to SDA port directly. The other bits after the MSB bit are outputted after the falling edge of SCL irrespective of I2CSDAHR. #### 11.13 12-bit A/D Converter #### 11.13.1 Overview The analog-to-digital converter (A/D) allows conversion of an analog input signal to a corresponding 12-bit digital value. The A/D module has tenth analog inputs. The output of the multiplex is the input into the converter, which generates the result via successive approximation. The A/D module has four registers which are the control register ADCM (A/D Converter Mode Register), ADCM1 (A/D Converter Mode Register 1) and A/D result register ADCHR (A/D Converter Result High Register) and ADCLR (A/D Converter Result Low Register). It is selected for the corresponding channel to be converted by setting ADSEL[3:0]. To executing A/D conversion, ADST bit sets to '1'. The register ADCHR and ADCLR contains the results of the A/D conversion. When the conversion is completed, the result is loaded into the ADCHR and ADCLR, the A/D conversion status bit AFLAG is set to '1', and the A/D interrupt is set. For processing A/D conversion, AFLAG bit is read as '0'. If using STBY (power down) bit, the ADC is disabled. Also internal timer, external generating event, comparator, the trigger of timer1pwm and etc. can start ADC regardless of interrupt occurrence. ADC Conversion Time = ADCLK \* 60 cycles After STBY bit is reset (ADC power enable) and it is restarted, during some cycle, ADC conversion value may have an inaccurate value. When using ports as ADC input port, it is recommended to set corresponding PSR2, PSR3 registers to prevent current leakage or unexpected function, because analog value enters to digital circuit. #### NOTE) The A/D converter needs at least 20us for conversion time. So you must set the conversion time more than 20us. ## 11.13.2 Block Diagram Figure 11.52 12-bit ADC Block Diagram Figure 11.53 A/D Analog Input Pin with Capacitor Figure 11.54 A/D Power (AVREF) Pin with Capacitor ## 11.13.3 ADC Operation Figure 11.55 ADC Operation for Align Bit Figure 11.56 A/D Converter Operation Flow ## 11.13.4 Register Map | Name Address D | | Direction | Default | Description | | | |----------------|---------------|-----------|---------|------------------------------------|--|--| | ADCM 9AH R/W | | R/W | 8FH | A/D Converter Mode Register | | | | ADCM2 | ADCM2 92H R/W | | 02H | A/D Converter Mode 2 Register | | | | ADCRL | ADCRL 9BH R | | - | A/D Converter Result Low Register | | | | ADCRH | 9CH | R | - | A/D Converter Result High Register | | | Table 11.20 ADC Register Map ## 11.13.5 ADC Register Description The ADC Register consists of A/D Converter Mode Register (ADCM), A/D Converter Result High Register (ADCRH), A/D Converter Result Low Register (ADCRL), A/D Converter Mode 1 Register (ADCM2). NOTE) When STBY bit is set to '1', ADCM2 is read. If ADC enables, it is possible only to write ADCM2. When reading, ADCRL is read. ## 11.13.6 Register Description for ADC ## ADCM (A/D Converter Mode Register) : 9AH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |------------------|------------------|------------|------------------------------------------|-----------------|------------|---------------|--------|--|--|--| | STBY | ADST | REFSEL | AFLAG | ADSEL3 | ADSEL2 | ADSEL1 | ADSEL0 | | | | | RW | RW | RW | R | RW | RW | RW | RW | | | | | Initial value: 8 | FH | | | | | | | | | | | | STB | y Con<br>0 | trol operation of<br>ADC modul | A/D standby (po | ower down) | | | | | | | | | 1 | | e disable (powe | r down) | | | | | | | | ADS <sup>-</sup> | т Con | trol A/D Convers | ** | , | | | | | | | | 7.20 | | ADC Conve | • | | | | | | | | | | 1 | ADC Conve | ersion Start | | | | | | | | | REF | SEL A/D | Converter refere | ence selection | | | | | | | | | | 0 | Internal Ref | erence (Vref=VI | DD) | | | | | | | | | 1 | 1 External Reference(AVREF, AN0 disable) | | | | | | | | | | AFLA | AG A/D | A/D Converter operation state | | | | | | | | | | | 0 | During A/D | Conversion | | | | | | | | | | 1 | | sion finished | | | | | | | | | ADSI | | Converter input | | | | | | | | | | | ADS | SEL3 ADSEL2 | ADSEL1 | ADSEL0 | Description | | | | | | | | 0 | 0 | 0 | 0 | Channel0(AN0) | | | | | | | | 0 | 0 | 0 | 1 | Channel1(AN1) | | | | | | | | 0 | 0 | 1 | 0 | Channel2(AN2) | | | | | | | | 0 | 0 | 1 | 1 | Channel3(AN3) | | | | | | | | 0 | 1 | 0 | 0 | Channel4(AN4) | | | | | | | | 0 | 1 | 0 | 1 | Channel5(AN5) | | | | | | | | 0 | 1 | 1 | 0 | Channel6(AN6) | | | | | | | | 0 | 1 | 1 | 1 | Channel7(AN7) | | | | | | | | 1 | 0 | 0 | 0 | Channel7(AN8) | | | | | | | | 1 | 0 | 0 | 1 | Channel7(AN9) | | | | | | | | 1 | 0 | 1 | 0 | Reserved | | | | | | | | 1 | 0 | 1 | 1 | Reserved | | | | | | | | 1 | 1 | 0 | 0 | Reserved | | | | | 1 Reserved Reserved VDD18 (Test Only) ## ADCM2 (A/D Converter Mode Register): 92H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|--------|--------|--------| | EXTRG | TSEL2 | TSEL1 | TSEL0 | ALIGN | CKSEL2 | CKSEL1 | CKSEL0 | | RW Initial value: 02H | EXTRG | A/D External Trigger | | | | | | | | | |------------|------------------------------|-------------------------------------|----------------------------------------------------------|---------------------|---------------------|--|--|--|--| | | A/D conversion | n Start by | external T | rigger, and Stop by | y clearing this bit | | | | | | | 0 | | A/D conversion Stop and External Trigger disable (defaul | | | | | | | | | 1 | External | Trigger er | nable | , , | | | | | | TSEL[2:0] | A/D Trigger Source selection | | | | | | | | | | 1022[2.0] | TSEL2 | TSEL1 | TSEL0 | Description | | | | | | | | 0 | 0 | 0 | Ext. Interrupt0 | | | | | | | | 0 | 0 | 1 | Ext. Interrupt1 | | | | | | | | 0 | 1 | 0 | Comparator inter | rupt | | | | | | | 0 | 1 | 1 | TIMER2 A-Match | interrupt | | | | | | | 1 | 0 | 0 | TIMER3 A-Match | interrupt | | | | | | | 1 | 0 | 1 | TIMER4 A-Match | interrupt | | | | | | | 1 | 1 | 0 | TIMER5 A-Match | interrupt | | | | | | | 1 | 1 | 1 | TIMER6 A-Match | interrupt | | | | | | ALIGN | A/D Converte | A/D Converter data align selection. | | | | | | | | | | 0 | MSB alig | gn (ADCRI | H[7:0], ADCRL[7:4 | ]) | | | | | | | 1 | | | | | | | | | | CKSEL[2:0] | A/D Converte | r Clock sel | ection | | | | | | | | | CKSEL2 | CKSEL1 | CKSEL | .0 ADC Clock | ADC VDD | | | | | | | 0 | 0 | 0 | fx/2 | Test Only | | | | | | | 0 | 0 | 1 | fx/4 | 3V~5V | | | | | | | 0 | 1 | 0 | fx/8 (default) | 3V~5V | | | | | | | 0 | 1 | 1 | fx/16 | 3V~5V | | | | | | | 1 | 0 | 0 | fx/32 | 2.7V~3V | | | | | | | 1 | 0 | 1 | fx/64 | 2.4V~2.7V | | | | | | | 1 | 1 | 0 | fx/64 | 2.4V~2.7V | | | | | | | 1 | 1 | 1 | fx/64 | 2.4V~2.7V | | | | | | NOTE | ) 1. fx : system | n clock | | | | | | | | - 2. ADC clock must be used Max. 3MHz greater than 4V. - 3. ADC clock must be used Max. 2MHz less than 4V. ## ADCRL (A/D Converter Result Low Register): 9BH | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-------|-------|-------|-------|-------|-------|-------|-------| | | ADDM3 | ADDM2 | ADDM1 | ADDM0 | | | | | | | ADDL7 | ADDL6 | ADDL5 | ADDL4 | ADDL3 | ADDL2 | ADDL1 | ADDL0 | | Ī | R | R | R | R | R | R | R | R | Initial value: xxH ADDM[3:0] MSB align, A/D Converter Low result (4-bit) ADDL[7:0] LSB align, A/D Converter Low result (8-bit) ## ADCRH (A/D Converter Result High Register): 9CH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|-------|-------|--------|--------|-------|-------| | ADDM11 | ADDM10 | ADDM9 | ADDM8 | ADDM7 | ADDM6 | ADDM5 | ADDM4 | | | | | | ADDL11 | ADDL10 | ADDL9 | ADDL8 | | R | R | R | R | R | R | R | R | Initial value: xxH ADDM[11:4] MSB align, A/D Converter High result (8-bit) ADDL[11:8] LSB align, A/D Converter High result (4-bit) ## 11.14 HDMI™- CEC Controller #### 11.14.1 Introduction The A97C450 embeds a HDMI<sup>TM</sup>-CEC interface controller hardware supporting the CEC standard specification (HDMI Specification Version 1.3a). The Consumer electronics control (CEC) is the appendix supplement 1 to the HDMI standard. This protocol including the physical layer and link layer provides high-level communication control between various audio and video products. In this section, we explain the hardware stack including PHY layer and link layer. The CEC block consists of clock control block, TX/RX buffer (40 data buffers about each of TX buffers 20, RX buffers 20) and data control block. CEC Data transmitting and receiving process are executing by H/W block. The following functionalities are supported by CEC H/W block: - Bit timing control (One, Zero tolerance) - Control signal free time by H/W and Message time constraints by S/W application - Issue end of message bit (EOM) by H/W - Generate ACK/NACK signal depended on Message characteristic (broadcasting or direct address) - Frame Re-transmissions - Bit/Line error Handling - Arbitration by end of transmission, and independently processing arbitration with RX process (does not lose RX Data even if device loses arbitration process) ## 11.14.2 HDMI™-CEC register map | Name | Address | Direction | Default | Description | | |---------------------------|------------------|-----------|---------|--------------------------------------|--| | CEC_PRES1 | 8F60H | R/W | 00H | Clock prescaler register (High byte) | | | CEC_PRES0 | 8F61H | R/W | 00H | Clock prescaler register (Low byte) | | | CEC_CONF1 | 8F62H | R/W | 00H | CEC Block configuration register 1 | | | CEC_CONF0 | 8F63H | R/W | 00H | CEC Block configuration register 0 | | | CEC_GCTRL | 8F64H | R/W | 00H | Signal free time control register | | | CEC_ICTRL | 8F65H | R/W | 00H | TX data control register | | | CEC_FCTRL | 8F66H | W | 00H | RX data count register | | | CEC_ISTAT | 8F67H | R | 00H | TX block state register | | | CEC_FSTAT | 8F68H | R | 00H | RX block state register | | | CEC_ICLR | 8F69H | W | 00H | TX block state clear register | | | CEC_FCLR | 8F6AH | W | 00H | RX block status clear register | | | CEC_TXH | 8F6BH | R/W | 00H | TX Header data buffer | | | CEC_TXD_1 ~<br>CEC_TXD_19 | 8F6CH ~<br>8F7EH | R/W | 00H | TX Data buffers | | | CEC_RXH | 8F7FH | R | - | RX Header Data buffer | | | CEC_RXD_1 ~<br>CEC_RXD_19 | 8F80H ~<br>8F92H | R | - | RX Data buffer | | Table 11.21 HDMI CEC Register Map ## 11.14.3 HDMI-CEC Registers description The HDMI-CEC Registers are defined at xdata SFR address area. ## CEC\_PRESx (CEC Prescaler Register): 8F60H, 8F61H | 1 | ь | 5 | 4 | 3 | 2 | 1 | U | |---------|---------|---------|---------|---------|---------|---------|--------------------| | PRES1_7 | PRES1_6 | PRES1_5 | PRES1_4 | PRES1_3 | PRES1_2 | PRES1_1 | PRES1_0 | | RW | | | | | | | lr | nitial value : 00H | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | PRES0\_7 PRES0\_6 PRES0\_5 PRES0\_4 PRES0\_3 PRES0\_2 PRES0\_1 PRESO\_0 RW RW RW RW RW RW RW RW Initial value: 00H CEC\_PRESx The basic clock of CEC block requests 32.768KHz. Input source clock( System clock) changes to CEC base clock(32.68kHz) by setting prescaler register. $CEC_PRESx = (F_{SCLK} / 32.768kHz) / 2 - 1$ F<sub>SCLK</sub> = System clock #### CEC\_CONF1 (CEC Configuration Register 1): 8F62H CEC\_EN | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------|--------------------|---|---|---|---|-----------|--------| | INT_ERR_TX_E<br>N | INT_ERR_ACK<br>_EN | - | - | - | - | SUBCLK_EN | CEC_EN | | RW | RW | - | - | - | - | RW | RW | Initial value: 00H At finding an error on CEC line, enable or disable CEC Interrupt event INT\_ERR\_TX 0 Disable CEC Interrupt at TX error \_EN Enable CEC Interrupt at TX error At ACK error, enable or disable CEC Interrupt event INT\_ERR\_AC 0 K\_EN Disable CEC Interrupt 1 Enable CEC Interrupt It selects CEC block clock source to use Sub OSC or Main system clock SUBCLK\_EN Select Main system clock as CEC clock source Select Sub OSC Enable / Disable CEC block active ( In case of disable, CEC wake up is not available) 1 Inactive CEC block 1 Active CEC block ## CEC\_CONF0 (CEC Configuration Register 0): 8F63H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|-----------|-----------|-----------|----------|----------|----------|----------| | - | TX_RETRY2 | TX_RETRY1 | TX_RETRY0 | Dev_Add3 | Dev_Add2 | Dev_Add1 | Dev_Add0 | | RW | - | - | - | RW | RW | RW | RW | Initial value: 00H TX\_RETRY[6:4] Under uncertain condition of CEC line, if a CEC follower do not response ACK it decides Re-transmission times after 4 \*2.4 Msec. Dev\_Add[3:0] Own Device Address ( self-logical address ) CEC Device logical Address (0 ~ 15) ### CEC\_GCTRL (Signal free time control register): 8F64H | 1 | 0 | Э | 4 | 3 | 2 | 1 | U | |----------|----------|----------|---------|---------|---------|----------------|--------------------| | SFT_7_10 | SFT_7_10 | SFT_7_10 | SFT_5_7 | SFT_5_7 | SFT_3_5 | SFT_3_5 | LINE_BUSY | | RW R | | | | | | | | l <sub>r</sub> | sitial value : 00L | Initial value: 00H **CEC\_GCTRL**Before attempting to transmit or re-transmit a frame, a device shall ensure that the CEC line has been inactive for a number of bit periods. This signal free time is defined as the time since the start of the final bit of the previous frame. It define signal free times. SFT\_7\_10[2:0] When present initiator wants to send another frame immediately after its previous frame, it decide waiting time before sending. Default signal free time (7x2.4) ms Waiting time = $(7+0.5 \times SFT_7_10)x2.4$ ms SFT\_5\_7[1:0] When new initiator wants to send a frame, it decide waiting time before sending. Default signal free time (5x2.4)ms Waiting time = $(5+0.5 * SFT_5_7)x2.4 ms$ SFT\_3\_5[1:0] When previous attempt to send frame unsuccessful, it decide waiting time before sending. Default signal free time $(3 \times 2.4)$ ms Waiting time = $(3+0.5 * SFT_3_5) \times 2.4$ ms LINE\_BUSY If it is high state, CEC line is busy ( occupying CEC line by any CEC device) 0 Free CEC line 1 Line busy # CEC\_ICTRL (CEC TX data control register): 8F65H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|----------|----------|----------|----------|----------|---------| | - | - | TX_DSIZE | TX_DSIZE | TX_DSIZE | TX_DSIZE | TX_DSIZE | TX_MODE | | - | - | RW | RW | RW | RW | RW | | Initial value: 00H TX\_DSIZE TX data buffers on CEC block have 19. It decides transmission data sizes except header byte. 0 Just transmit header byte.n Max TX data size is 19 TX\_MODE If it is set, it starts to transmit TX data after writing TX data on TX data buffers and TX Data size. It is cleared by H/W after finishing data transmission completely ( It is possible to use a busy signal for transmission line ) # CEC\_FCTRL (CEC RX data count register): 8F66H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|----------|----------|----------|----------|----------| | - | - | - | RX_DSISE | RX_DSISE | RX_DSISE | RX_DSISE | RX_DSISE | | - | - | - | - | R | R | R | R | Initial value: 00H RX\_DSIZE RX data buffers on CEC block have 19. The value of register is RX data size received from initiator. Just receive header byte.Max RX data size is 19 ### CEC\_ISTAT (CEC TX block state register): 8F67H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|----------------------|-------------|-----------|-------------|-------------| | - | - | - | INT_ERR_TX_<br>OTHER | INT_ERR_ACK | INT_ARBIT | INT_TX_FAIL | INT_TX_DONE | | - | - | - | - | R | R | R | R | Initial value: 00H INT\_ERR\_TX \_OTHER After finishing transmission it indicates an error from a follower or CEC line. It is cleared by setting CLR\_INT\_ERR\_TX\_OTHER bit on CEC\_ICLR register 0 No error 1 An error is invoked INT\_ERR\_AC After finishing transmission, it indicates to have right ACK/NACK or not. It is cleared by setting CLR\_INT\_ERR\_ACK bit on CEC\_ICLR register 0 Getting right ACK/NACK 1 An ACK/NACK error is invoked **INT\_ARBIT** It indicates to have an arbitration process and the device has lost CEC line occupation. If the device loses CEC line right, S/W has to start re-transmit data after waiting signal from time. It is cleared by setting CLR\_INT\_ARBIT bit on CEC\_ICLR register 0 no lost CEC line occupation 1 lost arbitration INT\_TX\_FAIL It indicates a transmission fail after finishing re-transmissions (defined by TX\_RETRY). It is cleared by setting CLR\_INT\_TX\_FAIL bit on CEC\_ICLR register 0 No error transmission Completely transmission fail INT\_TX\_DON It indicates a transmission to be completely done. It is cleared by setting CLR\_INT\_TX\_DONE bit on CEC\_ICLR register 0 No meaning 1 Set after a frame transmission to be done. ### CEC\_FSTAT (CEC RX block state register): 8F68H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|----------------------|-------------|-------------|-------------| | - | - | - | - | INT_ERR_RX_<br>OTHER | INT_ERR_BIT | INT_ERR_OVF | INT_RX_DONE | | R | - | - | - | R | R | R | R | Initial value: XXH INT\_ERR\_RX \_OTHER While receiving RX data and it has any error by other device or abnormal line condition, it indicates an error (insert 3.6ms low time). It is cleared by setting CLR\_INT\_ERR\_RX\_OTHER bit on CEC\_FCLR register 0 No error 1 An error is invoked INT\_ERR\_BIT It indicates low period of RX data to be long. 0 No error 1 Low period of RX is long. INT\_ERR\_OV Low period of ICA is long. It indicates to overflow RX buffers( more than receiving 19 data ) It is cleared by setting CLR\_INT\_ERR\_OVF bit on CEC\_FCLR register 0 No overflow 1 RX buffer overflow INT\_RX\_DON It indicates to finish RX reception without any problem. It is cleared by setting CLR\_INT\_RX\_DONE bit on CEC\_FCLR register 0 No meaning 1 Completely received RX Data (directly or broadcasting data) ### CEC\_ICLR (CEC TX block state clear register): 8F69H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|--------------------------|---------------------|-------------------|---------------------|---------------------| | - | - | - | CLR_INT_ERR<br>_TX_OTHER | CLR_INT_ERR<br>_ACK | CLR_INT_AR<br>BIT | CLR_INT_TX_FAI<br>L | CLR_INT_TX_D<br>ONE | | - | - | - | W | W | W | W | W | Initial value: 00H R\_TX\_OTHE 0 R 1 Clear INT\_ERR\_TX\_OTHER bit CLR\_INT\_ER It clear INT\_ERR\_ACK bit on CEC\_ISTAT register R\_ACK 0 - 1 Clear INT\_ERR\_ACK bit CLR\_INT\_AR It clear INT\_ARBIT bit on CEC\_ISTAT register BIT 1 Clear INT\_ARBIT bit CLR\_INT\_TX It clear INT\_TX\_FAIL bit on CEC\_ISTAT register \_FAIL 0 1 Clear INT\_TX\_FAIL bit \_DONE 0 - 1 Clear INT\_TX\_DONE bit ### CEC\_FCLR (CEC RX block state clear register): 8F6AH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|--------------------------|---------------------|---------------------|---------------------| | - | - | - | - | CLR_INT_ERR<br>_RX_OTHER | CLR_INT_ERR<br>_BIT | CLR_INT_ERR<br>_OVF | CLR_INT_RX_<br>DONE | | W | - | - | - | W | W | W | W | Initial value: XXH ${\tt CLR\_INT\_ER} \hspace{0.5cm} {\tt It\ clear\ INT\_ERR\_RX\_OTHER\ bit\ on\ CEC\_FSTAT\ register}$ R\_RX\_OTHE 0 R 1 Clear INT\_ERR\_RX\_OTHER bit CLR\_INT\_ERR\_ It clear INT\_ERR\_BIT bit on CEC\_FSTAT register BIT 0 1 Clear INT\_ERR\_BIT bit CLR\_INT\_ER It clear INT\_ERR\_OVF bit on CEC\_FSTAT register R\_OVF 0 1 Clear INT\_ERR\_OVF bit CLR INT RX It clear INT\_RX\_DONE bit on CEC\_FSTAT register \_DONE 0 - 1 Clear INT\_RX\_DONE bit # CEC\_TXH (CEC TX Header data buffer): 8F6BH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | TXH_7 | TXH_6 | TXH_5 | TXH_4 | TXH_3 | TXH_2 | TXH_1 | TXH_0 | | RW Initial value: XXH CEC\_TXH Initiator logical address 4 bit [7:4] **CEC\_TXH** Follower logical address 4 bit [3:0] (or 0x0F broadcasting address) # CEC\_TXD\_X (CEC TX Data buffers) : 8F6CH ~ 8F7EH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | TXD_7 | TXD_6 | TXD_5 | TXD_4 | TXD_3 | TXD_2 | TXD_1 | TXD_0 | | RW Initial value: 00H CEC\_TXD CEC TX data buffers( TX CEC Op code, parameters ) # CEC\_RXH (CEC RX Header data buffer): 8F7FH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | TXH_7 | TXH_6 | TXH_5 | TXH_4 | TXH_3 | TXH_2 | TXH_1 | TXH_0 | | RW Initial value: 00H CEC\_RXH destination logical address 4 bit [7:4] (0xF0 broadcasting address) initiator logical address 4 bit CEC\_TXH [3:0] # CEC\_RXD\_X (CEC RX Data buffers) : 8F80H ~8F92H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | RXD_7 | RXD_6 | RXD_5 | RXD_4 | RXD_3 | RXD_2 | RXD_1 | RXD_0 | | RW Initial value: 00H CEC\_RXD CEC RX data buffers( RX CEC Op code, parameters ) The following diagram describes response state for TX block state register when CEC line has no follower device or CEC devices do retry Figure 11.57 A/D Analog Input Pin Connecting Capacitor ### 11.15 IR Controller #### 11.15.1 Introduction The A97C450 embeds the hardware IR receiver with noise filter. Remote infra-red receivers are very sensitive to optical signals and may result in wrong data decoding. The noise filter will improve noise immunity of remote control signal. And then, the probabilities of wrong data decoding and the wake-up by noise on Stop mode are decreased. ## 11.15.2 IR Controller Register map | Name | Address | Direction | Default | Description | |-----------|---------|-----------|---------|------------------------------------------| | IRC_PRES1 | 8F48H | R/W | 00H | IRC Prescaler High Register | | IRC_PRES0 | 8F49H | R/W | 00H | IRC Prescaler Low Register | | IRC_FRMP1 | 8F4AH | R/W | 00H | IRC Frame Period Parameter High Register | | IRC_FRMP0 | 8F4BH | R/W | 00H | IRC Frame Period Parameter Low Register | | IRC_CONF | 8F4CH | R/W | 00H | IRC Configuration Register | | IRC_FLAG | 8F4DH | R/W | 00H | IRC Status Register | | IRC_EDGE1 | 8F4EH | R | 00H | IRC Edge Counter Data High Register | | IRC_EDGE0 | 8F4FH | R | 02H | IRC Edge Counter Data Low Register | Table 11.22 IR Controller Register map # 11.15.3 IR Controller Registers description The IR Controller consists of IRC Prescaler Register (IRC\_PRES1, IRC\_PRES0), IRC Frame Time Data Register (IRC\_FRMP1, IRC\_FRMP0), IRC Configuration Register (IRC\_CONF), IRC Status Register (IRC\_FLAG), and IRC Edge Capture Data Register (IRC\_EDGE1, IRC\_EDGE0). ### IRC\_PRES1 (IRC Prescaler Register): 8F48H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | PRES1_7 | PRES1_6 | PRES1_5 | PRES1_4 | PRES1_3 | PRES1_2 | PRES1_1 | PRES1_0 | | RW Initial value: 00H ### IRC\_PRES0 (IRC Prescaler Register): 8F49H | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---------|---------|---------|---------|---------|---------|---------|---------| | | PRES0_7 | PRES0_6 | PRES0_5 | PRES0_4 | PRES0_3 | PRES0_2 | PRES0_1 | PRES0_0 | | Ī | RW Initial value: 00H IRC\_PRES1/IRC\_PRES0 The registers are the prescaler value to set IR timer counter clock of IR pulse. It is written by software. IRC\_PRESx = (F<sub>SCLK</sub> / Target frequency) / 2 - 1 Fsclk is system clock frequency. Target frequency is a base clock of IRC Edge Counter and IRC Frame Period Parameter Ex) In case of IRC\_EDGE1/0 base clock = 0.03msec (32.768kHz), F<sub>SCLK</sub> = 16MHz , IRC\_PRES1/0 = 243 ((16MHz/32.768kHz))/2-1) ## IRC\_FRMP1 (IRC Frame Period Parameter Register): 8F4AH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | FRMP1_7 | FRMP1_6 | FRMP1_5 | FRMP1_4 | FRMP1_3 | FRMP1_2 | FRMP1_1 | FRMP1_0 | | RW Initial value: 00H ### IRC\_FRMP0 (IRC Frame Period Parameter Register): 8F4BH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | FRMP0_7 | FRMP0_6 | FRMP0_5 | FRMP0_4 | FRMP0_3 | FRMP0_2 | FRMP0_1 | FRMP0_0 | | RW Initial value: 00H IRC\_FRAM1/IRC\_FRMP0 The both registers are used to make IR frame periods. These values are written by software. The counter step depends on IRC Prescaler Register. If IRC frame period has more than the value of IRC\_FRMPx, it invokes interrupt event (The interrupt vector address is equal to IR INT0). IR frame periods = Frame time \* Target frequency If the values of IRC\_FRAM1 and IRC\_FRMP0 are 0FFH, frame interrupt event isn't invoked and interrupt is disabled. # IRC\_CONF (IRC Configuration Register) : 8F4CH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------------|----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------------|--------------------|----------------------------------|--|--| | AWAKE_EN | REDGE_EN | SEDGE_EN | FLT_SEL[2] | FLT_SEL[1] | FLT_SEL[0] | SUBCLK_EN | IRC_EN | | | | RW | RW | RW | RW | RW | R | RW | RW | | | | Initial value: 00 | Н | | | | | | | | | | | AWAKE | oscilla | | k source. If this | | | e of using sub-<br>e waked up by | | | | | | 0 | disable asyncl | nronous wake-up | ) | | | | | | | | 1 | • | ronous wake-up | | | | | | | | RDGE_I | EN This is | s rising or falling | - | nable bit. | | | | | | | | 0 | enable falling | | | | | | | | | | 1 | enable rising e | • | | | | | | | | SEDGE. | | lecide the edge in the edge in the decide the decide (rising an decided and de | | at is single edge | (rising or falling | g state) interrupt | | | | | | 0 | enable both e | dge interrupt | | | | | | | | | 1 | enable single | edge interrupt | | | | | | | | FLT_SE | L These | are noise filter s | election bits. | | | | | | | | | 0 | No noise filter | | | | | | | | | | 1 | Noise: <1 cycl | e, Sign | al: >2 cycles | | | | | | | | 2 | Noise: <2 cycl | | al: >3 cycles | | | | | | | | 3 | Noise: <3 cycl | e, Sign | al: >4 cycles | | | | | | | | 4 | Noise: <4 cycl | e, Sign | al: >5 cycles | | | | | | | | 5 | Noise: <5 cycl | | al: >6 cycles | | | | | | | | 6 | Noise: <6 cycl | e, Sign | al: >7 cycles | | | | | | | | 7 | Noise: <7 cycl | e, Sign | al: >8 cycles | | | | | | | SUBCL | <_EN Sub-o | scillator clock se | lect. If this bit is | set, IRC clock so | urce is sub-osc | illator clock. | | | | | | 0 | The system cl | ock is used as IF | RC clock source | | | | | | | | 1 | 1 Sub-oscillator clock is used as IRC clock source | | | | | | | | | IRC_EN | Enabl | e IRC block | | | | | | | | | | 0 | IRC block is in | active | | | | | | IRC block is active ## IRC\_FLAG (IRC status Register): 8F4DH IRC\_RX | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|---|---|---|---------|----------|--------|----------| | INT_AWAKE | - | - | - | INT_FRM | INT_EDGE | IRC_RX | TIMER_EN | | R | - | - | - | R | R | R | RW | Initial value: 00H INT\_AWAKE This bit is used to indicate when IRC is waked up from STOP mode in case of using sub-oscillator clock as IRC clock source. This bit can be invoked when AWAKE\_EN of IRC\_CONF is set. 0 Asynchronous wake-up is not invoked 1 Asynchronous wake-up is invoked INT\_FRM It indicate the interrupt event by IRC frame counter. It is cleared by software. O Frame time interrupt is not invoked 1 Frame time interrupt is invoked INT\_EDGE This is single edge interrupt flag bit. It is cleared by software. Edge interrupt is not invokedEdge interrupt is invoked The state of IR signal line is indicated 0 IR line is low1 IR line is high TIMER\_EN This bit is used to control frame and edge timer. If IRC\_RX has event, TIMER\_EN is set by hardware. If frame is finished, TIMER\_EN is cleared by software for next frame. 0 Frame and edge timer is cleared and disable. 1 Frame and edge timer is enable # IRC\_EDGE1 (IRC Edge Counter Register): 8F4EH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | EDGE1_7 | EDGE1_6 | EDGE1_5 | EDGE1_4 | EDGE1_3 | EDGE1_2 | EDGE1_1 | EDGE1_0 | | R | R | R | R | R | R | R | R | Initial value: 00H # IRC\_EDGE0 (IRC Edge Counter Register): 8F4FH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | EDGE0_7 | EDGE0_6 | EDGE0_5 | EDGE0_4 | EDGE0_3 | EDGE0_2 | EDGE0_1 | EDGE0_0 | | R | R | R | R | R | R | R | R | Initial value: 00H **IRC\_EDGE1/** The both registers are IR capture counter between IR signal edge events. At any **IRC\_EDGE0** case, IRC\_EDGE1/0 is only used depended on IRC Prescaler value(IRC\_PRES1/0) Figure 11.58 IR Receive Timing # 11.16 Comparator #### **11.16.1 Overview** The A97C450 contains 2 analog comparators which can be easily used to compare the external input voltage with internal reference voltage. ADC and Comparator have the same input. When the comparator input voltage is smaller than the reference voltage comparator output status is '0' and interrupt flag is generated. Each comparator interrupt flag is assigned to one interrupt vector. Comparator input debounce clock and length can be set. # 11.16.2 Block Diagram Figure 11.59 Buzzer Driver Block Diagram ## 11.16.3 Register Map | Name | Address | Direction | Default | Description | |-------------|---------|-----------|---------|----------------------------------------------| | COMPCON | 8F30H | R/W | 00H | Comparator Control Register | | COMPVREFSEL | 8F31H | R/W | 00H | Comparator Voltage Reference Select Register | | COMPST | 8F32H | R | 11H | Comparator Output Read Register | | COMPDBCNT | 8F33H | R/W | FFH | Comparator Output Debounce Register | Table 11.23 Comparator Register Map # 11.16.4 Comparator Register description # COMPCON (Comparator Control Register): 8F30H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------------|---------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------------|-----------|---------|--|--|--| | COMP2IF | COMP2DBCLKSEL | COMP2DBEN | COMP2EN | COMP1IF | COMP1DBCLKSEL | COMP1DBEN | COMP1EN | | | | | RW | | | | Initial value : F | FH | | | | | | | | | | | | COMP2 | | | | | | | | | | | | | 1 | • | interrupt occure | | | | | | | | | COMP2I | DBCL Selec | t debounce clock | • | 2 (DBCLK2) | | | | | | | | KSEL | | DBCLK2 = SC | | 00 | | | | | | | | | ]<br>Daha | | ernal 256KHz-O | | | | | | | | | COMP2 | | Debounce of comparator 2 output control Comparator 2 output debounce disable | | | | | | | | | | | 0 | • | output debound | | | | | | | | | COMPO | EN Comi | comparator 2<br>parator 2 operatio | • | e enable | | | | | | | | COMP2 | EN 00111 | Comparator 2 | | | | | | | | | | | 1 | 1 Comparator 2 enable | | | | | | | | | | COMP1 | | Comparator 1 interrupt flag. The flag is cleared only by writing a '1' to the bit. So, the flag should be cleared by software. Writing "0" has no effect. | | | | | | | | | | | 0 | Comparator 1 | interrupt not occ | curred | | | | | | | | | 1 | Comparator 1 | interrupt occure | d | | | | | | | | COMP1 | DBCL Selec | Select debounce clock of comparator 1 (DBCLK1) | | | | | | | | | | KSEL | 0 | DBCLK1 = SC | | | | | | | | | | | 1 | | ernal 256KHz-O | | | | | | | | | COMP1 | 002.1 | unce of compara | • | | | | | | | | | | 0 | • | output debounc | | | | | | | | | | 1 | • | output debounc | e enable | | | | | | | | COMP1 | | parator 1 operation | | | | | | | | | | | 0 | Comparator 1 | Disable | | | | | | | Comparator 1 Enable 1 # COMPVREFSEL (Comparator Voltage Reference Select Register) : 8F31H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----|--------|-------------|----|------------------|----|----|----|--| | | COMP2V | REFSEL[3:0] | | COMP1VREFSEL[30] | | | | | | RW | Initial value: 00H | COMP2VREF | | comparator 2 reference voltage | |-----------|--------|--------------------------------| | SEL[3:0] | 0000 | VDD x 0.348 | | | 0001 | VDD x 0.377 | | | 0010 | VDD x 0.406 | | | 0011 | VDD x 0.435 | | | 0100 | VDD x 0.464 | | | 0101 | VDD x 0.493 | | | 0110 | VDD x 0.522 | | | 0111 | VDD x 0.551 | | | 1000 | VDD x 0.580 | | | 1001 | Not used | | | 1010 | Not used | | | 1011 | Not used | | | 1100 | Not used | | | 1101 | Not used | | | 1110 | Not used | | | 1111 | Not used | | COMP1VREF | Select | comparator 1 reference voltage | | SEL[3:0] | 0000 | VDD x 0.348 | | | 0001 | VDD x 0.377 | | | 0010 | VDD x 0.406 | | | 0011 | VDD x 0.435 | | | 0100 | VDD x 0.464 | | | 0101 | VDD x 0.493 | | | 0110 | VDD x 0.522 | | | 0111 | VDD x 0.551 | | | 1000 | VDD x 0.580 | | | 1001 | Not used | | | 1010 | Not used | | | 1011 | Not used | | | 1100 | Not used | | | 1101 | Not used | | | 1110 | Not used | | | 1111 | Not used | # COMPST (Comparator Output Read Register): 8F32H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|----------|---|---|---|----------| | - | - | - | COMPOUT2 | - | - | - | COMPOUT1 | | _ | - | - | RW | - | - | - | RW | Initial value: 11H COMPOUT2 Comparator 2 output status 0 Comparator 2 output low 1 Comparator 2 output high (default) COMPOUT1 Comparator 1 output status 0 Comparator 1 output low 1 Comparator 1 output high (default) ## COMPDBCNT (Comparator Output Debounce Register): 8F33H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|------------|----|----|---|------------|----|----| | ı | COMP2DBCNT | | | - | COMP1DBCNT | | | | _ | RW | RW | RW | - | RW | RW | RW | Initial value: FFH $\begin{array}{ll} \text{COMP2DBCN} & \text{Select comparator 2 output debounce length} \\ \text{T[2:0]} & \text{Debounce length} = \text{COMP2DBCNT x 2 x 1/f}_{\text{dbclk2}} \\ \text{COMP1DBCN} & \text{Select comparator 1 output debounce length} \\ \text{T[2:0]} & \text{Debounce length} = \text{COMP1DBCNT x 2 x 1/f}_{\text{dbclk1}} \\ \end{array}$ # 11.17 RTC (Real-time Clock) ### **11.17.1 Overview** The real-time clock has the following features. - Using the SUB clock as RTC clock source (fRTC) - Having counters of year, month, week, day, hour, minute, and second, and can count up to 99 years. - Constant-period interrupt function (period: 0.5 seconds, 1 second, 1 minute, 1 hour, 1 day, 1 month) - Alarm interrupt function (alarm: week, hour, minute) - Pin output function of 1Hz The real-time clock interrupt signal (RTCIFR) can be utilized for wakeup from STOP. # 11.17.2 Block Diagram Figure 11.60 RTC block diagram # 11.17.3 RTC Operation Figure 11.61 Procedure for Starting Operation of RTC - 1. First set the RTCEN bit to 1, while oscillation of the count clock (SUB-clock) is stable. - 2. Set up the ERRCOR register only if the error must be corrected. For details about how to calculate the correction value, see error correction register (ERRCOR) description. ## 11.17.4 Shifting to Power-Down mode after starting operation Perform one of the following processing when shifting to power down mode immediately after setting the RTCE bit to 1. However, after setting the RTCE bit to 1, this processing is not required when shifting to power down mode after the RTC interrupt has occurred. - 1. Shifting to HALT/STOP mode when at least two cycles of the count clock (fRTC) have elapsed after setting the RTCE bit to 1 (see Example 1). - 2. Checking by polling the RWST bit to become 1, after setting the RTCE bit to 1 and then setting the RWAIT bit to 1. Afterward, setting the RWAIT bit to 0 and shifting to HALT/STOP mode after checking again by polling that the RWST bit has become 0 (see Example 2). Figure 11.62 Procedure for Starting Operation of RTC ## 11.17.5 Reading/writing RTC Read or write the counter after setting 1 to RWAIT first. Set RWAIT to 0 after completion of reading or writing the counter. Figure 11.63 Procedure for Reading RTC ### NOTE) - 1. Be sure to confirm that RWST = 0 before setting STOP mode. - Complete the series of process of setting the RWAIT bit to 1 to clearing the RWAIT bit to 0 within 1 second. - 3. The second count register (SEC), minute count register (MIN), hour count register (HOUR), week count register (WEEK), day count register (DAY), month count register (MONTH), and year count register (YEAR) may be read/written in any sequence. - 4. All the registers do not have to read and only some registers may be read or written. - 5. When changing the values of the SEC, MIN, HOUR, WEEK, DAY, MONTH, and YEAR register while the counter operates (RTCE = 1), rewrite the values of the MIN register after disabling interrupt servicing INTRTC by using the interrupt mask flag register. Furthermore, clear the WAFG, RIFG and RTCIF flags after rewriting the MIN register. <</p> ## 11.17.6 Setting alarm of RTC Set time of alarm after setting 0 to WALIE (alarm operation invalid.) first. Figure 11.64 Procedure for Reading RTC The alarm week register (ALARMWW), alarm hour register (ALARMWH), and alarm week register (ALARMWW) may be written in any sequence. Fixed-cycle interrupts and alarm match interrupts use the same interrupt source (RTC interrupt). When using these two types of interrupts at the same time, which interrupt occurred can be judged by checking the fixed-cycle interrupt status flag (RIFG) and the alarm detection status flag (WAFG) upon RTC interrupt occurrence. | | | Day<br>(ALARMWW) | | | | | | | 12-Hour Display | | 24-Hour Display | | |------------------------------------|-----------------------|-----------------------|------------------------|--------------------------|-------------------------|-----------------------|-------------------------|-------------------|---------------------|-------------------|---------------------|--| | Time of Alarm | Sunday<br>W<br>W<br>0 | Monday<br>W<br>W<br>1 | Tuesday<br>W<br>W<br>2 | Wednesday<br>W<br>W<br>3 | Thursday<br>W<br>W<br>4 | Friday<br>W<br>W<br>5 | Saturday<br>W<br>W<br>6 | Hour<br>(ALARMWH) | Minute<br>(ALARMWM) | Hour<br>(ALARMWH) | Minute<br>(ALARMWM) | | | Every day, 0:00 a.m. | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 12 | 00 | 00 | 00 | | | Every day, 1:30 a.m. | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 01 | 30 | 01 | 30 | | | Every day, 11:59 a.m | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 11 | 59 | 11 | 59 | | | Monday through<br>Friday, 0:00 p.m | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 32 | 00 | 12 | 00 | | | Sunday, 1:30 p.m | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 21 | 30 | 13 | 30 | | | Monday, Wednesday,<br>11:59 p.m | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 31 | 59 | 23 | 59 | | Table 11.24 Example of setting the alarm ### 11.17.7 Error Correction of RTC The watch can be corrected with high accuracy when it is slow or fast, by setting a value to the error correction register. The correction value is 2, 4, 6, 8, ... 120, 122, 124 or -2, -4, -6, -8, ... -120, -122, -124. The target frequency is the frequency resulting after correction performed by using the error correction register. <Example of calculating the correction value> The correction value used when correcting the count value of the internal counter (16-bit) is calculated by using the following expression. Set the DEV bit to 0 when the correction range is 63.1 ppm or less, or 63.1 ppm or more. - When DEV = 0 : Correction value = Number of correction counts in 1 minute ÷ 3 $$= (f_{RTC} \div 32768 - 1) \times (32768 \times 60 \div 3)$$ - When DEV = 1 : Correction value = Number of correction counts in 1 minute $$= (f_{RTC} \div 32768 - 1) \times (32768 \times 60)$$ The correction value is the calculated by using bits 6 to 0 of the error correction register (ERRCOR). (When F6 = 0) Correction value = {(F5, F4, F3, F2, F1, F0) - 1} x 2 (When F6 = 1) Correction value = $\{(/F5, /F4, /F3, /F2, /F1, /F0) + 1\} \times 2$ When (F6, F5, F4, F3, F2, F1, F0) is (\*, 0, 0, 0, 0, 0, \*), watch error correction is not performed. "\*" is 0 or 1. /F5 to /F0 are bit-inverted values (000011 when 111100). <Correction example> Example of correcting from 32772.3 Hz to 32768 Hz (32772.3 Hz – 131.2 ppm) #### 1. Measuring the oscillation frequency The free is measured by outputting to RTC1HZ pin when the ERRCOR register is set to its initial value (00H). #### 2. Calculating the correction value Assume the target frequency to be 32768 Hz (32772.3Hz-131.2ppm) and DEV to be 0, because the correctable range of -131.2 ppm is -63.1 ppm or lower. Correction value = $$(f_{RTC} \div 32768 - 1) \times 32768 \times 60 \div 3$$ = $(32772.3 \div 32768 - 1) \times 32768 \times 60 \div 3 = 86$ # 3. Calculating the values to be set to (F6 to F0) If the correction value is 0 or larger (when slowing), assume F6 to be 0. Calculate (F5, F4, F3, F2, F1, F0) from the correction value. $$\{ (F5, F4, F3, F2, F1, F0) - 1 \} \times 2 = 86$$ $(F5, F4, F3, F2, F1, F0) = (1, 0, 1, 1, 0, 0)$ Consequently, when correcting from 32772.3 Hz to 32768 Hz (32772.3 Hz - 131.2 ppm), setting the error correction register such that DEV is 0 and the correction value is 86 (bits 6 to 0 of the ERROR register : 0101100) results in 32768 Hz (0 ppm). # 11.17.8 Register Map | Name | Address | Direction | Default | Description | | |---------|---------|-----------|---------|---------------------------------|--| | RTCC0 | 8FB1H | R/W | 00H | RTC Control Register 0 | | | RTCC1 | 8FB2H | R/W | 00H | RTC Control Register 1 | | | ERRCOR | 8FB3H | R/W | 00H | Watch Error Correction Register | | | SEC | 8FB4H | R/W | 00H | Second Count Register | | | MIN | 8FB5H | R/W | 00H | Minute Count Register | | | HOUR | 8FB6H | R/W | 12H | Hour Count Register | | | DAY | 8FB7H | R/W | 01H | Day Count Register | | | WEEK | 8FB8H | R/W | 00H | Week Count Register | | | MONTH | 8FB9H | R/W | 01H | Month Count Register | | | YEAR | 8FBAH | R/W | 00H | Year Count Register | | | ALARMWM | 8FBBH | R/W | 00H | Alarm Minute Register | | | ALARMWH | 8FBCH | R/W | 12H | Alarm Hour Register | | | ALARMWW | 8FBDH | R/W | 00H | Alarm Week Register | | Table 11.25 RTC Register Map # 11.17.9 RTC Register description # RTCC0 (RTC Control Register 0): 8FB1H | , | 0 | 3 | | 4 | 3 | 2 | • | U | | | |------|--------|-----------------------------------|----------|------------|---------------------------------|--------------------|------------------|--------------------|--|--| | RTCE | - | RTCO1HZEN | | - | AMPM | CT2 | CT1 | СТО | | | | RW | - | RW | | - | RW | RW | RW | RW | | | | | | | | | | | Ir | nitial value : 00H | | | | | RTCE | RTC o | peratio | n control | . (RWST, RWAIT) | | | | | | | | | 0 | Stops | s counter | operation. | | | | | | | | RTCO1H | ZEN RTCO | 1HZ pir | output o | control. | | | | | | | | | 0 | Disab | oles outp | ut of the RTCO1H | Z pin (1Hz). | | | | | | | AMPM | PM Selection of 1/-24-hour system | | | | | | | | | | | | 0 | 12-h | our syste | m (a.m. and p.m. | are displayed.) | | | | | | | | 1 | 24-h | our syste | m | | | | | | | | CT | Consta | ant-peri | od interru | upt (INTRTC) sele | ction | | | | | | | | CT2 | CT1 | CT0 | description | | | | | | | | | 0 | 0 | 0 | Does not use con | stant-period inte | errupt function. | | | | | | | 0 | 0 | 1 | Once per 0.5 s (s | ynchronized with s | second count up) | | | | | | | 0 | 1 | 0 | Once per 1 s (sar | ne time as seco | nd count up) | | | | | | | 0 | 1 | 1 | Once per 1 m (se | cond 00 of ever | y minute) | | | | | | | 1 | 0 | 0 | Once per 1 hour ( | (minute 00 and s | second 00 of ev | ery hour) | | | | | | 1 | 0 | 1 | Once per 1 day (h | nour 00, minute | 00, and second | 00 of every day) | | | | | | 1 | 1 | 0 | Once per 1 mont of every month) | h (Day 1, hour ( | 00 a.m., minute | 00, and second 00 | | | ## NOTE) 1. AMPM can be changed only in WAIT mode. If the AMPM bit value is changed, the values of the hour count register (HOUR) change according to the specified time system in Table 11.26. reserved 1 1 ### RTCC1 (RTC Control Register 1): 8FB2H | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-------|-------------|-------|------|------|---|------|-------| | | RTCEN | SUB_ON_STOP | WALIE | WAFG | RIFG | - | RWST | RWAIT | | Ī | RW | RW | RW | RW | RW | - | R | RW | Initial value: 00H | | | Titlet ve | |-----------|-----------|----------------------------------------------------------------------------------------------------| | RTCEN | Control I | RTC input clock supply. | | | 0 | Stop RTC input clock supply. | | | | SFR used by the RTC cannot be written. | | | | The RTC is in the reset status. | | | 1 | Enable RTC input clock supply. | | | | SFR used by the RTC can be read and written. | | SUB_ON_ST | SUB clo | ck enable or disable at stop mode | | OP | 0 | SUB clock disable at stop mode | | | 1 | SUB clock enable at stop mode | | WALIE | Alarm op | peration control | | | 0 | Match operation is invalid. | | | 1 | Match operation is valid | | WAFG | | etection status flag. This flag is cleared when "0" is written to it. 1" to it is invalid. | | | 0 | Alarm mismatch | | | 1 | Detection of matching of alarm | | RIFG | | t-period interrupt status flag. This flag is cleared when "0" is written ing "1" to it is invalid. | | | 0 | Constant-period interrupt is not generated. | | | 1 | Constant-period interrupt is generated. | | RWST | Wait-mod | de status flag of real-time clock | | | 0 | Counter is operating. | | | 1 | Mode to write counter value | | RWAIT | Wait con | trol of real-time clock | | | 0 | Sets counter operation. | | | 1 | Stops SEC to YEAR counters. Mode to write counter value | # NOTE) - 2. If RTCEN = 0, writing to a control register of the real-time clock or interval timer is ignored. Even if the registers are read, only default values are read. (SEC to YEAR, ALARMWx, ERRCOR) - 3. RWST indicates whether the setting of the RWAIT bit is valid. Before writing the counter value, confirm that the value of this flag is 1. - 4. RWAIT controls the operation of the counter. Be sure to write "1" to it to write the counter value. As the sub-count register is continuing to run, complete writing within one second and turn back to 0. When the sub-count register overflowed while RWAIT = 1, it keeps the event of overflow until RWAIT = 0, then counts up. However, when it wrote a value to second count register, it will not keep the overflow event. - Remark Fixed-cycle interrupts and alarm match interrupts use the same interrupt source (RTCIFR). When using these two types of interrupts at the same time, which interrupt occurred can be judged by checking the fixed-cycle interrupt status flag (RIFG) and the alarm detection status flag (WAFG) upon INTRTC occurrence ### SEC (Second count register): The SEC register is an 8-bit register that takes a value of 0 to 59 (decimal) and indicates the count value of seconds. It counts up when the sub-count register overflows. When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'. Set a decimal value of 00 to 59 to this register in BCD code. If a value that is not a BCD code is written, it is ignored. If a value outside the range is written, the reset value is set. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|------|------|------|------|------|------|------| | - | SEC6 | SEC5 | SEC4 | SEC3 | SEC2 | SEC1 | SEC0 | | - | RW Initial value: 00H # MIN (Minute count register): The MIN register is an 8-bit register that takes a value of 0 to 59 (decimal) and indicates the count value of minutes. It counts up when the second counter overflows. When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'. Even if the second count register overflows while this register is being written, this register ignores the overflow and is set to the value written. Set a decimal value of 00 to 59 to this register in BCD code. If a value that is not a BCD code is written, it is ignored. If a value outside the range is written, the reset value is set. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|------|------|------|------|------|------|------| | - | MIN6 | MIN5 | MIN4 | MIN3 | MIN2 | MIN1 | MINO | | - | RW Initial value: 00H ### **HOUR** (Hour count register): The HOUR register is an 8-bit register that takes a value of 00 to 23 or 01 to 12 and 21 to 32 (decimal) and indicates the count value of hours. It counts up when the minute counter overflows. When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'. Even if the minute count register overflows while this register is being written, this register ignores the overflow and is set to the value written. Specify a decimal value of 00 to 23, 01 to 12, or 21 to 32 by using BCD code according to the time system specified using bit 3 (AMPM) of real-time clock control register 0 (RTCC0). If the AMPM bit value is changed, the values of the HOUR register and ALARMWH register change according to the specified time system. If a value that is not a BCD code is written, it is ignored. If a value outside the range is written, the reset value is set. Reset signal clears this register to 12H. However, the value of this register is 00H if the AMPM bit (bit 3 of the RTCC0 register) is set to 1 after reset. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | - | - | HOUR5 | HOUR4 | HOUR3 | HOUR2 | HOUR1 | HOUR0 | | - | - | RW | RW | RW | RW | RW | RW | Initial value: 12H In 12-hour display, the fifth bit of the HOUR register displays 0 for AM and 1 for PM. This table below shows the relationship between the setting value of the AMPM bit, the hour count register (HOUR) value, and time. | 24-Hour Disp | lay (AMPM=1) | 12-Hour Display (AMPM=0) | | | | |--------------|------------------|--------------------------|-----|--|--| | Time | HOUR<br>Register | Time | 00H | | | | 0 | 00H | 12 a.m. | 12H | | | | 1 | 01H | 1 a.m. | 01H | | | | 2 | 02H | 2 a.m. | 02H | | | | 3 | 03H | 3 a.m. | 03H | | | | 4 | 04H | 4 a.m. | 04H | | | | 5 | 05H | 5 a.m. | 05H | | | | 6 | 06H | 6 a.m. | 06H | | | | 7 | 07H | 7 a.m. | 07H | | | | 8 | 08H | 8 a.m. | 08H | | | | 9 | 09H | 9 a.m. | 09H | | | | 10 | 10H | 10 a.m. | 10H | | | | 11 | 11H | 11 a.m. | 11H | | | | 12 | 12H | 12 p.m. | 32H | | | | 13 | 13H | 1 p.m. | 21H | | | | 14 | 14H | 2 p.m. | 22H | | | | 15 | 15H | 3 p.m. | 23H | | | | 16 | 16H | 4 p.m. | 24H | | | | 17 | 17H | 5 p.m. | 25H | | | | 18 | 18H | 6 p.m. | 26H | | | | 19 | 19H | 7 p.m. | 27H | | | | 20 | 20H | 8 p.m. | 28H | | | | 21 | 21H | 9 p.m. | 29H | | | | 22 | 22H | 10 p.m. | 30H | | | | 23 | 23H | 11 p.m. | 31H | | | Table 11.26 Time system of HOUR ## DAY (Day count register): The DAY register is an 8-bit register that takes a value of 1 to 31 (decimal) and indicates the count value of days. It counts up when the hour counter overflows. This counter counts as follows. - 01 to 31 (January, March, May, July, August, October, December) - 01 to 30 (April, June, September, November) - 01 to 29 (February, leap year) - 01 to 28 (February, normal year) When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'. Even if the hour count register overflows while this register is being written, this register ignores the overflow and is set to the value written. Set a decimal value of 01 to 31 to this register in BCD code. If a value that is not a BCD code is written, it is ignored. If a value outside the range is written, the reset value is set. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|------|------|------|------|------|------| | - | - | DAY5 | DAY4 | DAY3 | DAY2 | DAY1 | DAY0 | | - | - | RW | RW | RW | RW | RW | RW | Initial value: 01H ### WEEK (Week count register): The WEEK register is an 8-bit register that takes a value of 0 to 6 (decimal) and indicates the count value of weekdays. It counts up in synchronization with the day counter. When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'. Set a decimal value of 00 to 06 to this register in BCD code. If a value that is not a BCD code is written, it is ignored. If a value outside the range is written, the reset value is set. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|-------|-------|-------| | - | - | - | - | ı | WEEK2 | WEEK1 | WEEK0 | | - | - | - | - | - | RW | RW | RW | Initial value: 00H The value corresponding to the month count register (MONTH) or the day count register (DAY) is not stored in the week count register (WEEK) automatically. After reset release, set the week count register as follow. | Day | | | | | | |-----------|-----|--|--|--|--| | Sunday | 00H | | | | | | Monday | 01H | | | | | | Tuesday | 02H | | | | | | Wednesday | 03H | | | | | | Thursday | 04H | | | | | | Friday | 05H | | | | | | Saturday | 06H | | | | | Table 11.27 Week count register setting ### **MONTH** (Month count register): The MONTH register is an 8-bit register that takes a value of 1 to 12 (decimal) and indicates the count value of months. It counts up when the day counter overflows. When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'. Even if the day count register overflows while this register is being written, this register ignores the overflow and is set to the value written. Set a decimal value of 01 to 12 to this register in BCD code. If a value that is not a BCD code is written, it is ignored. If a value outside the range is written, the reset value is set. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|--------|--------|--------|--------|--------| | - | - | - | MONTH4 | MONTH3 | MONTH2 | MONTH1 | MONTH0 | | - | - | - | RW | RW | RW | RW | RW | Initial value: 01H ### YEAR (Year count register): The YEAR register is an 8-bit register that takes a value of 0 to 99 (decimal) and indicates the count value of years. It counts up when the month count register overflows. Values 00, 04, 08, ..., 92, and 96 indicate a leap year. When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'. Even if the MONTH register overflows while this register is being written, this register ignores the overflow and is set to the value written. Set a decimal value of 00 to 99 to this register in BCD code. If a value that is not a BCD code is written, it is ignored. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | YEAR7 | YEAR6 | YEAR5 | YEAR4 | YEAR3 | YEAR2 | YEAR1 | YEAR0 | | RW Initial value: 00H ### ERRCOR (Watch error correction register): This register is used to correct the watch with high accuracy when it is slow or fast by changing the value that overflows from the sub-count register to the second count register (SEC) (reference value: 7FFFH). | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|----|----|----|----|----|----|----| | DEV | F6 | F5 | F4 | F3 | F2 | F1 | F0 | | RW Initial value: 00H DEV Setting of watch error correction timing O Corrects watch error when the second digits are at 00, 20, or 40 (every 20 seconds). 1 Corrects watch error only when the second digits are at 00 (every 60 seconds) F6~F0 Setting of watch error correction value F6=0 Decreases by $\{(F5, F4, F3, F2, F1, F0) - 1\} \times 2$ . F6=1 Increases by $\{(/F5, /F4, /F3, /F2, /F1, /F0) + 1\} \times 2$ . When (F6, F5, F4, F3, F2, F1, F0) = (\*, 0, 0, 0, 0, 0, \*), the watch error is not corrected. \* is 0 or 1. /F5 to /F0 are the inverted values of the corresponding bits (000011 when 111100). Range of correction value: (when F6 = 0) 2, 4, 6, 8, ..., 120, 122, 124 (when F6 = 1) -2, -4, -6, -8, ..., -120, -122, -124 The range of value that can be corrected by using the watch error correction register (ERRCOR) is shown below. | | DEV = 0 (correction every 20 seconds) | DEV = 1 (correction every 60 seconds) | |-------------------------------------|---------------------------------------|---------------------------------------| | Correctable range | -189.2 ppm to 189.2 ppm | -63.1 ppm to 63.1 ppm | | Maximum excludes quantization error | ±1.53 ppm | ±0.51 ppm | | Minimum resolution | ±3.05 ppm | ±1.02 ppm | Table 11.28 The range of correction If a correctable range is -63.1 ppm or lower and 63.1 ppm or higher, set 0 to DEV. ## ALARMWM (Alarm minute register) : This register is used to set minutes of alarm. Set a decimal value of 00 to 59 to this register in BCD code. If a value outside the range is set, the alarm is not detected. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-----|-----|-----|-----|-----|-----|-----| | - | WM6 | WM5 | WM4 | WM3 | WM2 | WM1 | WMO | | - | RW Initial value: 00H ### ALARMWH (Alarm hour register): This register is used to set hours of alarm. Reset signal generation clears this register to 12H. However, the value of this register is 00H if the AMPM bit (bit 3 of the RTCC0 register) is set to 1 after reset. Set a decimal value of 00 to 23, 01 to 12, or 21 to 32 to this register in BCD code. If a value outside the range is set, the alarm is not detected. The values of the ALARMWH register change according to the specified time system when AMPM bit is changing. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-----|-----|-----|-----|-----|-----| | - | - | WH5 | WH4 | WH3 | WH2 | WH1 | WHO | | - | - | RW | RW | RW | RW | RW | RW | Initial value: 12H ## ALARMWW (Alarm week register): This register is used to set date of alarm. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-----|-----|------|-----|-----|------|-----| | - | WW6 | WW5 | VWV4 | WW3 | WW2 | VVV1 | WWO | | - | RW Initial value: 00H ### 11.18 BISC #### 11.18.1 Overview The A97C450 has built in self calibration circuit for internal 16MHz RC-OSC. If the BISC counter is less than the reference counter the trim value sets to slow value, if the BISC counter is larger than the reference counter the trim value sets to fast value. Reference counter input clock is sub-OSC. Refer to the following example. - 1. Enables reference clock source. - 2. Set the BISC counter register value (INTCNTH, INTCNTL). - Set the reference counter register value (XTLCNTH, XTLCNTL). The overflow period of XTLCNTH,XTLCNTL must be the same as the expected overflow period of INTCNTH,INTCNTL. - 4. Enable built in self calibration by set CAL\_EN of BISCCON register. Figure 11.65 BISC waveform ## 11.18.2 Register Map | Name | Address | Direction | Default | Description | | | |---------|---------|-----------|---------|--------------------------------------|--|--| | BISCCON | 8F28H | R | 00H | BISC Control Register | | | | INTCNTH | 8F29H | R/W | 00H | BISC Counter Register High | | | | INTCNTL | 8F2AH | R/W | 00H | BISC Counter Register Low | | | | XTLCNTH | 8F2BH | R/W | 00H | BISC Reference Counter Register High | | | | XTLCNTL | 8F2CH | R/W | 00H | BISC Reference Counter Register Low | | | Table 11.29 BISC Register Map # 11.18.3 BISC Register description **BISCCON (BISC Control Register): 8F28H** | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---------|--------| | - | - | - | - | - | - | SUB_SEL | CAL_EN | | - | - | - | - | - | - | - | RW | Initial value: 00H SUB\_SEL Select reference clock. 0 Don't'use Select sub-crystal oscillator CAL\_EN Enable built in self calibration of internal RC-OSC 0 BISC disable1 BISC enable ## INTCNTH (BISC Counter Register High): 8F29H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---------|----|----|----|----|----|----|--------------------|--|--| | INTONTH | | | | | | | | | | | RW | | | | | | | | | Ir | nitial value : 00H | | | ### INTCNTL (BISC Counter Register Low): 8F2AH | 7 6 5 4 3 2 1 | | | | | | | | | | |---------------|---------|----|----|----|----|----|----|----|--| | | INTONTL | | | | | | | | | | | RW | Initial value: 00H INTCNT[15:0] BISC counter register, the clock of this register is internal RC-OSC. ## XTLCNTH (BISC Reference Counter Register High): 8F2BH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|----|----|----|----|----|----|----|--| | XTLCNTH | | | | | | | | | | RW | | | | | | | | | | | Initial value: 00H # XTLCNTL (BISC Reference Counter Register Low): 8F2CH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |----|-------------------|---|---|---|---|---|---|--|--| | | XTLCNTL | | | | | | | | | | RW | RW RW RW RW RW RW | | | | | | | | | Initial value: 00H XTLCNT[15:0] BISC reference counter register, the clock of this register is sub-OSC. # 11.19 CRC #### 11.19.1 Overview Using the CRC, it can be monitor the memory of the specified area. This is a one-time operation, and reset is required for continuous operation. In CRC MNT mode, when the CRC read is finished, CRC\_FLAG occurs. In CRC validate mode, if the CRC validate fail after the CRC reading is finished, CRC\_FLAG occurs. CRC\_FAIL indicates the status of validate results when the CRC read is finished. If the CRC\_FLAG is generated and the interrupt is enabled, interrupt service routine is served. CRC-FLAG is not cleared by hardware. CRC-TYPE 0~3 are not supported. Validate is done by comparing the CRC\_MNT register and the CRC register value. CRC are not automatically initialized, you need to calculate a new CRC after CRC\_H, CRC\_L Clear. When using CRC for CRC\_TYPE 5 and CRC\_TYPE 7, add 256 to the XRAM address and use it. (For IXRAM data CRC, use the physical address.: IRAM (0~0xFF), XRAM (0x100~0x10FF) | CRC TYPE | CRC mode | input | Condition of CRC_FLAG | Condition of CRC reset | | | |--------------------|----------|-------|-----------------------------------|------------------------|--|--| | CRC_TYPE = 4 MNT F | | Flash | After CRC reading | Validate fail | | | | CRC_TYPE = 5 MNT | | IXRAM | After CRC reading | Validate fail | | | | CRC_TYPE = 6 | Validate | Flash | After CRC reading & Validate fail | Validate fail | | | | CRC_TYPE = 7 | validate | IXRAM | After CRC reading & Validate fail | Validate fail | | | Table 11.30 CRC mode # 11.19.2 Block Diagram Figure 11.66 CRC block diagram # 11.19.3 Register Map | Name | Address | Direction | Default | Description | |------------------|---------|-----------|---------|-----------------------------------| | CRC_CON | 8FE0H | R/W | 00H | CRC Control Register | | CRC_H | 8FE2H | R/W | 00H | CRC High Register | | CRC_L | 8FE3H | R/W | 00H | CRC Low Register | | CRC_MNT_H | 8FE4H | R/W | 00H | CRC Monitor High Register | | CRC_MNT_L | 8FE5H | R/W | 00H | CRC Monitor Low Register | | CRC_ADDR_START_H | 8FE9H | R/W | 00H | CRC Start Address High Register | | CRC_ADDR_START_M | 8FEAH | R/W | 00H | CRC Start Address Middle Register | | CRC_ADDR_START_L | 8FEBH | R/W | 00H | CRC Start Address Low Register | | CRC_ADDR_END_H | 8FECH | R/W | 00H | CRC End Address High Register | | CRC_ADDR_END_M | 8FEDH | R/W | 00H | CRC End Address Middle Register | | CRC_ADDR_END_L | 8FEEH | R/W | 00H | CRC End Address Low Register | Table 11.31 CRC Register Map # 11.19.4 CRC Register description # CRC\_CON (CRC Control Register) : 8FE0H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |--------------------|-----------|-------------|----------------------------------------------------------------------------------------|---------------------------------------|------------------|------------------|----------------|--|--|--|--| | CRC_FLAG | CRC_INTEN | CRC_RESETEN | CRC_EN | CRC_FAIL | CRC_TYPE[2] | CRC_TYPE[1] | CRC_TYPE[0] | | | | | | RW | | | | | Initial value : 00 | H | | | | | | | | | | | | | CRC_FL | | | cleared only by<br>/riting "1" has no | | the bit. So, the | flag should be | | | | | | | | * When o | go to interrupt se<br>CRC flag not o | rvice routine, CR<br>occur | C_FLAG is not cl | eared. | | | | | | | | | 1 | CRC flag occu | ır | | | | | | | | | | INT_EN | Enable | CRC interrupt | | | | | | | | | | | | 0 | CRC interrupt | disable | | | | | | | | | | | 1 | 1 CRC interrupt enable | | | | | | | | | | | RESET_ | _EN Enable | Enable CRC reset | | | | | | | | | | | | 0 | CRC reset dis | able | | | | | | | | | | | 1 | 1 CRC reset enable | | | | | | | | | | | CRC_E | ا Enable | Enable CRC operation, it is cleared automatically after the CRC monitoring is finished | | | | | | | | | | | | 0 | CRC disable | | | | | | | | | | | | 1 | CRC enable | | | | | | | | | | | CRC_F/ | \IL | of CRC validate | ). | | | | | | | | | | | 0 | Validate pass | | | | | | | | | | | | 1 | Validate fail | | | | | | | | | | | CRC_T\ | · · -լ-· | the CRC input of | = = | | | | | | | | | | 0] | | | anged only wher | CRC_EN=0. | | | | | | | | | | 0xx | Not used | | | | | | | | | | | | 100 | Specified flash | | | | | | | | | | | | 101 | Specified IXRA | | | | | | | | | | | | 110 | • | data, validate C | | | | | | | | | | | 111 | Specified IXRA | AM data, validate | e CRC value | | | | | | | | CRC_H ( | (CRC High | Register) | ): 8FE2 | ŁΗ | |---------|-----------|-----------|---------|----| |---------|-----------|-----------|---------|----| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|--------|---------|---------|--------|--------| | CRO[15] | CRQ[14] | CRQ[13] | CRQ12] | CRQ[11] | CRC[10] | CRC[9] | CRC[8] | | RW Initial value: 00H CRC\_L (CRC Low Register): 8FE3H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | CRQ[7] | CRC[6] | CRC[5] | CRC[4] | CRC[3] | CRC[2] | CRQ[1] | CRC[0] | | RW Initial value: 00H CRC[15:0] CRC result ## CRC\_MNT\_H (CRC Monitor High Register): 8FE4H | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------------|-------------|-------------|-------------|-------------|-------------|-------------|------------|------------| | | CRC_MNT[15] | CRC_MNT[14] | CRC_MNT[13] | CRC_MNT[12] | CRC_MNT[11] | CRC_MNT[10] | CRC_MNT[9] | CRC_MNT[8] | | | RW | Initial value : 00H | | | | | | | | | # CRC\_MNT\_L (CRC Monitor Low Register): 8FE5H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|------------|------------|------------|------------|------------|------------|------------| | CRC_MNT[7] | CRC_MNT[6] | CRC_MNT[5] | CRC_MNT[4] | CRC_MNT[3] | CRC_MNT[2] | CRC_MNT[1] | CRC_MNT[0] | | RW Initial value: 00H CRC\_MNT[15:0] CRC compare register, when performing a validate # CRC\_ADDR\_START\_H (CRC Start Address High Register): 8FE9H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|------------------------| | - | - | - | - | - | - | - | CRC_ADDR_STA<br>RT[16] | | RW Initial value: 00H # CRC\_ADDR\_START\_M (CRC Start Address Middle Register) : 8FEAH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|-----------------------|-----------------------| | CRC_ADDR_STA<br>RT[15] | CRC_ADDR_STA<br>RT[14] | CRC_ADDR_STA<br>RT[13] | CRC_ADDR_STA<br>RT[12] | CRC_ADDR_STA<br>RT[11] | CRC_ADDR_STA<br>RT[10] | CRC_ADDR_STA<br>RT[9] | CRC_ADDR_STA<br>RT[8] | | RW Initial value: 00H # CRC\_ADDR\_START\_L (CRC Start Address Low Register) : 8FEBH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | U | |--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | CRC_ADDR_STA | RT[7] | RT[6] | RT[5] | RT[4] | RT[3] | RT[2] | RT[1] | RT[10] | | RW Initial value: 00H CRC\_ADDR\_START[16:0] CRC start address # CRC\_ADDR\_END\_H (CRC End Address High Register) : 8FECH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|----|----------------------| | - | - | - | - | - | - | - | CRC_ADDR_END<br>[16] | | RW Initial value: 00H # CRC\_ADDR\_END\_M (CRC End Address Middle Register) : 8FEDH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | CRC_ADDR_END | [15] | [14] | [13] | [12] | [11] | [10] | [9] | [8] | | RW Initial value: 00H # CRC\_ADDR\_END\_L (CRC End Address Low Register) : 8FEEH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------------|---------------------|---------------------|---------------------|------------------|------------------|------------------|----------------------| | CRC_ADDR_END<br>[7] | CRC_ADDR_END<br>[6] | CRC_ADDR_END<br>[5] | CRC_ADDR_END<br>[4] | CRC_ADDR_END [3] | CRC_ADDR_END [2] | CRC_ADDR_END [1] | CRC_ADDR_END<br>[10] | | RW Initial value: 00H CRC\_ADDR\_END[16:0] CRC end address # 11.19.5 CRC Polynomial $f(x) = 1+x^7+x^10+x^11+x^15+x^16$ CRC16, Polynomial representations Normal: 0x8C81 # 12 Power Down Operation ## 12.1 Overview The A97C450 has five power-down modes to minimize the power consumption of the device. In power down mode, power consumption is reduced considerably. The device provides five kinds of power saving functions, IDLE, SLEEP1, SLEEP2, STOP1 and STOP2 mode. In five modes, program is stopped. # 12.2 Peripheral Operation in IDLE/STOP Mode | Peripheral | IDLE, SLEEP1 Mode | SLEEP2, STOP1, STOP2 Mode | |--------------------------------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CPU | ALL CPU Operation are Disable | ALL CPU Operation are Disable | | RAM | Retain | Retain | | Basic Interval<br>Timer | Operates Continuously | Stop | | Watch Dog<br>Timer | Operates Continuously | Operates Continuously | | Watch Timer | Operates Continuously | Stop (Only operate in sub clock mode) | | TimerP0~1 | Operates Continuously | Halted (Only when the External Clock Mode is Enable, Timer operates Normally) | | ADC | Operates Continuously | Stop | | BUZ | Operates Continuously | Stop | | SPI/SCI | Operates Continuously | Only operate with external clock | | I2C | Operates Continuously | Stop | | Main OSC<br>(1~16MHz) | Oscillation | Stop | | Sub OSC<br>(32.768kHz) | Oscillation | Depending on the settings | | Internal RC<br>OSC<br>(256kHz) | Oscillation | Depending on the settings | | I/O Port | Retain | Retain | | Control<br>Register | Retain | Retain | | Address Data<br>Bus | Retain | Retain | | Release<br>Method | By RESET, all Interrupts | By RESET, Timer Interrupt (External clock), SIO (External clock), External Interrupt, UART by ACK, I2C (slave mode), WT (sub clock),WDT, BIT(only when RCOSC256Khz enabled). H/W CEC, IR | Table 12.1 Peripheral Operation during Power Down Mode. ## 12.3 IDLE, SLEEP1 mode The power control register is set to '01h' to enter the IDLE and SLEEP1 Mode. In this mode, the internal oscillation circuits remain active. Oscillation continues and peripherals are operated normally but CPU stops. It is released by reset or interrupt. To be released by interrupt, interrupt should be enabled before this mode. If using reset, because the device becomes initialized state, the registers have reset value. Figure 12.1 IDLE Mode Release Timing by External Interrupt Figure 12.2 IDLE and SLEEP1 Mode Release Timing by RESETB (Ex) MOV PCON, #0000\_0001b; setting of IDLE and SLEEP1 mode : # 12.4 STOP mode (STOP1, STOP2, SLEEP2) In the stop mode, the main oscillator(internal 16MHz-OSC) and internal 256KHz-OSC stop. With the clock frozen, all functions are stopped, but the on-chip RAM and control registers are held. The sources for exit from STOP mode are hardware reset and interrupts. The reset re-defines all the control registers. When exit from STOP mode, enough oscillation stabilization time is required to normal operation. Figure 12.3 shows the timing diagram. When released from STOP mode, the Basic interval timer is activated on wake-up. Therefore, before STOP instruction, user must be set its relevant prescaler divide ratio to have long enough time (more than 1msec). This guarantees that oscillator has started and stabilized. Figure 12.3 STOP Mode Release Timing by External Interrupt Figure 12.4 Mode Release Timing by RESETB # 12.5 Release Operation of Power-Down Mode After five Power-Down mode is released, the operation begins according to content of related interrupt register just before Power-Down mode start (Figure 12.5). It is released by only interrupt which each interrupt enable flag = `1`, and jump to the relevant interrupt service routine when EA='1' or next instruction. Figure 12.5 STOP1, 2 Mode Release Flow ### 12.5.1 Register Map | Name | Name Address | | Default | Description | | | |--------|--------------|--|---------|---------------------------|--|--| | PCON | PCON 87H | | 00H | Power Control Register | | | | VDCMOD | B8H R/W 0 | | 01H | VDC Mode Control Register | | | **Table 12.2** Power Down Operation Register Map ### 12.5.2 Power Down Operation Register description The Power Down Operation Register consists of the Power Control Register (PCON) and VDC Mode control Register (VDCMOD). ## 12.5.3 Register description for Power Down Operation ### VDCMOD (VDC Mode Control Register): B8H | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---|---------------------|---|---|---|---------|---------|---------|---------|--|--| | | - | - | - | - | VDCMOD3 | VDCMOD2 | VDCMOD1 | VDCMOD0 | | | | | - | - | - | - | RW | RW | RW | RW | | | | | Initial value : 01H | | | | | | | | | | | _ | 2011/2 | | | | | | | | | | #### PCON (Power Control Register): 87H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|------|------| | - | - | - | - | - | - | BIT1 | BITO | | - | - | - | - | - | - | RW | RW | Initial value: 00H | VDCMOD, | Select Power Down Mode | | | | | | | |---------|------------------------|------|----------------------------|--|--|--|--| | PCON | VDCMOD | PCON | Description | | | | | | | 00H | Χ | Not Power Down Mode | | | | | | | 00H | 01H | IDLE | | | | | | | 08H | 01H | SLEEP1(Low Power VDC Mode) | | | | | | | 04H | 03H | SLEEP2 | | | | | | | 02H | 03H | STOP1(Low Power VDC Mode) | | | | | | | 01H | 03H | STOP2(Low Power VDC Mode) | | | | | #### NOTE) - 1. To enter IDLE mode and SLEEP1 mode, PCON must be set to '01H'. - To enter STOP1, STOP2, SLEEP2, PCON must be set to '03H'. (In this power down mode, PCON register is cleared automatically after interrupt or reset.) - The different thing in Power Down mode is VDC operating mode and clock operation of internal 16MHz-OSC at each STOP mode. - 4. If WDTRCONSTOP is set to '0', the internal 256kHz RCOSC stops at STOP2, STOP1 and SLEEP2 modes and works again to count up wakeup time when stop wakeup interrupt occurs. If WDTRCONSTOP is set to '1', the internal 256kHz RCOSC does not stop at STOP2, STOP1 and SLEEP2 modes - 5. It is not supported except the above 5 modes. - 6. Two 'NOP' instructions are required after PCON is set - 7. By writing 'A5h' to AUTHORITY register, it is possible to change VDCMOD. ## 13 RESET ## 13.1 Overview The A97C450 can be reset by some reset sources. The followings are the hardware reset values. | On Chip Hardware | Initial Value | | | |----------------------|----------------------------|--|--| | Program Counter (PC) | 0000h | | | | Accumulator | 00h | | | | Stack Pointer (SP) | 07h | | | | Peripheral Clock | On | | | | Control Register | Peripheral Registers refer | | | | Low Voltage Reset | Enable | | | Table 13.1 Reset state ## 13.2 Reset source The A97C450 has five types of reset generation procedures. The followings are the reset sources. - External RESET pin - Power ON RESET (POR) - WDT Overflow Reset (In the case of WDTEN = `1`) - Low voltage Reset (In the case of LVREN = `1 `) - Low voltage indicator Reset (In the case of LVILS ≠ `00 `) - OCD Reset # 13.3 Block Diagram Figure 13.1 RESET Block Diagram # 13.4 Power ON RESET When rising device power, the POR (Power ON Reset) has a function to reset the device. If using POR, it executes the device RESET function instead of the RESET IC or the RESET circuits. And external RESET pin is able to use as Normal I/O pin. Figure 13.2 Fast VDD rising time Figure 13.3 Internal RESET Release Timing On Power-Up Figure 13.4 Configuration timing when Power-on Figure 13.5 Boot Process Waveform | Process | Description | Remarks | |---------|----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------| | 1 | -No Operation | | | 2 | -1st POR level Detection<br>-Internal OSC (256KHz) ON | -about 1.4V ~ 1.5V | | 3 | - (INT-OSC256KHz/256×Eh Delay section (=14ms) -VDD input voltage must rise over than flash operating voltage for Config read | -Slew Rate >= 0.025V/ms | | 4 | - Config read point | -about 1.5V ~ 1.6V<br>-Config Value is determined by Writing Option | | (5) | - Rising section to Reset Release Level | -16ms point after POR or Ext_reset release | | 6 | - Reset Release section (BIT overflow) i) after16ms, after External Reset Release (External reset) ii) 16ms point after POR (POR only) | - BIT is used for Peripheral stability | | 7 | -Normal operation | | Table 13.2Boot Process Description Figure 13.6 Oscillator generating waveform example # 13.5 External RESETB Input The External RESETB is the input to a Schmitt trigger. A reset in accomplished by holding the reset pin low for at least 16us over, within the operating voltage range and oscillation stable, it is applied, and the internal state is initialized. In stop mode, however, the reset is applied as soon as the reset pin goes low. After reset state becomes '1', it needs the stabilization time with 16ms and after the stable state, the internal RESET becomes '1'. The Reset process step needs 5 oscillator clocks. And the program execution starts at the vector address stored at address 0000H. The Figure 13.7 is the Noise canceller time diagram. It has the Noise cancel value of about 10us (@VDD=5V) to the low input of System Reset. Figure 13.7 Reset noise canceller time diagram Figure 13.8 Timing Diagram after RESET # 13.6 Low Voltage Reset and Low Voltage Indicator Processor The A97C450 has an On-chip low voltage reset(LVR) and indicator(LVI) circuit for monitoring the VDD level during operation by comparing it to a fixed trigger level. The LVR trigger level is 1.6V and it is enabled by default. The LVR can be disable in the STOP mode by register setting. The trigger level for the LVI can be selected by LVILS[1:0] bit to be 2.4V, 2.8V or 3.5V. In the STOP mode, this will contribute significantly to the total current consumption. So to minimize the current consumption, the LVR and LVI is set to off by software. Figure 13.9 Block Diagram of LVR, LVI Figure 13.10 Internal Reset at the power fail situation Figure 13.11 Configuration timing when Power-on ## 13.6.1 Register Map | Name | Address Direction | | Default | Description | | | |------|-------------------|-----|---------|----------------------------|--|--| | RSFR | 85H | R/W | 88H | Reset Source Flag Register | | | | LVIR | 86H | R/W | 09H | LVI Control Register | | | Table 13.3 Register Map # 13.6.2 Reset Operation Register description Reset Register consists of the Reset Source Flag Register (RSFR) and the LVI Control Register (LVIR). # 13.6.3 Register description for Reset Operation # RSFR (Reset Source Flag Register): 85H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------|-------|-------|---------------------------------------------|-------------------|----------------------|---------------------|------------| | PORF | CRCRF | WDTRF | OCDRF | LVRRF | LMRF | EXTRF | - | | RW - | | Initial value: 8 | 8H | | | | | | | | | I | PORF | Power-On Rese<br>0 No det<br>1 Detect | ection | it is reset by writi | ng '0' to this bit. | | | | ( | CRCRF | CRC Reset flaç ON reset. No det Detect | ection | reset by writing ' | 0' to this bit or b | y Power | | | V | WDTRF | | set flag bit. The | bit is reset by w | vriting '0' to this | bit or by | | | | | <ul><li>0 No det</li><li>1 Detect</li></ul> | | | | | | | ( | OCDRF | On-Chip Debug<br>by Power ON re | | The bit is reset to | by writing '0' to t | his bit or | | | | | <ul><li>0 No det</li><li>1 Detect</li></ul> | ion | | | | | | I | LVRRF | Low Voltage Ro<br>Power ON rese | | e bit is reset by v | vriting '0' to this | bit or by | | | | | 0 No det<br>1 Detect | | | | | | | 1 | LVIRF | Low Voltage In-<br>bit or by Power | | ag bit. The bit is i | reset by writing ' | 0' to this | | | | | 0 No det | ection | | | | | | 1 | EXTRF | | flag bit. The b | it is reset by wr | iting '0' to this | bit or by | | | | | 0 No det | | | | | | | | | 1 Detect | 1011 | | | | Note 1. By writing 'A5h' to AUTHORITY register, RSFR changing is possible. Note 2. Only Power on reset resets the LVIR register. # LVIR (LVI Control Register) : 86H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------|----|------------|----------------|-----------------|---------|--------|-------| | - | - | LVI_BYPASS | LVR_BYPASS | LVIINTON | LVILS1 | LVILS0 | LVREN | | - | - | RW | RW | RW | RW | RW | RW | | Initial value : 0 | 9H | | | | | | | | | I | LVI_BYPASS | Select LVI del | ounce or bypass | 5 | | | | | | _ | 0 Debo | unce | | | | | | | | 1 Bypa: | SS | | | | | | I | LVR_BYPASS | Select LVR de | bounce or bypas | ss | | | | | | | 0 Debo | unce | | | | | | | | 1 Bypa: | ss | | | | | | l | LVIINTON | Select LVI res | et or interrupt | | | | | | | | 0 reset | | | | | | | | | 1 interr | ıpt | | | | | | I | LVILS[1:0] | LVI level Volt | age | | | | | | | | LVILS1 L | VILS0 Desc | ription | | | | | | | 0 0 | disab | le | | | | | | | 0 1 | 2.4V | | | | | | | | 1 0 | 2.8V | | | | | | | | 1 1 | 3.5V | | | | | | I | LVREN | LVR stop mod | e operation | | | | | | | | 0 LVR o | isable | | | | | | | | 1 LVR e | nable | | | | Note 1. By writing 'A5h' to AUTHORITY register, LVIR changing is possible. # 14 On-chip Debug System ### 14.1 Overview ### 14.1.1 Description On-chip debug system (OCD2) of A97C450 can be used for programming the non-volatile memories and on-chip debugging. Detail descriptions for programming via the OCD2 interface can be found in the following chapter. Figure 14.1 shows a block diagram of the OCD2 interface and the On-chip Debug system. #### **14.1.2** Feature - Two-wire external interface: 1-wire serial clock input, 1-wire bi-directional serial data bus - Debugger Access to: - All Internal Peripheral Units - Internal data RAM - Program Counter - Flash and Data EEPROM Memories - Extensive On-chip Debug Support for Break Conditions, Including - Break Instruction - Single Step Break - Program Memory Break Points on Single Address - Programming of Flash, EEPROM, Fuses and Lock Bits through the two-wire Interface - On-chip Debugging Supported by OCD dongle - Operating frequency - Supports the maximum frequency of the target MCU Figure 14.1 Block Diagram of On-Chip Debug System ### 14.2 Two-Pin External Interface #### 14.2.1 Basic Transmission Packet - 10-bit packet transmission using two-pin interface. - packet consists of 8-bit data, 1-bit parity and 1-bit acknowledge. - Parity is even of '1' for 8-bit data in transmitter. - Receiver generates acknowledge bit as '0' when transmission for 8-bit data and its parity has no error. - When transmitter has no acknowledge (Acknowledge bit is '1' at tenth clock), error process is executed in transmitter. - When acknowledge error is generated, host PC makes stop condition and transmits command which has error again. - · Background debugger command is composed of a bundle of packet. - Start condition and stop condition notify the start and the stop of background debugger command respectively. Figure 14.2 10-bit Transmission Packet # 14.2.2 Packet Transmission Timing ### 14.2.2.1 Data Transfer Figure 14.3 Data transfer on the twin bus # 14.2.2.2 Bit Transfer Figure 14.4 Bit transfer on the serial bus ## 14.2.2.3 Start and Stop Condition Figure 14.5 Start and stop condition ## 14.2.2.4 Acknowledge bit Figure 14.6 Acknowledge on the serial bus Figure 14.7 Clock synchronization during wait procedure ## 14.2.3 Connection of Transmission Two-pin interface connection uses open-drain(wire-AND bidirectional I/O). Figure 14.3 Connection of Transmission # 15 Memory Programming ### 15.1 Overview ### 15.1.1 Description A97C450 has flash memory to which a program can be written, erased, and overwritten while mounted on the board. Serial ISP modes and byte-parallel ROM writer mode are supported. #### 15.1.2 Features - Flash Size: 64KB - Single power supply program and erase - Command interface for fast program and erase operation - Up to 10,000 program/erase cycles at typical voltage and temperature for flash memory - · Security feature # 15.2 Flash Control and status register Registers to control Flash and Data EEPROM are Mode Register (FEMR), Control Register (FECR), Status Register (FESR), Time Control Register (FETCR), Address Low Register (FEARL), Address Middle Register (FEARM), address High Register (FEARH), Data Register (FEDR), and OTP Page Selection Register (OTPADD). They are mapped to SFR area and can be accessed only in programming mode. ### 15.2.1 Register Map | Name | Address | Direction | Default | Description | |--------|---------|-----------|---------|-------------------------------| | FEMR | EAH | R/W | 00H | Flash Mode Register | | FECR | EBH | R/W | 03H | Flash Control Register | | FESR | ECH | R/W | 80H | Flash Status Register | | FETCR | EDH | R/W | 00H | Flash Time Control Register | | FEARL | F2H | R/W | 00H | Flash Address Low Register | | FEARM | F3H | R/W | 00H | Flash Address Middle Register | | FEARH | F4H | R/W | 00H | Flash Address High Register | | FEDR | F5H | R/W | 00H | Flash Data Register | | OTPADD | 93H | R/W | 00H | OTP Page Selection Register | Table 15.1 Memory Programming Register Map # 15.2.2 Register description for Flash # FEMR (Flash Mode Register) : EAH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------------------------|-----------------------|----------------|------------------|-------------------|-------------------|----------------|----------------|--| | FSEL | ESEL | PGM | ERASE | PBUFF | OTPE | VFY | FEEN | | | RW | | Initial value : 0 | 0H | | | | | | | | | FSEL Select flash memory. | | | | | | | | | | | | 0 | Deselect flash | n memory | | | | | | | 1 Select flash memory | | | | | | | | | | ESEL | Select | data EEPROM | | | | | | | | | 0 | Deselect data | EEPROM | | | | | | | | 1 | Select data E | EPROM | | | | | | | PGM | Enable | e program or pro | gram verify mod | le with VFY | | | | | | | 0 | Disable progra | am or program v | erify mode | | | | | | | 1 | Enable progra | am or program ve | erify mode | | | | | | ERASE | Enable | e erase or erase | verify mode with | า VFY | | | | | | | 0 | | or erase verify r | | | | | | | | 1 | | or erase verify m | node | | | | | | PBUFF | | page buffer | | | | | | | | | 0 | Deselect page | | | | | | | | | 1<br>Calast | Select page b | | | | | | | | OTPE | Select<br>0 | Deselect OTF | ad of program m | emory | | | | | | | 1 | Select OTP a | | | | | | | | VFY | Set pro | | | PGM or ERASE | | | | | | VFI | - | nm Verify: PGM= | - | | | | | | | | _ | - | | | | | | | | | | Verify: ERASE= | | | | | | | | FEEN | Enable<br>mode | e program and | erase of Flash. | When inactive, it | is possible to | read as normal | | | | | 0 | Disable progra | am and erase | | | | | | | | 1 | Enable progra | am and erase | | | | | ## FECR (Flash Control Register) : EBH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |--------------------|------------|---------------------|-------------------------------------------------------------------------|---------------------|--------------------|--------------------|-------------------|--|--| | AEF | AEE | EXIT1 | EXITO | WRITE | READ | nFERST | nPBRST | | | | RW | | | Initial value : 03 | 3H | | | | | | | | | | | AEF | Enable | flash bulk erase | e mode | | | | | | | | <u>_</u> . | 0 | Disable bulk e | rase mode of Fla | ash memory | | | | | | | | 1 | Enable bulk ei | rase mode of Fla | sh memory | | | | | | | AEE | Enable | data EEPROM | bulk erase mode | е | | | | | | | | 0 | Disable bulk e | rase mode of da | ta EEPROM | | | | | | | | 1 | Enable bulk e | rase mode of dat | ta EEPROM | | | | | | | EXIT[1:0 | <b>'</b> ] | . • | le. It is cleared a | utomatically afte | er 1 clock | | | | | | | EXIT1 | EXIT0 | Description | | | | | | | | | 0 | 0 | | m program mod | | | | | | | | 0 | 1 | | m program mod | | | | | | | | 1 | 0 | | m program mod | le | | | | | | | 1 | 1 | Exit from pro | • | | | | | | | WRITE | Start to<br>1 clock | | ase of Flash and | I data EEPROM | . It is cleared au | tomatically after | | | | | | 0 | No operation | | | | | | | | | | 1 | Start to progra | m or erase of Fl | ash and data EB | PROM | | | | | | READ | Start a | • | sh or data EEPR | OM. It is cleared | d automatically a | fter 1 clock | | | | | | 0 | No operation | | | | | | | | | | 1 | | fy of Flash or da | | | | | | | | nFERST | | | EPROM control l | ogic. It is cleare | d automatically a | fter 1 clock | | | | | | 0 | No oper | | | | | | | | | | 1 | | lash or data EEF | | - | | | | | | nPBRS1 | - Reset | Reset page buffer with PBUFF. It is cleared automatically after 1 clock | | | | | | | | | | PBUFI | nPBRST | | | | | | | | | | 0 | 0 | Page buffer | | | | | | | | | 1 | 0 | Write check | sum reset | | | | | WRITE and READ bits can be used in program, erase and verify mode with FEAR registers. Read or writes for memory cell or page buffer uses read and write enable signals from memory controller. Indirect address mode with FEAR is only allowed to program, erase and verify #### FESR (Flash Status Register): ECH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|--------|-------|--------|-------|-------|-------| | PEVBSY | VFYGOOD | PCRCRD | MWAIT | ROMINT | WMODE | EMODE | VMODE | | R | RW | R | R | RW | R | R | R | Initial value: 80H PEVBSY Operation status flag. It is cleared automatically when operation starts. Operations are program, erase or verification 0 Busy (Operation processing) 1 Complete Operation VFYGOOD Auto-verification result flag. 0 Auto-verification fails 1 Auto-verification successes PCRCRD CRC read Enable O CRC read disable(Checksum read for verify operation) 16-bit CRC read enable (from FEARM, FEARL) MWAIT Enable CPU wait 0 Disable CPU wait 1 Enable CPU wait during flash erase or program. ROMINT Flash interrupt request flag. Auto-cleared when program/erase/verify starts. Active in program/erase/verify completion No interrupt request. Interrupt request. WMODE Write mode flag EMODE Erase mode flag VMODE Verify mode flag ### FETCR (Flash Time Control Register): EDH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | TCR7 | TCR6 | TCR5 | TCR4 | TCR3 | TCR2 | TCR1 | TCR0 | | RW Initial value: 00H TCR[7:0] Flash Time control Program and erase time is controlled by setting FETCR register. Program and erase timer uses 10-bit counter. It increases by one at each divided watchdog ring clock frequency (=WDTRC/2). It is cleared when program or erase starts. Timer stops when 10-bit counter is same to FETCR. PEVBSY is cleared when program, erase or verify starts and set when program, erase or verify stops. Max program/erase time at 256 kHz clock: (255+1) \* 2 \* ((1/fWDTRC) \* 2) = 4.0ms In the case of 10% of error rate of counter source clock, program or erase time is 2.63~4.44ms \* Program/erase time calculation For page write or erase, Tpe = (FETCR+1) \* 2 \* ((1/fWDTRC) \* 2) For bulk erase, Tbe = (FETCR+1) \* 2 \* ((1/fWDTRC) \* 2) 1/fWDTRC = input system clock into EEPROM control block Tpe = Typical program or erase time (2.5 ms) FETCR = Value of FETCR register #### ※ Recommended program/erase time at fWDTRC 256kHz(FETCR = A0H) | | Min | Тур | Max | Unit | |--------------------|-----|-----|-----|------| | program/erase Time | 2.4 | 2.5 | 2.6 | ms | Table 15.2 Program/Erase Time ### FEARL (Flash address low Register): F2H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | ARL7 | ARL6 | ARL5 | ARL4 | ARL3 | ARL2 | ARL1 | ARL0 | | W | W | W | W | W | W | W | W | Initial value: 00H ARL[7:0] Flash address low #### FEARM (Flash address middle Register): F3H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | ARM7 | ARM6 | ARM5 | ARM4 | ARM3 | ARM2 | ARM1 | ARM0 | | W | W | W | W | W | W | W | W | Initial value: 00H ARM[7:0] Flash address middle ### FEARH (Flash address high Register): F4H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | ARH7 | ARH6 | ARH5 | ARH4 | ARH3 | ARH2 | ARH1 | ARH0 | | W | W | W | W | W | W | W | W | Initial value: 00H ARH[7:0] Flash address high FEAR registers are used for program, erase and auto-verify. In program and erase mode, it is page address and ignored the same least significant bits as the number of bits of page address. In auto-verify mode, address increases automatically by one. FEARs are write-only register. Reading these registers returns 24-bit checksum results(FEARH, FEARM, FEARL) or 16-bit CRC results(FEARM, FEARL) when PCRCRD bit of FESR is set. ## FEDR (Flash control Register): F5H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | FEDR7 | FEDR6 | FEDR5 | FEDR4 | FEDR3 | FEDR2 | FEDR1 | FEDR0 | | W | W | W | W | W | W | W | W | Initial value: 00H FEDR[7:0] Flash data Data register. In no program/erase/verify mode, READ/WRITE of FECR read or write data from FLASH to this register or from this register to Flash. The sequence of writing data to this register is used for EEPROM program entry. The mode entrance sequence is to write 0xA5 and 0x5A to it in order. # OTPADD (OTP Page Selection Register): 93H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | OTPADD7 | OTPADD6 | OTPADD5 | OTPADD4 | OTPADD3 | OTPADD2 | OTPADD1 | OTPADD0 | | W | W | W | W | W | W | W | W | Initial value: 00H | | OTD 7 1 1 | |---------|----------------------| | OTPADD7 | OTP page 7 selection | | | 0 Deselect | | | 1 Select | | OTPADD6 | OTP page 6 selection | | 0/.220 | 0 Deselect | | | 1 Select | | OTDADD5 | OTP page 5 selection | | OTPADD5 | | | | 0 Deselect | | | 1 Select | | OTPADD4 | OTP page 4 selection | | | 0 Deselect | | | 1 Select | | OTPADD3 | OTP page 3 selection | | | 0 Deselect | | | 1 Select | | OTPADD2 | OTP page 2 selection | | 0, | 0 Deselect | | | 1 Select | | OTPADD1 | OTP page 1 selection | | OTTABBI | 0 Deselect | | | 1 Select | | OTDADDO | OTP page 0 selection | | OTPADD0 | · · | | | 0 Deselect | | | 1 Select | # 15.3 Memory map ## 15.3.1 Flash Memory Map Program memory uses 64Kbyte of Flash memory. It is read by byte and written by byte or page. One page is 64 bytes. Figure 15.1 Flash Memory Map Figure 15.2 Address configuration of Flash memory # 15.4 Serial In-System Program Mode Serial in-system program uses the interface of debugger which uses two wires. Refer to chapter 14 in details about debugger ## 15.4.1 Flash operation Configuration(This Configuration is just used for follow description) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---------------|---------------|---|---|---------|---------|---------| | - | FEMR[4] & [1] | FEMR[5] & [1] | - | - | FEMR[2] | FECR[6] | FECR[7] | | - | FRASF&VFY | PGM&VFY | - | - | OTPF | AFF | AFF | Figure 15.3 The sequence of page program and erase of Flash memory Figure 15.4 The sequence of bulk erase of Flash memory ## 15.4.1.1 Flash Read - Step 1. Enter OCD(=ISP) mode. - Step 2. Set ENBDM bit of BCR. - Step 3. Enable debug and Request debug mode. - Step 4. Read data from Flash. ### 15.4.1.2 Enable program mode - Step 1. Enter OCD(=ISP) mode.1 - Step 2. Set ENBDM bit of BCR. - Step 3. Enable debug and Request debug mode. - Step 4. Enter program/erase mode sequence.2 - (1) Write 0xAA to 0xF555. - (2) Write 0x55 to 0xFAAA. - (3) Write 0xA5 to 0xF555. ### 15.4.1.3 Flash write mode - Step 1. Enable program mode. - Step 2. Reset page buffer. FEMR: 1000 0001 FECR:0000 0010 - Step 3. Select page buffer. FEMR:1000\_1001 - Step 4. Write data to page buffer.(Address automatically increases by twin.) - Step 5. Set write mode. FEMR:1010 0001 - Step 6. Set page address. FEARH:FEARM:FEARL=20'hx xxxx - Step 7. Set FETCR. - Step 8. Start program. FECR:0000 1011 - Step 9. Insert one NOP operation - Step 10. Read FESR until PEVBSY is 1. - Step 11. Repeat step2 to step 8 until all pages are written. ### 15.4.1.4 Flash page erase mode - Step 1. Enable program mode. - Step 2. Reset page buffer. FEMR: 1000\_0001 FECR:0000\_0010 - Step 3. Select page buffer. FEMR:1000\_1001 - Step 4. Write 'h00 to page buffer. (Data value is not important.) - Step 5. Set erase mode. FEMR:1001\_0001 - Step 6. Set page address. FEARH:FEARM:FEARL=20'hx xxxx - Step 7. Set FETCR. - Step 8. Start erase. FECR:0000 1011 - Step 9. Insert one NOP operation - Step 10. Read FESR until PEVBSY is 1. - Step 11. Repeat step2 to step 8 until all pages are erased. <sup>&</sup>lt;sup>1</sup> Refer to how to enter ISP mode.. <sup>&</sup>lt;sup>2</sup> Command sequence to activate Flash write/erase mode. It is composed of sequentially writing data of Flash memory. #### 15.4.1.5 Flash bulk erase mode - Step 1. Enable program mode. - Step 2. Reset page buffer. FEMR: 1000\_0001 FECR:0000\_0010 - Step 3. Select page buffer. FEMR:1000\_1001 - Step 4. Write 'h00 to page buffer. (Data value is not important.) - Step 5. Set erase mode. FEMR:1001\_0001. (Only main cell area is erased. For bulk erase including OTP area, select OTP area.(set FEMR to 1000\_1101.) - Step 6. Set FETCR - Step 7. Start bulk erase. FECR:1000\_1011 - Step 8. Insert one NOP operation - Step 9. Read FESR until PEVBSY is 1. #### 15.4.1.6 Flash OTP area read mode - Step 1. Enter OCD(=ISP) mode. - Step 2. Set ENBDM bit of BCR. - Step 3. Enable debug and Request debug mode. - Step 4. Select OTP area. FEMR:1000 0101 - Step 5. Read data from Flash. ## 15.4.1.7 Flash OTP area write mode - Step 1. Enable program mode. - Step 2. Reset page buffer. FEMR: 1000\_0001 FECR:0000\_0010 - Step 3. Select page buffer. FEMR:1000\_1001 - Step 4. Write data to page buffer.(Address automatically increases by twin.) - Step 5. Set write mode and select OTP area. FEMR:1010 0101 - Step 6. Set page address. FEARH:FEARM:FEARL=20'hx\_xxxx - Step 7. Set FETCR. - Step 8. Start program. FECR:0000\_1011 - Step 9. Insert one NOP operation - Step 10. Read FESR until PEVBSY is 1. ### 15.4.1.8 Flash OTP area erase mode - Step 1. Enable program mode. - Step 2. Reset page buffer. FEMR: 1000\_0001 FECR:0000\_0010 - Step 3. Select page buffer. FEMR:1000\_1001 - Step 4. Write 'h00 to page buffer. (Data value is not important.) - Step 5. Set erase mode and select OTP area. FEMR:1001\_0101 - Step 6. Set page address. FEARH:FEARM:FEARL=20'hx\_xxxx - Step 7. Set FETCR. - Step 8. Start erase. FECR:0000\_1011 - Step 9. Insert one NOP operation - Step 10. Read FESR until PEVBSY is 1. ### 15.4.1.9 Flash program verify mode - Step 1. Enable program mode. - Step 2. Set program verify mode. FEMR:1010\_0011 - Step 3. Read data from Flash. ### 15.4.1.10 OTP program verify mode - Step 1. Enable program mode. - Step 2. Set program verify mode. FEMR:1010\_0111 - Step 3. Read data from Flash. ### 15.4.1.11 Flash erase verify mode - Step 1. Enable program mode. - Step 2. Set erase verify mode. FEMR:1001\_0011 - Step 3. Read data from Flash. #### 15.4.1.12 Flash page buffer read - Step 1. Enable program mode. - Step 2. Select page buffer. FEMR:1000 1001 - Step 3. Read data from Flash. ### 15.4.2 Data EEPROM operation Program and erase operation of Data EEPROM are executed by direct and indirect address mode. Direct address mode uses external data area of 8051. Indirect address mode uses address register of SFR area.. #### 15.4.2.1 Data EEPROM Read - Step 1. Enter OCD(=ISP) mode. - Step 2. Set ENBDM bit of BCR. - Step 3. Enable debug and Request debug mode. - Step 4. Read data from Data EEPROM. ### 15.4.2.2 Enable program mode - Step 1. Enter OCD(=ISP) mode.1 - Step 2. Set ENBDM bit of BCR. - Step 3. Enable debug and Request debug mode. - Step 4. Enter program/erase mode sequence.<sup>2</sup> - (1) EA = 0 (Grobal interrupt disable) - (2) Write 0xA5 to FEDR. - (3) Write 0x5A to FEDR. - (4) EA = 1 (Grobal interrupt Enable) #### 15.4.2.3 EEPROM write mode - Step 1. Enable program mode. - Step 2. Reset page buffer. FEMR: 0100\_0001 FECR:0000\_0010 - Step 3. Select page buffer. FEMR:0100\_1001 - Step 4. Write data to page buffer.(Address automatically increases by twin.) - Step 5. Set write mode. FEMR:0110\_0001 - Step 6. Set page address. FEARH:FEARM:FEARL=20'hx\_xxxx - Step 7. Set FETCR. - Step 8. Start program. FECR:0000\_1011 - Step 9. Insert one NOP operation - Step 10. Read FESR until PEVBSY is 1. - Step 11. Repeat step2 to step 8 until all pages are written. <sup>&</sup>lt;sup>1</sup> Refer to how to enter ISP mode.. <sup>&</sup>lt;sup>2</sup> Command sequence to activate data EEPROM write/erase mode. It is composed of sequentially writing to data register.(FEDR) <sup>&</sup>lt;sup>3</sup> No other instructions should be entered in the middle of sequential operations. ### 15.4.2.4 EEPROM page erase mode - Step 1. Enable program mode. - Step 2. Reset page buffer. FEMR: 0100\_0001 FECR:0000\_0010 - Step 3. Select page buffer. FEMR:0100\_1001 - Step 4. Write 'h00 to page buffer. (Data value is not important.) - Step 5. Set erase mode. FEMR:0101\_0001 - Step 6. Set page address. FEARH:FEARM:FEARL=20'hx xxxx - Step 7. Set FETCR. - Step 8. Start erase. FECR:0000\_1011 - Step 9. Insert one NOP operation - Step 10. Read FESR until PEVBSY is 1. - Step 11. Repeat step2 to step 8 until all pages are erased. #### 15.4.2.5 **EEPROM** bulk erase mode - Step 1. Enable program mode. - Step 2. Reset page buffer. FEMR: 0100\_0001 FECR:0000\_0010 - Step 3. Select page buffer. FEMR:0100 1001 - Step 4. Write 'h00 to page buffer. (Data value is not important.) - Step 5. Set erase mode. FEMR:0101 0001. - Step 6. Set FETCR - Step 7. Start bulk erase. FECR:0100 1011 - Step 8. Insert one NOP operation - Step 9. Read FESR until PEVBSY is 1. #### 15.4.2.6 Data EEPROM program verify mode - Step 1. Enable program mode. - Step 2. Set program verify mode. FEMR:0110 0011 - Step 3. Read data from Flash. #### 15.4.2.7 Data EEPROM erase verify mode - Step 1. Enable program mode. - Step 2. Set erase verify mode. FEMR:0101\_0011 - Step 3. Read data from Flash. ### 15.4.2.8 Data EEPROM page buffer read - Step 1. Enable program mode. - Step 2. Select page buffer. FEMR:0100\_1001 - Step 3. Read data from Flash. # 15.4.3 Summary of Flash and Data EEPROM Program/Erase Mode | Opera | tion mode | Description | |--------|------------------------------|---------------------------------------------| | | Flash read | Read cell by byte. | | _ | Flash write | Write cell by bytes or page. | | F | Flash page erase | Erase cell by page. | | Ā | Flash bulk erase | Erase the whole cells. | | S<br>H | Flash program verify | Read cell in verify mode after programming. | | '' | Flash erase verify | Read cell in verify mode after erase. | | | Flash page buffer load | Load data to page buffer. | | | Data EEPROM read | Read cell by byte. | | Е | Data EEPROM write | Write cell by bytes or page. | | E | Data EEPROM page erase | Erase cell by page. | | P<br>R | Data EEPROM bulk erase | Erase the whole cells. | | 0 | Data EEPROM program verify | Read cell in verify mode after programming. | | М | Data EEPROM erase verify | Read cell in verify mode after erase. | | | Data EEPROM page buffer load | Load data to page buffer. | Table 15.3Operation Mode ### 15.5 Parallel Mode #### 15.5.1 Overview Parallel program mode transfers address and data by byte. 3-byte address can be entered by one from the lease significant byte of address. If only LSB is changed, only one byte can be transferred. And if the second byte is changed, the first and second byte can be transferred. Upper 4-bit of the most significant byte selects memory to be accessed. Table 15.4 show memory type according to address. Address auto-increment is supported when read or write data without address Figure 15.5 Pin diagram for parallel programming | | ADDR | H[7:4] | | Memory Type | |---|------|--------|---|-----------------| | 0 | 0 | 0 | 0 | Program Memory | | 0 | 0 | 0 | 1 | External Memory | | 0 | 0 | 1 | 0 | SFR | **Table 15.4** The selection of memory type by ADDRH[7:4] ## 15.5.2 Parallel Mode instruction format | Instruction | Signal | Instruction Sequence | | | | | | | | | | | | | | |---------------------|--------|----------------------|---|-------|---|-------|---|-------|---|-------|---|---|---|-------|---| | | nALE | L | | L | | L | | Н | | Н | | Н | | Н | | | n-byte data read | nWR | L | Н | L | Н | L | Н | Н | Н | Н | Н | Н | Н | Н | Н | | with 3-byte address | nRD | Н | Н | Н | Н | Н | Н | L | Н | L | Н | L | Н | L | Н | | | PDATA | ADDRL | | ADDRM | | ADDRH | | DATA0 | | DATA1 | | | | DATAn | | | | nALE | L | | L | | L | | Н | | Н | | Н | | Н | | | n-byte data write | nWR | L | Н | L | Н | L | Н | L | Н | L | Н | L | Н | L | Н | | with 3-byte address | nRD | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | | | PDATA | ADDRL | | ADDRM | | ADDRH | | DATA0 | | DATA1 | | | | DATAn | | | n-byte data read | nALE | L | | L | | Н | | н | | Н | | Н | | Н | | | | nWR | L | Н | L | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | | with 2-byte address | nRD | Н | Н | Н | Н | L | Н | L | Н | L | Н | L | Н | L | Н | | | PDATA | ADDRL | | ADDRM | | DATA0 | | DATA1 | | DATA2 | | | | DATAn | | | | nALE | L | | L | | Н | | Н | | Н | | Н | | Н | | | n-byte data write | nWR | L | Н | L | Н | L | Н | L | Н | L | Н | L | Н | L | Н | | with 2-byte address | nRD | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | | | PDATA | ADDRL | | ADDRM | | DATA0 | | DATA1 | | DATA2 | | | | DATAn | | | | nALE | L | | Н | | Н | | Н | | Н | | Н | | Н | | | n-byte data read | nWR | L | Н | Н | Н | L | Н | L | Н | L | Н | L | Н | L | Н | | with 1-byte address | nRD | Н | Н | L | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | | | PDATA | ADDRL | | DATA0 | | DATA1 | | DATA2 | | DATA3 | | | | DATAn | | | | nALE | L | | Н | | Н | | Н | | Н | | Н | | Н | | | n-byte data write | nWR | L | Н | L | Н | L | Н | L | Н | L | Н | L | Н | L | Н | | with 1-byte address | nRD | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | Н | | | PDATA | ADDRL | | DATA0 | | DATA1 | | DATA2 | | DATA3 | | | | DATAn | | Table 15.5 Parallel Mode instruction format ### 15.5.3 Parallel Mode timing diagram Figure 15.6 Parallel Byte Read Timing of Program Memory Figure 15.7 Parallel Byte Write Timing of Program Memory ## 15.6 Mode entrance method of ISP and byte-parallel mode ### 15.6.1 Mode entrance method for ISP | TARGET MODE | DSDA | DSCL | DSDA | |-------------|------|------|------| | OCD(ISP) | 'hC | 'hC | 'hC | Figure 14.8 ISP mode ### 15.6.2 Mode entrance of Byte-parallel | TARGET MODE | P0[3:0] | P0[3:0] | P0[3:0] | |--------------------|---------|---------|---------| | Byte-Parallel Mode | 4'h5 | 4'hA | 4'h5 | Figure 14.1 Byte-parallel mode ### 15.7 Security A97C450 provides Lock bits which can be left un-programmed ("0") or can be programmed ("1") to obtain the additional features listed in Table 15.6. The Lock bit can only be erased to "0" with the bulk erase command and a value of more than 0x80 at FETCR. | LOCK MODE | | | | USER N | MODE | | | | | | | ISP/P | MODE | | | | |-----------|---|----|-----|--------|------|---|-----|----|-------|---|----|-------|------|---|----|----| | LOCK MODE | | FL | ASH | | | C | OTP | | FLASH | | | ОТР | | | | | | LOCKF | R | W | PE | BE | R | W | PE | BE | R | W | PE | BE | R | W | PE | BE | | 0 | 0 | 0 | 0 | х | х | Х | Х | Х | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 1 | 0 | 0 | 0 | Х | х | Х | Х | Х | Х | Х | Х | 0 | 0 | Х | Х | 0 | Table 15.6 Security policy using lock-bits LOCKF: Lock bit of Flash memory R: ReadW: Write PE: Page eraseBE: Bulk Erase • O: Operation is possible. • X: Operation is impossible. # 16 Configure option ## 16.1 Configure option Control Register FUSE\_CONF (Pseudo-Configure Data): 000H (OPT) | 1 | 6 | 5 | 4 | 3 | 2 | 1 | U | | |-------------------|-------------------------------------------------|------|----------------|--------------------|------------------|------------|-------|--| | - | RSTDIS | - | BSIZE1 | BSIZE0 | LOCKB | LOCKE | LOCKF | | | - | RW | - | RW | RW | RW | RW | RW | | | Initial value : 4 | 0H | | | | | | | | | | | | | | | | | | | | | | 0 Enable | RESETB pin (d | efault) | | | | | | | | 1 Disable | RESETB pin | | | | | | | BSIZE Select Specific Area for Write Protection | | | | | | | | | | | | Note)When LO | CKB is set, it's a | pplied | | | | | | | | 00 0000H | ~01FFH, 0.5Kby | tes (default) | | | | | | | | 01 0000H | ~03FFH, 1kbyte: | S | | | | | | | | 10 0000H | ~07FFH, 2kbyte: | S | | | | | | | | 11 0000H | ~0FFFH, 4kbyte | S | | | | | | L | OCKB | Select Code Wr | rite Protection wi | th Specific Area | | | | | | | | 0 Disable | e Code Write Pro | otection | | | | | | | | 1 Enable | Code Write Pro | tection | | | | | | L | OCKE | Select Data EE | PROM Write Pro | tection with Spe | cific Area | | | | | | | 0 Disable | Data EEPROM | Write Protection | า | | | | | | | 1 Enable | Data EEPROM | Write Protection | | | | In OCD debug mode, user can change FUSE\_CONF bits value temporarily except LOCKF for debugging job. Select Code Read Protection Disable Code Read Protection Enable Code Read Protection FUSE\_SWAPEN (Bootloader SWAP Enable): 001H (OPT) LOCKF | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------|----|----|----|----|----|----|----| | BOOT_SWAPEN | | | | | | | | | RW | Initial value: 00 | H | | | | | | | Writing 5Ah to BOOT\_SWAPEN enables bootloader swap operation ### FUSE\_XTAL (XTAL/Sub-XTAL Control): 002H (OPT) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---------------|--------|------------|-----|--------|-------------|-------------| | - | XTAL_FIL_SKIP | FUSE_X | TALEN[1:0] | ISE | L[1:0] | SUB_NC_BYPS | FUSE_SUBENA | | - | RW | RW | RW | RW | RW- | RW | RW | Initial value: 00H XTAL\_FIL\_SK Main-OSC noise canceller bypass selection P 0 Use noise canceller 1 Bypass noise canceller FUSE\_XTALE Enable main-OSC and select whether to use P53, P54 as GPIO or main- N[1:0] OSC 00 Disable main-OSC. P54, P53 is used as GPIO 01 Enable main-OSC. P54 is used as XOUT and P53 is used as XIN 10 Enable main-OSC. P54 is used as GPIO and P53 is used as XIN ISEL[1:0] Sub osc Current option. This value be written by OCD or Write device according to FUSE\_SUBENA bit. $FUSE\_SUBENA = 0 \Rightarrow ISEL[1:0] = 00b$ $FUSE\_SUBENA = 1 \Rightarrow ISEL[1:0] = 11b$ SUB\_NC\_BYP Sub-OSC noise canceller bypass selection 0 Use noise canceller 1 Bypass noise canceller Enable sub-OSC and use P51, P50 as SXI and SXO FUSE\_SUBE Enable sub-OSC and use P51, P50 as SXI and SXO NA Disable sub-OSC. P51, P50 is used as GPIO 1 Enable sub-OSC. P51, P50 is used as SXI and SXO ### FUSE\_BTSEL (Bootloader select): 043H (OPT) 7 6 5 4 3 1 0 BTSEL RW RW RW RW RW RW RW RW Initial value: 00H This option select the bootloader when boot loader swap is enabled. **Boot load Select** 0xA5 = Select Page 1, Others = Select Page 0 ## 17 APPENDIX ### 17.1 Instruction Table Instructions are either 1, 2 or 3 bytes long as listed in the 'Bytes' column below. Each instruction takes either 1, 2 or 4 machine cycles to execute as listed in the following table. 1 machine cycle comprises 2 system clock cycles. | | ARITHMETIC | | | | |---------------|---------------------------------------------|-------|--------|----------| | Mnemonic | Description | Bytes | Cycles | Hex code | | ADD A, Rn | Add register to A | 1 | 1 | 28-2F | | ADD A, dir | Add direct byte to A | 2 | 1 | 25 | | ADD A, @Ri | Add indirect memory to A | 1 | 1 | 26-27 | | ADD A, #data | Add immediate to A | 2 | 1 | 24 | | ADDC A, Rn | Add register to A with carry | 1 | 1 | 38-3F | | ADDC A, dir | Add direct byte to A with carry | 2 | 1 | 35 | | ADDC A, @Ri | Add indirect memory to A with carry | 1 | 1 | 36-37 | | ADDC A, #data | Add immediate to A with carry | 2 | 1 | 34 | | SUBB A, Rn | Subtract register from A with borrow | 1 | 1 | 98-9F | | SUBB A, dir | Subtract direct byte from A with borrow | 2 | 1 | 95 | | SUBB A, @Ri | Subtract indirect memory from A with borrow | 1 | 1 | 96-97 | | SUBB A, #data | Subtract immediate from A with borrow | 2 | 1 | 94 | | INC A | Increment A | 1 | 1 | 04 | | INC Rn | Increment register | 1 | 1 | 08-0F | | INC dir | Increment direct byte | 2 | 1 | 05 | | INC @Ri | Increment indirect memory | 1 | 1 | 06-07 | | DEC A | Decrement A | 1 | 1 | 14 | | DEC Rn | Decrement register | 1 | 1 | 18-1F | | DEC dir | Decrement direct byte | 2 | 1 | 15 | | DEC @Ri | Decrement indirect memory | 1 | 1 | 16-17 | | INC DPTR | Increment data pointer | 1 | 2 | A3 | | MUL AB | Multiply A by B | 1 | 4 | A4 | | DIV AB | Divide A by B | 1 | 4 | 84 | | DAA | Decimal Adjust A | 1 | 1 | D4 | | | LOGICAL | | | | |----------------|---------------------------------------|-------|--------|----------| | Mnemonic | Description | Bytes | Cycles | Hex code | | ANL A, Rn | AND register to A | 1 | 1 | 58-5F | | ANL A, dir | AND direct byte to A | 2 | 1 | 55 | | ANL A, @Ri | AND indirect memory to A | 1 | 1 | 56-57 | | ANL A, #data | AND immediate to A | 2 | 1 | 54 | | ANL dir, A | AND A to direct byte | 2 | 1 | 52 | | ANL dir, #data | AND immediate to direct byte | 3 | 2 | 53 | | ORLA, Rn | OR register to A | 1 | 1 | 48-4F | | ORL A, dir | OR direct byte to A | 2 | 1 | 45 | | ORLA, @Ri | OR indirect memory to A | 1 | 1 | 46-47 | | ORL A, #data | OR immediate to A | 2 | 1 | 44 | | ORL dir, A | OR A to direct byte | 2 | 1 | 42 | | ORL dir, #data | OR immediate to direct byte | 3 | 2 | 43 | | XRL A, Rn | Exclusive-OR register to A | 1 | 1 | 68-6F | | XRL A, dir | Exclusive-OR direct byte to A | 2 | 1 | 65 | | XRL A, @Ri | Exclusive-OR indirect memory to A | 1 | 1 | 66-67 | | XRL A, #data | Exclusive-OR immediate to A | 2 | 1 | 64 | | XRL dir, A | Exclusive-OR A to direct byte | 2 | 1 | 62 | | XRL dir, #data | Exclusive-OR immediate to direct byte | 3 | 2 | 63 | | CLR A | Clear A | 1 | 1 | E4 | | CPLA | Complement A | 1 | 1 | F4 | | SWAPA | Swap Nibbles of A | 1 | 1 | C4 | | RLA | Rotate A left | 1 | 1 | 23 | | RLC A | Rotate A left through carry | 1 | 1 | 33 | | RR A | Rotate A right | 1 | 1 | 03 | | RRC A | Rotate A right through carry | 1 | 1 | 13 | | | DATA TRANSFER | | | | |-----------------|---------------------------------------------------|-------|--------|----------| | Mnemonic | Description | Bytes | Cycles | Hex code | | MOV A, Rn | Move register to A | 1 | 1 | E8-EF | | MOV A, dir | Move direct byte to A | 2 | 1 | E5 | | MOV A, @Ri | Move indirect memory to A | 1 | 1 | E6-E7 | | MOV A, #data | Move immediate to A | 2 | 1 | 74 | | MOV Rn, A | Move A to register | 1 | 1 | F8-FF | | MOV Rn, dir | Move direct byte to register | 2 | 2 | A8-AF | | MOV Rn, #data | Move immediate to register | 2 | 1 | 78-7F | | MOV dir, A | Move A to direct byte | 2 | 1 | F5 | | MOV dir, Rn | Move register to direct byte | 2 | 2 | 88-8F | | MOV dir, dir | Move direct byte to direct byte | 3 | 2 | 85 | | MOV dir, @Ri | Move indirect memory to direct byte | 2 | 2 | 86-87 | | MOV dir, #data | Move immediate to direct byte | 3 | 2 | 75 | | MOV @Ri, A | Move A to indirect memory | 1 | 1 | F6-F7 | | MOV @Ri, dir | Move direct byte to indirect memory | 2 | 2 | A6-A7 | | MOV @Ri, #data | Move immediate to indirect memory | 2 | 1 | 76-77 | | MOV DPTR, #data | Move immediate to data pointer | 3 | 2 | 90 | | MOVC A, @A+DPTR | Move code byte relative DPTR to A | 1 | 2 | 93 | | MOVC A, @A+PC | Move code byte relative PC to A | 1 | 2 | 83 | | MOVX A, @Ri | Move external data(A8) to A | 1 | 2 | E2-E3 | | MOVX A, @DPTR | Move external data(A16) to A | 1 | 2 | E0 | | MOVX @Ri, A | Move A to external data(A8) | 1 | 2 | F2-F3 | | MOVX @DPTR, A | Move A to external data(A16) | 1 | 2 | F0 | | PUSH dir | Push direct byte onto stack (except PUSH SP)NOTE1 | 2 | 2 | C0 | | POP dir | Pop direct byte from stack | 2 | 2 | D0 | | XCH A, Rn | Exchange A and register | 1 | 1 | C8-CF | | XCH A, dir | Exchange A and direct byte | 2 | 1 | C5 | | XCH A, @Ri | Exchange A and indirect memory | 1 | 1 | C6-C7 | | XCHD A, @Ri | Exchange A and indirect memory nibble | 1 | 1 | D6-D7 | | | BOOLEAN | | | | | | | | |-------------|---------------------------------|-------|--------|----------|--|--|--|--| | Mnemonic | Description | Bytes | Cycles | Hex code | | | | | | CLR C | Clear carry | 1 | 1 | C3 | | | | | | CLR bit | Clear direct bit | 2 | 1 | C2 | | | | | | SETB C | Set carry | 1 | 1 | D3 | | | | | | SETB bit | Set direct bit | 2 | 1 | D2 | | | | | | CPL C | Complement carry | 1 | 1 | B3 | | | | | | CPL bit | Complement direct bit | 2 | 1 | B2 | | | | | | ANL C, bit | AND direct bit to carry | 2 | 2 | 82 | | | | | | ANL C, /bit | AND direct bit inverse to carry | 2 | 2 | В0 | | | | | | ORL C, bit | OR direct bit to carry | 2 | 2 | 72 | | | | | | ORL C, /bit | OR direct bit inverse to carry | 2 | 2 | A0 | | | | | | MOV C, bit | Move direct bit to carry | 2 | 1 | A2 | | | | | | MOV bit, C | Move carry to direct bit | 2 | 2 | 92 | | | | | | | BRANCHING | | | | |-------------------|------------------------------------------|-------|--------|----------| | Mnemonic | Description | Bytes | Cycles | Hex code | | ACALL addr 11 | Absolute jump to subroutine | 2 | 2 | 11→F1 | | LCALL addr 16 | Long jump to subroutine | 3 | 2 | 12 | | RET | Return from subroutine | 1 | 2 | 22 | | RETI | Return from interrupt | 1 | 2 | 32 | | AJMP addr 11 | Absolute jump unconditional | 2 | 2 | 01→E1 | | LJMP addr 16 | Long jump unconditional | 3 | 2 | 02 | | SJMP rel | Short jump (relative address) | 2 | 2 | 80 | | JC rel | Jump on carry = 1 | 2 | 2 | 40 | | JNC rel | Jump on carry = 0 | 2 | 2 | 50 | | JB bit, rel | Jump on direct bit = 1 | 3 | 2 | 20 | | JNB bit, rel | Jump on direct bit = 0 | 3 | 2 | 30 | | JBC bit, rel | Jump on direct bit = 1 and clear | 3 | 2 | 10 | | JMP @A+DPTR | Jump indirect relative DPTR | 1 | 2 | 73 | | JZ rel | Jump on accumulator = 0 | 2 | 2 | 60 | | JNZ rel | Jump on accumulator ≠0 | 2 | 2 | 70 | | CJNE A, dir, rel | Compare A, direct jne relative | 3 | 2 | B5 | | CJNE A, #d, rel | Compare A, immediate jne relative | 3 | 2 | B4 | | CJNE Rn, #d, rel | Compare register, immediate jne relative | 3 | 2 | B8-BF | | CJNE @Ri, #d, rel | Compare indirect, immediate jne relative | 3 | 2 | B6-B7 | | DJNZ Rn, rel | Decrement register, jnz relative | 2 | 2 | D8-DF | | DJNZ dir, rel | Decrement direct byte, jnz relative | 3 | 2 | D5 | | MISCELLANEOUS | | | | | | | |---------------|--------------|-------|--------|----------|--|--| | Mnemonic | Description | Bytes | Cycles | Hex code | | | | NOP | No operation | 1 | 1 | 00 | | | | ADDITIONAL INSTRUCTIONS (selected through EO[7:4]) | | | | | |----------------------------------------------------|--------------------------------------------------------------------------------------|-------|--------|----------| | Mnemonic | Description | Bytes | Cycles | Hex code | | MOVC @(DPTR++), A | M8051W/M8051EW-specific instruction supporting software download into program memory | 1 | 2 | A5 | | TRAP | Software break command | 1 | 1 | A5 | In the above table, an entry such as E8-EF indicates a continuous block of hex opcodes used for 8 different registers, the register numbers of which are defined by the lowest three bits of the corresponding code. Non-continuous blocks of codes, shown as 11 $\rightarrow$ F1 (for example), are used for absolute jumps and calls, with the top 3 bits of the code being used to store the top three bits of the destination address. The CJNE instructions use the abbreviation #d for immediate data; other instructions use #data. NOTE1) If the operand of the PUSH instruction is SP, the operation is slightly different from that of the 8051. The use of this instruction only occurs when using the assembly language, and its use is very limited. Refer to "ERRATA\_95\_96\_97 CPU(M8051) Incompatible Instruction" for more details. ### 17.2 Flash Protection for Invalid Erase/Write #### Overview This is example to prevent changing code or data in flash by abnormal operation(noise, unstable power, malfunction, etc...). ### How to protect the flash - Divide into decision and execution to Erase/Write in flash. - Check the program sequence from decision to execution in order of precedence about Erase/Write. - Setting the flags in program and check the flags in main loop at the end - When the Flash Erase/Write is executed, check the flags. If not matched, do not execute. - · Check the range of Flash Sector Address - If the flash sector address is outside of specific area, do not execute. - · Use the Dummy Address - Set the flash sector address to dummy address in usually run time. - Change the flash sector address to real area range shortly before Erase/Write. - Even if invalid Erase/Write occurred, it will be Erase/Write in dummy address in flash. - Use the LVR/LVI - Unstable or low powers give an adverse effect on MCU. So use the LVR/LVI ### > Flowchart ### Descript of Flowchart - 1 Initialization - Set the LVR/LVI Check the power by LVR/LVI and do not execute under unstable or low power. - Initialize User ID1/2/3 - Set Flash Sector Address High/Middle/Low to Dummy address Dummy address is set to unused area range in flash. - ② Decide to Write - When the Erase/Write are determined, set flag. Do not directly Erase/Write in flash. - Make the user data. - 3 Check and Set User\_ID1/2/3 - In the middle of source, insert code which can check and set the flags. - By setting the User ID 1/2/3 sequentially and identify the flow of the program. - 4 Set Flash Sector Address - Set address to real area range shortly before Erase/Write in flash. Set to Dummy address after Erase/Write Even if invalid work occurred, it will be Erase/Write in Dummy address in flash. - (5) Check Flags - If every flag(User ID1/2/3, LVI, Flash Address Min/Max) was set, than do Erase/Write. - If the Flash Sector Address is outside of Min/Max, do not execute - Address Min/Max is set to unused area. - 6 Initialize Flags - Initialize User\_ID1/2/3 - Set Flash Sector Address to Dummy Address - · Sample Source - Refer to the ABOV homepage. - It is created based on the A97C450. - Each product should be modified according to the Page Buffer Size and Flash Size #### > Etc - · Protection by Configure option - Set flash protection by MCU Write Tool(OCD, PGM+, etc...) Specific Area : 4KBytes (Address 0000H - 0FFFH) 2KBytes (Address 0000H - 07FFH) 1KBytes (Address 0000H – 03FFH) 512 Bytes (Address 0000H - 01FFH) - The range of protection may be different each product. # **Table of contents** | Rev | evision History2 | | | |----------|------------------|-------------------------------------------------------------|----| | 1 | Ove | rview | 3 | | 1. | 1 | Description | 3 | | 1. | | Ordering information | | | 1.3 | | Features | | | 1. | | MTP programming | | | | 1.5. | | | | | 1.5.2 | | | | | 1. | 5.2.1 Circuit Design Guide | 10 | | 2 | Bloc | ck diagram | 12 | | 3 | Pin : | assignment | 13 | | 4 | Pac | kage Diagram | 14 | | 5 | Pin | Description | 15 | | 6 | Port | Structures | 17 | | 6. | | General Purpose I/O Port with Analog Input | | | | | · | | | 7 | Elec | ctrical Characteristics | 18 | | 7. | 1 | Absolute Maximum Ratings | 18 | | 7.3 | | Recommended Operating Conditions | | | 7. | | A/D Converter Characteristics | | | 7. | | Analog Comparator Characteristics | | | 7. | | Power-On Reset Characteristics | | | 7. | | Low Voltage Reset and Low Voltage Indicator Characteristics | | | 7. | | Internal RC Oscillator Characteristics | | | 7. | | Internal Watch-Dog Timer RC Oscillator Characteristics | | | 7. | | DC Characteristics | | | 7. | | AC Characteristics | | | 7. | | SPI Characteristics | | | | | USART Characteristics | | | | | I2C Characteristics | | | 7.<br>7. | | Data Retention Voltage in Stop Mode | | | 7. | | Internal EEPROM Characteristics | | | 7. | | Input/Output Capacitance | | | | | Main Clock Oscillator Characteristics | | | | | Sub Clock Oscillator Characteristics | | | | | Operating Voltage Range | | | 7. | | Recommended Circuit and Layout | | | | | Recommended Circuit and Layout with SMPS Power | | | | | Typical Characteristics | | | 8 | Men | nory | 34 | | 8. | | Program Memory | | | 8. | | Data Memory | | | 8. | | External Data Memory | | | 8.4 | | Extended Stack Pointer(XSP) | | | 8. | | Memory Extension Stack | | | 8. | | Bootloader Swap | | | 8. | | SFR Map | | | | 8.7. | | 42 | | | 8.7.2 | 2 SFR Map | 44 | | 9 I/O Ports | 48 | |--------------------------------------------------------------------------------------|----| | 9.1 I/O Ports | 48 | | 9.2 Port Register | | | 9.2.1 Data Register (Px) | 48 | | 9.2.2 Direction Register (PxIO) | | | 9.2.3 Pull-up Resistor Selection Register (PxPU) | | | 9.2.4 Open-drain Selection Register (PxOD) | | | 9.2.5 De-bounce Enable Register (PxDB) | | | 9.2.6 Port Selection Register 1 (PSR1) | | | 9.2.7 Port Selection Register 2 (PSR2) | 49 | | 9.2.8 Port Debounce Length Selection Register (IODBCNT) | | | 9.2.9 Register Map | | | 9.3 P0 Port | | | 9.3.2 Register description for P0 | | | 9.4 P1 Port | | | 9.4.1 P1 Port Description | | | 9.4.2 Register description for P1 | 53 | | 9.5 P2 Port | | | 9.5.1 P2 Port Description | | | 9.5.2 Register description for P2 | | | 9.6 P3 Port | 57 | | 9.6.1 P3 Port Description | | | 9.6.2 Register description for P3 | | | 9.7 P4 Port | | | 9.7.1 P4 Port Description | | | 9.7.2 Register description for P4 | | | 9.8 P5 Port | | | 9.8.1 P5 Port Description | | | | | | 10 Interrupt Controller | 64 | | 10.1 Overview | | | 10.2 External Interrupt | | | 10.3 Block Diagram | | | 10.4 Interrupt Vector Table | | | 10.5 Interrupt Sequence | | | 10.6 Effective Timing after Controlling Interrupt Bit | | | 10.7 Multi Interrupt | | | 10.8 Interrupt Enable Accept Timing | | | 10.10 Saving/Restore General-Purpose Registers | | | 10.10 Saving/Restore General-Fulpose Registers | | | 10.12 Interrupt Register Overview | | | 10.12.1 Interrupt Enable Register (IE, IE1, IE2, IE3, IE4) | | | 10.12.2 10.12.2 Interrupt Priority Register (IP0H/L, IP1H/L, IP2H/L, IP3H/L, IP4H/L) | | | 10.12.3 External Interrupt Flag Register (EIFLAG) | | | 10.12.4 External Interrupt Edge Register (EIEDGE) | 73 | | 10.12.5 External Interrupt Polarity Register (EIPOLA) | | | 10.12.6 External Interrupt Both Edge Enable Register (EIBOTH) | | | 10.12.7 External Interrupt Enable Register (EIENAB) | | | 10.12.8 Register Map | | | 10.12.9 Interrupt Register Description | | | 10.12.10 Register Description for Interrupt | | | 11 Peripheral Hardware | 82 | | 11.1 Stack Pointer Management Unit | 82 | | 11.1.1 | Overview | | |------------------|-----------------------------------------------|-----| | 11.1.2 | Register Map | | | 11.1.3 | Register Description for SPMU | | | 11.2 Clo | ck Generator | 87 | | 11.2.1 | Overview | | | 11.2.2 | Block Diagram | 87 | | 11.2.3 | CPU clock and Peripherals Clock | 88 | | 11.2.4 | Register Map | 89 | | 11.2.5 | Clock Generator Register Description | 89 | | 11.2.6 | Register Description for Clock Generator | | | 11.3 Bas | ic Interval Timer | | | 11.3.1 | Overview | 91 | | 11.3.2 | Block Diagram | | | 11.3.3 | Register Map | | | 11.3.4 | Basic Interval Timer Register Description | | | 11.3.5 | Register Description for Basic Interval Timer | | | | ich Dog Timer | | | 11.4.1 | Overview | | | 11.4.2 | WDT Interrupt Timing Waveform | | | 11.4.3 | Block Diagram | | | 11.4.4 | Register Map | | | 11.4.5 | Watch Dog Timer Register Description | | | 11.4.6 | Register Description for Watch Dog Timer | | | | tch Timer | | | 11.5.1 | Overview | | | 11.5.1 | Block Diagram | | | 11.5.2 | Register Map | | | | | | | 11.5.4<br>11.5.5 | Watch Timer Register Description | | | | Register Description for Watch Timerer 0/1 | | | | | | | 11.6.1 | Overview | | | 11.6.2 | 8-Bit Timer/Counter Mode | | | 11.6.3 | 8-Bit PWM Mode | | | 11.6.4 | 8-Bit Capture Mode | | | 11.6.5 | Block Diagram | | | 11.6.6 | Register Map | | | 11.6.7 | Timer/Counter 0 Register Description | | | 11.6.8 | Register Description for Timer/Counter 0/1 | | | | er 2/3 | | | 11.7.1 | Overview | | | 11.7.2 | 16-bit Timer/Counter Mode | | | 11.7.3 | 16-bit Capture Mode | | | 11.7.4 | 16-bit PPG Mode | | | 11.7.5 | Block Diagram | | | 11.7.6 | Register Map | | | 11.7.7 | Timer/Counter 2/3 Register Description | | | 11.7.8 | Register Description for Timer/Counter 2/3 | | | | er 4/5/6 | | | 11.8.1 | Overview | | | 11.8.2 | 16-bit Timer/Counter Mode | | | 11.8.3 | 16-bit Capture Mode | 123 | | 11.8.4 | 16-bit PPG Mode | | | 11.8.5 | Block Diagram | 127 | | 11.8.6 | Register Map | 127 | | 11.8.7 | Timer/Counter 4/5/6 Register Description | | | 11.8.8 | Register Description for Timer/Counter 4/5/6 | | | 11.9 Buz | zer Driver | 131 | | 11.9.1 | Overview | 131 | | 11.9.2 B | lock Diagram | 131 | |-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | 11.9.3 R | egister Map | 132 | | | uzzer Driver Register Description | | | 11.9.5 R | egister Description for Buzzer Driver | 132 | | | 4ŘT | | | 11.10.1 | Overview | 133 | | 11.10.2 | Block Diagram | 134 | | 11.10.3 | Clock Generation | | | 11.10.4 | External Clock (XCK) | | | 11.10.5 | Synchronous mode Operation | | | 11.10.6 | Data format | | | 11.10.7 | Parity bit | | | 11.10.8 | USART Transmitter | | | 11.10.8.1 | | | | 11.10.8.2 | · · · · · · · · · · · · · · · · · · · | | | 11.10.8.3 | | | | 11.10.8.4 | | | | 11.10.9 | USART Receiver | 139 | | 11.10.9.1 | | | | 11.10.9.2 | | | | 11.10.9.3 | , and the state of | | | 11.10.9.4 | | | | 11.10.9.5 | | | | 11.10.10 | SPI Mode | | | | 1 SPI Clock formats and timing | | | 11.10.11 | Register Map | | | 11.10.12 | USART Register Description | | | 11.10.13 | Register Description for USART | | | 11.10.14 | Baud Rate setting (example) | | | 11.10.15 | 0% Error Baud Rate | | | | | | | 11.11.1 | Overview | | | 11.11.2 | Block Diagram | | | 11.11.3 | Data Transmit / Receive Operation | | | 11.11.4 | SS pin function | | | 11.11.5 | Timing Waveform | | | 11.11.6 | Register Map | | | 11.11.7 | SPI Register description | | | 11.11.8 | Register Description for SPI | | | 11.12 I2C | | | | 11.12.1 | Overview | | | 11.12.2 | Block Diagram | 158 | | 11.12.3 | I2C bit Transfer | | | 11.12.4 | Start / Repeated Start / Stop | 159 | | 11.12.5 | Data Transfer | 160 | | 11.12.6 | Acknowledge | | | 11.12.7 | Synchronization / Arbitration | 161 | | 11.12.8 | Operation | 162 | | 11.12.8.1 | Master Transmitter | 162 | | 11.12.8.2 | | | | 11.12.8.3 | | | | 11.12.8.4 | | | | 11.12.9 | Register Map | | | 11.12.10 | I2C Register Description | | | 11.12.11 | Register Description for I2C | | | | pit A/D Converter | | | 11.13.1 | Overview | | | 11.13.2 | Block Diagram | | | 11.13.3 | ADC Operation | | | 11.13.4 | Register Map | 175 | | 11.13.5 | ADC Register Description | | |-----------|------------------------------------------------------|-----| | 11.13.6 | Register Description for ADC | | | 11.14 HI | DMI™- CEC Controller | 179 | | 11.14.1 | Introduction | 179 | | 11.14.2 | HDMI™-CEC register map | 179 | | 11.14.3 | HDMI-CEC Registers description | 180 | | 11.15 IR | Controller | | | 11.15.1 | Introduction | | | 11.15.2 | IR Controller Register map | | | 11.15.3 | IR Controller Registers description | | | | omparator | | | 11.16.1 | Overview | | | 11.16.1 | Block Diagram | | | | Register Map | | | 11.16.3 | | | | 11.16.4 | Comparator Register description | | | | TC (Real-time Clock) | | | 11.17.1 | Overview | | | 11.17.2 | Block Diagram | | | 11.17.3 | RTC Operation | | | 11.17.4 | Shifting to Power-Down mode after starting operation | | | 11.17.5 | Reading/writing RTC | | | 11.17.6 | Setting alarm of RTC | | | 11.17.7 | Error Correction of RTC | | | 11.17.8 | Register Map | 203 | | 11.17.9 | RTC Register description | 203 | | 11.18 BI | SC | 211 | | 11.18.1 | Overview | 211 | | 11.18.2 | Register Map | 212 | | 11.18.3 | BISC Register description | 212 | | 11.19 CI | ₹C | 213 | | 11.19.1 | Overview | 213 | | 11.19.2 | Block Diagram | | | 11.19.3 | Register Map | | | 11.19.4 | CRC Register description | | | 11.19.5 | CRC Polynomial | | | 12 Power | Down Operation | | | | rview | | | | pheral Operation in IDLE/STOP Mode | | | | SIEEP1 mode | | | | | | | | P mode (STOP1, STOP2, SLEEP2) | | | | ase Operation of Power-Down Mode | | | | Register Map | | | | Power Down Operation Register description | | | 12.5.3 | Register description for Power Down Operation | 221 | | 13 RESE | Г | 222 | | 13.1 Ove | rview | 222 | | | et source | | | | k Diagram | | | | er ON RESET | | | | rnal RESETB Input | | | | Voltage Reset and Low Voltage Indicator Processor | | | | Register Map | | | | Reset Operation Register description | | | | Register description for Reset Operation | | | | • | | | 14 ()n-ch | ip Debug System | 231 | | 14.1 Overview | | |------------------------------------------------------------|-----| | 14.1.1 Description | | | 14.1.2 Feature | | | 14.2 Two-Pin External Interface | | | 14.2.1 Basic Transmission Packet | | | 14.2.2 Packet Transmission Timing | | | 14.2.2.1 Data Transfer | | | 14.2.3 Connection of Transmission | | | 15 Memory Programming | 236 | | 15.1 Overview | | | 15.1.1 Description | | | 15.1.2 Features | | | 15.2 Flash Control and status register | | | 15.2.1 Register Map | | | 15.2.2 Register description for Flash | | | 15.3 Memory map | | | 15.3.1 Flash Memory Map | | | 15.4 Serial In-System Program Mode | | | 15.4.1 Flash operation | | | 15.4.1.1 Flash Read | | | 15.4.1.2 Enable program mode | | | 15.4.1.4 Flash page erase mode | | | 15.4.1.5 Flash bulk erase mode | | | 15.4.1.6 Flash OTP area read mode | | | 15.4.1.7 Flash OTP area write mode | | | 15.4.1.8 Flash OTP area erase mode | | | 15.4.1.9 Flash program verify mode | | | 15.4.1.10 OTP program verify mode | | | 15.4.1.11 Flash erase verify mode | | | 15.4.2 Data EEPROM operation | | | 15.4.2.1 Data EEPROM Read | | | 15.4.2.2 Enable program mode | | | 15.4.2.3 EEPROM write mode | | | 15.4.2.4 EEPROM page erase mode | | | 15.4.2.5 EEPROM bulk erase mode | | | 15.4.2.6 Data EEPROM program verify mode | | | 15.4.2.7 Data EEPROM erase verify mode | | | 15.4.2.8 Data EEPROM page buffer read | | | 15.4.3 Summary of Flash and Data EEPROM Program/Erase Mode | | | 15.5 Parallel Mode | | | 15.5.1 Overview | | | | | | | | | 15.6 Mode entrance method of ISP and byte-parallel mode | | | 15.6.1 Mode entrance method for ISP | | | , , | | | 15.7 Security | | | 16 Configure option | | | 16.1 Configure option Control Register | | | 17 APPENDIX | 258 | | 17.1 Instruction Table | 258 | | 17.2 Flash Protection for Invalid Erase/Write | | | Table of contents | 265 |