## A96T418 ## **User's Manual** # CMOS Single Chip 8-bit MCU for Touch Sensing, Smart Proximity Sensing Microcontroller User's Manual Version 1.00 #### Introduction This user's manual targets application developers who use A96T418 for their specific needs. It provides complete information of how to use A96T418 device. Standard functions and blocks including corresponding register information of A96T418 are introduced in each chapter, while instruction set is in Appendix. A96T418 is based on M8051 core, and provides standard features of 8051 such as 8-bit ALU, PC, 8-bit registers, timers and counters, serial data communication, PSW, DPTR, SP, 8-bit data bus and 2x16-bit address bus, and 8/11/16-bit operations. In addition, A96T418 incorporates following features to offer highly flexible and cost effective solutions: - 32Kbytes of FLASH, 256bytes of IRAM, and 1792bytes of XRAM - Basic interval timer, watchdog timer, and 16-bit timer/counter - 16-bit PPG output, I2C, and 12-bit ADC - 20-Channel Self Capacitive Touch Sensing, 8COM / 16SEG LED Driver - On-chip POR, LVR - On-chip oscillator and clock circuitry. As a field proven best seller, A96T418 introduces rich features such as excellent noise immunity, code optimization, cost effectiveness, and so on. #### Reference document - A96T418 programming tools and manuals released by ABOV: They are available at ABOV website, <a href="www.abovsemi.com">www.abovsemi.com</a>. - SDK-51 User's guide (System Design Kit) released by Intel in 1982: It contains all of components of a single-board computer based on Intel's 8051 single-chip microcomputer - Information on Mentor Graphics 8051 microcontroller: The technical document is provided at Mentor® website: https://www.mentor.com/products/ip/peripheral/microcontroller/ ## **Contents** | Reference document | 1 | |--------------------------------------------------|----| | 1 Description | 14 | | 1.1 Device overview | 14 | | 1.2 Block Diagram | 16 | | 2 Pinouts and pin description | 17 | | 2.1 Pinouts | 17 | | 2.2 Pin Description | 20 | | 3 Port Structures | 26 | | 3.1 General Purpose I/O Port | 26 | | 3.2 SEG I/O Port | 27 | | 3.3 COM & SEG I/O Port | 28 | | 4 Memory organization | 29 | | 4.1 Program Memory | 29 | | 4.2 Data Memory | | | 4.3 External Data Memory | 33 | | 4.4 SFR Map | 34 | | 4.4.1 SFR Map Summary | 34 | | 4.4.2 SFR Map | | | 4.4.3 Compiler Compatible SFR | | | 5 I/O Ports | | | 5.1 I/O Ports | 44 | | 5.2 Port Register | 44 | | 5.2.1 Data Register (Px) | 44 | | 5.2.2 Direction Register (PxIO) | | | 5.2.3 Pull-up Resistor Selection Register (PxPU) | | | 5.2.4 Open-drain Selection Register (PxOD) | | | 5.2.5 De-bounce Enable Register (PxDB) | | | 5.2.6 Port Function Selection Register (PxFSR) | | | 5.2.7 Register Map | | | 5.3 P0 Port | | | 5.3.1 P0 Port Description | 46 | | 5.3.2 Register Description for P0 | 46 | | 5.4 P1 Port | 50 | | 5.4.1 P1 Port Description | 50 | | 5.4.2 Register description for P1 | 50 | | 5.5 P2 Port | 54 | | 5.5.1 P2 Port Description | 54 | | 5.5.2 Register Description for P2 | | | 5.6 P3 Port | 57 | | 5.6.1 P3 Port Description | 57 | | 5.6.2 Register Description for P3 | 57 | | 6 Interrupt Controller | | | 6.1 Overview | 59 | | 6.2 External Interrupt | 61 | | 6.3 Block Diagram | 62 | | 6.4 Interrupt Vector Table | 63 | | | 6.5 | Interrupt | Sequence | 65 | |----|----------------|-----------|-----------------------------------------------------------------|----| | | 6.6 | Effective | Timing after Controlling Interrupt Bit | 66 | | | 6.7 | | errupt | | | | 6.8 | | Enable Accept Timing | | | | 6.9 | • | Service Routine Address | | | | 6.10 | _ | Restore General-Purpose Registers | | | | 6.11 | • | : Timing | | | | 6.12 | • | Register Overview | | | | | 6.12.1 | Interrupt Enable Register (IE, IE1, IE2, IE3) | | | | | 6.12.2 | Interrupt Priority Register (IP, IP1) | | | | | 6.12.3 | External Interrupt Flag Register (EIFLAG0, EIFLAG1) | | | | | 6.12.4 | External Interrupt Polarity Register (EIPOL0L, EIPOL0H, EIPOL1) | | | | | 6.12.5 | Register Map | | | | | 6.12.6 | Interrupt Register Description | | | _ | | 6.12.7 | Register Description for Interrupt | | | 7 | | | ator | | | | 7.1 | | N | | | | 7.2 | | agram | | | | 7.3 | • | Map | | | | 7.4 | | enerator Register Description | | | _ | 7.5 | _ | Description for Clock Generator | | | 8 | | | ıl Timer | | | | 8.1 | | N | | | | 8.2 | | agram | | | | 8.3 | • | Map | | | | 8.4 | | terval Timer Register Description | | | ^ | 8.5 | • | Description for Basic Interval Timer | | | 9 | | U | imer | | | | 9.1 | | N | | | | 9.2 | | errupt Timing Waveform | | | | 9.3 | | agram<br>· Map | | | | 9.4 | • | • | | | | 9.5 | | og Timer Register Description Description for Watch Dog Timer | | | 10 | 9.6 | • | Description for water bog filler | | | 10 | 7 vvai<br>10.1 | | N | | | | 10.1 | | agram | | | | 10.2 | | · Map | | | | 10.3 | _ | imer Register Description | | | | 10.4 | | Description for Watch Timer | | | 11 | | - | 3/4/5 | | | | 11.1 | | <i>9</i> -10 | | | | 11.1 | 11.1.1 | Overview | | | | | 11.1.2 | 8-bit Timer/Counter Mode | | | | | 11.1.2 | 8-bit PWM Mode | | | | | 11.1.4 | 8-bit Capture Mode | | | | | 11.1.5 | Block Diagram | | | | | 11.1.6 | Register Map | | | | | 11.1.7 | Timer/Counter 0 Register Description | | | | | 11.1.8 | Register Description for Timer/Counter 0 | | | | | • | <u> </u> | | | 11.2 | Timer 1. | | 100 | |--------|----------|------------------------------------------|-----| | | 11.2.1 | Overview | 100 | | | 11.2.2 | 16-bit Timer/Counter Mode | 100 | | | 11.2.3 | 16-bit Capture Mode | 102 | | | 11.2.4 | 16-bit PPG Mode | 104 | | | 11.2.5 | Block Diagram | 106 | | | 11.2.6 | Register Map | 106 | | | 11.2.7 | Timer/Counter 1 Register Description | 107 | | | 11.2.8 | Register Description for Timer/Counter 1 | 107 | | 11.3 | Timer 2. | | 110 | | | 11.3.1 | Overview | 110 | | | 11.3.2 | 16-bit Timer/Counter Mode | 111 | | | 11.3.3 | 16-bit Capture Mode | 112 | | | 11.3.4 | 16-bit PPG Mode | | | | 11.3.5 | Block Diagram | 117 | | | 11.3.6 | Register Map | | | | 11.3.7 | Timer/Counter 2 Register Description | | | | 11.3.8 | Register Description for Timer/Counter 2 | | | 11.4 | | | | | | 11.4.1 | Overview | | | | 11.4.2 | 16-bit Timer/Counter Mode | | | | 11.4.3 | 16-bit Capture Mode | | | | 11.4.4 | 16-bit PPG Mode | | | | 11.4.5 | Block Diagram | | | | 11.4.6 | Register Map | | | | 11.4.7 | Timer/Counter 3 Register Description | | | | 11.4.8 | Register Description for Timer/Counter 3 | | | 11.5 | | -9 | | | | 11.5.1 | Overview | | | | 11.5.2 | 16-bit Timer/Counter Mode | | | | 11.5.3 | 16-bit Capture Mode | | | | 11.5.4 | 16-bit PPG Mode | | | | 11.5.5 | Block Diagram | | | | 11.5.6 | Register Map | | | | 11.5.7 | Timer/Counter 4 Register Description | | | | 11.5.8 | Register Description for Timer/Counter 4 | | | 11.6 | | | | | | 11.6.1 | Overview | | | | 11.6.2 | 16-bit Timer/Counter Mode | | | | 11.6.3 | 16-bit Capture Mode | | | | 11.6.4 | 16-bit PPG Mode | | | | 11.6.5 | Block Diagram | | | | 11.6.6 | Register Map | | | | 11.6.7 | Timer/Counter 5 Register Description | | | | 11.6.8 | Register Description for Timer/Counter 5 | | | 12 Buz | | er | | | 12.1 | | W | | | 12.1 | | iagram | | | 12.3 | | r Map | | | 12.4 | • | Driver Register Description | | | | | | | | 12.5 | Register Description for Buzzer Driver | 151 | |--------|-------------------------------------------------|-----| | 13 USI | (USART + SPI + I2C) | 152 | | 13.1 | Overview | 152 | | 13.2 | USIn UART Mode | 153 | | 13.3 | USIn UART Block Diagram | 154 | | 13.4 | USIn Clock Generation | 155 | | 13.5 | USIn External Clock (SCKn) | 156 | | 13.6 | USIn Synchronous mode operation | 156 | | 13.7 | USIn UART Data format | 157 | | 13.8 | USIn UART Parity bit | 158 | | 13.9 | USIn UART Transmitter | 158 | | | 13.9.1 USIn UART Sending TX data | | | | 13.9.2 USIn UART Transmitter flag and interrupt | 158 | | | 13.9.3 USIn UART Parity Generator | 159 | | | 13.9.4 USIn UART Disabling Transmitter | 159 | | 13.10 | USIn UART Receiver | | | | 13.10.1 USIn UART Receiving RX data | | | | 13.10.2 USIn UART Receiver Flag and Interrupt | | | | 13.10.3 USIn UART Parity Checker | 161 | | | 13.10.4 USIn UART Disabling Receiver | 161 | | | 13.10.5 USIn Asynchronous Data Reception | 162 | | 13.11 | USIn SPI Mode | 164 | | 13.12 | USIn SPI Clock Formats and Timing | 164 | | 13.13 | USIn SPI Block Diagram | 167 | | 13.14 | USIn I2C Mode | 168 | | | USIn I2C Bit Transfer | | | | USIn I2C Start / Repeated Start / Stop | | | 13.17 | USIn I2C Data Transfer | 169 | | | USIn I2C Acknowledge | | | | USIn I2C Synchronization / Arbitration | | | 13.20 | USIn I2C Operation | | | | 13.20.1 USIn I2C Master Transmitter | | | | 13.20.2 USIn I2C Master Receiver | | | | 13.20.3 USIn I2C Slave Transmitter | | | | 13.20.4 USIn I2C Slave Receiver | 178 | | | USIn I2C Block Diagram | | | 13.22 | Register Map | 180 | | 13.23 | USIn Register Description | 180 | | | Register Description for USIn | | | 13.25 | Baud Rate setting (example) | 190 | | | \RT1 | | | 14.1 | Overview | 192 | | 14.2 | Block Diagram | | | 14.3 | Clock Generation | | | | External Clock (XCK) | | | | Synchronous mode Operation | | | | Data format | | | 14.7 | Parity bit | | | 14.8 | USART1 Transmitter | | | | 14.8.1 Sending Tx data | 197 | | | 14.8.2 | Transmitter flag and interrupt | 197 | |-------|------------------|--------------------------------------|-----| | | 14.8.3 | Parity Generator | 198 | | | 14.8.4 | Disabling Transmitter | 198 | | 14.9 | USART1 | Receiver | 198 | | | 14.9.1 | Receiving Rx data | 198 | | | 14.9.2 | Receiver flag and interrupt | 199 | | | 14.9.3 | Parity Checker | 200 | | | 14.9.4 | Disabling Receiver | 200 | | | 14.9.5 | Asynchronous Data Reception | 200 | | 14.10 | SPI Mod | le | 202 | | | | SPI Clock formats and timing | | | 14.11 | | r Time Out (RTO) | | | | | Map | | | | • | Register Description | | | | | Description for USART1 | | | | • | ate setting (example) | | | | | r Baud Rate | | | | | | | | 15.1 | | N | | | | | agram | | | | | Map | | | | • | Description for LED Driver | | | | 0 | M | | | | | e Circuit | | | 13.0 | 15.6.1 | SEG0~SEG7 Matrix | | | | 15.6.2 | SEG8~SEG15 Matrix | | | 15.7 | | unctions | | | 13.7 | | LED AUTO Mode | | | | 15.7.1 | LED Alone Mode | | | | 15.7.2 | Hand Shake Mode | | | | | | | | | 15.7.4<br>15.7.5 | LED Stop Count Mode Smart Share Mode | | | 16 00 | | | | | | | Touch Switch | | | 16.1 | | 5 | | | | | agram | | | | | ort | | | | • | Map | | | 16.5 | • | Description for Touch Sensing | | | | | ogramming Procedure | | | | | onverter | | | 17.1 | | N | | | | | ion Timing | | | | | agram | | | | - | eration | | | | • | Map | | | | | gister Description | | | | • | Description for ADC | | | | | Operation | | | | | N | | | 18.2 | Peripher | al Operation in IDLE/STOP Mode | 257 | | 260<br>261 | |-------------------| | 261<br>261 | | 261 | | | | 261 | | | | 262 | | 262 | | 262 | | 262 | | 263 | | 266 | | 267 | | 269 | | 269 | | 269 | | 270 | | 273 | | 273 | | 273 | | 274 | | 280 | | 280 | | 281 | | 281 | | 288 | | 288 | | 289 | | | | 290 | | 290<br>290 | | 290<br>290<br>290 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 21.19 | Sub Osc | cillation Characteristics | 304 | |----|--------|----------------------|----------------------------------------|-----| | | 21.20 | Operatin | ng Voltage Range | 304 | | | 21.21 | Recomm | nended Circuit and Layout | 305 | | | 21.22 | Typical ( | Characteristics | 306 | | 22 | Dev | elopmen <sup>°</sup> | t Tools | 309 | | | 22.1 | Compile | r | 309 | | | 22.2 | OCD(Or | n-chip debugger) emulator and debugger | 309 | | | 22.3 | Program | nmer | 310 | | | | 22.3.1 | E-PGM+ | 310 | | | 22.4 | Flash Pr | ogramming | 311 | | | | 22.4.1 | Overview | 311 | | | | 22.4.2 | On-Board Programming | 311 | | | | 22.4.3 | Circuit Design Guide | 311 | | | | 22.4.4 | OCD emulator | 313 | | | | 22.4.5 | Gang programmer | 313 | | | 22.5 | On-chip | Debug System | 313 | | | | 22.5.1 | Two-Pin External Interface | 315 | | 23 | Pac | kage Dia | gram | 319 | | 24 | Ord | ering Info | ormation | 322 | | | | | | | | Re | visior | n History . | | 330 | ## List of figures | Figure 1. Block diagram of A96T418 | | |-------------------------------------------------------------------------------------|-----| | Figure 2. A96T418 28SOP pin assignment (Without VDDLED) | 17 | | Figure 3. A96T418 24SOP pin assignment (Without VDDLED) | 18 | | Figure 4. A96T418 20SOP pin assignment (Without VDDLED) | 19 | | Figure 5. General Purpose I/O Port | | | Figure 6. SEG I/O Port | | | Figure 7. COM & SEG I/O Port | 28 | | Figure 8. Program Memory | 30 | | Figure 9. Data Memory Map | | | Figure 10. Lower 128bytes RAM | | | Figure 11. XDATA Memory Area | | | Figure 12. External Interrupt Description | | | Figure 13. Block Diagram of Interrupt | | | Figure 14. Interrupt Sequence Flow | 65 | | Figure 15. Effective Timing of Interrupt Enable Register | | | Figure 16. Effective Timing of Interrupt Flag Register | | | Figure 17. Effective Timing of Multi-Interrupt | | | Figure 18. Interrupt Response Timing Diagram | | | Figure 19. Correspondence between Vector Table Address and the Entry Address of ISR | | | Figure 20. Saving/Restore Process Diagram and Sample Source | | | Figure 21. Timing Chart of Interrupt Acceptance and Interrupt Return Instruction | | | Figure 22. Clock Generator Block Diagram | | | Figure 23. Basic Interval Timer Block Diagram | | | Figure 24. Watch Dog Timer Interrupt Timing Waveform | | | Figure 25. Watch Dog Timer Block Diagram | | | Figure 26. Watch Timer Block Diagram | | | Figure 27. 8-bit Timer/Counter Mode for Timer 0 | | | Figure 28. 8-bit Timer/Counter 0 Example | | | Figure 29. 8-bit PWM Mode for Timer 0 | | | Figure 30. PWM Output Waveforms in PWM Mode for Timer 0 | | | Figure 31. 8-bit Capture Mode for Timer 0 | | | Figure 32. Input Capture Mode Operation for Timer 0 | 96 | | Figure 33. Express Timer Overflow in Capture Mode | | | Figure 34. 8-bit Timer 0 Block Diagram | 97 | | Figure 35. 16-bit Timer/Counter Mode for Timer 1 | | | Figure 36. 16-bit Timer/Counter 1 Example | | | Figure 37. 16-bit Capture Mode for Timer 1 | | | Figure 38. Input Capture Mode Operation for Timer 1 | | | Figure 39. Express Timer Overflow in Capture Mode | | | Figure 41. 16-bit PPG Mode Timming chart for Timer 1 | | | | | | Figure 42. 16-bit Timer 1 Block Diagram | 111 | | Figure 44. 16-bit Timer/Counter 2 Example | | | Figure 44. 16-bit Capture Mode for Timer 2 | | | Figure 46. Input Capture Mode Operation for Timer 2 | | | Figure 47. Express Timer Overflow in Capture Mode | | | Figure 48. 16-bit PPG Mode for Timer 2 | | | Figure 49. 16-bit PPG Mode Timming chart for Timer 2 | | | Figure 50. 16-bit Timer 2 Block Diagram | | | Figure 51. 16-bit Timer/Counter Mode for Timer 3 | 122 | | Figure 52. 16-bit Timer/Counter 3 Example | | | Figure 53. 16-bit Capture Mode for Timer 3 | 124 | | Figure 54. Input Capture Mode Operation for Timer 3 | | | Figure 55. Express Timer Overflow in Capture Mode | | | Figure 56. 16-bit PPG Mode for Timer 3 | | | · · · · · · · · · · · · · · · · · · · | | | | 16-bit PPG Mode Timming chart for Timer 3 | | |------------|-----------------------------------------------------------|------------| | | 16-Bit Timer 3 Block Diagram | | | | 16-bit Timer/Counter Mode for Timer 4 | | | | 16-bit Timer/Counter 4 Example | | | Figure 61. | 16-bit Capture Mode for Timer 4 | 134 | | | Input Capture Mode Operation for Timer 4 | | | | Express Timer Overflow in Capture Mode | | | | 16-bit PPG Mode for Timer 4 | | | | 16-bit PPG Mode Timming chart for Timer 4 | | | | 16-bit Timer 4 Block Diagram | | | | 16-bit Timer/Counter Mode for Timer 5 | | | | 16-bit Timer/Counter 4 Example | | | | Input Capture Mode Operation for Timer 5 | | | | Express Timer Overflow in Capture Mode | | | | 16-bit PPG Mode for Timer 5 | | | Figure 72. | 16-bit PPG Mode Timming chart for Timer 5 | 143<br>146 | | | 16-bit Timer 5 Block Diagram | | | | Buzzer Driver Block Diagram | | | | USIn USART Block Diagram(n = 0, 1) | | | Figure 77. | Clock Generation Block Diagram (USIn) | 155 | | Figure 78. | Synchronous Mode SCKn Timing (USIn) | 156 | | | Frame Format (USIn) | | | Figure 80. | Asynchronous Start Bit Sampling (USIn) | 162 | | | Asynchronous Sampling of Data and Parity Bit (USIn) | | | | Stop Bit Sampling and Next Start Bit Sampling (USIn) | | | Figure 83. | USIn SPI Clock Formats when CPHAn=0 | 165 | | Figure 84. | USIn SPI Clock Formats when CPHAn=1 | 166 | | Figure 85. | USIn SPI Block Diagram(n = 0, 1) | 167 | | | Bit Transfer on the I2C-Bus (USIn) | | | | START and STOP Condition (USIn) | | | | Data Transfer on the I2C-Bus (USIn) | | | | Acknowledge on the I2C-Bus (USIn) | | | | Clock Synchronization during Arbitration Procedure (USIn) | | | | Arbitration Procedure of Two Masters (USIn) | | | | USIn I2C Block Diagram | | | | USART1 Block Diagram | | | | Clock Generation Block Diagram | | | | Synchronous Mode XCK Timing | | | | Start bit Sampling of Date and Barity hit | | | | Sampling of Data and Parity bit | | | | Stop bit Sampling and Next Start bit Sampling | | | | SPI Clock Formats when UCPHA=1 | | | | Example for RTO in USART1 | | | | . 0% Error Baud Rate Block Diagram | | | | . LED Driver Block Diagram | | | | SEG0~SEG7 Matrix | | | | . SEG8~SEG15 Matrix | | | - | LED auto Mode | | | • | LED alone Mode | | | • | . Hand Shake Mode | | | | LED Stop Count Mode2 | | | | Smart Share Mode | | | | 16-bit Touch Block Diagram | | | | CAPN Pin with Cs Capacitor2 | | | | User Programming Procedure2 | | | | . 12-bit ADC Block Diagram | | | | · · · · · · · · · · · · · · · · · · · | 251 | | | | A/D Power (AVREF) Pin with Capacitor | | |----------|------|---------------------------------------------------------|------| | | | ADC Operation for Align Bit | | | | | A/D Converter Operation Flow | | | Figure | 119. | IDLE Mode Release Timing by External Interrupt | 258 | | | | STOP Mode Release Timing by External Interrupt | | | | | STOP Mode Release Flow | | | Figure | 122. | RESET Block Diagram | 262 | | Figure | 123. | Fast VDD Rising Time | 263 | | Figure | 124. | Internal RESET Release Timing On Power-Up | 263 | | | | Configuration Timing when Power-on | | | | | Boot Process WaveForm | | | | | Timing Diagram after RESET | | | | | Oscillator generating waveform example | | | | | Block Diagram of LVR | | | | | Internal Reset at the power fail situation | | | | | Configuration timing when LVR RESET | | | | | LVI Diagram | | | | | Read device internal CkeckSum(Full size) | | | | | Read device internal CkeckSum(User define size) | | | | | Flash Memory Map | | | | | Address Configuration of Flash Memory | | | | | The Sequence of Page Program and Erase of Flash Memory | | | | | The Sequence of Bulk Erase of Flash Memory | | | | | ISP Mode | | | | | AC Timing | | | | | Waveform for USART Timing Characteristics | | | | | Timing Waveform for the USART Module | | | | | SPI0/1/2 Timing | | | | | Waveform for UART0 Timing Characteristics | | | | | Timing Waveform for the UART0 Module | | | | | I2C0 Timing | | | | | Stop Mode Release Timing when Initiated by an Interrupt | | | | | Stop Mode Release Timing when Initiated by RESETB | | | | | Crystal Oscillator | | | | | External Clock | | | | | Clock Timing Measurement at SXIN | | | | | Operating Voltage Range | | | | | Recommended Voltage Range | | | | | RUN (IDD1) Current | | | | | IDLE (IDD2) Current | | | | | SUB RUN (IDD3) Current | | | | | SUB IDLE (IDD4) Current | | | | | STOP (IDD5) Current | | | | | Debugger(OCD1/OCD2) and pin description | | | | | E-PGMplus (Single writer) | | | | | PCB design guide for on board programming | | | | | E-GANG4 and E-GANG6 (for Mass Production) | | | | | Block Diagram of On-Chip Debug System | | | | | 10-bit Transmission Packet | | | | | Data Transfer on the Twin Bus | | | _ | | Bit Transfer on the Serial Bus | | | | | Start and Stop Condition | | | | | Acknowledge on the Serial Bus | | | | | Clock Synchronization during Wait Procedure | | | | | Connection of Transmission | | | _ | | 28-Pin SOP Package | | | | | 24-Pin SOP Package | | | | | 20-Pin SOP Package | | | . igui c | | 20 · 00. · dolago | J_ 1 | ## List of tables | Table 1. A96T418 Device Features and Peripheral Counts | 14 | |--------------------------------------------------------------------------------------------|-------| | Table 1. A96T418 Device Features and Peripheral Counts (continued) | 15 | | Table 2. Normal Pin Description | | | Table 2. Normal Pin Description (continued) | | | Table 2. Normal Pin Description (continued) | | | Table 2. Normal Pin Description (continued) | | | Table 2. Normal Pin Description (continued) | | | Table 3. SFR Map Summary | 34 | | Table 4. XSFR Map Summary | | | Table 5. SFR Map | | | Table 5. SFR Map (Continued) | 37 | | Table 5. SFR Map (Continued) | 38 | | Table 5. SFR Map (Continued) | 39 | | Table 6. XSFR Map | 40 | | Table 6. XSFR Map (Continued) | 41 | | Table 7. Port Register Map | 45 | | Table 8. Interrupt Group Priority Level | 60 | | Table 9. Interrupt Vector Address Table | 63 | | Table 10. Interrupt Register Map | 70 | | Table 11. Clock Generator Register Map | 78 | | Table 12. Basic Interval Timer Register Map | 82 | | Table 13. Watch Dog Timer Register Map | 85 | | Table 14. Watch Timer Register Map | 88 | | Table 15. Timer 0 Operating Modes | | | Table 16. Timer 0 Register Map | | | Table 17. Timer 1 Operating Modes | | | Table 18. Timer 1 Register Map | . 106 | | Table 19. Timer 2 Operating Modes | | | Table 20. Timer 2 Register Map | | | Table 21. Timer 3 Operating Modes | | | Table 22. Timer 3 Register Map | | | Table 23. TIMER 4 Operating Modes | . 131 | | Table 24. Timer 4 Register Map | | | Table 25. TIMER 5 Operating Modes | | | Table 26. Timer 5 Register Map | | | Table 27. Buzzer Frequency at 8 MHz | | | Table 28. Buzzer Driver Register Map | | | Table 29. Equations for Calculating USIn Baud Rate Register Setting | | | Table 30. CPOLn Functionality | | | Table 31. USI Register Map | | | Table 32. Examples of USI0BD Settings for Commonly Used Oscillator Frequencies | | | Table 33. Examples of USI0BD Settings for Commonly Used Oscillator Frequencies (continued) | | | Table 33. Examples of USI0BD Settings for Commonly Used Oscillator Frequencies (continued) | | | Table 33. Equations for Calculating Baud Rate Register Setting | | | Table 34. CPOL Functionality | | | Table 35. USART1 Register Map | | | Table 36. Examples of UBAUD Settings for Commonly Used Oscillator Frequencies | | | Table 37. LED Driver Register Map | | | Table 38. LED RAM | | | Table 39. Touch Register Map | | | Table 40. ADC Register Map | | | Table 41. Peripheral Operation during Power Down Mode | | | Table 42. Power Down Operation Register Map | | | Table 43. Reset State | | | Table 44. Boot Process Description | | | Table 45. Reset Operation Register Map | . 269 | | Table 46. Register Map | 273 | |--------------------------------------------------------------------------------|-----| | Table 47. Program/erase Time | 279 | | Table 48. Operation Mode | 287 | | Table 49. Security policy using lock-bits | 289 | | Table 50. Absolute Maximum Ratings | 291 | | Table 51. Recommended Operating Conditions | 291 | | Table 52. Touch Switch Characteristics | 292 | | Table 53. A/D Converter Characteristics | 292 | | Table 54. Power-on Reset Characteristics | 292 | | Table 55. LVR and LVI Characteristics | | | Table 56. High Internal RC Oscillator Characteristics | | | Table 57. Internal WDTRC Oscillator Characteristics | 294 | | Table 58. DC Characteristics | | | Table 59. AC Characteristics | 296 | | Table 60. USART Characteristics | 297 | | Table 61. SPI0 Characteristics | 298 | | Table 62. UART0 Characteristics | 299 | | Table 63. I2C0 Characteristics | 300 | | Table 64. Data Retention Voltage in Stop Mode | 301 | | Table 65. Internal Flash Rom Characteristics | 302 | | Table 66. Input / Output Capacitance | 302 | | Table 67. Sub Clock Oscillator Characteristics | 303 | | Table 68. Sub Oscillation Stabilization Characteristics | 304 | | Table 69. Descriptions of pins which are used to programming/reading the Flash | 311 | | Table 70. Descriptions of pins which are used to programming/reading the Flash | 314 | | Table 71. Ordering Information of A96T418 | 322 | 1. Description A96T418 User's manual ## 1 Description The A96T418 is an advanced CMOS 8-bit microcontroller with 32Kbytes of FLASH. This is powerful microcontroller which provides a highly flexible and cost effective solution to many embedded control applications. #### 1.1 Device overview In this section, features of A96T418 and peripheral counts are introduced. Table 1. A96T418 Device Features and Peripheral Counts | Peripherals | | Description | |--------------|------------------------|------------------------------------------------------------------------| | Core | CPU | 8-bit CISC core (M8051, 2 clocks per cycle) | | | Interrupt | Up to 23 peripheral interrupts supported. | | | | <ul> <li>EINT0 to 7, EINT8, EINT10, EINT11, EINT12 (5)</li> </ul> | | | | • Timer (0/1/2/3/4/5) (6) | | | | • WDT (1) | | | | • BIT (1) | | | | • WT (1) | | | | • USART Rx/Tx (2) | | | | <ul> <li>USI 1-ch. *Rx/Tx/I2C (3)</li> </ul> | | | | • Touch (1) | | | | • LED (1) | | | | • ADC (1) | | | | • LVI (1) | | Memory | ROM (FLASH) | <ul> <li>32Kbytes FLASH with self-read and write capability</li> </ul> | | | capacity | <ul> <li>In-system programming (ISP)</li> </ul> | | | | Endurance: 10,000 times | | | IRAM | 256Bytes | | | XRAM | 1792Bytes | | Programmabl | e pulse generation | <ul> <li>Pulse generation (by T1/T2/T3/T4/T5)</li> </ul> | | | | 8-bit PWM (by T0) | | | | • 16-bit PPG (by T1/T2/T3/T4/T5) | | Buzzer | | 8-bit × 1-ch | | Minimum inst | ruction execution time | 125ns (@ 16MHz, NOP Instruction) | | Power down r | mode | STOP1 mode | | | | STOP2 mode | | | | IDLE mode | | General Purp | ose I/O (GPIO) | Normal I/O : 26 ports | | | | <ul> <li>High sink current port: 8 ports (P2[7:0])</li> </ul> | A96T418 User's manual 1. Description Table 1. A96T418 Device Features and Peripheral Counts (continued) | Peripherals | | Description | | | | | |------------------------|-------------------|------------------------------------------------------|--|--|--|--| | Reset | Power on reset | Power on reset : 1.2V | | | | | | | Low voltage reset | 15 levels detect | | | | | | | | • 1.61/1.77/1.88/2.00/2.13/2.28/2.46/2.68/2.81/3.06/ | | | | | | | | 3.21/3.56/3.73/3.91/4.25V | | | | | | Low voltage indicator | | level detect: 1.88~4.25V with 13 Levels | | | | | | Watch Timer (WT) | | • 14-bit x 1-ch | | | | | | | | 3.91ms/0.25s/0.5s/1s/1min interval at 32.768KHz | | | | | | Timer/counter | | Basic interval timer (BIT) 8-bit x 1-ch. | | | | | | | | Watch Dog Timer (WDT) 8-bit x 1-ch. | | | | | | | | 8-bit x 1-ch (Timer 0) | | | | | | | | • 16-bit x 5-ch (Timer 1/2/3/4/5) | | | | | | Communication | USI | USART + SPI + I2C | | | | | | function | | 8-bit USART × 1-ch, 8-bit SPI × 1-ch and I2C × 1-ch | | | | | | | USART | USART + SPI | | | | | | | | 8-bit USART × 1-ch and 8-bit SPI × 1-ch | | | | | | | | Receiver timer out (RTO) | | | | | | | | 0% error baud rate | | | | | | 12-bit A/D converter | | 8 Input channels | | | | | | 20-Ch Self Capacitive | Touch Switch | Fast Initial Self-Calibration | | | | | | | | Key detection mode : Single/Multi-mode | | | | | | | | CS Immunity : 10V | | | | | | | | 16-bit Sensing Resolutions | | | | | | | | Support Touch Key Int. Wakeup at Power down | | | | | | LED Driver | | • 8COM (160mA) / 16SEG (13.61mA) | | | | | | | | Constant Current Segment (3 level) | | | | | | Oscillator type | | 2, 4, 8, 16MHz (internal RC oscillator) | | | | | | | | 32.768kHz Crystal for sub clock | | | | | | Internal RC oscillator | | • HSIRC 16MHz ±3.0% (TA=-40~ +85°C) | | | | | | | | • LSIRC 128kHz ±20% (TA= -40~ +85°C) | | | | | | Operating voltage and | d frequency | • 2.0V~ 5.5V @ 16MHz | | | | | | | | 2.7V~ 5.5V ( Touch, ADC, LED Driver) | | | | | | Operating temperatur | е | -40°C to +85°C | | | | | | Package | | • 28 SOP | | | | | | | | • 24 SOP | | | | | | | | • 20 SOP | | | | | | | | Pb-free packages | | | | | 1. Description A96T418 User's manual #### 1.2 Block Diagram In this section, A96T418 devices and peripheral are described in a block diagram. Figure 1. Block diagram of A96T418 ## 2 Pinouts and pin description Pinouts and pin descriptions of A96T418 device are introduce in the following sections. #### 2.1 Pinouts Figure 2. A96T418 28SOP pin assignment (Without VDDLED) Figure 3. A96T418 24SOP pin assignment (Without VDDLED) Figure 4. A96T418 20SOP pin assignment (Without VDDLED) Figure 1 ## 2.2 Pin Description Table 2. Normal Pin Description | PIN | 1/0 | Function @RES | | Shared with | | | | | |------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------------------------------------|--|--|--|--| | Name | Ş | i dilodori | | Charca war | | | | | | P00 | | Port P0 | | RESETB/SEG13/TXD1/MOSI1/CS18 | | | | | | P01 | | | | DSDA/RXD0/MISO0/SCL0/EC3 | | | | | | P02 | | 8-Bit I/O Port Can be set in input or output mode in 1-bit units Internal pull-up register can be used via software when this port is used as input port Open Drain enable register can be used via software when this port is used as output port Port P1 8-Bit I/O Port Can be set in input or output mode in 1-bit units Internal pull-up register can be used via software when this port is used as input port Open Drain enable register can be used via software when this port is used as output port. The P12 – P15 are not in the 24-pin package. The P10 – P17 are not in the | | DSCL/TXD0/MOSI0/SDA0/T3O/PWM3O | | | | | | P03 | I/O | | Input | BUZ0/SEG12/SCK0/EINT0/AN7/AVREF/CS19 | | | | | | P04 | 1/0 | | прис | SEG11/SS0/EINT1/AN0/CS0 | | | | | | P05 | | Open Drain enable register can | | SEG10/EINT2/T3O/PWM3O/AN1/CS1 | | | | | | P06 | | Open Drain enable register can be used via software when this port is used as output port Port P1 8-Bit I/O Port Can be set in input or output mode in 1-bit units Internal pull-up register can be used via software when this port is used as input port Open Drain enable register can | | SEG9/EINT3/EC3/T4O/PWM4O/AN2/CS2 | | | | | | P07 | | port is used as output port | | SEG8/EINT4/T5O/PWM5O/AN3/CS3 | | | | | | P10 | | | | SEG15/AN4/CS4/(RXD0)/(MISO0)/(SCL0) | | | | | | P11 | | Can be set in input or output mode in 1-bit units Internal pull-up register can be used via software when this port is used as input port Open Drain enable register can be used via software when this port is used as output port. The P12 – P15 are not in the | | EINT5/T1O/PWM1O/AN5/CS5/(TXD0)/(MOSI0)/(SDA0) | | | | | | P12 | | | | EINT12/T2O/PWM2O/AN6/CS6 | | | | | | P13 | | | | | | | | | | P14 | I/O | | Input | SS1/CS7 | | | | | | P15 | | be used via software when this | | SCK1/CS8 | | | | | | P16 | | 1 ' | | (RXD1)/(MISO1)/CS9 | | | | | | P17 | | | | (TXD1)/(MOSI1)/CS10 | | | | | | P20 | | Port P2 | | COM0(SEG0) | | | | | | P21 | | 8-Bit I/O Port | | COM1(SEG1) | | | | | | P22 | | | | COM2(SEG2)/CS11 | | | | | | P23 | I/O | 8-Bit I/O Port Can be set in input or output mode in 1-bit units Internal pull-up register can be | Input | COM3(SEG3)/EC1/CS12 | | | | | | P24 | 1/0 | used via software when this port is used as input port | прис | COM4(SEG4)/CS13 | | | | | | P25 | | Open Drain enable register can | | COM5(SEG5)/EINT11/EC0/CS14 | | | | | | P26 | | be used via software when this | | SXOUT/COM6(SEG6)/EINT10/CS15 | | | | | | P27 | | port is used as output port. | | SXIN/COM7(SEG7)/T0O/PWM0O/CS16 | | | | | Table 2. Normal Pin Description (continued) | PIN | | | | 2 | | | | | |--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------|--|--|--|--| | Name | I/O | Function | @RESET | Shared with | | | | | | P30 | I/O | Port P3 2-Bit I/O Port Can be set in input or output mode in 1-bit units Internal pull-up register can be used via software when this port is used as input port | Input | CAPN | | | | | | P31 | | Open Drain enable register can be used via software when this port is used as output port. The P31 is not in the package with VDDLED pin. | | SEG14/RXD1/MISO1/EINT8/CS17 | | | | | | EINT0 | I/O | External interrupt inputs | Input | P03/BUZ0/SEG12/SCK0/AN7/AVREF/CS19 | | | | | | EINT1 | | External interrupt inputs | input | P04/SEG11/SS0/AN0/CS0 | | | | | | EINT2 | I/O | External interrupt input and Timer 3 capture input | Input | P05/SEG10/T3O/PWM3O/AN1/CS1 | | | | | | EINT3 | I/O | External interrupt input and Timer 4 capture input | Input | P06/SEG9/EC3/T4O/PWM4O/AN2/CS2 | | | | | | EINT4 | I/O | External interrupt input and Timer 5 capture input | Input | P07/SEG8/T5O/PWM5O/AN3/CS3 | | | | | | EINT5 | I/O | External interrupt input and Timer 1 capture input | Input | P11/T1O/PWM1O/AN5/CS5/(TXD0)/(MOSI0)/(SDA0) | | | | | | EINT8 | I/O | External Interrupt input | Input | P31/SEG14/RXD1/MISO1/CS17 | | | | | | EINT10 | I/O | External interrupt input | Input | P26/SXOUT/COM6(SEG6)/CS15 | | | | | | EINT11 | I/O | External interrupt input | Input | P25/COM5(SEG5)/EC0/CS14 | | | | | | EINT12 | I/O | External interrupt input and Timer 2 capture input | Input | P12/T2O/PWM2O/AN6/CS6 | | | | | | T0O | I/O | Timer 0 interval output | Input | P27/SXIN/COM7(SEG7)/PWM0O/CS16 | | | | | | T10 | I/O | Timer 1 interval output | Input | P11/EINT5/PWM1O/AN5/CS5/(TXD0)/(MOSI0)/(SDA0) | | | | | | T2O | I/O | Timer 2 interval output | Input | P12/EINT12/PWM2O/AN6/CS6 | | | | | Table 2. Normal Pin Description (continued) | PIN<br>Name | I/O | Function | @RESE<br>T | Shared with | | | |-------------|-----|--------------------------------------------|----------------------------------------|-----------------------------------------------------------------------------|--|--| | T3O | I/O | Timer 3 interval output | Input | P02/DSCL/TXD0/MOSI0/SDA0/PWM3O<br>P05/ SEG10/EINT2/PWM3O/AN1/CS1 | | | | T40 | I/O | Timer 4 interval output | Input P06/SEG9/EINT3/EC3/PWM4O/AN2/CS2 | | | | | T5O | I/O | Timer 5 interval output | Input | P07/SEG8/EINT4/PWM5O/AN3/CS3 | | | | PWM0O | I/O | Timer 0 PWM output | Input | P27/SXIN/T0O/COM7/CS16 | | | | PWM1O | I/O | Timer 1 PWM output | Input | P11/EINT5/T1O/AN5/CS5/(TXD0)/(MOSI0)/(SDA0) | | | | PWM2O | I/O | Timer 2 PWM output | Input | P12/EINT12/T2O/AN6/CS6 | | | | PWM3O | I/O | Timer 3 PWM output | Input | P02/DSCL/TXD0/MOSI0/SDA0/T3O<br>P05/ SEG10/EINT2/T3O/AN1/CS1 | | | | PWM4O | I/O | Timer 4 PWM output | Input | P06/SEG9/EINT3/EC3/T4O/AN2/CS2 | | | | PWM5O | I/O | Timer 5 PWM output | Input | P07/SEG8/EINT4/T5O/AN3/CS3 | | | | EC0 | I/O | Timer 0 event count input | Input | P25/COM5(SEG5)/EINT11/CS14 | | | | EC1 | I/O | Timer 1 event count input | Input | P23/COM3(SEG3)/CS12 | | | | EC3 | I/O | Timer 3 event count input | Input | P01/DSDA/RXD0/MISO0/SCL0<br>P06/SEG9/EINT3/T4O/PWM4O/AN2/CS2 | | | | BUZ0 | I/O | Buzzer signal output | Input | P03/SEG12/SCK0/AN7/EINT0/AVREF/CS19 | | | | SCK0 | I/O | Serial 0 clock input/output | Input | P03/BUZ0/SEG12/AN7/EINT0/AVREF/CS19 | | | | SCK1 | I/O | Serial 1 clock input/output | Input | P15/CS8 | | | | MOSI0 | I/O | SPI 0 master output, slave input | Input | P02/DSCL/TXD0/SDA0/T3O/PWM3O<br>P11/EINT5/T1O/PWM1O/AN5/CS5/(TXD0)/(SDA0) | | | | MOSI1 | I/O | SPI 1 master output, slave input | Input | P00/RESETB/SEG13/TXD1/CS18<br>P17/(TXD1)/CS10 | | | | MISO0 | I/O | SPI 0 master input, slave output | Input | P01/DSDA/RXD0/SCL0/EC3<br>P10/SEG15/AN4/CS4/(RXD0)/(SCL0) | | | | MISO1 | I/O | SPI 1 master input, slave output | Input | P16/(RXD1)/CS9<br>P31/SEG14/RXD1/EINT8/CS17 | | | | SS0 | I/O | SPI 0 slave select input (Slave mode only) | Input | P04/SEG11/SS0/EINT1/AN0/CS0 | | | | SS1 | I/O | SPI 1 slave select input (Slave mode only) | Input | P14/CS7 | | | | TXD0 | I/O | UART 0 data output | Input | P02/DSCL/MOSI0/SDA0/T3O/PWM3O<br>P11/EINT5/T1O/PWM1O/AN5/CS5/(MOSI0)/(SDA0) | | | | TXD1 | I/O | UART 1 data output | Input | P00/RESETB/SEG13/MOSI1/CS18<br>P17/(MOSI1)/CS10 | | | | RXD0 | I/O | UART 0 data input | Input | P01/DSDA/MISO0/SCL0/EC3<br>P10/SEG15/AN4/CS4/(MISO0)/(SCL0) | | | | RXD1 | I/O | UART 1 data input | Input | P16/(MISO1)/CS9<br>P31/SEG14/MISO1/EINT8/CS17 | | | Table 2. Normal Pin Description (continued) | DIN | Table 2. Normal Pin Description (continued) | | | | | | | | | |-------------|---------------------------------------------|---------------------------------|--------|-----------------------------------------------------------------------------|--|--|--|--|--| | PIN<br>Name | 1/0 | Function | @RESET | Shared with | | | | | | | SCL0 | I/O | I2C 0 clock input/output | Input | P01/DSDA/RXD0/MISO0/EC3<br>P10/SEG15/AN4/CS4/(RXD0)/(MISO0) | | | | | | | SDA0 | I/O | I2C 0 data input/output | Input | P02/DSCL/TXD0/MOSI0/T3O/PWM3O<br>P11/EINT5/T1O/PWM1O/AN5/CS5/(TXD0)/(MOSI0) | | | | | | | AVREF | I/O | A/D converter reference voltage | Input | P03/BUZ0/SEG12/SCK0/AN7/EINT0/CS19 | | | | | | | AN0 | | | | P04/SEG11/SS0/EINT1/CS0 | | | | | | | AN1 | | | | P05/SEG10/EINT2/T3O/PWM3O/CS1 | | | | | | | AN2 | | | | P06/SEG9/EINT3/EC3/T4O/PWM4O/CS2 | | | | | | | AN3 | 1/0 | A/D converter analog | la a t | P07/SEG8/EINT4/T5O/PWM5O/CS3 | | | | | | | AN4 | I/O | input channels | Input | P10/SEG15/CS4/(RXD0)/(MISO0)/(SCL0) | | | | | | | AN5 | | | | P11/EINT5/T1O/PWM1O/CS5/(TXD0)/(MOSI0)/(SDA0) | | | | | | | AN6 | | | | P12/EINT12/T2O/PWM2O/CS6 | | | | | | | AN7 | | | | P03/BUZ0/SEG12/SCK0/AVREF/EINT0/CS19 | | | | | | | COM0 | | | | P20/(SEG0) | | | | | | | COM1 | | | Input | P21/(SEG1) | | | | | | | COM2 | | | | P22/(SEG2)/CS11 | | | | | | | СОМЗ | | 1 ED 0014 | | P23/(SEG3)EC1/CS12 | | | | | | | COM4 | | LED COM ports | | P24/(SEG4)/CS13 | | | | | | | COM5 | | | | P25/(SEG5)/EINT11/EC0/CS14 | | | | | | | COM6 | | | | P26/(SEG6)/SXOUT/EINT10/CS15 | | | | | | | COM7 | | | | P27/(SEG7)SXIN/T0D/PWM0O/CS16 | | | | | | | SEG0 | | | | P20/(COM0) | | | | | | | SEG1 | | | | P21/(COM1) | | | | | | | SEG2 | | | | P22/(COM2)/CS11 | | | | | | | SEG3 | | | | P23/(COM3)EC1/CS12 | | | | | | | SEG4 | | | | P24/(COM4)/CS13 | | | | | | | SEG5 | | | | P25/(COM5)/EINT11/EC0/CS14 | | | | | | | SEG6 | | | | P26/(COM6)/SXOUT/EINT10/CS15 | | | | | | | SEG7 | I/O | LED SEG ports | Input | P27/(COM7)SXIN/T0D/PWM0O/CS16 | | | | | | | SEG8 | | | | P07/EINT4/T5O/PWM5O/AN3/CS3 | | | | | | | SEG9 | | | | P06/EINT3/EC3/T4O/PWM4O/AN2/CS2 | | | | | | | SEG10 | | | | P05/EINT2/T3O/PWM3O/AN1/CS1 | | | | | | | SEG11 | | | | P04/SS0/EINT1/AN0/CS0 | | | | | | | SEG12 | | | | P03/BUZ0/SCK0/EINT0/AN7/AVREF/CS19 | | | | | | | SEG13 | | | | P00/RESETB/TXD1/MOSI1/CS18 | | | | | | | SEG14 | | | | P31/RXD1/MISO1/EINT8/CS17 | | | | | | | CAPN | I/O | Modulation CAP | Input | P30 | | | | | | Table 2. Normal Pin Description (continued) | PIN | | Function @RESET | | 2 | | | | | |-------------|-----|------------------------------------------------------------------------------------------------|--------|-----------------------------------------------|--|--|--|--| | Name | 1/0 | Function | @RESET | Shared with P04/SEG11/SS0/EINT1/AN0 | | | | | | CS0 | | | | P04/SEG11/SS0/EINT1/AN0 | | | | | | CS1 | | | | P05/SEG10/EINT2/T3O/PWM3O/AN1 | | | | | | CS2 | | | | P06/SEG9/EINT3/EC3/T4O/PWM4O/AN2 | | | | | | CS3 | | | | P07/SEG8/EINT4/T5O/PWM5O/AN3 | | | | | | CS4 | | | | P10/SEG15/AN4/(RXD0)/(MISO0)/(SCL0) | | | | | | CS5 | | | | P11/EINT5/T1O/PWM1O/AN5/(TXD0)/(MOSI0)/(SDA0) | | | | | | CS6 | | Touch Switch Inputs | | P12/EINT12/T2O/PWM2O/AN6 | | | | | | CS7 | | | | P14/SS1 | | | | | | CS8 | | | | P15/SCK1 | | | | | | CS9 | 1/0 | | Innut | P16/(RXD1)/(MISO1) | | | | | | CS10 | 1/0 | | Input | P17/(TXD1)/(MOSI1) | | | | | | CS11 | | | | P22/COM2(SEG2) | | | | | | CS12 | | | | P23/COM3(SEG3)/EC1 | | | | | | CS13 | | | | P24/COM4(SEG4) | | | | | | CS14 | | | | P25/COM5(SEG5)/EINT11/EC0 | | | | | | CS15 | | | | P26/SXOUT/COM6(SEG6)/EINT10 | | | | | | CS16 | | | | P27/SXIN/COM7(SEG7)/T0O/PWM0O | | | | | | CS17 | | | | P31/SEG14/RXD1/MISO1/EINT8 | | | | | | CS18 | | | | P00/RESETB/SEG13/TXD1/MOSI1 | | | | | | CS19 | | | | P03/BUZ0/SEG12/SCK0/EINT0/AN7/AVREF | | | | | | RESETB | I/O | System reset pin with a pull-up resistor when it is selected as the RESETB by CONFIGURE OPTION | Input | P00/SEG13/TXD1/MOSI1/CS18 | | | | | | DSDA | I/O | In-system programming data input/output | Input | P01/RXD0/MISO0/SCL0/EC3 | | | | | | DSCL | I/O | In-system programming clock input | Input | P02/TXD0/MOSI0/SDA0/T3O/PWM3O | | | | | | SXIN | I/O | Sub oscillator pins | Input | P27/T0O/PWM0O/COM7(SEG7)/CS16 | | | | | | SXOUT | | | | P26/COM6(SEG6)/EINT10/CS15 | | | | | | VDD,<br>VSS | _ | Power input pins | _ | - | | | | | | VDDLED | _ | Power input pin for LED | _ | - | | | | | #### NOTES: - 1. The P12-P15 are not in the 24-pin package. - 2. The P10-P17 are not in the 20-pin package. - 3. The P00/RESETB pin is configured as one of the P00 and RESETB pin by the "CONFIGURE OPTION." - 4. If the P01/EC3/MISO0/RXD0/SCL0/DSDA and P02/T3O/PWM3O/MOSI0/TXD0/SDA0/DSCL pins are connected to the programmer during power-on reset, the pins are automatically configured as In-system programming pins. - 5. The P01/EC3/MISO0/RXD0/SCL0/DSDA and P02/T3O/PWM3O/MOSI0/TXD0/SDA0/DSCL pins are configured as inputs with internal pull-up resistor only during the reset or power-on reset. - The P00/RESETB/SEG13/TXD1/MOSI1/CS18, P27/T00/PWM00/COM7/CS16/SXIN, and P26/COM6/EINT10/CS15/SXOUT pins are configured as a function pin by software control. 3. Port Structures A96T418 User's manual ## 3 Port Structures ## 3.1 General Purpose I/O Port Figure 5. General Purpose I/O Port A96T418 User's manual 3. Port Structures #### 3.2 SEG I/O Port Figure 6. SEG I/O Port 3. Port Structures A96T418 User's manual #### 3.3 COM & SEG I/O Port Figure 7. COM & SEG I/O Port ## 4 Memory organization The A96T418 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. A96T418 provides on-chip 32Kbytes of the ISP type flash program memory, which can be read and written to. Internal data memory (IRAM) is 256bytes and it includes the stack area. External data memory (XRAM) is 1792bytes. #### 4.1 Program Memory A 16-bit program counter is capable of addressing up to 64Kbytes, but this device has just 32Kbytes program memory space. Figure 8 shows the map of the lower part of the program memory. After reset, the CPU begins execution from location 0000H. Each interrupt is assigned a fixed location in program memory. The interrupt causes the CPU to jump to that location, where it commences execution of the service routine. External interrupt 3, for example, is assigned to location 001BH. If external interrupt 3 is going to be used, its service routine must begin at location 001BH. If the interrupt is not going to be used, its service location is available as general purpose program memory. If an interrupt service routine is short enough (as is often the case in control applications), it can reside entirely within that 8bytes interval. Longer service routines can use a jump instruction to skip over subsequent interrupt locations, if other interrupts are in use. Figure 8. Program Memory #### NOTES: 1. 32Kbytes Including Interrupt Vector Region #### 4.2 Data Memory Figure 9. Data Memory Map The internal data memory space is divided into three blocks, which are generally referred to as the lower 128bytes, upper 128bytes, and SFR space. Internal data memory addresses are always one byte wide, which implies an address space of only 256bytes. However, in fact, the addressing modes for internal RAM can accommodate up to 384bytes 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 9 shows the upper 128bytes and SFR space occupying the same block of addresses, 80H through FFH, although they are physically separate entities. The lower 128bytes of RAM are present in all 8051 devices as mapped in Figure 10. The lowest 32bytes 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 use of code space, since register instructions are shorter than instructions that use direct addressing. The next 16bytes 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 128bytes can be accessed by either direct or indirect addressing. The upper 128bytes RAM can only be accessed by indirect addressing. These spaces are used for data RAM and stack. Figure 10. Lower 128bytes RAM ## 4.3 External Data Memory A96T418 has 1792bytes XRAM and XSFR. This area has no relation with RAM/FLASH. It can be read and written to through SFR with 8-bit unit. Figure 11. XDATA Memory Area 4. Memory organization A96T418 User's manual ## 4.4 SFR Map #### 4.4.1 SFR Map Summary Table 3. SFR Map Summary | - | Reserved | |---|------------------| | | M8051 compatible | | | 00H/8H <sup>(1)</sup> | 01H/9H | 02H/0AH | 03H/0BH | 04H/0CH | 05H/0DH | 06H/0EH | 07H/0FH | | |------|-----------------------|----------------|---------|---------|----------------|---------------|------------------|----------|--| | 0F8H | IP1 | _ | _ | _ | UBAUD | UDATA | _ | _ | | | 0F0H | В | _ | _ | _ | | | _ | _ | | | 0E8H | RSTFR | _ | _ | _ | _ | _ | P3FSR | - | | | 0Е0Н | ACC | USI0ST1 | USI0ST2 | USI0BD | USI0SDHR | USI0DR | USI0SCLR | USI0SCHR | | | 0D8H | LVRCR | USI0CR1 | USI0CR2 | USI0CR3 | USI0CR4 | USI0SAR | P0DB | P123DB | | | 0D0H | PSW | _ | P0FSRL | P0FSRH | P1FSRL P1FSRH | | P2FSRL | P2FSRH | | | 0C8H | OSCCR | _ | _ | UCTRL1 | UCTRL2 UCTRL3 | | _ | USTAT | | | 0C0H | EIFLAG0 | P3IO | T2CRL | T2CRH | T2ADRL T2ADRH | | T2BDRL | T2BDRH | | | 0B8H | IP | P2IO | T1CRL | T1CRH | T1ADRL | T1ADRH T1BDRL | | T1BDRH | | | 0В0Н | _ | P1IO | T0CR | TOCNT | T0DR/<br>T0CDR | _ | _ | _ | | | 0A8H | IE | IE1 | IE2 | IE3 | P0PU | P1PU | P2PU | P3PU | | | 0A0H | _ | P0IO | EO | _ | EIPOL0L | EIPOL0H | EIFLAG1 | EIPOL1 | | | 98H | P3 | _ | _ | _ | ADCCRL | ADCCRH | ADCDRL | ADCDRH | | | 90H | P2 | P0OD | P1OD | P2OD | _ | _ | WTCR | BUZCR | | | 88H | P1 | WTDR/<br>WTCNT | SCCR | BITCR | BITCNT | WDTCR | WDTDR/<br>WDTCNT | BUZDR | | | 80H | P0 | SP | DPL | DPH | DPL1 | DPH1 | LVICR | PCON | | #### NOTES: 1. 00H/8H, These registers are bit-addressable. Table 4. XSFR Map Summary | | 00H/8H <sup>(1)</sup> | 01H/9H | 02H/0AH | 03H/0BH | 04H/0CH | 05H/0DH | 06H/0EH | 07H/0FH | | |-------|-----------------------|--------|---------|---------|---------|---------|---------|---------|--| | 1078H | - | _ | _ | _ | _ | _ | _ | _ | | | 1070H | _ | - | _ | - | _ | _ | _ | _ | | | 1068H | _ | - | _ | - | _ | _ | _ | _ | | | 1060H | _ | - | - | - | - | - | - | _ | | | 1058H | - | - | - | - | - | - | _ | _ | | | 1050H | _ | _ | _ | _ | _ | _ | _ | _ | | | 1048H | - | - | - | - | - | - | - | - | | | 1040H | _ | _ | _ | _ | _ | _ | _ | - | | | 1038H | - | - | _ | - | _ | _ | _ | _ | | | 1030H | - | - | - | - | - | - | - | _ | | | 1028H | FEARH | FEARM | FEARL | FEDR | FETR | _ | _ | _ | | | 1020H | FEMR | FECR | FESR | FETCR | FEARM1 | FEARL1 | _ | _ | | | 1018H | UCTRL4 | FPCR | RTOCH | RTOCL | - | - | - | _ | | | 1010H | T5CRH | T5CRL | T5ADRH | T5ADRL | T5BDRH | T5BDRL | - | _ | | | 1008H | T4CRH | T4CRL | T4ADRH | T4ADRL | T4BDRH | T4BDRL | _ | _ | | | 1000H | T3CRH | T3CRL | T3ADRH | T3ADRL | T3BDRH | T3BDRL | _ | _ | | ## 4.4.2 SFR Map Table 5. SFR Map | A .1.1 | Foreston | 0 | DAM | @F | @Reset | | | | | | | | |---------|----------------------------------------|--------|-----|----|--------|---|---|---|---|---|---|--| | Address | Function | Symbol | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 80H | P0 Data Register | P0 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 81H | Stack Pointer | SP | R/W | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | | 82H | Data Pointer Register Low | DPL | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 83H | Data Pointer Register High | DPH | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 84H | Data Pointer Register Low 1 | DPL1 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 85H | Data Pointer Register High 1 | DPH1 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 86H | Low Voltage Indicator Control Register | LVICR | R/W | - | - | 0 | 0 | 0 | 0 | 0 | 0 | | | 87H | Power Control Register | PCON | R/W | 0 | _ | - | - | 0 | 0 | 0 | 0 | | | 88H | P1 Data Register | P1 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 0011 | Watch Timer Data Register | WTDR | W | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | 89H | Watch Timer Counter Register | WTCNT | R | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 8AH | System and Clock Control Register | SCCR | R/W | _ | - | - | _ | - | _ | 0 | 0 | | | 8BH | Basic Interval Timer Control Register | BITCR | R/W | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | | | 8CH | Basic Interval Timer Counter Register | BITCNT | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 8DH | Watch Dog Timer Control Register | WDTCR | R/W | 0 | 0 | 0 | - | - | - | 0 | 0 | | | | Watch Dog Timer Data Register | WDTDR | W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | 8EH | Watch Dog Timer Counter Register | WDTCNT | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 8FH | BUZZER Data Register | BUZDR | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | 90H | P2 Data Register | P2 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 91H | P0 Open-drain Selection Register | P0OD | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 92H | P1 Open-drain Selection Register | P1OD | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 93H | P2 Open-drain Selection Register | P2OD | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 94H | Reserved | - | _ | - | _ | - | ı | _ | - | ı | _ | | | 95H | Reserved | _ | _ | _ | - | - | - | - | - | - | | | | 96H | Watch Timer Control Register | WTCR | R/W | 0 | _ | - | 0 | 0 | 0 | 0 | 0 | | | 97H | BUZZER Control Register | BUZCR | R/W | - | _ | - | - | _ | 0 | 0 | 0 | | | 98H | P3 Data Register | P3 | R/W | _ | _ | - | - | _ | - | 0 | 0 | | | 99H | Reserved | _ | _ | - | - | ı | ı | - | - | ı | _ | | | 9AH | Reserved | _ | _ | - | _ | - | - | _ | - | - | - | | | 9BH | Reserved | _ | _ | _ | _ | - | - | _ | - | - | _ | | | 9CH | A/D Converter Control Low Register | ADCCRL | R/W | 0 | 0 | 0 | 0 | _ | 0 | 0 | 0 | | | 9DH | A/D Converter Control High Register | ADCCRH | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | 9EH | A/D Converter Data Low Register | ADCDRL | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 9FH | A/D Converter Data High Register | ADCDRH | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Table 5. SFR Map (Continued) | | | | D.44 | @Reset | | | | | | | | |---------|---------------------------------------------|---------|------|--------|---|---|---|---|---|---|---| | Address | Function | Symbol | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | A0H | Reserved | _ | _ | _ | _ | _ | - | _ | _ | _ | - | | A1H | P0 Direction Register | P0IO | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | A2H | Extended Operation Register | EO | R/W | _ | _ | _ | 0 | - | 0 | 0 | 0 | | АЗН | Reserved | - | _ | _ | _ | _ | _ | _ | _ | _ | _ | | A4H | External Interrupt Polarity 0 Low Register | EIPOL0L | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | A5H | External Interrupt Polarity 0 High Register | EIPOL0H | R/W | _ | _ | _ | - | 0 | 0 | 0 | 0 | | A6H | External Interrupt Flag 1 Register | EIFLAG1 | R/W | 0 | 0 | _ | - | 0 | 0 | 0 | 0 | | A7H | External Interrupt Polarity 1 Register | EIPOL1 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | A8H | Interrupt Enable Register | IE | R/W | 0 | _ | 0 | 0 | 0 | 0 | 0 | 0 | | А9Н | Interrupt Enable Register 1 | IE1 | R/W | _ | _ | 0 | 0 | 0 | 0 | _ | 0 | | AAH | Interrupt Enable Register 2 | IE2 | R/W | _ | _ | 0 | 0 | 0 | 0 | 0 | 0 | | ABH | Interrupt Enable Register 3 | IE3 | R/W | _ | _ | 0 | 0 | 0 | 0 | 0 | 0 | | ACH | P0 Pull-up Resistor Selection Register | P0PU | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ADH | P1 Pull-up Resistor Selection Register | P1PU | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | AEH | P2 Pull-up Resistor Selection Register | P2PU | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | AFH | P3 Pull-up Resistor Selection Register | P3PU | R/W | _ | _ | _ | _ | _ | _ | 0 | 0 | | ВОН | Reserved | _ | _ | _ | _ | _ | - | - | - | _ | - | | B1H | P1 Direction Register | P1IO | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | В2Н | Timer 0 Control Register | T0CR | R/W | 0 | _ | 0 | 0 | 0 | 0 | 0 | 0 | | ВЗН | Timer 0 Counter Register | T0CNT | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | DALL | Timer 0 Data Register | T0DR | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | B4H | Timer 0 Capture Data Register | T0CDR | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | В5Н | Reserved | - | _ | _ | _ | - | - | - | - | _ | _ | | В6Н | Reserved | _ | _ | ı | ı | - | ı | - | - | _ | - | | В7Н | Reserved | _ | _ | ı | ı | - | ı | - | - | _ | - | | В8Н | Interrupt Priority Register | IP | R/W | _ | _ | 0 | 0 | 0 | 0 | 0 | 0 | | В9Н | P2 Direction Register | P2IO | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | BAH | Timer 1 Control Low Register | T1CRL | R/W | 0 | 0 | 0 | 0 | _ | 0 | 0 | 0 | | BBH | Timer 1 Counter High Register | T1CRH | R/W | 0 | _ | 0 | 0 | _ | _ | _ | 0 | | ВСН | Timer 1 A Data Low Register | T1ADRL | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | BDH | Timer 1 A Data High Register | T1ADRH | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | BEH | Timer 1 B Data Low Register | T1BDRL | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | BFH | Timer 1 B Data High Register | T1BDRH | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Table 5. SFR Map (Continued) | | | | D.0.4/ | @F | @Reset | | | | | | | | |---------|-------------------------------------|---------|--------|----|--------|---|---|---|---|---|---|--| | Address | Function | Symbol | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | C0H | External Interrupt Flag 0 Register | EIFLAG0 | R/W | _ | - | 0 | 0 | 0 | 0 | 0 | 0 | | | C1H | P3 Direction Register | P3IO | R/W | _ | - | - | _ | _ | - | 0 | 0 | | | C2H | Timer 2 Control Low Register | T2CRL | R/W | 0 | 0 | 0 | 0 | _ | 0 | _ | 0 | | | СЗН | Timer 2 Control High Register | T2CRH | R/W | 0 | _ | 0 | 0 | _ | _ | - | 0 | | | C4H | Timer 2 A Data Low Register | T2ADRL | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | C5H | Timer 2 A Data High Register | T2ADRH | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | C6H | Timer 2 B Data Low Register | T2BDRL | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | C7H | Timer 2 B Data High Register | T2BDRH | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | C8H | Oscillator Control Register | OSCCR | R/W | 0 | 0 | 1 | 0 | 1 | 0 | - | 0 | | | C9H | Reserved | _ | _ | _ | - | - | - | _ | _ | - | _ | | | CAH | Reserved | _ | _ | _ | - | _ | _ | _ | _ | _ | - | | | СВН | USART Control Register 1 | UCTRL1 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | ССН | USART Control Register 2 | UCTRL2 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | CDH | USART Control Register 3 | UCTRL3 | R/W | 0 | 0 | 0 | 0 | _ | 0 | 0 | 0 | | | CEH | Reserved | _ | _ | _ | - | - | - | _ | _ | - | _ | | | CFH | USART Status Register | USTAT | R/W | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | D0H | Program Status Word Register | PSW | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | D1H | Reserved | - | - | - | - | - | - | - | - | - | - | | | D2H | P0 Function Selection Low Register | P0FSRL | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | D3H | P0 Function Selection High Register | P0FSRH | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | D4H | P1 Function Selection Low Register | P1FSRL | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | D5H | P1 Function Selection High Register | P1FSRH | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | D6H | P2 Function Selection Low Register | P2FSRL | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | D7H | P2 Function Selection High Register | P2FSRH | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | D8H | Low Voltage Reset Control Register | LVRCR | R/W | - | _ | - | 0 | 0 | 0 | 0 | 0 | | | D9H | USI0 Control Register 1 | USI0CR1 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | DAH | USI0 Control Register 2 | USI0CR2 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | DBH | USI0 Control Register 3 | USI0CR3 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | DCH | USI0 Control Register 4 | USI0CR4 | R/W | 0 | _ | 0 | 0 | 0 | 0 | 0 | 0 | | | DDH | USI0 Slave Address Register | USI0SAR | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | DEH | P0 De-bounce Enable Register | P0DB | R/W | 0 | 0 | - | 0 | 0 | 0 | 0 | 0 | | | DFH | P1/P2/P3 De-bounce Enable Register | P123DB | R/W | _ | _ | - | 0 | 0 | 0 | 0 | 0 | | Table 5. SFR Map (Continued) | Address | Foreston | 0 | D.04/ | @F | Reset | | | | | | | |---------|-------------------------------------|----------|-------|----|-------|---|---|---|---|---|---| | Address | Function | Symbol | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | E0H | Accumulator Register | ACC | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | E1H | USI0 Status Register 1 | USI0ST1 | R/W | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | E2H | USI0 Status Register 2 | USI0ST2 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | E3H | USI0 Baud Rate Generation Register | USI0BD | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | E4H | USI0 SDA Hold Time Register | USI0SHDR | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | E5H | USI0 Data Register | USI0DR | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | E6H | USI0 SCL Low Period Register | USI0SCLR | R/W | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | E7H | USI0 SCL High Period Register | USI0SCHR | R/W | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | | E8H | Reset Flag Register | RSTFR | R/W | 1 | х | 0 | 0 | х | _ | _ | _ | | E9H | Reserved | _ | - | _ | _ | _ | _ | - | _ | _ | _ | | EAH | Reserved | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | | EBH | Reserved | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | | ECH | Reserved | _ | _ | _ | _ | _ | _ | - | _ | _ | _ | | EDH | Reserved | - | _ | _ | _ | - | _ | - | - | - | - | | EEH | P3 Function Selection Register | P3FSR | R/W | _ | _ | - | _ | 0 | 0 | 0 | 0 | | EFH | Reserved | - | _ | _ | _ | - | _ | - | - | - | - | | F0H | B Register | В | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | F1H | Reserved | - | _ | _ | _ | - | _ | - | - | - | _ | | F2H | Reserved | - | _ | _ | _ | - | _ | - | - | - | _ | | F3H | Reserved | - | _ | _ | _ | _ | _ | _ | - | - | _ | | F4H | Reserved | | _ | _ | _ | - | _ | _ | - | - | _ | | F5H | Reserved | - | _ | _ | _ | _ | _ | _ | _ | - | _ | | F6H | Reserved | - | _ | _ | _ | _ | _ | _ | - | - | _ | | F7H | Reserved | - | _ | _ | _ | - | _ | - | - | - | _ | | F8H | Interrupt Priority Register 1 | IP1 | R/W | _ | _ | 0 | 0 | 0 | 0 | 0 | 0 | | F9H | Reserved | - | _ | _ | _ | - | _ | - | - | - | _ | | FAH | Reserved | - | _ | _ | _ | - | _ | - | - | - | - | | FBH | Reserved | _ | _ | - | _ | - | _ | - | - | _ | _ | | FCH | USART Baud Rate Generation Register | UBAUD | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | FDH | USART Data Register | UDATA | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | FEH | Reserved | _ | - | - | - | _ | _ | _ | - | - | _ | | FFH | Reserved | _ | - | _ | _ | - | _ | _ | - | - | _ | Table 6. XSFR Map | | | | D.44 | @R | @Reset | | | | | | | |---------|-----------------------------------------|--------|------|----|--------|---|---|---|---|---|---| | Address | Function | Symbol | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 1000H | Timer 3 Control High Register | T3CRH | R/W | 0 | _ | 0 | 0 | _ | _ | _ | 0 | | 1001H | Timer 3 Control Low Register | T3CRL | R/W | 0 | 0 | 0 | 0 | _ | 0 | 0 | 0 | | 1002H | Timer 3 A Data High Register | T3ADRH | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 1003H | Timer 3 A Data Low Register | T3ADRL | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 1004H | Timer 3 B Data High Register | T3BDRH | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 1005H | Timer 3 B Data Low Register | T3BDRL | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 1006H | Reserved | _ | _ | _ | - | _ | _ | _ | _ | - | _ | | 1007H | Reserved | _ | _ | - | _ | _ | _ | - | _ | _ | _ | | 1008H | Timer 4 Control High Register | T4CRH | R/W | 0 | _ | 0 | 0 | - | _ | _ | 0 | | 1009H | Timer 4 Control Low Register | T4CRL | R/W | 0 | 0 | 0 | 0 | _ | 0 | _ | 0 | | 100AH | Timer 4 A Data High Register | T4ADRH | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 100BH | Timer 4 A Data Low Register | T4ADRL | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 100CH | Timer 4 B Data High Register | T4BDRH | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 100DH | Timer 4 B Data Low Register | T4BDRL | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 100EH | Reserved | _ | _ | - | - | - | - | - | _ | _ | - | | 100FH | Reserved | _ | _ | _ | - | - | _ | - | _ | _ | - | | 1010H | Timer 5 Control High Register | T5CRH | R/W | 0 | - | 0 | 0 | - | - | - | 0 | | 1011H | Timer 5 Control Low Register | T5CRL | R/W | 0 | 0 | 0 | 0 | - | 0 | _ | 0 | | 1012H | Timer 5 A Data High Register | T5ADRH | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 1013H | Timer 5 A Data Low Register | T5ADRL | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 1014H | Timer 5 B Data High Register | T5BDRH | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 1015H | Timer 5 B Data Low Register | T5BDRL | R/W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 1016H | Reserved | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | | 1017H | Reserved | _ | - | _ | _ | _ | _ | - | _ | _ | - | | 1018H | USART Control Register 4 | UCTRL4 | R/W | _ | _ | - | 0 | 0 | 0 | 0 | 0 | | 1019H | USART Floating Point Counter | FPCR | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 101AH | Receiver Time Out Counter High Register | RTOCH | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 101BH | Receiver Time Out Counter Low Register | RTOCL | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 101CH | Reserved | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | | 101DH | Reserved | _ | _ | - | _ | _ | _ | _ | - | _ | - | | 101EH | Reserved | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | | 101FH | Reserved | _ | _ | - | _ | _ | _ | - | _ | _ | _ | Table 6. XSFR Map (Continued) | | | | | @R | eset | | | | | | | |---------|-----------------------------------------|------------|-----|----|------|---|---|---|---|---|---| | Address | Function | Symbol | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 1020H | Flash Mode Register | FEMR | R/W | 0 | _ | 0 | 0 | 0 | 0 | 0 | 0 | | 1021H | Flash Control Register | FECR | R/W | 0 | _ | 0 | 0 | 0 | 0 | 1 | 1 | | 1022H | Flash Status Register | FESR | R/W | 1 | _ | _ | _ | 0 | 0 | 0 | 0 | | 1023H | Flash Time Control Register FETCR R/W | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 1024H | Flash Address Middle Register 1 | FEARM1 R/W | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 1025H | Flash Address Low Register 1 | FEARL1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 1026H | Reserved | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | 1027H | Reserved | - | _ | - | - | - | - | - | - | _ | - | | 1028H | Flash Address High Register | FEARH | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 1029H | Flash Address Middle Register FEARM R/W | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 102AH | Flash Address Low Register | FEARL | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 102BH | Flash Data Register | FEDR | - | - | - | - | - | - | - | - | - | | 102CH | Flash Test Register | FETR | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 102DH | Reserved | - | - | _ | _ | _ | _ | _ | _ | _ | _ | | 102EH | Reserved | _ | _ | _ | _ | - | _ | - | _ | - | _ | | 102FH | Reserved | _ | _ | _ | _ | - | _ | - | _ | - | _ | | 1030H | Reserved | - | _ | - | - | - | - | - | - | - | - | | 1031H | Reserved | _ | _ | _ | _ | - | _ | _ | _ | _ | _ | | 1032H | Reserved | _ | _ | - | - | - | - | - | - | - | - | | 1033H | Reserved | - | - | _ | _ | _ | _ | _ | _ | _ | _ | | 1034H | Reserved | - | - | - | - | - | - | - | - | _ | - | | 1035H | Reserved | - | - | _ | - | - | _ | _ | _ | _ | - | | 1036H | Reserved | - | - | - | _ | - | - | - | - | - | - | | 1037H | Reserved | - | - | _ | _ | _ | _ | _ | _ | - | - | 4. Memory organization A96T418 User's manual ### 4.4.3 Compiler Compatible SFR ACC (Accumulator Register): E0H A96T418 User's manual 4. Memory organization #### DPL1 (Data Pointer Register Low 1): 84H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |----|--------------------|----|----|----|----|----|----|--|--|--|--| | | DPL1 | | | | | | | | | | | | RW | | | | | | Initial value: 00H | | | | | | | | | | | DPL1 Data Pointer Low 1 ### DPH1 (Data Pointer Register High 1): 85H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | |----|------|----|----|----|----|-------|---------------|--|--|--|--|--| | | DPH1 | | | | | | | | | | | | | RW | | | | | | | | | | | | Initi | al value: 00H | | | | | | DPH1 Data Pointer High 1 #### PSW (Program Status Word Register): D0H | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-----|----|----|-----|-----|----|----|----| | | CY | AC | F0 | RS1 | RS0 | OV | F1 | Р | | ı | RW. | 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 #### EO (Extended Operation Register): A2H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---------|---|--------|--------|--------| | _ | _ | ı | TRAP_EN | 1 | DPSEL2 | DPSEL1 | DPSEL0 | | - | - | _ | RW | - | RW | RW | RW | Initial value: 00H TRAP\_EN Select the Instruction (Keep always '0'). number of '1' bits in the accumulator 0 Select MOVC @(DPTR++), A 1 Select Software TRAP Instruction DPSEL[2:0] Select Banked Data Pointer Register DPSEL2 DPSEL1 SPSEL0 Description 0 0 0 DPTR0 0 0 1 DPTR1 Reserved # 5 I/O Ports #### 5.1 I/O Ports The A96T418 has four groups of I/O ports (P0 ~ P3). 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. ### 5.2 Port Register #### 5.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. #### 5.2.2 Direction Register (PxIO) Each I/O pin can be independently used as an input or an output through the PxIO register. Bits cleared in this register will make the corresponding pin of Px to 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. #### **5.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. #### 5.2.4 Open-drain Selection Register (PxOD) There are internally open-drain selection registers (PxOD) for P0 ~ P2. 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. #### 5.2.5 De-bounce Enable Register (PxDB) P0[7:3], P1[2:1], P2[6:5] and P31 support debounce function. Debounce clocks of each ports are fx/1, fx/4, and fx/4096. A96T418 User's manual 5. I/O Ports # 5.2.6 Port Function Selection Register (PxFSR) These registers define alternative functions of ports. Please remember that these registers should be set properly for alternative port function. A reset clears the PxFSR register to '00H', which makes all pins to normal I/O ports. ## 5.2.7 Register Map Table 7. Port Register Map | Name | Address | Direction | Default | Description | |--------|---------|-----------|---------|----------------------------------------| | P0 | 80H | R/W | 00H | P0 Data Register | | P0IO | A1H | R/W | 00H | P0 Direction Register | | P0PU | ACH | R/W | 00H | P0 Pull-up Resistor Selection Register | | P0OD | 91H | R/W | 00H | P0 Open-drain Selection Register | | P0DB | DEH | R/W | 00H | P0 De-bounce Enable Register | | P0FSRH | D3H | R/W | 00H | P0 Function Selection High Register | | P0FSRL | D2H | R/W | 00H | P0 Function Selection Low Register | | P1 | 88H | R/W | 00H | P1 Data Register | | P1IO | B1H | R/W | 00H | P1 Direction Register | | P1PU | ADH | R/W | 00H | P1 Pull-up Resistor Selection Register | | P1OD | 92H | R/W | 00H | P1 Open-drain Selection Register | | P123DB | DFH | R/W | 00H | P1/P2/P3 De-bounce Enable Register | | P1FSRH | D5H | R/W | 00H | P1 Function Selection High Register | | P1FSRL | D4H | R/W | 00H | P1 Function Selection Low Register | | P2 | 90H | R/W | 00H | P2 Data Register | | P2IO | В9Н | R/W | 00H | P2 Direction Register | | P2PU | AEH | R/W | 00H | P2 Pull-up Resistor Selection Register | | P2OD | 93H | R/W | 00H | P2 Open-drain Selection Register | | P2FSRH | D7H | R/W | 00H | P2 Function Selection High Register | | P2FSRL | D6H | R/W | 00H | P2 Function Selection Low Register | | P3 | 98H | R/W | 00H | P3 Data Register | | P3IO | C1H | R/W | 00H | P3 Direction Register | | P3PU | AFH | R/W | 00H | P3 Pull-up Resistor Selection Register | | P3FSR | EEH | R/W | 00H | P3 Function Selection Register | ### 5.3 P0 Port ### 5.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), de-bounce enable register (P0DB), P0 pull-up resistor selection register (P0PU), and P0 open-drain selection register (P0DD). Refer to the port function selection registers for the P0 function selection. ### 5.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 | | | | | | | Initi | ial value: 00H | P0[7:0] I/O Data ### P0IO (P0 Direction Register): A1H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P07IO | P06IO | P05IO | P04IO | P03IO | P02IO | P01IO | P00IO | | RW Initial value: 00H P0IO[7:0] P0 Data I/O Direction. 0 Input 1 Output NOTES: 1. EC3(P06) possible when P0FSRH[5:4] = '01' #### P0PU (P0 Pull-up Resistor Selection Register): ACH | 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 Disable 1 Enable A96T418 User's manual 5. I/O Ports #### P00D (P0 Open-drain Selection Register): 91H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P07OD | P06OD | P05OD | P04OD | P03OD | P02OD | P01OD | P000D | | RW Initial value: 00H P0OD[7:0] DBCLK[1:0] Configure Open-drain of P0 Port 0 Push-pull output 1 Open-drain output Configure De-bounce Clock of Port ### P0DB (P0 De-bounce Enable Register): DEH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|---|-------|-------|-------|-------|-------| | DBCLK1 | DBCLK0 | - | P07DB | P06DB | P05DB | P04DB | P03DB | | RW | RW | - | RW | RW | RW | RW | RW | Initial value: 00H | 2202.1(1.0) | Comigaro | Do boarioo | CICCIT OIL | |-------------|-----------|------------|----------------| | | DBCLK1 | DBCLK0 | Description | | | 0 | 0 | fx/1 | | | 0 | 1 | fx/4 | | | 1 | 0 | fx/4096 | | | 1 | 1 | LSIRC (128KHz) | | P07DB | Configure | De-bounce | of P07 Port | | | 0 | Disable | | | | 1 | Enable | | | P06DB | Configure | De-bounce | of P06 Port | | | 0 | Disable | | | | 1 | Enable | | | P05DB | Configure | De-bounce | of P05 Port | | | 0 | Disable | | | | 1 | Enable | | | P04DB | Configure | De-bounce | of P04Port | | | 0 | Disable | | | | 1 | Enable | | | P03DB | Configure | De-bounce | of P03 Port | | | 0 | Disable | | | | 1 | Enable | | | | | | | #### NOTES: - 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. - 2. A pulse level should be input for the duration of 3 clocks or more to be actually detected as a valid edge. - 3. The port de-bounce is automatically disabled at stop mode and recovered after stop mode release. # P0FSRH (Port 0 Function Selection High Register): D3H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---------|-------------|--------------|---------------------|-----------------------------------------------|------------------|-------------|----------------|--|--| | P0FSRH7 | POFSRH6 | P0FSRH5 | P0FSRH4 | P0FSRH3 | P0FSRH2 | P0FSRH1 | P0FSRH0 | | | | RW | | | | | | | | | Init | ial value: 00H | | | | | P0FSRH[7:6] | P07 Function | on Select | | | | | | | | | | P0FSRH7 | P0FSRH6 | Description | | | | | | | | | | 0 | I/O Port (EINT4 function possible when input) | | | | | | | | | 0 | 1 | Reserved | | | | | | | | | 1 | 0 | AN3 Function | | | | | | | | | 1 | 1 | PWM5O/T5O Fu | nction | | | | | | | P0FSRH[5:4] | P06 Function | P06 Function Select | | | | | | | | | | P0FSRH5 | P0FSRH4 | Description | | | | | | | | | 0 | 0 | I/O Port (EINT3 f | unction possible | when input) | | | | | | | 0 | 1 | EC3 Function | | | | | | | | | 1 | 0 | AN2 Function | | | | | | | | | 1 | 1 | PWM4O/T4O Function | | | | | | | | P0FSRH[3:2] | P05 Function | on Select | | | | | | | | | | P0FSRH3 | P0FSRH2 | Description | | | | | | | | | 0 | 0 | I/O Port (EINT2 f | unction possible | when input) | | | | | | | 0 | 1 | Reserved | | | | | | | | | 1 | 0 | AN1 Function | | | | | | | | | 1 | 1 | PWM3O/T3O Fu | nction | | | | | | | P0FSRH[1:0] | P04 Function | | | | | | | | | | | P0FSRH1 | P0FSRH0 | Description | | | | | | | | | 0 | 0 | I/O Port (EINT1 f | unction possible | when input) | | | | | | | 0 | 1 | Reserved | | | | | | | | | 1 | 0 | AN0 Function | | | | | | | | | 1 | 1 | SS0 Function | | | | | | A96T418 User's manual 5. I/O Ports ## P0FSRL (Port 0 Function Selection Low Register): D2H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---------|-----------------|------------|-----------|--------------------|------------------|-------------|---------------|--|--| | P0FSRL7 | P0FSRL6 | P0FSRL5 | P0FSRL4 | P0FSRL3 | P0FSRL2 | P0FSRL1 | P0FSRL0 | | | | RW | | | | | | | | | Init | al value: 00H | | | | | P0FSRL[7:6] | P03 Functi | on Select | | | | | | | | | | P0FSRL7 | P0FSRL6 | Description | | | | | | | | | 0 | 0 | I/O Port (EINT0 ft | unction possible | when input) | | | | | | | 0 | 1 | BUZ0 Function | | | | | | | | | 1 | 0 | AN7/AVREF Fund | ction | | | | | | | | 1 | 1 | SCK0 Function | | | | | | | | P0FSRL[5:4] | P02 Functi | on Select | | | | | | | | | | P0FSRL5 | P0FSRL4 | Description | | | | | | | | | 0 | 0 | I/O Port | | | | | | | | | 0 | 1 | Reserved | | | | | | | | | 1 | 0 | Reserved | | | | | | | | | 1 | 1 | TXD0/MOSI0/SD | A0 Function | | | | | | | P0FSRL[3:2] | P01 Functi | on Select | | | | | | | | | P0FSRL3 P0FSRL2 | | P0FSRL2 | Description | | | | | | | | | 0 | 0 | I/O Port (EC3 fun | ction possible w | hen input) | | | | | | | 0 | 1 | T3O/PWM3O Fur | nction(P02 Outp | ut) | | | | Reserved Description I/O Port Reserved Reserved TXD1/MOSI1 Function RXD0/MISO0/SCL0 Function #### NOTES: 1. EINT0 ~ 4 function possible when input P0FSRL[1:0] 1 0 0 1 - 2. Both TXD0 and RXD0 function should be selected even for TXD0 only function at P02 - T3O/PWM3O Function(P02 Output) should be set at P01 Function Select position. 0 0 0 1 P0FSRL0 P00 Function Select P0FSRL1 ## 5.4 P1 Port #### 5.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 enble register (P123DB), 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. ### 5.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): B1H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P17IO | P16IO | P15IO | P14IO | P13IO | P12IO | P11IO | P10IO | | RW Initial value: 00H P1IO[7:0] P1 Data I/O Direction 0 Input 1 Output #### P1PU (P1 Pull-up Resistor Selection Register): ADH | 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 Disable 1 Enable A96T418 User's manual 5. I/O Ports #### P1OD (P1 Open-drain Selection Register): 92H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P17OD | P160D | P150D | P140D | P130D | P120D | P110D | P100D | | RW Initial value: 00H P1OD[7:0] Configure Open-drain of P1 Port 0 Push-pull output1 Open-drain output ## P123DB (P1/P2/P3 De-bounce Enable Register): DFH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|-------|-------|-------|-------|-------| | _ | - | _ | P31DB | P26DB | P25DB | P12DB | P11DB | | _ | _ | _ | RW | RW | RW | RW | RW | Initial value: 00H | P31DB | Configure | De-bounce of P31 Port | |-------|-----------|-----------------------| | | 0 | Disable | | | 1 | Enable | | P26DB | Configure | De-bounce of P26 Port | | | 0 | Disable | | | 1 | Enable | | P25DB | Configure | De-bounce of P25 Port | | | 0 | Disable | | | 1 | Enable | | P12DB | Configure | De-bounce of P12 Port | | | 0 | Disable | | | 1 | Enable | | P11DB | Configure | De-bounce of P11 Port | | | 0 | Disable | | | 1 | Enable | #### NOTES: - 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. - 2. A pulse level should be input for the duration of 3 clocks or more to be actually detected as a valid edge. - 3. The port de-bounce is automatically disabled at stop mode and recovered after stop mode release. - 4. Refer to the port 0 de-bounce enable register (P0DB) for the de-bounce clock of port 1, port 2 and port 3. ### P1FSRH (Port 1 Function Selection High Register): D5H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------------| | P1FSRH7 | P1FSRH6 | P1FSRH5 | P1FSRH4 | P1FSRH3 | P1FSRH2 | P1FSRH1 | P1FSRH0 | | RW | | | | | | | Initi | al value: 00H | P1FSRH[7:6] P17 Function Select P1FSRH7 P1FSRH6 Description 0 0 I/O Port 0 1 Reserved 0 1 Reserved 1 TXD1/MOSI1 Function P1FSRH[5:4] P16 Function Select P1FSRH5 P1FSRH4 Description 0 0 I/O Port 0 1 Reserved 0 1 Reserved 1 1 RXD1/MISO1 Function P1FSRH[3:2] P15 Function Select P1FSRH3 P1FSRH2 Description 0 I/O Port 0 1 Reserved 0 Reserved 1 1 SCK1 Function P1FSRH[1:0] P14 Function Select P1FSRH1 P1FSRH0 Description I/O Port 0 0 0 Reserved 1 1 0 Reserved 1 SS1 Function A96T418 User's manual 5. I/O Ports # P1FSRL (Port 1 Function Selection Low Register): D4H | 7 | 6 | 5 | 4 | | 3 | 2 | 1 | 0 | |---------|-------------|--------------|-----------|-------------|----------|------------------|-------------|----------------| | P1FSRL7 | P1FSRL6 | P1FSRL5 | P1FSRL4 | P1I | SRL3 | P1FSRL2 | P1FSRL1 | P1FSRL0 | | RW | RW | RW | RW | F | ₹₩ | RW | RW | RW | | | | | | | | | Initi | ial value: 00H | | | P1FSRL[7:6] | P13 Functi | on Select | | | | | | | | | P1FSRL7 | P1FSRL6 | Description | on | | | | | | | 0 | 0 | I/O Port | | | | | | | | 0 | 1 | Reserved | ł | | | | | | | 1 | 0 | Reserved | d | | | | | | | 1 | 1 | Reserved | d | | | | | | P1FSRL[5:4] | P12 Functi | on Select | | | | | | | | | P1FSRL5 | P1FSRL4 | Description | on | | | | | | | 0 | 0 | I/O Port ( | EINT12 f | unction possible | when input) | | | | | 0 | 1 | Reserved | t | | | | | | | 1 | 0 | AN6 Fun | ction | | | | | | | 1 | 1 | T2O/PWI | M2O Fun | ction | | | | | P1FSRL[3:2] | P11 Functi | on Select | | | | | | | | | P1FSRL3 | P1FSRL2 | Description | on | | | | | | | 0 | 0 | I/O Port ( | EINT5 fu | nction possible | when input) | | | | | 0 | 1 | T10/PWI | | ction | | | | | | 1 | 0 | AN5 Fun | ction | | | | | | | 1 | 1 | TXD0/M0 | DSI0/SDA | NO Function | | | | | P1FSRL[1:0] | P10 Function | on Select | | | | | | | | | P1FSRL1 | P1FSRL0 | Description | on | | | | | | | 0 | 0 | I/O Port | | | | | | | | 0 | 1 | Reserved | | | | | | | | 1 | 0 | AN4 Fun | ction | | | | RXD0/MISO0/SCL0 Function ### 5.5 P2 Port ## 5.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), 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. ### 5.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: 00H P2[7:0] I/O Data ### P2IO (P2 Direction Register): B9H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P271O | P261O | P251O | P24IO | P23IO | P2210 | P211O | P20IO | | RW Initial value: 00H P2IO[7:0] P2 Data I/O Direction 0 Input 1 Output A96T418 User's manual 5. I/O Ports ## P2PU (P2 Pull-up Resistor Selection Register): AEH | 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 Disable1 Enable ## P2OD (P2 Open-drain Selection Register): 93H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | P27OD | P260D | P250D | P240D | P230D | P220D | P210D | P200D | | RW 3 2 1 Initial value: 00H 0 P2OD[7:0] Configure Open-drain of P2 Port 0 0 Push-pull output1 Open-drain output 4 ## P2FSRH (Port 2 Function Selection High Register): D7H 5 6 | P2FSRH7 | P2FSRH6 | P2FSRH5 | P2FSRH4 | P2FSRH3 | P2FSRH2 | P2FSRH1 | P2FSRH0 | |---------|-------------|--------------|-----------|------------------|-------------------|---------------|----------------| | RW | | | | | | | Init | ial value: 00H | | | P2FSRH[7:6] | P27 Function | on Select | | | | | | | | P2FSRH7 | P2FSRH6 | Description | | | | | | | 0 | 0 | I/O Port | | | | | | | 0 | 1 | SXIN Function | | | | | | | 1 | 0 | T0O/PWM0O Fur | nction | | | | | | 1 | 1 | Reserved | | | | | | P2FSRH[5:4] | P26 Function | on Select | | | | | | | | P2FSRH5 | P2FSRH4 | Description | | | | | | | 0 | 0 | I/O Port (EINT10 | function possible | e when input) | | | | | 0 | 1 | SXOUT Function | | | | | | | 1 | 0 | Reserved | | | | | | | 1 | 1 | Reserved | | | | | | P2FSRH[3:2] | P25 Function | on Select | | | | | | | | P2FSRH3 | P2FSRH2 | Description | | | | | | | 0 | 0 | I/O Port (EINT11 | function possible | e when input) | | | | | 0 | 1 | EC0 Function | | | | | | | 1 | 0 | Reserved | | | | | | | 1 | 1 | Reserved | | | | | | P2FSRH[1:0] | P24 Function | on Select | | | | | | | | P2FSRH1 | P2FSRH0 | Description | | | | I/O Port 7 3 2 0 1 Reserved 1 Reserved 1 Reserved ## P2FSRL (Port 2 Function Selection Low Register): D6H 5 P2FSRL[3:2] 6 | P2FSRL7 | P2FSRL6 | P2FSRL5 | P2FSRL4 | P2FSRL3 | P2FSRL2 | P2FSRL1 | P2FSRL0 | |---------|---------|-------------|------------|-----------|--------------|---------|----------------| | RW | | | | | | | Init | ial value: 00H | | | | P2FSRL[7:6] | P23 Functi | on Select | | | | | | | | P2FSRL7 | P2FSRL6 | Description | | | | | | | 0 | 0 | I/O Port | | | | | | | 0 | 1 | EC1 Function | | | | | | | 1 | 0 | Reserved | | | | | | | 1 | 1 | Reserved | | | | | | P2FSRL[5:4] | P22 Functi | on Select | | | | | | | | P2FSRL5 | P2FSRL4 | Description | | | | | | | 0 | 0 | I/O Port | | | | | | | 0 | 1 | Reserved | | | | | | | 1 | 0 | Reserved | | | | | | | 1 | 1 | Reserved | | | P21 Function Select 0 1 0 | | 1 | 1 | |-------------|--------|---------------| | P2FSRL[1:0] | P20 Fu | nction Select | 0 | P20 Function | on Select | | |--------------|-----------|-------------| | P2FSRL3 | P2FSRL2 | Description | | 0 | 0 | I/O Port | | 0 | 1 | Reserved | | 1 | 0 | Reserved | | 1 | 1 | Reserved | P2FSRL3 P2FSRL2 Description I/O Port Reserved Reserved Reserved A96T418 User's manual 5. I/O Ports ### 5.6 P3 Port ### 5.6.1 P3 Port Description P3 is 2-bit I/O port. P3 control registers consist of P3 data register (P3), P3 direction register (P3IO) and P3 pull-up resistor selection register (P3PU). Refer to the port function selection registers for the P3 function selection. ### 5.6.2 Register Description for P3 ### P3 (P3 Data Register): 98H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|-----|-----| | - | - | - | i | - | - | P31 | P30 | | - | - | - | - | - | - | RW | RW | Initial value: 00H P3[1:0] I/O Data ### P3IO (P3 Direction Register): C1H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|-------|-------| | - | - | - | - | - | - | P31IO | P30IO | | - | - | - | - | - | - | RW | RW | Initial value: 00H P3IO[1:0] P3 Data I/O Direction 0 Input 1 Output ### P3PU (P3 Pull-up Resistor Selection Register): AFH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|-------|-------| | - | - | - | - | - | - | P31PU | P30PU | | - | - | - | - | - | - | RW | RW | Initial value: 00H P3PU[1:0] Configure Pull-up Resistor of P3 Port 0 Disable 1 Enable # P3FSR (Port 3 Function Selection Register): EEH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|--------|--------|--------|--------| | - | - | - | - | P3FSR3 | P3FSR2 | P3FSR1 | P3FSR0 | | - | - | - | - | RW | RW | RW | RW | Initial value: 00H | P3FSR[3:2] | P31 Function | on Select | | | | |------------|---------------------|-----------|-----------------------------------------------|--|--| | | P3FSR3 | P3FSR2 | Description | | | | | 0 | 0 | I/O Port (EINT8 function possible when input) | | | | | 0 | 1 | Reserved | | | | | 1 | 0 | Reserved | | | | | 1 | 1 | RXD1/MISO1 Function | | | | P3FSR[1:0] | P30 Function Select | | | | | | | P3FSR1 | P3FSR0 | Description | | | | | 0 | 0 | I/O Port | | | | | 0 | 1 | Reserved | | | | | 1 | 0 | Reserved | | | | | 1 | 1 | Reserved | | | A96T418 User's manual 6. Interrupt Controller # 6 Interrupt Controller #### 6.1 Overview The A96T418 supports up to 23 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 23 interrupt source - group 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, and IE3). Each bit of IE, IE1, IE2, IE3 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 A96T418 supports a four-level priority scheme. Each maskable interrupt is individually assigned to one of four priority levels according to IP and IP1. Default interrupt mode is level-trigger mode basically, but if needed, it is possible to change to edge-trigger mode. Table 8 shows the Interrupt Group Priority Level that is available for sharing interrupt priority. 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. Table 8. Interrupt Group Priority Level | Interrupt<br>Group | Highest | | | Lowest - | | |--------------------|-------------|--------------|--------------|--------------|---------| | 0 (Bit0) | Interrupt 0 | Interrupt 6 | Interrupt 12 | Interrupt 18 | Highest | | 1 (Bit1) | Interrupt 1 | Interrupt 7 | Interrupt 13 | Interrupt 19 | | | 2 (Bit2) | Interrupt 2 | Interrupt 8 | Interrupt 14 | Interrupt 20 | | | 3 (Bit3) | Interrupt 3 | Interrupt 9 | Interrupt 15 | Interrupt 21 | | | 4 (Bit4) | Interrupt 4 | Interrupt 10 | Interrupt 16 | Interrupt 22 | | | 5 (Bit5) | Interrupt 5 | Interrupt 11 | Interrupt 17 | Interrupt 23 | Lowest | A96T418 User's manual 6. Interrupt Controller # 6.2 External Interrupt The external interrupt on INT0, INT1, INT5, INT6 and INT11 receive various interrupt request depending on the external interrupt polarity 0 high/low register (EIPOL0H/L) and external interrupt polarity 1 register (EIPOL1) as shown in Figure 12. Also each external interrupt source has enable/disable bits. The External interrupt flag 0 register (EIFLAG0) and external interrupt flag 1 register 1 (EIFLAG1) provides the status of external interrupts. Figure 12. External Interrupt Description # 6.3 Block Diagram Figure 13. Block Diagram of Interrupt NOTES: A96T418 User's manual 6. Interrupt Controller 1. The release signal for stop/idle mode may be generated by all interrupt sources which are enabled without reference to the priority level. 2. An interrupt request is delayed while data are written to IE, IE1, IE2, IE3, IP, IP1, and PCON register. ## 6.4 Interrupt Vector Table The interrupt controller supports 23 interrupt sources as shown in the Table 9. 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. Table 9. Interrupt Vector Address Table | Interrupt Source | Symbol | Interrupt<br>Enable Bit | Polarity | Mask | Vector Address | |--------------------------|--------|-------------------------|----------|--------------|----------------| | Hardware Reset | RESETB | - | 0 | Non-Maskable | 0000H | | External Interrupt 10 | INT0 | IE.0 | 1 | Maskable | 0003H | | External Interrupt 11 | INT1 | IE.1 | 2 | Maskable | 000BH | | LED Interrupt | INT2 | IE.2 | 3 | Maskable | 0013H | | Touch Interrupt | INT3 | IE.3 | 4 | Maskable | 001BH | | Reserved | INT4 | IE.4 | 5 | Maskable | 0023H | | External Interrupt 0 – 5 | INT5 | IE.5 | 6 | Maskable | 002BH | | External Interrupt 8 | INT6 | IE1.0 | 7 | Maskable | 0033H | | USART1 TX Interrupt | INT7 | IE1.1 | 8 | Maskable | 003BH | | USI0 I2C Interrupt | INT8 | IE1.2 | 9 | Maskable | 0043H | | USI0 RX Interrupt | INT9 | IE1.3 | 10 | Maskable | 004BH | | USI0 TX Interrupt | INT10 | IE1.4 | 11 | Maskable | 0053H | | External Interrupt 12 | INT11 | IE1.5 | 12 | Maskable | 005BH | | T0 Overflow Interrupt | INT12 | IE2.0 | 13 | Maskable | 0063H | | T0 Match Interrupt | INT13 | IE2.1 | 14 | Maskable | 006BH | | T1 Match Interrupt | INT14 | IE2.2 | 15 | Maskable | 0073H | | T2 Match Interrupt | INT15 | IE2.3 | 16 | Maskable | 007BH | | T3 Match Interrupt | INT16 | IE2.4 | 17 | Maskable | 0083H | | T4/T5 Match Interrupt | INT17 | IE2.5 | 18 | Maskable | 008BH | | ADC Interrupt | INT18 | IE3.0 | 19 | Maskable | 0093H | | USART1 RX Interrupt | INT19 | IE3.1 | 20 | Maskable | 009BH | | WT Interrupt | INT20 | IE3.2 | 21 | Maskable | 00A3H | | WDT Interrupt | INT21 | IE3.3 | 22 | Maskable | 00ABH | | BIT Interrupt | INT22 | IE3.4 | 23 | Maskable | 00B3H | | LVI Interrupt | INT23 | IE3.5 | 24 | Maskable | 00BBH | 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. A96T418 User's manual 6. Interrupt Controller ## 6.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 14. Interrupt Sequence Flow # 6.6 Effective Timing after Controlling Interrupt Bit Case a) Control Interrupt Enable Register (IE, IE1, IE2, IE3) Figure 15. Effective Timing of Interrupt Enable Register ### Case b) Interrupt flag Register Figure 16. Effective Timing of Interrupt Flag Register A96T418 User's manual 6. Interrupt Controller ## 6.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 17. Effective Timing of Multi-Interrupt Figure 17 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. # 6.8 Interrupt Enable Accept Timing Figure 18. Interrupt Response Timing Diagram ## 6.9 Interrupt Service Routine Address Figure 19. Correspondence between Vector Table Address and the Entry Address of ISR ## 6.10 Saving/Restore General-Purpose Registers Figure 20. Saving/Restore Process Diagram and Sample Source A96T418 User's manual 6. Interrupt Controller # 6.11 Interrupt Timing Figure 21. 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. #### NOTES: 1. command cycle CLPx: L=Last cycle, 1=1st cycle or 1st phase, 2=2nd cycle or 2nd phase ## 6.12 Interrupt Register Overview ### 6.12.1 Interrupt Enable Register (IE, IE1, IE2, IE3) Interrupt enable register consists of global interrupt control bit (EA) and peripheral interrupt control bits. Total 23 peripherals are able to control interrupt. #### 6.12.2 Interrupt Priority Register (IP, IP1) The 23 interrupts are divided into 6 groups which have each 4 interrupt sources. A group 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 IP and IP1 are cleared to '00H'. If interrupts have the same priority level, lower number interrupt is served first. #### 6.12.3 External Interrupt Flag Register (EIFLAG0, EIFLAG1) The external interrupt flag 0 register (EIFLAG0) and external interrupt flag 1 register (EIFLAG1) are set to '1' when the external interrupt generating condition is satisfied. The flag is cleared when the interrupt service routine is executed. Alternatively, the flag can be cleared by writing '0' to it. #### 6.12.4 External Interrupt Polarity Register (EIPOL0L, EIPOL0H, EIPOL1) The external interrupt polarity0 high/low register (EIPOL0H/L) and external interrupt polarity1 register (EIPOL1) determines which type of rising/falling/both edge interrupt. Initially, default value is no interrupt at any edge. #### 6.12.5 Register Map Name Address Direction Default Description ΙE H8A R/W 00H Interrupt Enable Register 00H IE1 A9H R/W Interrupt Enable Register 1 IE2 AAH R/W 00H Interrupt Enable Register 2 IE3 00H ABH R/W Interrupt Enable Register 3 IΡ R/W 00H **B8H** Interrupt Priority Register IP1 F8H R/W 00H Interrupt Priority Register 1 EIFLAG0 C0H R/W 00H External Interrupt Flag 0 Register **EIPOL0L** 00H A4H R/W External Interrupt Polarity 0 Low Register **EIPOL0H** A5H R/W 00H External Interrupt Polarity 0 High Register EIFLAG1 A6H R/W 00H External Interrupt Flag 1 Register EIPOL1 A7H R/W 00H External Interrupt Polarity 1 Register Table 10. Interrupt Register Map #### 6.12.6 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) and interrupt enable register 3 (IE3). For external interrupt, it consists of external interrupt flag 0 register(EIFLAG0), external interrupt polarity 0 high/low register (EIPOL0H/L), external interrupt flag 1 register (EIFLAG1) and external interrupt polarity 1 register(EIPOL1). A96T418 User's manual 6. Interrupt Controller #### 6.12.7 Register Description for Interrupt ### IE (Interrupt Enable Register): A8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|---|-------|-------|-------|-------|-------|---------------| | EA | _ | INT5E | INT4E | INT3E | INT2E | INT1E | INT0E | | RW | - | RW | RW | RW | RW | RW | RW | | | | | | | | Initi | al value: 00H | EΑ Enable or Disable All Interrupt bits All Interrupt disable All Interrupt enable Enable or Disable External Interrupt 0 ~ 5 (EINT0 ~ EINT5) INT5E Disable 1 Enable INT4E Reserved 0 Disable 1 Enable Enable or Disable Touch Interrupt INT3E Disable Enable INT2E Enable or Disable LED Interrupt Disable 1 Enable INT1E Enable or Disable External Interrupt 11 (EINT11) Disable Enable 1 INT0E Enable or Disable External Interrupt 10 (EINT10) 0 Disable Enable # 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: 00H | 11E | Enable o | or Disable External Interrupt 12 (EINT12) | |-----|------------------------------------|--------------------------------------------------------------------------| | | 0 | Disable | | | 1 | Enable | | 10E | Enable o | or Disable USI0 TX Interrupt | | | 0 | Disable | | | 1 | Enable | | 9E | Enable o | or Disable USI0 RX Interrupt | | | 0 | Disable | | | 1 | Enable | | 8E | Enable o | or Disable USI0 I2C Interrupt | | | 0 | Disable | | | 1 | Enable | | 7E | Enable o | or Disable USART1 TX Interrupt | | | 0 | Disable | | | 1 | Enable | | 6E | Enable of | or Disable External Interrupt 8 (EINT8) | | | 0 | Disable | | | 1 | Enable | | | 11E<br>10E<br>9E<br>8E<br>7E<br>6E | 0 1 10E Enable 0 1 9E Enable 0 1 8E Enable 0 1 7E Enable 0 1 6E Enable 0 | A96T418 User's manual 6. Interrupt Controller ### IE2 (Interrupt Enable Register 2): AAH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|--------|--------|--------|--------|--------|--------| | - | _ | INT17E | INT16E | INT15E | INT14E | INT13E | INT12E | | - | _ | RW | RW | RW | RW | RW | RW | Initial value: 00H INT17E Enable or Disable Timer 4/5 Match Interrupt 0 Disable1 Enable INT16E Enable or Disable Timer 3 Match Interrupt 0 Disable1 Enable INT15E Enable or Disable Timer 2 Match Interrupt 0 Disable1 Enable INT14E Enable or Disable Timer 1 Match Interrupt 0 Disable1 Enable INT13E Enable or Disable Timer 0 Match Interrupt 0 Disable1 Enable INT12E Enable or Disable Timer 0 Overflow Interrupt 0 Disable1 Enable ### IE3 (Interrupt Enable Register 3): ABH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|--------|--------|--------|--------|--------|--------| | _ | _ | INT23E | INT22E | INT21E | INT20E | INT19E | INT18E | | _ | _ | RW | RW | RW | RW | RW | RW | Initial value: 00H INT23E Enable or Disable LVI Interrupt 0 Disable1 Enable INT22E Enable or Disable BIT Interrupt 0 Disable1 Enable INT21E Enable or Disable WDT Interrupt 0 Disable1 Enable INT20E Enable or Disable WT Interrupt 0 Disable1 Enable INT19E Enable or Disable USART1 RX Interrupt 0 Disable1 Enable INT18E Enable or Disable ADC Interrupt 0 Disable 6. Interrupt Controller A96T418 User's manual ### 1 Enable # IP (Interrupt Priority Register): B8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-----|-----|-----|-----|-----|-----| | _ | _ | IP5 | IP4 | IP3 | IP2 | IP1 | IP0 | | _ | _ | RW | RW | RW | RW | RW | RW | Initial value: 00H # IP1 (Interrupt Priority Register 1): F8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|------|------|------|------|------|------| | _ | _ | IP15 | IP14 | IP13 | IP12 | IP11 | IP10 | | _ | - | RW | RW | RW | RW | RW | RW | Initial value: 00H | IP[5:0], IP1[5:0] | Select Interrupt Group Priority | |-------------------|---------------------------------| |-------------------|---------------------------------| | IP1x | IPx | Description | |------|-----|-------------------| | 0 | 0 | level 0 (lowest) | | 0 | 1 | level 1 | | 1 | 0 | level 2 | | 1 | 1 | level 3 (highest) | | | | | A96T418 User's manual 6. Interrupt Controller ### EIFLAG0 (External Interrupt Flag0 Register): C0H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-------|-------|-------|-------|-------|-------| | _ | _ | FLAG5 | FLAG4 | FLAG3 | FLAG2 | FLAG1 | FLAG0 | | - | _ | RW | RW | RW | RW | RW | RW | Initial value: 00H #### EIFLAG0[5:0] When an External Interrupt 0-5 is occurred, the flag becomes '1'. The flag is cleared only by writing '0' to the bit. So, the flag should be cleared by software. - 0 External Interrupt 0 ~ 5 not occurred - 1 External Interrupt 0 ~ 5 occurred ## EIPOL0H (External Interrupt Polarity 0 High Register): A5H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|----|-----|-----|-----| | | _ | - | _ | PC | )L5 | PC | DL4 | | _ | _ | _ | - | RW | RW | RW | RW | | | | | | | | 114 | -1 | Initial value: 00H EIPOL0H[3:0] External interrupt (EINT5, EINT4) polarity selection POLn[1:0] Description 0 0 No interrupt at any edge 0 1 Interrupt on rising edge 1 0 Interrupt on falling edge 1 Interrupt on both of rising and falling edge Where n = 4 and 5 Where n = 0, 1, 2 and 3 ### EIPOL0L (External Interrupt Polarity 0 Low Register): A4H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|-----|----|-----|----|-----|----|-----| | PC | DL3 | PC | )L2 | PC | DL1 | PC | DLO | | RW Initial value: 00H EIPOL0[7:0] External interrupt (EINT0, EINT1, EINT2, EINT3) polarity selection POLn[1:0] Description 0 0 No interrupt at any edge 0 1 Interrupt on rising edge 1 0 Interrupt on falling edge 1 1 1 Interrupt on both of rising and falling edge 6. Interrupt Controller A96T418 User's manual #### EIFLAG1 (External Interrupt Flag 1 Register): A6H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-------|---|---|--------|--------|--------|-------| | T00VIFR | TOIFR | _ | _ | FLAG12 | FLAG11 | FLAG10 | FLAG8 | | RW | RW | _ | _ | RW | RW | RW | RW | Initial value: 00H T00VIFR When T0 overflow interrupt occurs, this bit becomes '1'. For clearing bit, write'0' to this bit or automatically clear by INT\_ACK signal. Writing "1" has no effect. 0 T0 overflow Interrupt no generation T0 overflow Interrupt generation T0IFR When T0 interrupt occurs, this bit becomes '1'. For clearing bit, write '0' to this bit or automatically clear by INT\_ACK signal. Writing "1" has no effect. 0 T0 Interrupt no generation 1 T0 Interrupt generation EIFLAG1[3:0] When an External Interrupt (EINT8, EINT10-EINT12) is occurred, the flag becomes '1'. The flag is cleared by writing '0' to the bit or automatically cleared by INT\_ACK signal. Writing "1" has no effect. 0 External Interrupt not occurred 1 External Interrupt occurred #### EIPOL1 (External Interrupt Polarity 1 Register): A7H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|------|----|-----|----|-----|----|-----| | PC | )L12 | PO | L11 | PC | L10 | PC | DL8 | | RW Initial value: 00H EIPOL1[7:2] External interrupt (EINT8, EINT10,EINT11,EINT12) polarity selection POLn[1:0] Description 0 0 No interrupt at any edge 1 Interrupt on falling edge 1 Description 1 Interrupt on both of rising and falling edge Where n = 8, 10, 11 and 12 A96T418 User's manual 7. Clock Generator # 7 Clock Generator ### 7.1 Overview As shown in Figure 22, the clock generator produces the basic clock pulses which provide the system clock to be supplied to the CPU and the peripheral hardware. It contains sub-frequency clock oscillator. The sub clock operation can be easily obtained by attaching a crystal between the SXIN and SXOUT pin. The sub clock can be also obtained from the external oscillator. In this case, it is necessary to put the external clock signal into the SXIN pin and open the SXOUT pin. The default system clock is 1MHz INT-RC Oscillator. In order to stabilize system internally, it is used 128kHz LOW INT-RC oscillator on POR. - Calibrated High Internal RC Oscillator (fhsirc =16MHz) - HSIRC OSC (16MHz, Default system clock) - HSIRC OSC/2 (8MHz) - HSIRC OSC/4 (4MHz) - HSIRC OSC/8 (2MHz) - HSIRC OSC/16 (1MHz) - HSIRC OSC/32 (0.5MHz) - SubCrystal Oscillator (32.768kHz) - Internal LSIRC Oscillator (128kHz) 7. Clock Generator A96T418 User's manual # 7.2 Block Diagram Figure 22. Clock Generator Block Diagram # 7.3 Register Map Table 11. Clock Generator Register Map | Name | Address | Direction | Default | Description | |-------|---------|-----------|---------|-----------------------------------| | SCCR | 8AH | R/W | 00H | System and Clock Control Register | | OSCCR | С8Н | R/W | 28H | Oscillator Control Register | ## 7.4 Clock Generator Register Description The clock generatorregister uses clock control for system operation. The clock generation consists of System and clock control register and oscillator control register. A96T418 User's manual 7. Clock Generator # 7.5 Register Description for Clock Generator # SCCR (System and Clock Control Register): 8AH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|-------|-------| | _ | - | ı | - | - | _ | SCLK1 | SCLK0 | | _ | - | - | - | - | _ | RW | RW | Initial value: 00H | SCLK [1:0] | System Clock Selection Bit | | | | | | |------------|----------------------------|-------|--------------------------------------------------------------|--|--|--| | | SCLK1 | SCLK0 | Description | | | | | | 0 | 0 | Internal 16MHz RC OSC (f <sub>HSIRC</sub> ) for system clock | | | | | | 0 | 1 | Reserved | | | | | | 1 | 0 | External Sub OSC (f <sub>SUB</sub> ) for system clock | | | | | | 1 | 1 | Internal 128kHz RC OSC (fLSIRC) for system clock | | | | 7. Clock Generator A96T418 User's manual # OSCCR (Oscillator Control Register): C8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|--------|-------|-------|-------|--------|---|-------| | TIRCE | LSIRCE | IRCS2 | IRCS1 | IRCS0 | HSIRCE | - | SCLKE | | RW | RW | RW | RW | RW | RW | - | RW | Initial value: 28H | | | | | | Initial valu | | | | | |-----------|-------------------------------------------------------------------|----------------------|--------------------|---------------------------------|--------------|--|--|--|--| | TIRCE | Control the Operation of the Touch (16MHz) Internal RC Oscillator | | | | | | | | | | | 0 | Disable operatio | n of TIRC OSC | | | | | | | | | 1 | Enable operation | of TIRC OSC | | | | | | | | LSIRCE | Control the Ope | ration of the Low F | requency (128kF | Hz) internal RC Oscillator at | Stop mode | | | | | | | 0 | Disable operatio | n of LSIRC OSC | | | | | | | | | 1 | Enable operation | of LSIRC OSC | | | | | | | | IRCS[2:0] | Internal RC Osc | illator Post-divider | Selection | | | | | | | | | IRCS2 | IRCS1 | IRCS0 | Description | | | | | | | | 0 | 0 | 0 | f <sub>HSIRC</sub> /32 (0.5MHz) | | | | | | | | 0 | 0 | 1 | f <sub>HSIRC</sub> /16 (1MHz) | | | | | | | | 0 | 1 | 0 | f <sub>HSIRC</sub> /8 (2MHz) | | | | | | | | 0 | 1 | 1 | f <sub>HSIRC</sub> /4 (4MHz) | | | | | | | | 1 | 0 | 0 | f <sub>HSIRC</sub> /2 (8MHz) | | | | | | | | 1 | 0 | 1 | f <sub>HSIRC</sub> (16MHz) | | | | | | | | 1 | 1 | 0 | Test only | | | | | | | | Other Values | | | reserved | | | | | | | HSIRCE | Control the Ope | ration of the High | Frequency (16MF | dz) Internal RC Oscillator | | | | | | | | 0 | Enable operation | of HSIRC OSC | | | | | | | | | 1 | Disable operatio | n of HSIRC OSC | | | | | | | | SCLKE | Control the Ope | ration of the Exter | nal Sub Oscillatoi | ſ | | | | | | | | 0 | Disable operatio | n of SX-TAL | | | | | | | | | 1 | Enable operation | n of SX-TAL | | | | | | | | | | | | | | | | | | A96T418 User's manual 8. Basic Interval Timer # 8 Basic Interval Timer ### 8.1 Overview The A96T418 has one 8-bit basic interval timer that is free-run and can't stop. Block diagram is shown in Figure 23. In addition, the basic interval timer generates the time base for watchdog timer counting. It also provides a basic interval timer interrupt (BITIFR). The A96T418 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 # 8.2 Block Diagram Figure 23. Basic Interval Timer Block Diagram 8. Basic Interval Timer A96T418 User's manual # 8.3 Register Map Table 12. Basic Interval Timer Register Map | Name | Address | Direction | Default Description | | |--------|---------|-----------|---------------------|---------------------------------------| | BITCNT | 8CH | R | 00H | Basic Interval Timer Counter Register | | BITCR | 8BH | R/W | 45H | Basic Interval Timer Control Register | # 8.4 Basic Interval Timer Register Description The basicinterval timer register consists of basic interval timer counter register (BITCNT) and basic interval timer control register (BITCR). If BCLR bit is set to '1', BITCNT becomes '0' and then counts up. After 1 machine cycle, BCLR bit is cleared to '0' automatically. A96T418 User's manual 8. Basic Interval Timer # 8.5 Register Description for Basic Interval Timer ## BITCNT (Basic Interval Timer Counter Register): 8CH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | BITCNT7 | BITCNT6 | BITCNT5 | BITCNT4 | BITCNT3 | BITCNT2 | BITCNT1 | BITCNT0 | | R | R | R | R | R | R | R | R | Initial value: 00H BITCNT[7:0] **BIT Counter** ## BITCR (Basic Interval Timer Control Register): 8BH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|--------|--------|--------|------|------|------|------| | BMFR | BITCK2 | BITCK1 | BITCK0 | BCLR | BCK2 | BCK1 | BCK0 | | RW Initial value: 45H BITIFR When BIT Interrupt occurs, this bit becomes '1'. For clearing bit, write '0' to this bit or signal. Writing "1" has no auto clear by INT\_ACK effect. 0 BIT interrupt no generation 1 BIT interrupt generation BITCK[2:0] Select BIT clock source | BITCK2 | BITCK1 | BITCK0 | Description | |--------|--------|--------|--------------------| | 0 | 0 | 0 | fx/4096 | | 0 | 0 | 1 | fx/1024 | | 0 | 1 | 0 | fx/128 | | 0 | 1 | 1 | fx/16 | | 1 | 0 | 0 | LSIRC/32 (Default) | | 1 | 0 | 1 | LSIRC/32 | | 1 | 1 | 0 | LSIRC/32 | | 1 | 1 | 1 | Temperature Sensor | BCLR If this bit is written to '1', BIT Counter is cleared to '0' 0 Free Running 1 Clear Counter BCK[2:0] Select BIT overflow period | Golda Bir avamow panda | | | | | | | | | |------------------------|------|------|---------------------------------|--|--|--|--|--| | BCK2 | BCK1 | BCK0 | Description (fx= LSIRC 128k) | | | | | | | 0 | 0 | 0 | 0.5ms (BIT Clock * 2) | | | | | | | 0 | 0 | 1 | 1ms (BIT Clock * 4) | | | | | | | 0 | 1 | 0 | 2ms (BIT Clock * 8) | | | | | | | 0 | 1 | 1 | 4ms (BIT Clock * 16) | | | | | | | 1 | 0 | 0 | 8ms (BIT Clock * 32) | | | | | | | 1 | 0 | 1 | 16ms (BIT Clock * 64) (default) | | | | | | | 1 | 1 | 0 | 32ms (BIT Clock * 128) | | | | | | | 1 | 1 | 1 | 64ms (BIT Clock * 256) | | | | | | | | | | | | | | | | 9. Watch Dog Timer A96T418 User's manual # 9 Watch Dog Timer #### 9.1 Overview The watchdog timer rapidly detects the CPU malfunction such as endless looping caused by noise or something like that, and resumes the CPU to the normal state. The watchdog timer signal for malfunction detection can be used as either a CPU reset 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 WDTCR[6] bit. If WDTCR[5] is written to '1', WDT counter value is cleared and counts up. After 1 machine cycle, this bit is cleared to '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 WDTCNT, the interrupt request flag is generated. This can be used as Watchdog timer interrupt or reset of CPU in accordance with the bit WDTRSON. The input clock source of watch dog timer is the BIT overflow. The interval of watchdog timer interrupt is decided by BIT overflow period and WDTDR set value. The equation can be described as WDT Interrupt Interval = (BIT Interrupt Interval) X (WDTDR Value+1) # 9.2 WDT Interrupt Timing Waveform Figure 24. Watch Dog Timer Interrupt Timing Waveform A96T418 User's manual 9. Watch Dog Timer # 9.3 Block Diagram Figure 25. Watch Dog Timer Block Diagram # 9.4 Register Map Table 13. Watch Dog Timer Register Map | Name | Address | Direction | Default | Description | |--------|---------|-----------|---------|----------------------------------| | WDTCNT | 8EH | R | 00H | Watch Dog Timer Counter Register | | WDTDR | 8EH | W | FFH | Watch Dog Timer Data Register | | WDTCR | 8DH | R/W | 00H | Watch Dog Timer Control Register | # 9.5 Watch Dog Timer Register Description The watch dog timer register consists of watch dog timer counter register (WDTCNT), watch dog timer dataregister (WDTDR) and watch dog timer controlregister (WDTCR). 9. Watch Dog Timer A96T418 User's manual # 9.6 Register Description for Watch Dog Timer WDTCNT (Watch Dog Timer Counter Register: Read Case): 8EH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | WDTCNT7 | WDTCNT6 | WDTCNT5 | WDTCNT4 | WDTCNT3 | WDTCNT2 | WDTCNT1 | WDTCNT0 | | R | R | R | R | R | R | R | R | Initial value: 00H WDTCNT[7:0] **WDT Counter** WDTDR (Watch Dog Timer Data Register: Write Case): 8EH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | WDTDR7 | WDTDR6 | WDTDR5 | WDTDR4 | WDTDR3 | WDTDR2 | WDTDR1 | WDTDR0 | | W | W | W | W | W | W | W | W | Initial value: FFH WDTDR[7:0] Set a period WDT Interrupt Interval=(BIT Interrupt Interval) x (WDTDR Value+1) NOTES: 1. Do not write "0" in the WDTDR register. WDTCR (Watch Dog Timer Control 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 BIT overflow/8 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. Writing "1" has no effect. 0 WDT Interrupt no generation 1 WDT Interrupt generation A96T418 User's manual 10. Watch Timer # 10 Watch Timer ### 10.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 control register. To operate the watch timer, determine the input clock source, output interval, and set WTEN to '1' in watch timer control register (WTCR). It is able to execute simultaneously or individually. To stop or reset WT, clear the WTEN bit in WTCR register. Even if CPU is STOP mode, sub clock is able to be so alive that WT can continue the operation. The watch timer counter circuits may be composed of 21-bit counter which contains low 14-bit with binary counter and high 7-bit counter in order to raise resolution. In WTDR, it can control WT clear and set interval value at write time, and it can read 7-bit WT counter value at read time. ### 10.2 Block Diagram Figure 26. Watch Timer Block Diagram 10. Watch Timer A96T418 User's manual # 10.3 Register Map Table 14. Watch Timer Register Map | Name | Address | Direction | Default | Description | |-------|---------|-----------|---------|------------------------------| | WTCNT | 89H | R | 00H | Watch Timer Counter Register | | WTDR | 89H | W | 7FH | Watch Timer Data Register | | WTCR | 96H | R/W | 00H | Watch Timer Control Register | # 10.4 Watch Timer Register Description The watch timer register consists of watch timer counter register (WTCNT), watch timer data register (WTDR), and watch timer controlregister (WTCR). As WTCR is 6-bit writable/ readable register, WTCR can control the clock source (WTCK[1:0]), interrupt interval (WTIN[1:0]), and function enable/disable (WTEN). Also there is WT interrupt flag bit (WTIFR). ## 10.5 Register Description for Watch Timer WTCNT (Watch Timer Counter Register: Read Case): 89H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|--------|--------|--------|--------|--------|--------|---------------| | _ | WTCNT6 | WTCNT5 | WTCNT4 | WTCNT3 | WTCNT2 | WTCNT1 | WTCNT0 | | _ | R | R | R | R | R | R | R | | | | | | | | Initi | al value: 00H | WTCNT[6:0] WT Counter ### WTDR (Watch Timer Data Register: Write Case): 89H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|-------|-------|-------|-------|-------|-------|-------| | WTCL | WTDR6 | WTDR5 | WTDR4 | WTDR3 | WTDR2 | WTDR1 | WTDR0 | | RW | 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) WTDR[6:0] Set WT period WT Interrupt Interval=fwck/(2^14 x(7bit WTDR Value+1)) NOTES: 1. Do not write "0" in the WTDR register. A96T418 User's manual 10. Watch Timer # WTCR (Watch Timer Control Register): 96H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|---|-------|-------|-------|-------|-------| | WTEN | _ | _ | WTIFR | WTIN1 | WTIN0 | WTCK1 | WTCK0 | | RW | - | - | RW | RW | RW | RW | RW | Initial value: 00H | WTEN | Control W | atch Timer | | | | | | |-----------|-------------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------|--|--|--|--| | | 0 | Disable | | | | | | | | 1 | Enable | | | | | | | WTIFR | | | occurs, this bit becomes '1'. For clearing bit, write '0' to this bit or y INT_ACK signal. Writing "1" has no effect. | | | | | | | 0 | WT Inter | rupt no generation | | | | | | | 1 | WT Inter | rupt generation | | | | | | WTIN[1:0] | N[1:0] Determine interrupt interval | | | | | | | | | WTIN1 | WTIN0 | Description | | | | | | | 0 | 0 | f <sub>WCK</sub> /2^7 | | | | | | | 0 | 1 | f <sub>WCK</sub> /2^13 | | | | | | | 1 | 0 | fwck/2^14 | | | | | | | 1 | 1 | fwck/(2^14 x (7bit WTDR Value+1)) | | | | | | WTCK[1:0] | Determin | e Source ( | Clock | | | | | | | WTCK1 | WTCK0 | Description | | | | | | | 0 | 0 | fsuв | | | | | | | 0 | 1 | f <sub>x</sub> /256 | | | | | | | 1 | 0 | f <sub>x</sub> /128 | | | | | | | 1 | 1 | fx/64 | | | | | ## NOTES: - 1. f<sub>X</sub>– System clock frequency (Where fx= 4.19MHz) - 2. f<sub>SUB</sub>- Sub clock oscillator frequency (32.768kHz) - 3. f<sub>WCK</sub>- Selected Watch timer clock # 11 Timer 0/1/2/3/4/5 ### 11.1 Timer 0 #### 11.1.1 Overview The 8-bit timer 0 consists of multiplexer, timer 0 counter register, timer 0 data register, timer 0 capture data register and timer 0 control register (T0CNT, T0DR, T0CDR, and T0CR). It has three operating modes: - 8-bit timer/counter mode - 8-bit PWM output mode - 8-bit capture mode The timer/counter 0 can be clocked by an internal or an external clock source (EC0). The clock source is selected by clock selection logic which is controlled by the clock selection bits (T0CK[2:0]). TIMER0 clock source: f<sub>X</sub>/2, 4, 8, 32, 128, 512, 2048 and EC0 In the capture mode, by EINT10, the data is captured into input capture data register (T0CDR). In timer/counter mode, whenever counter value is equal to T0DR, T0O port toggles. Also the timer 0 outputs PWM waveform through PWM0O port in the PWM mode. Table 15. Timer 0 Operating Modes | T0EN | T0MS[1:0] | T0CK[2:0] | Timer 0 | |------|-----------|-----------|--------------------------| | 1 | 00 | XXX | 8-bit Timer/Counter Mode | | 1 | 01 | XXX | 8-bit PWM Mode | | 1 | 1X | XXX | 8-bit Capture Mode | #### 11.1.2 8-bit Timer/Counter Mode The 8-bit timer/counter mode is selected by control register as shown in Figure 27. The 8-bit timer have counter and data register. The counter register is increased by internal or external clock input. Timer 0 can use the input clock with one of 2, 4, 8, 32, 128, 512 and 2048 prescaler division rates (T0CK[2:0]). When the value of T0CNT and T0DR is identical in timer 0, a match signal is generated and the interrupt of Timer 0 occurs. T0CNT value is automatically cleared by match signal. It can be also cleared by software (T0CC). The external clock (EC0) counts up the timer at the rising edge. If the EC0 is selected as a clock source by T0CK[2:0], EC0 port should be set to the input port by P25IO bit. Figure 27. 8-bit Timer/Counter Mode for Timer 0 Figure 28. 8-bit Timer/Counter 0 Example # 11.1.3 8-bit PWM Mode The timer 0 has a high speed PWM (Pulse Width Modulation) function. In PWM mode, T0O/PWM0O pin outputs up to 8-bit resolution PWM output. This pin should be configured as a PWM output by setting the T0O/PWM0O function by P2FSRH[7:6] bits. In the 8-bit timer/counter mode, a match signal is generated when the counter value is identical to the value of T0DR. When the value of T0CNT and T0DR is identical in timer 0, a match signal is generated and the interrupt of timer 0 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 overflow interrupt is generated whenever a counter overflow occurs. T0CNT value is cleared by software (T0CC) bit. Figure 29. 8-bit PWM Mode for Timer 0 Figure 30. PWM Output Waveforms in PWM Mode for Timer 0 #### 11.1.4 8-bit Capture Mode The timer 0 capture mode is set by T0MS[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 T0CNT is equal to T0DR. T0CNTvalue is automatically cleared by match signal and it can be also cleared by software (T0CC). 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 T0CDR. In the timer 0 capture mode, timer 0 output (T0O) waveform is not available. T0CDR and T0DR are in the same address. In the capture mode, reading operation readsT0CDR, not T0DR and writing operation will update T0DR. Figure 31. 8-bit Capture Mode for Timer 0 Figure 32. Input Capture Mode Operation for Timer 0 Figure 33. Express Timer Overflow in Capture Mode ## 11.1.5 Block Diagram Figure 34. 8-bit Timer 0 Block Diagram ## 11.1.6 Register Map Name **Address** Direction Default Description **TOCNT** взн R 00H Timer 0 Counter Register T0DR B4H R/W **FFH** Timer 0 Data Register T0CDR B4H R 00H Timer 0 Capture Data Register T0CR R/W 00H B2H Timer 0 Control Register Table 16. Timer 0 Register Map ## 11.1.7 Timer/Counter 0 Register Description The timer/counter 0 register consists of timer 0 counterregister (T0CNT), timer 0 data register (T0DR), timer 0 capture dataregister (T0CDR), and timer 0 controlregister (T0CR). T0IFR and T0OVIFR bits are in the external interrupt flag 1 register (EIFLAG1). # 11.1.8 Register Description for Timer/Counter 0 # T0CNT (Timer 0 Counter Register): B3H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | TOCNT7 | TOCNT6 | TOCNT5 | T0CNT4 | TOCNT3 | TOCNT2 | TOCNT1 | TOCNTO | | R | R | R | R | R | R | R | R | Initial value: 00H T0CNT[7:0] T0 Counter # T0DR (Timer 0 Data Register): B4H | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-------|-------|-------|-------|-------|-------|-------|-------| | | TODR7 | TODR6 | TODR5 | TODR4 | T0DR3 | T0DR2 | TODR1 | TODRO | | Ī | RW Initial value: FFH T0DR[7:0] T0 Data ## T0CDR (Timer 0 Capture Data Register: Read Case, Capture mode only): B4H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | T0CDR7 | T0CDR6 | T0CDR5 | T0CDR4 | T0CDR3 | T0CDR2 | T0CDR1 | TOCDR0 | | R | R | R | R | R | R | R | R | Initial value: 00H T0CDR[7:0] T0 Capture Data # T0CR (Timer 0 Control Register): B2H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|---|-------|-------|-------|-------|-------|------| | TOEN. | _ | T0MS1 | TOMS0 | TOCK2 | T0CK1 | TOCKO | TOCC | | RW | _ | RW | RW | RW | RW | RW | RW | Initial value: 00H | T0EN | Control | Timer 0 | | | | | | | |-----------|-----------|-------------------------------------------------------------|------------------------|--------------------------------------------------------------|--|--|--|--| | | 0 | Timer ( | ) disable | | | | | | | | 1 | Timer ( | enable | | | | | | | T0MS[1:0] | Control | Control Timer 0 Operation Mode | | | | | | | | | T0MS<br>1 | TOMS<br>0 | Descrip | otion | | | | | | | 0 | 0 | Timer/c | counter mode | | | | | | | 0 | 1 | PWM mode | | | | | | | | 1 | X | Capture | e mode | | | | | | T0CK[2:0] | Select T | Select Timer 0 clock source. fx is a system clock frequency | | | | | | | | | T0CK2 | T0CK<br>1 | T0CK<br>0 | 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 (EC0) | | | | | | T0CC | Clear tin | ner 0 Co | unter | | | | | | | | 0 | No effe | ct | | | | | | | | 1 | | ne Timer<br>I counter) | 0 counter (When write, automatically cleared "0" after being | | | | | ## NOTES: - 1. Match Interrupt is generated in Capture mode. - 2. Refer to the external interrupt flag 1 register (EIFLAG1) for the T0 interrupt flags. #### 11.2 Timer 1 #### 11.2.1 Overview The 16-bit timer 1 consists of multiplexer, timer 1 A data register high/low, timer 1 B data register high/low and timer 1 control register high/low (T1ADRH, T1ADRL, T1BDRH, T1BDRL, T1CRH, T1CRL). 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 1 can be clocked by an internal or an external clock source (EC1). The clock source is selected by clock selection logic which is controlled by the clock selection bits (T1CK[2:0]). TIMER 1 clock source: fx/1, 2, 4, 8, 64, 512, 2048 and EC1 In the capture mode, by EINT11, the data is captured into input capture data register (T1BDRH/T1BDRL). Timer 1 outputs the comparison result between counter and data register through T1O port in timer/counter mode. Also Timer 1 outputs PWM wave form through PWM1O port in the PPG mode. T1CK[2:0] T1EN P1FSRL[1:0] T1MS[1:0] Timer 1 1 XXX 16-bit Timer/Counter Mode 11 00 1 00 01 XXX 16-bit Capture Mode 1 11 XXX16-bit PPG Mode(one-shot mode) 10 1 11 XXX 16-bit PPG Mode(repeat mode) 11 Table 17. Timer 1 Operating Modes #### 11.2.2 16-bit Timer/Counter Mode The 16-bit timer/counter mode is selected by control register as shown in Figure 35. The 16-bit timer have counter and data register. The counter register is increased by internal or external clock input. Timer 1 can use the input clock with one of 1, 2, 4, 8, 64, 512 and 2048 prescaler division rates (T1CK[2:0]). When the value of T1CNTH, T1CNTL and the value of T1ADRH, T1ADRL are identical in Timer 1 respectively, a match signal is generated and the interrupt of Timer1occurs. The T1CNTH, T1CNTL value is automatically cleared by match signal. It can be also cleared by software (T1CC). The external clock (EC1) counts up the timer at the rising edge. If the EC1 is selected as a clock source by T1CK[2:0], EC1 port should be set to the input port by P23IO bit. Figure 35. 16-bit Timer/Counter Mode for Timer 1 Figure 36. 16-bit Timer/Counter 1 Example #### 11.2.3 16-bit Capture Mode The 16-bit timer 1 capture mode is set by T1MS[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 T1CNTH/T1CNTL is equal to T1ADRH/T1ADRL. The T1CNTH, T1CNTL values are automatically cleared by match signal. It can be also cleared by software (T1CC). 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 T1BDRH/T1BDRL. Figure 37. 16-bit Capture Mode for Timer 1 Figure 38. Input Capture Mode Operation for Timer 1 Figure 39. Express Timer Overflow in Capture Mode #### 11.2.4 16-bit PPG Mode The timer 1 has a PPG (Programmable Pulse Generation) function. In PPG mode, T1O/PWM1O pin outputs up to 16-bit resolution PWM output. This pin should be configured as a PWM output by setting P1FSRL[3:2] to '11'. The period of the PWM output is determined by the T1ADRH/T1ADRL. And the duty of the PWM output is determined by the T1BDRH/T1BDRL. Figure 40. 16-bit PPG Mode for Timer 1 Figure 41. 16-bit PPG Mode Timming chart for Timer 1 # 11.2.5 Block Diagram Figure 42. 16-bit Timer 1 Block Diagram ## 11.2.6 Register Map | Name | Address | Direction | Default | Description | |--------|---------|-----------|---------|-------------------------------| | T1ADRH | BDH | R/W | FFH | Timer 1 A Data High Register | | T1ADRL | ВСН | R/W | FFH | Timer 1 A Data Low Register | | T1BDRH | BFH | R/W | FFH | Timer 1 B Data High Register | | T1BDRL | BEH | R/W | FFH | Timer 1 B Data Low Register | | T1CRH | ВВН | R/W | 00H | Timer 1 Control High Register | | T1CRL | BAH | R/W | 00H | Timer 1 Control Low Register | Table 18. Timer 1 Register Map ## 11.2.7 Timer/Counter 1 Register Description The timer/counter 1 register consists of timer 1 A data high register (T1ADRH), timer 1 A data low register (T1ADRL), timer 1 B data high register (T1BDRH), timer 1 B data low register (T1BDRL), timer 1 control high register (T1CRH) and timer 1 control low register (T1CRL). ### 11.2.8 Register Description for Timer/Counter 1 ## T1ADRH (Timer 1 A Data High Register): BDH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|-----------|------------| | T1ADRH7 | T1ADRH6 | T1ADRH5 | T1ADRH4 | T1ADRH3 | T1ADRH2 | T1ADRH1 | T1ADRH0 | | R/W | | | | | | | Initial v | /alue: FFH | T1ADRH[7:0] T1 A Data High Byte T1ADRL (Timer 1 A Data Low Register): BCH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | T1ADRL7 | T1ADRL6 | T1ADRL5 | T1ADRL4 | T1ADRL3 | T1ADRL2 | T1ADRL1 | T1ADRL0 | | R/W Initial value: FFH T1ADRL[7:0] T1 A Data Low Byte NOTES: Do not write "0000H" in the T1ADRH/T1ADRL register when PPG mode ### T1BDRH (Timer 1 B Data High Register): BFH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|-----------|-----------| | T1BDRH7 | T1BDRH6 | T1BDRH5 | T1BDRH4 | T1BDRH3 | T1BDRH2 | T1BDRH1 | T1BDRH0 | | R/W | | | | | | | Initial v | alue: FFH | T1BDRH[7:0] T1 B Data High Byte T1BDRL (Timer 1 B Data Low Register): BEH | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-------|---------|---------|---------|---------|---------|---------|---------| | T1E | BDRL7 | T1BDRL6 | T1BDRL5 | T1BDRL4 | T1BDRL3 | T1BDRL2 | T1BDRL1 | T1BDRL0 | | F | R/W Initial value: FFH T1BDRL[7:0] T1 B Data Low Byte # T1CRH (Timer 1 Control High Register): BBH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|-------|-------|---|---|---|------| | T1EN | _ | T1MS1 | T1MS0 | _ | _ | _ | T1CC | | RW | _ | R/W | RW | _ | _ | - | RW | Initial value: 00H | T1EN | Control <sup>-</sup> | Timer 1 | | | | | | |-----------|--------------------------------|-----------------------------------------------------------------------------------------------|------------------------------------------------|--|--|--|--| | | 0 | Timer 1 disable | | | | | | | | 1 | Timer 1 enable (Counter clear and start) | | | | | | | T1MS[1:0] | Control Timer 1 Operation Mode | | | | | | | | | T1MS1 | T1MS0 | Description | | | | | | | 0 | 0 | Timer/counter mode (T1O: toggle at A match) | | | | | | | 0 | 1 | Capture mode (The A match interrupt can occur) | | | | | | | 1 | 0 | PPG one-shot mode (PWM1O) | | | | | | | 1 | 1 | PPG repeat mode (PWM1O) | | | | | | T1CC | Clear Timer 1 Counter | | | | | | | | | 0 | No effect | | | | | | | | 1 | Clear the Timer 1 counter (When write, automatically cleared "0" after being cleared counter) | | | | | | | | | | , | | | | | # T1CRL (Timer 1 Control Low Register): BAH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|---|-------|-------|--------| | T1CK2 | T1CK1 | T1CK0 | T1IFR | _ | T1POL | T1ECE | T1CNTR | | R/W | R/W | R/W | R/W | _ | RW | RW | RW | Initial value: 00H | T1CK[2:0] | Select Tim | ner 1 clock sou | rce. fx is main | system clock frequency | | | | |-----------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|---------------------------|--|--|--| | | T1CK2 | T1CK1 | T1CK0 | 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 (EC1) | | | | | T1IFR | | When T1 Interrupt occurs, this bit becomes '1'. For clearing bit, write '0' to this bit or auto clear by INT_ACK signal. Writing "1" has no effect. | | | | | | | | 0 | T1 Interrupt no generation | | | | | | | | 1 | T1 Interrup | ot generation | | | | | | T1POL | T10/PWM | 110 Polarity Se | election | | | | | | | 0 | Start High | (T1O/PWM1C | is low level at disable) | | | | | | 1 | Start Low | (T10/PWM10 | is high level at disable) | | | | | T1ECE | Timer 1 Ex | xternal Clock E | dge Selection | | | | | | | 0 | External c | lock falling edg | ge | | | | | | 1 | External c | lock rising edg | e | | | | | T1CNTR | Timer 1 Co | ounter Read C | ontrol | | | | | | | 0 | No effect | | | | | | | | 1 | | Load the counter value to the B data register (When write, automatically cleared "0" after being loaded) | | | | | ## 11.3 Timer 2 #### 11.3.1 Overview The 16-bit timer 2 consists of multiplexer, timer 2 A data high/low register, timer 2 B data high/low register and timer 2 control high/low register (T2ADRH, T2ADRL, T2BDRH, T2BDRL, T2CRH, and T2CRL). 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 can be divided clock of the system clock selected from prescaler output and T1 A Match (timer 1 A match signal). The clock source is selected by clock selection logic which is controlled by the clock selection bits (T2CK[2:0]). TIMER 2 clock source: fx/1, fx/2, fx/4,fx/8,fx/32, fx/128, fx/512 and T1 A Match In the capture mode, by EINT12, the data is captured into input capture data register (T2BDRH/T2BDRL). In timer/counter mode, whenever counter value is equal to T2ADRH/L, T2O port toggles. Also the timer 2 outputs PWM wave form to PWM2O port in the PPG mode. Table 19. Timer 2 Operating Modes | T2EN | P1FSRL[5:4] | T2MS[1:0] | T2CK[2:0] | Timer 2 | |------|-------------|-----------|-----------|---------------------------------| | 1 | 11 | 00 | XXX | 16-bit Timer/Counter Mode | | 1 | 00 | 01 | XXX | 16-bit Capture Mode | | 1 | 11 | 10 | XXX | 16-bit PPG Mode (one-shot mode) | | 1 | 11 | 11 | XXX | 16-bit PPG Mode (repeat mode) | #### 11.3.2 16-bit Timer/Counter Mode The 16-bit timer/counter mode is selected by control register as shown in Figure 43. The 16-bit timer have counter and data register. The counter register is increased by internal or timer 1 A match clock input. Timer 2 can use the input clock with one of 1, 2, 4, 8, 32, 128, 512 and T1 A Match prescaler division rates (T2CK[2:0]). When the values of T2CNTH/T2CNTL and T2ADRH/T2ADRL are identical in timer 2, a match signal is generated and the interrupt of Timer 2 occurs. The T2CNTH/T2CNTL values are automatically cleared by match signal. It can be also cleared by software (T2CC). Figure 43. 16-bit Timer/Counter Mode for Timer 2 Figure 44. 16-bit Timer/Counter 2 Example ### 11.3.3 16-bit Capture Mode The timer 2 capture mode is set by T2MS[1:0] as '01'. The clock source can use the internal clock. Basically, it has the same function as the 16-bit timer/counter mode and the interrupt occurs when T2CNTH/T2CNTL is equal to T2ADRH/T2ADRL. T2CNTH/T2CNTL values are automatically cleared by match signal and it can be also cleared by software (T2CC). 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 T2BDRH/T2BDRL. In the timer 2 capture mode, timer 2 output(T2O) waveform is not available. Figure 45. 16-bit Capture Mode for Timer 2 Figure 46. Input Capture Mode Operation for Timer 2 Figure 47. Express Timer Overflow in Capture Mode #### 11.3.4 16-bit PPG Mode The timer 2 has a PPG (Programmable Pulse Generation) function. In PPG mode, the T2O/PWM2O pin outputs up to 16-bit resolution PWM output. This pin should be configured as a PWM output by set P1FSRL[5:4] to '11'. The period of the PWM output is determined by the T2ADRH/T2ADRL. And the duty of the PWM output is determined by the T2BDRH/T2BDRL. Figure 48. 16-bit PPG Mode for Timer 2 Figure 49. 16-bit PPG Mode Timming chart for Timer 2 # 11.3.5 Block Diagram Figure 50. 16-bit Timer 2 Block Diagram ### 11.3.6 Register Map Table 20. Timer 2 Register Map | Name | Address | Direction | Default | Description | |--------|---------|-----------|---------|-------------------------------| | T2ADRH | C5H | R/W | FFH | Timer 2 A Data High Register | | T2ADRL | C4H | R/W | FFH | Timer 2 A Data Low Register | | T2BDRH | C7H | R/W | FFH | Timer 2 B Data High Register | | T2BDRL | C6H | R/W | FFH | Timer 2 B Data Low Register | | T2CRH | СЗН | R/W | 00H | Timer 2 Control High Register | | T2CRL | C2H | R/W | 00H | Timer 2 Control Low Register | ### 11.3.7 Timer/Counter 2 Register Description The timer/counter 2 register consists of timer 2 A data high register (T2ADRH), timer 2 A data low register (T2ADRL), timer 2 B data high register (T2BDRH), timer 2 B data low register (T2BDRL), timer 2 control high register (T2CRH) and timer 2 control low register (T2CRL). ### 11.3.8 Register Description for Timer/Counter 2 ## T2ADRH (Timer 2 A Data High Register): C5H | _ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---------|---------|---------|---------|---------|---------|---------|---------------| | | T2ADRH7 | T2ADRH6 | T2ADRH5 | T2ADRH4 | T2ADRH3 | T2ADRH2 | T2ADRH1 | T2ADRH0 | | Ī | R/W | | | | | | | | Initi | al value: FFH | T2ADRH[7:0] T2 A Data High Byte ### T2ADRL (Timer 2 A Data Low Register): C4H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------------| | T2ADRL7 | T2ADRL6 | T2ADRL5 | T2ADRL4 | T2ADRL3 | T2ADRL2 | T2ADRL1 | T2ADRL0 | | R/W | | | | | | | Initi | al value: FFH | T2ADRL[7:0] T2 A Data Low Byte NOTES: Do not write "0000H" in the T2ADRH/T2ADRL register when PPG mode. ### T2BDRH (Timer 2 B Data High Register): C7H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | T2BDRH7 | T2BDRH6 | T2BDRH5 | T2BDRH4 | T2BDRH3 | T2BDRH2 | T2BDRH1 | T2BDRH0 | | R/W Initial value: FFH T2BDRH[7:0] T2 B Data High Byte ### T2BDRL (Timer 2 B Data Low Register): C6H | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---------|---------|---------|---------|---------|---------|---------|---------------| | | T2BDRL7 | T2BDRL6 | T2BDRL5 | T2BDRL4 | T2BDRL3 | T2BDRL2 | T2BDRL1 | T2BDRL0 | | • | R/W | | | | | | | | lmi+i | al valuer EEH | Initial value: FFH T2BDRL[7:0] T2 B Data Low Byte # T2CRH (Timer 2 Control High Register): C3H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|-------|-------|---|---|---|------| | T2EN | _ | T2MS1 | T2MS0 | _ | _ | _ | T2CC | | RW | _ | R/W | RW | - | - | _ | RW | Initial value: 00H | T2EN | Control | ntrol Timer 2 | | | | | | | |-----------|--------------------------------|-----------------------------------------------------------------------------------------------|------------------------------------------------|--|--|--|--|--| | | 0 | Timer 2 | disable | | | | | | | | 1 | Timer 2 enable (Counter clear and start) | | | | | | | | T2MS[1:0] | Control Timer 2 Operation Mode | | | | | | | | | | T2MS1 | T2MS0 | Description | | | | | | | | 0 | 0 | Timer/counter mode (T2O: toggle at A match) | | | | | | | | 0 | 1 | Capture mode (The A match interrupt can occur) | | | | | | | | 1 | 0 | PPG one-shot mode (PWM2O) | | | | | | | | 1 | 1 | PPG repeat mode (PWM2O) | | | | | | | T2CC | Clear Ti | mer 2 Cou | nter | | | | | | | | 0 | No effec | t | | | | | | | | 1 | Clear the Timer 2 counter (When write, automatically cleared "0" after being cleared counter) | | | | | | | # T2CRL (Timer 2 Control Low Register): C2H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|---|-------|---|--------| | T2CK2 | T2CK1 | T2CK0 | T2IFR | _ | T2POL | _ | T2CNTR | | R/W | R/W | R/W | R/W | _ | RW | - | RW | Initial value: 00H | T2CK[2:0] | Select Timer 2 clo | 2 clock source. fx is main system clock frequency | | | | | | |-----------|--------------------|---------------------------------------------------|------------------------------------|---------------------------------------------|--|--|--| | | T2CK2 | T2CK1 | T2CK0 | Description | | | | | | 0 | 0 | 0 | fx/512 | | | | | | 0 | 0 | 1 | fx/128 | | | | | | 0 | 1 | 0 | fx/32 | | | | | | 0 | 1 | 1 | fx/8 | | | | | | 1 | 0 | 0 | fx/4 | | | | | | 1 | 0 | 1 | fx/2 | | | | | | 1 | 1 | 0 | fx/1 | | | | | | 1 | 1 | 1 | T1 A Match | | | | | T2IFR | | nterrupt occurs, thi<br>ar by INT_ACK sig | | For clearing bit, write '0' to s no effect. | | | | | | 0 | T2 interrupt no generation | | | | | | | | 1 | T2 interrupt gene | ration | | | | | | T2POL | T2O/PWM2O Pol | arity Selection | | | | | | | | 0 | Start High (T2O/F | WM2O is low leve | l at disable) | | | | | | 1 | Start Low (T2O/P | WM2O is high leve | el at disable) | | | | | T2CNTR | Timer 2 Counter I | Read Control | | | | | | | | 0 | No effect | | | | | | | | 1 | value to the B data<br>ared "0" after being | a register (When write,<br>loaded) | | | | | #### 11.4 Timer 3 #### 11.4.1 Overview The 16-bit timer 3 consists of multiplexer, timer 3 A data register high/low, timer 3 B data register high/low and timer 3 control register high/low (T3ADRH, T3ADRL, T3BDRH, T3BDRH, T3CRH, and T3CRL). 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 3 can be clocked by an internal or an external clock source (EC3). The clock source is selected by clock selection logic which is controlled by the clock selection bits (T3CK[2:0]). TIMER 3 clock source: f<sub>x</sub>/1, 2, 4, 8, 64, 512, 2048 and EC3 In the capture mode, by EINT3, the data is captured into input capture data register (T3BDRH/T3BDRL). Timer 3 outputs the comparison result between counter and data register through T3O port in timer/counter mode. Also Timer 3 outputs PWM wave form through PWM3O port in the PPG mode. Table 21. Timer 3 Operating Modes | T3EN | P0FSRL[3:2] | T3MS[1:0] | T3CK[2:0] | Timer 3 | |------|-------------|-----------|-----------|--------------------------------| | 1 | 11 | 00 | XXX | 16-bit Timer/Counter Mode | | 1 | 00 | 01 | XXX | 16-bit Capture Mode | | 1 | 11 | 10 | XXX | 16-bit PPG Mode(one-shot mode) | | 1 | 11 | 11 | XXX | 16-bit PPG Mode(repeat mode) | #### 11.4.2 16-bit Timer/Counter Mode The 16-bit timer/counter mode is selected by control register as shown in Figure 51. The 16-bit timer have counter and data register. The counter register is increased by internal or external clock input. Timer 3 can use the input clock with one of 1, 2, 4, 8, 64, 512 and 2048 prescaler division rates (T3CK[2:0]). When the value of T3CNTH, T3CNTL and the value of T3ADRH, T3ADRL are identical in Timer 3 respectively, a match signal is generated and the interrupt of Timer 3 occurs. The T3CNTH, T3CNTL value is automatically cleared by match signal. It can be also cleared by software (T3CC). The external clock (EC3) counts up the timer at the rising edge. If the EC3 is selected as a clock source by T3CK[2:0], EC3 port should be set to the input port by P00IO bit. Figure 51. 16-bit Timer/Counter Mode for Timer 3 Figure 52. 16-bit Timer/Counter 3 Example #### 11.4.3 16-bit Capture Mode The 16-bit timer 3 capture mode is set by T3MS[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 T3CNTH/T3CNTL is equal to T3ADRH/T3ADRL. The T3CNTH, T3CNTL values are automatically cleared by match signal. It can be also cleared by software (T3CC). 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 T3BDRH/T3BDRL. According to EIPOL0 registers setting, the external interrupt EINT3 function is chosen. Of course, the EINT3 pin must be set as an input port. Figure 53. 16-bit Capture Mode for Timer 3 Figure 54. Input Capture Mode Operation for Timer 3 Figure 55. Express Timer Overflow in Capture Mode ## 11.4.4 16-bit PPG Mode The timer 3 has a PPG (Programmable Pulse Generation) function. In PPG mode, T3O/PWM3O pin outputs up to 16-bit resolution PWM output. This pin should be configured as a PWM output by setting P0FSRH[3:2] to '11'. The period of the PWM output is determined by the T3ADRH/T3ADRL. And the duty of the PWM output is determined by the T3BDRH/T3BDRL. Figure 56. 16-bit PPG Mode for Timer 3 Figure 57. 16-bit PPG Mode Timming chart for Timer 3 # 11.4.5 Block Diagram Figure 58. 16-Bit Timer 3 Block Diagram # 11.4.6 Register Map Table 22. Timer 3 Register Map | Name | Address | Direction | Default | Description | |--------|---------|-----------|---------|-------------------------------| | T3ADRH | 1002H | R/W | FFH | Timer 3 A Data High Register | | T3ADRL | 1003H | R/W | FFH | Timer 3 A Data Low Register | | T3BDRH | 1004H | R/W | FFH | Timer 3 B Data High Register | | T3BDRL | 1005H | R/W | FFH | Timer 3 B Data Low Register | | T3CRH | 1000H | R/W | 00H | Timer 3 Control High Register | | T3CRL | 1001H | R/W | 00H | Timer 3 Control Low Register | ### 11.4.7 Timer/Counter 3 Register Description The timer/counter 3 register consists of timer 3 A data high register (T3ADRH), timer 3 A data low register (T3ADRL), timer 3 B data high register (T3BDRH), timer 3 B data low register (T3BDRL), timer 3 control high register (T3CRH) and timer 3 control low register (T3CRL). ### 11.4.8 Register Description for Timer/Counter 3 ### T3ADRH (Timer 3 A Data High Register): 1002H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------------| | T3ADRH7 | T3ADRH6 | T3ADRH5 | T3ADRH4 | T3ADRH3 | T3ADRH2 | T3ADRH1 | T3ADRH0 | | R/W | | | | | | | Initi | al value: FFH | T3ADRH[7:0] T3 A Data High Byte ### T3ADRL (Timer 3 A Data Low Register): 1003H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------------| | T3ADRL7 | T3ADRL6 | T3ADRL5 | T3ADRL4 | T3ADRL3 | T3ADRL2 | T3ADRL1 | T3ADRL0 | | R/W | | | | | | | Initi | al value: FFH | T3ADRL[7:0] T3 A Data Low Byte NOTES: Do not write "0000H" in the T3ADRH/T3ADRL register when PPG mode ### T3BDRH (Timer 3 B Data High Register): 1004H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | T3BDRH7 | T3BDRH6 | T3BDRH5 | T3BDRH4 | T3BDRH3 | T3BDRH2 | T3BDRH1 | T3BDRH0 | | R/W T3 B Data High Byte Initial value: FFH T3BDRH[7:0] ### T3BDRL (Timer 3 B Data Low Register): 1005H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | T3BDRL7 | T3BDRL6 | T3BDRL5 | T3BDRL4 | T3BDRL3 | T3BDRL2 | T3BDRL1 | T3BDRL0 | | R/W Initial value: FFH T3BDRL[7:0] T3 B Data Low Byte # T3CRH (Timer 3 Control High Register): 1000H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|-------|-------|---|---|---|------| | T3EN | _ | T3MS1 | T3MS0 | _ | _ | _ | T3CC | | RW | - | R/W | RW | - | - | - | RW | Initial value: 00H | T3EN | Control <sup>-</sup> | Timer 3 | | | | | |-----------|----------------------|-----------------------------------------------------------------------------------------------|------------------------------------------------|--|--|--| | | 0 | Timer 3 | disable | | | | | | 1 | Timer 3 enable (Counter clear and start) | | | | | | T3MS[1:0] | Control <sup>-</sup> | Timer 3 Operation Mode | | | | | | | T3MS1 | T3MS0 | Description | | | | | | 0 | 0 | Timer/counter mode (T3O: toggle at A match) | | | | | | 0 | 1 | Capture mode (The A match interrupt can occur) | | | | | | 1 | 0 | PPG one-shot mode (PWM3O) | | | | | | 1 | 1 | PPG repeat mode (PWM3O) | | | | | T3CC | Clear Tir | mer 3 Cou | nter | | | | | | 0 | No effec | t | | | | | | 1 | Clear the Timer 3 counter (When write, automatically cleared "0" after being cleared counter) | | | | | # T3CRL (Timer 3 Control Low Register): 1001H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|---|-------|-------|--------| | T3CK2 | T3CK1 | T3CK0 | T3IFR | _ | T3POL | T3ECE | T3CNTR | | R/W | R/W | R/W | R/W | _ | RW | RW | RW | | | | | | | Initial value: 00H | | | | |-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-------------|---------------------------------------|--------------------|--|--|--| | T3CK[2:0] | Select T | imer 3 cl | ock sour | ce. fx is main system clock frequency | | | | | | | T3CK2 | T3CK<br>1 | T3CK<br>0 | 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 (EC3) | | | | | | T3IFR | When T3 Interrupt occurs, this bit becomes '1'. For clearing bit, write '0' to this bit or auto clear by INT_ACK signal. Writing "1" has no effect. | | | | | | | | | | 0 | 0 T3 Interrupt no generation | | | | | | | | | 1 | T3 Inte | rrupt ger | neration | | | | | | T3POL | T3O/PW | /M3O Po | larity Sel | ection | | | | | | | 0 | Start H | igh (T3O | /PWM3O is low level at disable) | | | | | | | 1 | Start Lo | ow (T3O/ | /PWM3O is high level at disable) | | | | | | T3ECE | Timer 3 | External | Clock Ed | dge Selection | | | | | | | 0 | Externa | al clock fa | alling edge | | | | | | | 1 | Externa | al clock ri | ising edge | | | | | T3CNTR Timer 3 Counter Read Control 0 No effect Load the counter value to the B data register (When write, automatically cleared "0" after being loaded) ### 11.5 Timer 4 #### 11.5.1 Overview The 16-bit TIMER 4 consists of multiplexer, timer 4 A data high/low register, timer 4 B data high/low register and timer 4 control high/low register (T4ADRH, T4ADRH, T4BDRH, T4BDRH, T4CRH, and T4CRL). 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 can be divided clock of the system clock selected from prescaler output and T3 A Match (timer 3 A match signal). The clock source is selected by clock selection logic which is controlled by the clock selection bits (T4CK[2:0]). TIMER 4 clock source: fx/1, fx/2, fx/4,fx/8,fx/32, fx/128, fx/512 and T3 A Match In the capture mode, by EINT4, the data is captured into input capture data register (T4BDRH/T4BDRL). In timer/counter mode, whenever counter value is equal to T4ADRH/L, T4O port toggles. Also the TIMER 4 outputs PWM wave form to PWM4O port in the PPG mode. Table 23. TIMER 4 Operating Modes | T4EN | P0FSRH[5:4] | T4MS[1:0] | T4CK[2:0] | TIMER 4 | |------|-------------|-----------|-----------|---------------------------------| | 1 | 11 | 00 | XXX | 16-bit Timer/Counter Mode | | 1 | 00 | 01 | XXX | 16-bit Capture Mode | | 1 | 11 | 10 | XXX | 16-bit PPG Mode (one-shot mode) | | 1 | 11 | 11 | XXX | 16-bit PPG Mode (repeat mode) | #### 11.5.2 16-bit Timer/Counter Mode The 16-bit timer/counter mode is selected by control register as shown in Figure 59. The 16-bit timer have counter and data register. The counter register is increased by internal or timer 3 A match clock input. Timer 4 can use the input clock with one of 1, 2, 4, 8, 32, 128, 512 and T3 A Match prescaler division rates (T4CK[2:0]). When the values of T4CNTH/T4CNTL and T4ADRH/T4ADRL are identical in timer 4, a match signal is generated and the interrupt of Timer 4 occurs. The T4CNTH/T4CNTL values are automatically cleared by match signal. It can be also cleared by software (T4CC). Figure 59. 16-bit Timer/Counter Mode for Timer 4 Figure 60. 16-bit Timer/Counter 4 Example ### 11.5.3 16-bit Capture Mode The timer 4 capture mode is set by T4MS[1:0] as '01'. The clock source can use the internal clock. Basically, it has the same function as the 16-bit timer/counter mode and the interrupt occurs when T4CNTH/T4CNTL is equal to T4ADRH/T4ADRL. T4CNTH/T4CNTL values are automatically cleared by match signal and it can be also cleared by software (T4CC). 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 T4BDRH/T4BDRL. In the timer 4 capture mode, timer 4 output (T4O) waveform is not available. Figure 61. 16-bit Capture Mode for Timer 4 Figure 62. Input Capture Mode Operation for Timer 4 Figure 63. Express Timer Overflow in Capture Mode #### 11.5.4 16-bit PPG Mode The timer 4 has a PPG (Programmable Pulse Generation) function. In PPG mode, the T4O/PWM4O pin outputs up to 16-bit resolution PWM output. This pin should be configured as a PWM output by set P0FSRH[5:4] to '11'. The period of the PWM output is determined by the T4ADRH/T4ADRL. And the duty of the PWM output is determined by the T4BDRH/T4BDRL. Figure 64. 16-bit PPG Mode for Timer 4 Figure 65. 16-bit PPG Mode Timming chart for Timer 4 ## 11.5.5 Block Diagram Figure 66. 16-bit Timer 4 Block Diagram ### 11.5.6 Register Map | Name | Address | Direction | Default | Description | |--------|---------|-----------|---------|-------------------------------| | T4ADRH | 100AH | R/W | FFH | Timer 4 A Data High Register | | T4ADRL | 100BH | R/W | FFH | Timer 4 A Data Low Register | | T4BDRH | 100CH | R/W | FFH | Timer 4 B Data High Register | | T4BDRL | 100DH | R/W | FFH | Timer 4 B Data Low Register | | T4CRH | 1008H | R/W | 00H | Timer 4 Control High Register | | T4CRL | 1009H | R/W | 00H | Timer 4 Control Low Register | Table 24. Timer 4 Register Map ## 11.5.7 Timer/Counter 4 Register Description The timer/counter 4 register consists of timer 4 A data high register (T4ADRH), timer 4 A data low register (T4ADRL), timer 4 B data high register (T4BDRH), timer 4 B data low register (T4BDRL), timer 4 control high register (T4CRH) and timer 4 control low register (T4CRL). ### 11.5.8 Register Description for Timer/Counter 4 ## T4ADRH (Timer 4 A Data High Register): 100AH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | T4ADRH7 | T4ADRH6 | T4ADRH5 | T4ADRH4 | T4ADRH3 | T4ADRH2 | T4ADRH1 | T4ADRH0 | | R/W Initial value: FFH T4ADRH[7:0] T4 A Data High Byte ### T4ADRL (Timer 4 A Data Low Register): 100BH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | T4ADRL7 | T4ADRL6 | T4ADRL5 | T4ADRL4 | T4ADRL3 | T4ADRL2 | T4ADRL1 | T4ADRL0 | | R/W Initial value: FFH T4ADRL[7:0] T4 A Data Low Byte NOTES: Do not write "0000H" in the T4ADRH/T4ADRL register when PPG mode. ## T4BDRH (Timer 4 B Data High Register): 100CH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------------| | T4BDRH7 | T4BDRH6 | T4BDRH5 | T4BDRH4 | T4BDRH3 | T4BDRH2 | T4BDRH1 | T4BDRH0 | | R/W | | | | | | | Initi | al value: FFH | miliai vai T4BDRH[7:0] T4 B Data High Byte ## T4BDRL (Timer 4 B Data Low Register): 100DH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | T4BDRL7 | T4BDRL6 | T4BDRL5 | T4BDRL4 | T4BDRL3 | T4BDRL2 | T4BDRL1 | T4BDRL0 | | R/W Initial value: FFH T4BDRL[7:0] T4 B Data Low ### T4CRH (Timer 4 Control High Register): 1008H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|-------|-------|---|---|---|------| | T4EN | _ | T4MS1 | T4MS0 | _ | _ | _ | T4CC | | RW | - | R/W | RW | - | - | - | RW | Initial value: 00H T4EN Control Timer 4 0 Timer 4 disable 1 Timer 4 enable (Counter clear and start) T4MS[1:0] Control Timer 4 Operation Mode T4MS0 Description T4MS1 0 0 Timer/counter mode (T4O: toggle at A match) 0 1 Capture mode (The A match interrupt can occur) 1 0 PPG one-shot mode (PWM4O) 1 PPG repeat mode (PWM4O) T4CC Clear Timer 4 Counter 0 No effect 1 Clear the Timer 4 counter (When write, automatically ### T4CRL (Timer 4 Control Low Register): 1009H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|---|-------|---|--------| | T4CK2 | T4CK1 | T4CK0 | T4IFR | _ | T4POL | _ | T4CNTR | | R/W | R/W | R/W | R/W | - | RW | - | RW | cleared "0" after being cleared counter) Initial value: 00H | T4CK[2:0] | Select T | imer 4 clo | ck source. | fx is main system clock frequency | |-----------|----------|------------|--------------|----------------------------------------------------------------------| | | T4CK2 | T4CK1 | T4CK0 | Description | | | 0 | 0 | 0 | fx/512 | | | 0 | 0 | 1 | fx/128 | | | 0 | 1 | 0 | fx/32 | | | 0 | 1 | 1 | fx/8 | | | 1 | 0 | 0 | fx/4 | | | 1 | 0 | 1 | fx/2 | | | 1 | 1 | 0 | fx/1 | | | 1 | 1 | 1 | T3 A Match | | T4IFR | | | • | curs, this bit becomes '1'. For clearing bit,<br>" has no effect. | | | 0 | T4 inter | rupt no ger | neration | | | 1 | T4 inter | rupt genera | ation | | T4POL | T4O/PW | /M4O Pola | arity Select | tion | | | 0 | Start Hig | gh (T4O/P\ | WM4O is low level at disable) | | | 1 | Start Lo | w (T4O/PV | VM4O is high level at disable) | | T4CNTR | Timer 4 | Counter F | Read Contr | rol | | | 0 | No effec | t | | | | 1 | | | value to the B data register (When write, automatically eing loaded) | #### 11.6 Timer 5 #### 11.6.1 Overview The 16-bit TIMER 5 consists of multiplexer, timer 5 A data high/low register, timer 5 B data high/low register and timer 5 control high/low register (T5ADRH, T5ADRH, T5BDRH, T5BDRH, T5CRH, and T5CRL). 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 5 can be divided clock of the system clock selected from prescaler output. The clock source is selected by clock selection logic which is controlled by the clock selection bits (T5CK[2:0]). TIMER 5 clock source: fx/1, fx/2, fx/4,fx/8,fx/32, fx/128, fx/512 and HSIRC In the capture mode, by EINT5, the data is captured into input capture data register (T5BDRH/T5BDRL). In timer/counter mode, whenever counter value is equal to T5ADRH/L, T5O port toggles. Also the TIMER 5 outputs PWM wave form to PWM5O port in the PPG mode. Table 25. TIMER 5 Operating Modes | T5EN | P0FSRH[5:4] | T5MS[1:0] | T5CK[2:0] | TIMER 5 | |------|-------------|-----------|-----------|---------------------------------| | 1 | 11 | 00 | XXX | 16-bit Timer/Counter Mode | | 1 | 00 | 01 | XXX | 16-bit Capture Mode | | 1 | 11 | 10 | XXX | 16-bit PPG Mode (one-shot mode) | | 1 | 11 | 11 | XXX | 16-bit PPG Mode (repeat mode) | #### 11.6.2 16-bit Timer/Counter Mode The 16-bit timer/counter mode is selected by control register as shown in Figure 70. The 16-bit timer have counter and data register. The counter register is increased by internal clock input. Timer 5 can use the input clock with one of 1, 2, 4, 8, 32, 128, 512 and High Frequency Internal Oscillator (HSIRC) prescaler division rates (T5CK[2:0]). When the values of T5CNTH/T5CNTL and T5ADRH/T5ADRL are identical in timer 5, a match signal is generated and the interrupt of Timer 5 occurs. The T5CNTH/T5CNTL values are automatically cleared by match signal. It can be also cleared by software (T5CC). Figure 67. 16-bit Timer/Counter Mode for Timer 5 Figure 68. 16-bit Timer/Counter 4 Example #### 11.6.3 16-bit Capture Mode The timer 5 capture mode is set by T5MS[1:0] as '01'. The clock source can use the internal clock. Basically, it has the same function as the 16-bit timer/counter mode and the interrupt occurs when T5CNTH/T5CNTL is equal to T5ADRH/T5ADRL. T5CNTH/T5CNTL values are automatically cleared by match signal and it can be also cleared by software (T5CC). 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 T5BDRH/T5BDRL. In the timer 5 capture mode, timer 5 output (T5O) waveform is not available. Figure 69. 16-bit Capture Mode for Timer 5 Figure 70. Input Capture Mode Operation for Timer 5 Figure 71. Express Timer Overflow in Capture Mode A96T418 User's manual 11. Timer 0/1/2/3/4/5 ### 11.6.4 16-bit PPG Mode The timer 5 has a PPG (Programmable Pulse Generation) function. In PPG mode, the T5O/PWM5O pin outputs up to 16-bit resolution PWM output. This pin should be configured as a PWM output by set P0FSRH[7:6] to '11'. The period of the PWM output is determined by the T5ADRH/T5ADRL. And the duty of the PWM output is determined by the T5BDRH/T5BDRL. Figure 72. 16-bit PPG Mode for Timer 5 11. Timer 0/1/2/3/4/5 A96T418 User's manual Figure 73. 16-bit PPG Mode Timming chart for Timer 5 A96T418 User's manual 11. Timer 0/1/2/3/4/5 ## 11.6.5 Block Diagram Figure 74. 16-bit Timer 5 Block Diagram ## 11.6.6 Register Map Table 26. Timer 5 Register Map | Name | Address | Direction | Default | Description | | | |--------|---------------|--------------|------------------------------|-------------------------------|--|--| | T5ADRH | 1012H | R/W | FFH | Timer 5 A Data High Register | | | | T5ADRL | 1013H | 013H R/W FFH | | Timer 5 A Data Low Register | | | | T5BDRH | | | Timer 5 B Data High Register | | | | | T5BDRL | | | FFH | Timer 5 B Data Low Register | | | | T5CRH | 1010H R/W 00H | | 00H | Timer 5 Control High Register | | | | T5CRL | 1011H | R/W | 00H | Timer 5 Control Low Register | | | 11. Timer 0/1/2/3/4/5 A96T418 User's manual ## 11.6.7 Timer/Counter 5 Register Description The timer/counter 5 register consists of timer 5 A data high register (T5ADRH), timer 5 A data low register (T5ADRL), timer 5 B data high register (T5BDRH), timer 5 B data low register (T5BDRL), timer 5 control high register (T5CRH) and timer 5 control low register (T5CRL). ## 11.6.8 Register Description for Timer/Counter 5 ## T5ADRH (Timer 5 A Data High Register): 1012H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |--------------------|---------|---------|---------|---------|---------|---------|---------|--|--| | T5ADRH7 | T5ADRH6 | T5ADRH5 | T5ADRH4 | T5ADRH3 | T5ADRH2 | T5ADRH1 | T5ADRH0 | | | | R/W | | | Initial value: FFH | | | | | | | | | | T5ADRH[7:0] T5 A Data High Byte T5ADRL (Timer 5 A Data Low Register): 1013H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | T5ADRL7 | T5ADRL6 | T5ADRL5 | T5ADRL4 | T5ADRL3 | T5ADRL2 | T5ADRL1 | T5ADRL0 | | R/W Initial value: FFH T5ADRL[7:0] T5 A Data Low Byte NOTES: T5 B Data High Byte Do not write "0000H" in the T5ADRH/T5ADRL register when PPG mode. ### T5BDRH (Timer 5 B Data High Register): 1014H | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------------------|---------|---------|---------|---------|---------|---------|---------|---------|--| | | T5BDRH7 | T5BDRH6 | T5BDRH5 | T5BDRH4 | T5BDRH3 | T5BDRH2 | T5BDRH1 | T5BDRH0 | | | • | R/W | | Initial value: FFI | | | | | | | | | | Illitial value. I T5BDRL (Timer 5 B Data Low Register): 1015H T5BDRH[7:0] | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | T5BDRL7 | T5BDRL6 | T5BDRL5 | T5BDRL4 | T5BDRL3 | T5BDRL2 | T5BDRL1 | T5BDRL0 | | R/W Initial value: FFH T5BDRL[7:0] T5 B Data Low Byte A96T418 User's manual 11. Timer 0/1/2/3/4/5 # T5CRH (Timer 5 Control High Register): 1010H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|-------|-------|---|---|---|------| | T5EN | _ | T5MS1 | T5MS0 | _ | 1 | 1 | T5CC | | RW | - | R/W | RW | - | - | - | RW | Initial value: 00H | T5EN | Control 7 | Γimer 5 | | | | | |-----------|-----------|-----------------------------------------------------------------------------------------------|------------------------------------------------|--|--|--| | | 0 | Timer 5 | disable | | | | | | 1 | Timer 5 | enable (Counter clear and start) | | | | | T5MS[1:0] | Control 7 | Γimer 5 Ope | eration Mode | | | | | | T5MS1 | T5MS0 | Description | | | | | | 0 | 0 | Timer/counter mode (T5O: toggle at A match) | | | | | | 0 | 1 | Capture mode (The A match interrupt can occur) | | | | | | 1 | 0 | PPG one-shot mode (PWM5O) | | | | | | 1 | 1 | PPG repeat mode (PWM5O) | | | | | T5CC | Clear Tir | ner 5 Coun | ter | | | | | | 0 | No effect | t | | | | | | 1 | 1 Clear the Timer 5 counter (When write, automatical cleared "0" after being cleared counter) | | | | | | | | | , | | | | # T5CRL (Timer 5 Control Low Register): 1011H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---------|-------|-------|---|-------|---|--------| | T5CK | 2 T5CK1 | T5CK0 | T5IFR | _ | T5POL | _ | T5CNTR | | R/W | R/W | R/W | R/W | _ | RW | - | RW | | R/W | R/W | R/W | R | /W | - | RW | _ | RW | | | |--------------------------------------------------------------------------------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|------------|-----------------|------------------|---------|--------------|--|--| | | | | | | | | Initial | value: 00H | | | | | T5CK[2:0] | Select Ti | mer 5 clo | ck source. | fx is main syst | tem clock freque | ency | | | | | | | T5CK2 | T5CK1 | T5CK0 | Description | | | | | | | | | 0 | 0 | 0 | fx/512 | | | | | | | | | 0 | 0 | 1 | fx/128 | | | | | | | | | 0 | 1 | 0 | fx/32 | | | | | | | | | 0 | 1 | 1 | fx/8 | | | | | | | | | 1 | 0 | 0 | fx/4 | | | | | | | | | 1 | 0 | 1 | fx/2 | | | | | | | | | 1 | 1 | 0 | fx/1 | | | | | | | | | 1 | 1 | 1 | HSIRC Direc | ct (16MHz) | | | | | | | T5IFR | When T5 Match Interrupt occurs, this bit becomes '1'. For clearing bit, write '0' to this bit. Writing "1" has no effect. | | | | | | | | | | | | 0 | T5 interrupt no generation | | | | | | | | | | | 1 | T5 interr | upt genera | ation | | | | | | | | T5POL | T5O/PW | M5O Pola | rity Selec | tion | | | | | | | | | 0 | Start Hig | h (T5O/P) | WM5O is low le | evel at disable) | | | | | | | | 1 | Start Low (T5O/PWM5O is high level at disable) | | | | | | | | | | T5CNTR | Timer 5 ( | Counter Read Control | | | | | | | | | | | 0 | No effect | t | | | | | | | | 1 Load the counter value to the B data register (When write, autocleared "0" after being loaded) | | | | | | | | utomatically | | | 12. Buzzer Driver A96T418 User's manual # 12 Buzzer Driver ## 12.1 Overview The Buzzer consists of 8bit counter, buzzer data register (BUZDR), and buzzer control register (BUZCR). The Square Wave (61.035Hz~125.0kHz @8MHz) is outputted through P03/AN1/EINT1BUZ0 pin. The buzzer data register (BUZDR) controls the buzzer frequency (look at the following expression). In buzzer control register (BUZCR), BUCK[1:0] selects source clock divided by prescaler. Table 27. Buzzer Frequency at 8 MHz $$f_{BUZ}(Hz) = \frac{\text{Oscillator Frequency}}{2 \times \text{Prescaler Ratio} \times (BUZDR + 1)}$$ | DUZDD[7.0] | Buzzer Frequency (kHz) | | | | | | | | |---------------------|------------------------|---------------|---------------|---------------|--|--|--|--| | BUZDR[7:0] | BUZCR[2:1]=00 | BUZCR[2:1]=01 | BUZCR[2:1]=10 | BUZCR[2:1]=11 | | | | | | 0000_0000 | 125kHz | 62.5kHz | 31.25kHz | 15.625kHz | | | | | | 0000_0001 62.5kHz | | 31.25kHz | 15.625kHz | 7.812kHz | | | | | | | | | | | | | | | | 1111_1101 | 492.126Hz | 246.063Hz | 123.031Hz | 61.515Hz | | | | | | 1111_1110 490.196Hz | | 245.098Hz | 122.549Hz | 61.274Hz | | | | | | 1111_1111 | 488.281Hz | 244.141Hz | 122.07Hz | 61.035Hz | | | | | ## 12.2 Block Diagram Figure 75. Buzzer Driver Block Diagram A96T418 User's manual 12. Buzzer Driver ## 12.3 Register Map Table 28. Buzzer Driver Register Map | Name | Name Address | | Default | Description | |-------|--------------|-----|---------|-------------------------| | BUZDR | 8FH | R/W | FFH | Buzzer Data Register | | BUZCR | 97H | R/W | 00H | Buzzer Control Register | # 12.4 Buzzer Driver Register Description Buzzer driver consists of buzzer data register (BUZDR) and buzzer control register (BUZCR). ## 12.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 | 1 | 6 | 5 | 4 | 3 | 2 | 1 | U | |---|---|---|---|---|-------|-------|-------| | - | ı | _ | _ | _ | BUCK1 | BUCK0 | BUZEN | | - | - | - | - | _ | RW | RW | RW | Initial value: 00H | BUCK[1:0] | Buzzer D | Priver Sour | ce Clock Selection | |-----------|----------|-------------|--------------------| | | BUCK1 | BUCK0 | Description | | | 0 | 0 | fx/32 | | | 0 | 1 | fx/64 | | | 1 | 0 | fx/128 | | | 1 | 1 | fx/256 | | BUZEN | Buzzer D | Oriver Oper | ation Control | | | 0 | Buzzer D | river disable | | | 1 | Buzzer D | river enable | ### NOTES: 1. fx: System clock oscillation frequency. # 13 USI (USART + SPI + I2C) ## 13.1 Overview The USI is an acronym of USART, SPI and I2C, A96T418 has two USI function blocks. Each USI consists of USI control register1/2/3/4, USI status register 1/2, USI baud-rate generation register, USI data register, USI SDA hold time register, USI SCL high period register, USI SCL low period register, and USI slave address register (USInCR1, USInCR2, USInCR3, USInCR4, USInST1, USInST2, USInBD, USInDR, where n is 0, and USInSDHR, USInSCHR, USInSCLR, USInSAR where n is only 0). The operation mode is selected by the operation mode of USIn selection bits (USInMS[1:0]). It has four operating modes: - Asynchronous mode (UART) - Synchronous mode (USART) - SPI mode - I2C mode ## 13.2 USIn UART Mode 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 - 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 are Supported by Hardware - Data OverRun Detection - Framing Error Detection - Three Separate Interrupts on TX Completion, TX Data Register Empty and RX Completion - Double Speed Asynchronous communication mode The USIn comprises clock generator, transmitter and receiver. The clock generation logic consists of synchronization logic for external clock input used by synchronizing 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 continuous transfer of data without any delay between frames. The receiver is the most complex part of the UART 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 (USInDR) and control logic. The receiver supports the same frame formats as the transmitter and can detect frame error, data overrun and parity errors. # 13.3 USIn UART Block Diagram Figure 76. USIn USART Block Diagram(n = 0, 1) ## 13.4 USIn Clock Generation Figure 77. Clock Generation Block Diagram (USIn) The clock generation logic generates the base clock for the transmitter and receiver. The USIn supports fourmodes of clock operationand those are normal asynchronous, double speed asynchronous, master synchronous and slave synchronous mode. The clock generation scheme for master SPI and slave SPI mode is the same as master synchronous and slave synchronous operation mode. The USInMS[1:0] bits in USInCR1 register selects asynchronous or synchronous operation. Asynchronous double speed mode is controlled by the DBLSn bit in the USInCR2 register. The MASTERn bit in USInCR3 register controls whether the clock source is internal (master mode, output pin) or external (slave mode, input pin). The SCKn pin is active only when the USIn operates in synchronous or SPI mode. Following table shows the equations for calculating the baud rate (in bps). Table 29. Equations for Calculating USIn Baud Rate Register Setting | Operating Mode | Equation for Calculating Baud Rate | | | |------------------------------------------|-----------------------------------------|--|--| | Asynchronous Normal Mode (DBLSn=0) | Baud Rate = $\frac{fx}{16(USInBD + 1)}$ | | | | Asynchronous Double Speed Mode (DBLSn=1) | Baud Rate = $\frac{fx}{8(USInBD + 1)}$ | | | | Synchronous or SPI Master Mode | Baud Rate = $\frac{fx}{2(USInBD + 1)}$ | | | ## 13.5 USIn External Clock (SCKn) External clocking is used in the synchronous mode of operation. External clock input from the SCKn pin is sampled by a synchronization logic to remove meta-stability. The output from the synchronization logic must be passed through an edge detector before it is used by the transmitter and receiver. This process introduces two CPU clock period delay. The maximum frequency of the external SCKn pin is limited up-to 1MHz. ## 13.6 USIn Synchronous mode operation When synchronous or SPI mode is used, the SCKn pin will be used as either clock input (slave) or clock output (master). Data sampling and transmitter is issued on the different edge of SCKn clock each other. For example, if data input on RXDn (MISOn in SPI mode) pin is sampled on the rising edge of SCKn clock, data output on TXDn (MOSIn in SPI mode) pin is altered on the falling edge. The CPOLn bit in USInCR1 register selects which SCKn clock edge is used for data sampling and which is used for data change. As shown in the figure below, when CPOLn is zero, the data will be changed at rising SCKn edge and sampled at falling SCKn edge. Figure 78. Synchronous Mode SCKn Timing (USIn) ## 13.7 USIn UART 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 detection. 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 nine, are succeeding, ending with the most significant bit (MSB). If parity function is enabled, the parity bit is inserted between the last data bit and the stop bit. 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 following figure shows the possible combinations of the frame formats. Bits inside brackets are optional. Figure 79. Frame Format (USIn) 1 data frame consists of the following bits Idle No communication on communication line (TXDn/RXDn) 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 UART is set by the USInS[2:0], USInPM[1:0] bits in USInCR1 register and USInSB bit in USInCR3 register. The transmitter andreceiver use the same figures. ## 13.8 USIn UART 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 the MSB and first stop bit of a serial frame. $$P_{even} = D_{n-1} ^ ... ^ D_3 ^ D_2 ^ D_1 ^ D_0 ^ 0$$ $$P_{odd} = D_{n-1} ^{\land} ... ^{\land} D_3 ^{\land} D_2 ^{\land} D_1 ^{\land} D_0 ^{\land} 1$$ Peven: Parity bit using even parity Podd : Parity bit using odd parity D<sub>n</sub> : Data bit n of the character ## 13.9 USIn UART Transmitter The UART transmitter is enabled by setting the TXEn bit in USInCR2 register. When the Transmitter is enabled, the TXDn pin should be set to TXDn function for the serial output pin of UART by the P1FSRH[7:6], P1FSRL[3:2], P0FSRL[5:4] and P0FSRL[1:0]. The baud-rate, operation mode and frame format must be set up once before doing any transmission. In synchronous operation mode, the SCKn pin is used as transmission clock, so it should be selected to do SCKn function by P1FSRH[3:2] and P0FSRL[7:6]. ## 13.9.1 USIn UART Sending TX data A data transmission is initiated by loading the transmit buffer (USInDRregister I/O location) with the data to be transmitted. The data be 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 according to the settings of control registers. If the 9-bit characters are used in asynchronous or synchronous operation mode, the ninth bit must be written to the USInTX8 bit in USInCR3 register before it is loaded to the transmit buffer (USInDR register). ## 13.9.2 USIn UART Transmitter flag and interrupt The USART transmitter has two flags which indicate its state. One is USART data register empty flag (DREn) and the other is transmit completion flag (TXCn). Both flags can be interrupt sources. DREn flag indicates whether the transmit buffer is ready to receive new data. This bit is set when the transmit buffer is empty and cleared when the transmit buffer contains data to be transmitted but 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 prevented prohibited. When the data register empty interrupt enable (DRIEn) bit in USInCR2 register is set and the global interrupt is enabled, USInST1 status register empty interrupt is generated while DREn flag is set. The transmit complete (TXCn) flag bit is set when the entire frame in the transmit shift register has been shifted out and there is no more data in the transmit buffer. The TXCn flag is automatically cleared when the transmit complete interrupt serve routine is executed, or it can be cleared by writing '0' to TXCn bit in USInST1 register. When the transmit complete interrupt enable (TXCIEn) bit in USInCR2 register is setand the global interrupt is enabled, UART transmit complete interrupt is generated while TXCn flag is set. ### 13.9.3 USIn UART Parity Generator The parity generator calculates the parity bit for the serial frame data to be sent. When parity bit is enabled (USInPM1=1), the transmitter control logic inserts the parity bit between the MSB and the first stop bit of the frame to be sent. ### 13.9.4 USIn UART Disabling Transmitter Disabling the transmitter by clearing the TXEn bit will not become effective until ongoing transmission is completed. When the Transmitter is disabled, the TXDn pin can be used as a normal general purpose I/O (GPIO). ## 13.10 USIn UART Receiver The USART receiver is enabled by setting the RXEn bit in the USInCR2 register. When the receiver is enabled, the RXDn pin should be set to RXDn function for the serial input pin of UART by P1FSRH[5:4], P1FSRL[1:0], P0FSRL[3:2] and P3FSR[3:2]. The baud-rate, mode of operation and frame format must be set before serial reception. In synchronous or SPI operation mode the SCKn pin is used as transfer clock input, so it should be selected to do SCKn function by P1FSRH[3:2] and P0FSRL[7:6]. In SPI operation mode the SSn input pin in slave mode or can be configured as SSn output pin in master mode. This can be done by setting USInSSEN bit in USInCR3 register. ## 13.10.1 USIn UART Receiving RX data When UART is in synchronous or asynchronous operation mode, the receiver starts data reception when it detects a valid start bit (LOW) on RXD0 pin. Each bit after start bit is sampled at pre-defined baud-rate (asynchronous) or sampling edge of SCKn (synchronous), and shifted into the receive shift register until the first stop bit of a frame is received. Even if there's the second stop bit in the frame, the second stop bit is ignored by the receiver. That is, receiving the first stop bit means that a complete serial frame is presented 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 USInDR register. If 9-bit characters are used (USInS[2:0] = "111"), the ninth bit is stored in the USInRX8 bit position in the USInCR3 register. The nineth bit must be read from the USInRX8 bit before reading the low 8 bits from the USInDR register. Likewise, the error flags FEn, DORn, PEn must be read before reading the data from USInDR register. It's because the error flags are stored in the same FIFO position of the receive buffer. ### 13.10.2 USIn UART Receiver Flag and Interrupt The UARTreceiver has one flag that indicates the receiver state. The receive complete (RXCn) flag indicates whether there are unread data in the receive buffer. This flag is set when there is unread data in the receive buffer and cleared when the receive buffer is empty. If the receiver is disabled (RXEn=0), the receiver buffer is flushed and the RXCn flag is cleared. When the receive complete interrupt enable (RXCIEn) bit in the USInCR2 register is set and global interrupt is enabled, the UART receiver complete interrupt is generated while RXCn flag is set. The UART receiver has three error flags which are frame error (FEn), data overrun (DORn) and parity error (PEn). These error flags can be read from the USInST1 register. As received datas 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 USInDR register, read the USInST1 register first which contains error flags. The frame error (FEn) flag indicates the state of the first stop bit. The FEn flag is '0' when the stop bit was correctly detected as "1", and the FEn flag is "1" when the stop bit was incorrect, i.e. detected as "0". This flag can be used for detecting out-of-sync conditions between data frames. The data overrun (DORn) flag indicates data loss due to a receive buffer full condition. DORn occurs when the receive buffer is full, and another new data is presented in the receive shift register which are to be stored into the receive buffer. After the DORn flag is set, all the incoming data are lost. To avoid data loss or clear this flag, read the receive buffer. The parity error (PEn) flag indicates that the frame in the receive buffer had a parity error when received. If parity check function is not enabled (USInPM1=0), the PE bit is always read "0". ### 13.10.3 USIn UART Parity Checker If parity bit is enabled (USInPM1=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. ### 13.10.4 USIn UART Disabling Receiver In contrast to transmitter, disabling the Receiver by clearing RXEn bit makes the Receiver inactive immediately. When the receiver is disabled, the receiver flushes the receive buffer, the remaining data in the buffer is all reset, and the RXDn pin can be used as a normal general purpose I/O (GPIO). ### 13.10.5 USIn Asynchronous Data Reception To receive asynchronous data frame, the UART 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 RXDn pin. The data recovery logic does sampling and low pass filtering the incoming bits, and removing the noise of RXDn pin. The next figure illustrates the sampling process of the start bit of an incoming frame. The sampling rate is 16 times of the baud-rate in normal mode and 8 times the baud-rate for double speed mode (DBLSn=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 80. Asynchronous Start Bit Sampling (USIn) When the receiver is enabled (RXEn=1), the clock recovery logic tries to find a high-to-low transition on the RXDn line, the start bit condition. After detecting high to low transition on RXDn line, the clock recovery logic uses samples 8, 9 and 10 for normal 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 same 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. If more than 2 samples have low levels, the received bit is considered to a logic '0' and if 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 81. Asynchronous Sampling of Data and Parity Bit (USIn) The process for detecting stop bit is same as 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 (FEn) flag is set. After deciding whether the first stop bit is valid or not, the Receiver goes to idle state and monitors the RXDn line to check a valid high to low transition is detected (start bit detection). Figure 82. Stop Bit Sampling and Next Start Bit Sampling (USIn) ## 13.11 USIn SPI Mode The USIn 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 - Mater and Slave Operation - Supports all four SPIn modes of operation (mode 0, 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 (USInMS[1:0]="11"), the slave select (SSn) pin becomes active LOW input in slave mode operation, or can be output in master mode operation if USInSSEN bit is set to '0'. Note that during SPI mode of operation, the pin RXDn is renamed as MISOn and TXDn is renamed as MOSIn for compatibility to other SPI devices. ## 13.12 USIn SPI Clock Formats and Timing To accommodate a wide variety if synchronous serial peripherals from different manufacturers, the USIn has a clock polarity bit (CPOLn) and a clock phase control bit (CPHAn) to select one of four clock formats for data transfers. CPOLn selectively insert an inverter in series with the clock. CPHAn chooses between two different clock phase relationships between the clock and data. Note that CPHAn and CPOLn bits in USInCR1 register have different meanings according to the USInMS[1:0] bits which decides the operating mode of USIn. Table below shows four combinations of CPOLn and CPHAn for SPI mode 0, 1, 2, and 3. Table 30. CPOLn Functionality | SPI Mode | CPOLn | CPHAn | 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) | Figure 83. USIn SPI Clock Formats when CPHAn=0 When CPHAn=0, the slave begins to drive its MISOn output with the first data bit value when SSn goes to active low. The first SCKn edge causes both the master and the slave to sample the data bit value on their MISOn and MOSIn inputs, respectively. At the second SCKn edge, the USIn shifts the second data bit value out to the MOSIn and MISOn outputs of the master and slave, respectively. Unlike the case of CPHAn=1, when CPHAn=0, the slave's SSn 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 SSn input. Figure 84. USIn SPI Clock Formats when CPHAn=1 When CPHAn=1, the slave begins to drive its MISOn output when SSn goes active low, but the data is not defined until the first SCKn edge. The first SCKn edge shifts the first bit of data from the shifter onto the MOSIn output of the master and the MISOn output of the slave. The next SCKn edge causes both the master and slave to sample the data bit value on their MISOn and MOSIn inputs, respectively. At the third SCKn edge, the USIn shifts the second data bit value out to the MOSIn and MISOn output of the master and slave respectively. When CPHAn=1, the slave's SSn input is not required to go to its inactive high level between transfers. Because the SPI logic reuses the USIn resources, SPI mode of operation is similar to that of synchronous or asynchronous operation. An SPI transfer is initiated by checking for the USIn Data Register Empty flag (DREn=1) and then writing a byte of data to the USInDR Register. In master mode of operation, even if transmission is not enabled (TXEn=0), writing data to the USInDR register is necessary because the clock SCKn is generated from transmitter block. # 13.13 USIn SPI Block Diagram Figure 85. USIn SPI Block Diagram(n = 0, 1) ## 13.14 USIn I2C Mode The USIn can be set to operate in industrial standard serial communication protocols mode. The I2C mode uses 2 bus lines serial data line (SDAn) and serial clock line (SCLn) to exchange data. Because both SDAn and SCLn lines are open-drain output, each line needs pull-up resistor. A96T418 supports only one I2C, so n=0. The features are as shown below. - Compatible with I2C bus standard - Multi-master operation - Up to 400kHz data transfer read speed - 7 bit address - · Both master and slave operation - Bus busy detection - I2C Slave mode does not support repeated START bit mode ## 13.15 USIn I2C Bit Transfer The data on the SDAn line must be stable during HIGH period of the clock, SCLn. The HIGH or LOW state of the data line can only change when the clock signal on the SCLn 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 86. Bit Transfer on the I2C-Bus (USIn) ## 13.16 USIn I2C Start / Repeated Start / Stop One master can issue a START (S) condition to notice other devices connected to the SCLn, SDAn 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 SDAn line while SCLn is high defines a START (S) condition. A low to high transition on the SDAn line while SCLn 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 87. START and STOP Condition (USIn) ## 13.17 USIn I2C Data Transfer Every byte put on the SDAn line must be 8-bits 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 SCLn 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 SCLn. Figure 88. Data Transfer on the I2C-Bus (USIn) ## 13.18 USIn I2C Acknowledge The acknowledge related clock pulse is generated by the master. The transmitter releases the SDAn line (HIGH) during the acknowledge clock pulse. The receiver must pull down the SDAn 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 SDAn 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 89. Acknowledge on the I2C-Bus (USIn) ## 13.19 USIn I2C Synchronization / Arbitration Clock synchronization is performed using the wired-AND connection of I2C interfaces to the SCLn line. This means that a HIGH to LOW transition on the SCLn line will cause the devices concerned to start counting off their LOW period and it will hold the SCLn 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 SCLn line if another clock is still within its LOW period. In this way, a synchronized SCLn 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 SDAn line, while the SCLn 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 90. Clock Synchronization during Arbitration Procedure (USIn) Figure 91. Arbitration Procedure of Two Masters (USIn) ## 13.20 USIn I2C 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 carry on other operations during a I2C byte transfer. Note that when a I2C interrupt is generated, IICnIFR flag in USInCR4 register is set, it is cleared by writing an any value to USInST2. When I2C interrupt occurs, the SCLn line is hold LOW until writing any value to USInST2. When the IICnIFR flag is set, the USInST2 contains a value indicating the current state of the I2C bus. According to the value in USInST2, 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. #### 13.20.1 USIn I2C Master Transmitter To operate I2C in master transmitter, follow the recommended steps below. Enable I2C by setting USInMS[1:0]bits in USInCR1 and USInEN bit in USInCR2. This provides main clock to the peripheral. Load SLAn+W into the USInDR where SLAn is address of slave device and W is transfer direction from the viewpoint of the master. For master transmitter, W is '0'. Note that USInDR is used for both address and data. Configure baud rate by writing desired value to both USInSCLR and USInSCHR for the Low and High period of SCLn line. Configure the USInSDHR to decide when SDAn changes value from falling edge of SCLn. If SDAn should change in the middle of SCLn LOW period, load half the value of USInSCLR to the USInSDHR. Set the STARTCn bit in USInCR4. This transmits a START condition. And also configure how to handle interrupt and ACK signal. When the STARTCn bit is set, 8-bit data in USInDR is transmitted out according to the baud-rate. 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 SCLn. 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 MLOSTn bit in USInST2 is set, and I2C waits in idle state or can be operate as an addressed slave. To operate as a slave when the MLOSTn bit in USInST2 is set, the ACKnEN bit in USInCR4 must be set and the received 7-bit address must equal to the USInSLA[6:0] bits in USInSAR. In this case I2C operates as a slave transmitter or a slave receiver (go to appropriate section). In this stage, I2C holds the SCLn 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 USInDR. - 2) Master stops data transfer even if it receives ACK signal from slave. In this case, set the STOPCn bit in USInCR4. - 3) Master transmits repeated START condition with not checking ACK signal. In this case, load SLAn+R/W into the USInDR and set STARTCn bit in USInCR4. After doing one of the actions above, write any arbitrary to USInST2 to release SCLn 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 USInDR and if transfer direction bit is '1' go to master receiver section. 1-Byte of data is being transmitted. During data transfer, bus arbitration continues. This is ACK signal processing stage for data packet transmitted by master. I2C holds the SCLn LOW. When I2C loses bus mastership while transmitting data arbitrating other masters, the MLOSTn bit in USInST2 is set. If then, I2C waits in idle state. When the data in USInDR is transmitted completely, I2C generates TENDn 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 USInDR. - 2) Master stops data transfer even if it receives ACK signal from slave. In this case, set the STOPCn bit in USInCR4. - 3) Master transmits repeated START condition with not checking ACK signal. In this case, load SLAn+R/W into the USInDR and set the STARTCn bit in USInCR4. After doing one of the actions above, write any arbitrary to USInST2 to release SCLn 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 USInDR, and if transfer direction bit is '1' go to master receiver section. 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 USInST2, write any value to USInST2. After this, I2C enters idle state. #### 13.20.2 USIn I2C Master Receiver To operate I2C in master receiver, follow the recommended steps below. Enable I2C by setting USInMS[1:0]bits in USInCR1 and USInEN bit in USInCR2. This provides main clock to the peripheral. Load SLAn+R into the USInDR 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 USInDR is used for both address and data. Configure baud rate by writing desired value to both USInSCLR and USInSCHR for the Low and High period of SCLn line. Configure the USInSDHR to decide when SDAn changes value from falling edge of SCLn. If SDAn should change in the middle of SCLn LOW period, load half the value of USInSCLR to the USInSDHR. Set the STARTCn bit in USInCR4. This transmits a START condition. And also configure how to handle interrupt and ACK signal. When the STARTCn bit is set, 8-bit data in USInDR is transmitted out according to the baud-rate. 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 SCLn. 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 MLOSTn bit in USInST2 is set, and I2C waits in idle state or can be operate as an addressed slave. To operate as a slave when the MLOSTn bit in USInST2 is set, the ACKnEN bit in USInCR4 must be set and the received 7-bit address must equal to the USInSLA[6:0] bits in USInSAR. In this case I2C operates as a slave transmitter or a slave receiver (go to appropriate section). In this stage, I2C holds the SCLn 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 ACKnEN bit in USInCR4 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 STOPCn bit in USInCR4. - 3) Master transmits repeated START condition due to no ACK signal from slave. In this case, load SLAn+R/W into the USInDR and set STARTCn bit in USInCR4. After doing one of the actions above, write arbitrary value to USInST2 to release SCLn 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 USInDR and if transfer direction bit is '0' go to master transmitter section. 1-Byte of data is being received. This is ACK signal processing stage for data packet transmitted by slave. I2C holds the SCLn LOW. When 1-Byte of data is received completely, I2C generates TENDn interrupt. I2C can choose one of the following cases according to the RXACKn flag in USInST2. - 1) Master continues receiving data from slave. To do this, set ACKnEN bit in USInCR4 to ACKnowledge 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 ACKnEN bit in USInCR4. - 3) Because no ACK signal is detected, master terminates data transfer. In this case, set the STOPCn bit in USInCR4. - 4) No ACK signal is detected, and master transmits repeated START condition. In this case, load SLAn+R/W into the USInDR and set the STARTCn bit in USInCR4. After doing one of the actions above, write arbitrary value to USInST2 to release SCLn 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 USInDR, and if transfer direction bit is '0' go to master transmitter section. 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 USInST2, write any value to USInST2. After this, I2C enters idle state. #### 13.20.3 USIn I2C Slave Transmitter To operate I2C in slave transmitter, follow the recommended steps below. If the main operating clock (SCLK) of the system is slower than that of SCLn, load value 0x00 into USInSDHR to make SDAn change within one system clock period from the falling edge of SCLn. Note that the hold time of SDAn is calculated by SDAH x period of SCLK where SDAH is multiple of number of SCLK coming from USInSDHR. When the hold time of SDAn is longer than the period of SCLK, I2C (slave) cannot transmit serial data properly. Enable I2C by setting USInMS[1:0]bits in USInCR1, IICnIEbit in USInCR4 and USInEN bit in USInCR2. This provides main clock to the peripheral. When a START condition is detected, I2C receives one byte of data and compares it with USInSLA[6:0] bits in USInSAR. If the GCALLn bit in USInSAR is enabled, I2C compares the received data with value 0x00, the general call address. If the received address does not equal to USInSLA[6:0] bits in USInSAR, I2C enters idle state ie, waits for another START condition. Else if the address equals to USInSLA[6:0] bits and the ACKnEN bit is enabled, I2C generates SSELn interrupt and the SCLn line is held LOW. Note that even if the address equals to USInSLA[6:0] bits, when the ACKnEN bit is disabled, I2C enters idle state. When SSELn interrupt occurs, load transmit data to USInDR and write arbitrary value to USInST2 to release SCLn line. 1-Byte of data is being transmitted. In this step, I2C generates TENDn interrupt and holds the SCLn 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 and I2C waits STOP condition. - 2) ACK signal from master is detected. Load data to transmit into USInDR. After doing one of the actions above, write arbitrary value to USInST2 to release SCLn line. In case of 1) move to step 7 to terminate communication. In case of 2) move to step 5. This is the final step for slave transmitter function of I2C, handling STOP interrupt. The STOPCn bit indicates that data transfer between master and slave is over. To clear USInST2, write any value to USInST2. After this, I2C enters idle state. #### 13.20.4 USIn I2C Slave Receiver To operate I2C in slave receiver, follow the recommended steps below. If the main operating clock (SCLK) of the system is slower than that of SCLn, load value 0x00 into USInSDHR to make SDAn change within one system clock period from the falling edge of SCLn. Note that the hold time of SDAn is calculated by SDAH x period of SCLK where SDAH is multiple of number of SCLK coming from USInSDHR. When the hold time of SDAn is longer than the period of SCLK, I2C (slave) cannot transmit serial data properly. Enable I2C by setting USInMS[1:0] bits in USInCR1, IICnIEbit in USInCR4 and USInEN bit in USInCR2. This provides main clock to the peripheral. When a START condition is detected, I2C receives one byte of data and compares it with USInSLA[6:0] bits in USInSAR. If the GCALLn bit in USInSAR is enabled, I2Cn compares the received data with value 0x00, the general call address. If the received address does not equal to SLAn bits in USInSAR, I2C enters idle state ie, waits for another START condition. Else if the address equals to SLAn bits and the ACKnEN bit is enabled, I2C generates SSELn interrupt and the SCLn line is held LOW. Note that even if the address equals to SLAn bits, when the ACKnEN bit is disabled, I2C enters idle state. When SSELn interrupt occurs and I2C is ready to receive data, write arbitrary value to USInST2 to release SCLn line. Byte of data is being received. In this step, I2C generates TENDn interrupt and holds the SCLn 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 (ACKnEN=0) and I2C waits STOP condition. - 2) ACK signal is detected (ACKnEN=1) and I2C can continue to receive data from master. After doing one of the actions above, write arbitrary value to USInST2 to release SCLn line. In case of 1) move to step 7 to terminate communication. In case of 2) move to step 5. This is the final step for slave receiver function of I2C, handling STOP interrupt. The STOPCn bit indicates that data transfer between master and slave is over. To clear USInST2, write any value to USInST2. After this, I2C enters idle state. ## 13.21 USIn I2C Block Diagram Figure 92. USIn I2C Block Diagram ## 13.22 Register Map Table 31. USI Register Map | Name | Address | Direction | Default | Description | |----------|---------|-----------|---------|------------------------------------| | USI0BD | E3H | R/W | FFH | USI0 Baud Rate Generation Register | | USI0DR | E5H | R/W | 00H | USI0 Data Register | | USI0SDHR | E4H | R/W | 01H | USI0 SDA Hold Time Register | | USI0SCHR | E7H | R/W | 3FH | USI0 SCL High Period Register | | USI0SCLR | E6H | R/W | 3FH | USI0 SCL Low Period Register | | USI0SAR | DDH | R/W | 00H | USI0 Slave Address Register | | USI0CR1 | D9H | R/W | 00H | USI0 Control Register 1 | | USI0CR2 | DAH | R/W | 00H | USI0 Control Register 2 | | USI0CR3 | DBH | R/W | 00H | USI0 Control Register 3 | | USI0CR4 | DCH | R/W | 00H | USI0 Control Register 4 | | USI0ST1 | E1H | R/W | 80H | USI0 Status Register 1 | | USI0ST2 | E2H | R | 00H | USI0 Status Register 2 | ## 13.23 USIn Register Description USIn module consists of USIn baud rate generation register (USInBD), USIn data register (USInDR), USIn SDA hold time register (USInSDHR), USIn SCL high period register (USInSCHR), USIn SCL low period Register (USInSCLR), USIn slave address register (USInSAR), USIn control register 1/2/3/4 (USInCR1/2/3/4), and USIn status register 1/2 (USInST1/2). ## 13.24 Register Description for USIn ## USInBD (USIn Baud- Rate Generation Register: For UART and SPI mode): E3H, n = 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | USInBD7 | USInBD6 | USInBD5 | USInBD4 | USInBD3 | USInBD2 | USInBD1 | USInBD0 | | RW Initial value: FFH USInBD[7:0] The value in this register is used to generate internal baud rate in asynchronous mode or to generate SCKn clock in SPI mode. To prevent malfunction, do not write '0' in asynchronous mode and do not write '0' or '1' in SPI mode. #### NOTES: In common with USInSAR register, USInBD register is used for slave address register when the USIn I2C mode. ### USInDR (USIn Data Register: For UART, SPI, and I2C mode): E5H, n = 0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|------|---------|---------|---------|---------|---------|---------|---------| | USI | nDR7 | USInDR6 | USInDR5 | USInDR4 | USInDR3 | USInDR2 | USInDR1 | USInDR0 | | F | W. | RW Initial value: 00H USInDR[7:0] The USIn 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 USInDR register. Reading the USInDR register returns the contents of the receive buffer. Write to this register only when the DREn flag is set. In SPI master mode, the SCK clock is generated when data are written to this register. ### USInSDHR (USInSDA Hold Time Register: For I2C mode): E4H, n = 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | USInSDHR7 | USInSDHR6 | USInSDHR5 | USInSDHR4 | USInSDHR3 | USInSDHR2 | USInSDHR1 | USInSDHR0 | | RW Initial value: 01H USInSDHR[7:0] The register is used to control SDAn output timing from the falling edge of SCI in I2C mode. #### NOTES: - That SDAn is changed after t<sub>SCLK</sub> X (USInSDHR+2), in master SDAn change in the middle of SCLn. - 2. In slave mode, configure this register regarding the frequency of SCLn from master. - 3. The SDAn is changed after $t_{SCLK}$ X (USInSDHR+2) in master mode. So, to insure operation in slave mode, the value - 4. t<sub>SCLK</sub> X (USInSDHR+2) must be smaller than the period of SCL. ## USInSCHR (USInSCL High Period Register: For I2C mode): E7H, n = 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | USInSCHR7 | USInSCHR6 | USInSCHR5 | USInSCHR4 | USInSCHR3 | USInSCHR2 | USInSCHR1 | USInSCHR0 | | RW Initial value: 3FH USInSCHR[7:0] This register defines the high period of SCLn when it operates in I2C master mode. The base clock is SCLK, the system clock, and the period is calculated by the formula: $t_{SCLK} \times (4 \times USInSCHR + 2)$ where $t_{SCLK}$ is the period of SCLK. So, the operating frequency of I2C master mode is calculated by the following equation. $$f_{I2C} = \frac{1}{t_{SCLK}X (4 X (USInSCLR + USInSCHR) + 4)}$$ ## USInSCLR (USInSCL Low Period Register: For I2C mode): E6H, n = 0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | | USInSCLR7 | USInSCLR6 | USInSCLR5 | USInSCLR4 | USInSCLR3 | USInSCLR2 | USInSCLR1 | USInSCLR0 | | , | RW Initial value: 3FH USInSCLR[7:0] This register defines the high period of SCLn when it operates in I2C master mode. The base clock is SCLK, the system clock, and the period is calculated by the formula: $t_{SCLK} \times (4 \times USInSCLR + 2)$ where t<sub>SCLK</sub> is the period of SCLK. ## USInSAR (USIn Slave Address Register: For I2C mode): DDH, n = 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | Ü | |----------|----------|----------|----------|----------|----------|----------|---------| | USInSLA6 | USInSLA5 | USInSLA4 | USInSLA3 | USInSLA2 | USInSLA1 | USInSLA0 | USInGCE | | RW Initial value: 00H USInSLA[6:0] USInGCE These bits configure the slave address of I2C when it operates in I2C slave mode. This bit decides whether I2C allows general call address or not in I2C slave mode. 0 Ignore general call address 1 Allow general call address # USInCR1 (USIn Control Register 1: For UART, SPI, and I2C mode): D9H, n = 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|--------|----------------|-----------------|-------| | USInMS1 | USInMS0 | USInPM1 | USInPM0 | USInS2 | USInS1<br>ORDn | USInS0<br>CPHAn | CPOLn | | RW Initial value: 00H | | | | | | | ililiai value. Ooi i | | |-------------|---------------|----------------|---------------|------------------------------------------|--------------------------------------|------------------------|--| | USInMS[1:0] | Selects ope | ration mode | of USIn | | | | | | | USInMS1 | USInMS0 | Operation | mode | | | | | | 0 | 0 | Asynchro | nous Mode ( | UART) | | | | | 0 | 1 | Synchron | ous Mode | | | | | | 1 | 0 | - | | mode is not suppo | orted) | | | | 1 | 1 | SPI mode | | | | | | USInPM[1:0] | Selects pari | ity generation | n and chec | k methods (d | only UART mode) | | | | | USInPM1 | USInPM0 | Parity | | | | | | | 0 | 0 | No Parity | | | | | | | 0 | 1 | Reserved | | | | | | | 1 | 0 | Even Pari | ty | | | | | | 1 | 1 | Odd Parit | y | | | | | USInS[2:0] | When in as | ynchronous o | or synchror | nous mode o | f operation, | | | | | selects the | length of data | a bits in fra | me | | | | | | USInS2 | USInS1 | USInS0 | Data Length | า | | | | | 0 | 0 | 0 | 5 bit | | | | | | 0 | 0 | 1 | 6 bit | | | | | | 0 | 1 | 0 | 7 bit | | | | | | 0 | 1 | 1 | 8 bit | | | | | | 1 | 0 | 0 | Reserved | | | | | | 1 | 0 | 1 | Reserved | | | | | | 1 | 1 | 0 | Reserved | | | | | | 1 | 1 | 1 | 9 bit | | | | | ORDn | | | | | ne MSB of the dat<br>(only SPI mode) | ta byte is transmitted | | | | 0 | LSB-first | | | | | | | | 1 | MSB-first | | | | | | | CPHAn | | | | ith USInS0. <sup>-</sup><br>CKn (only SF | | s if data are sampled | | | | CPOLn | CPHAn | Leading e | dge | Trailing edge | | | | | 0 | 0 | Sample (F | Rising) | Setup (Falling) | | | | | 0 | 1 | Setup (Ri | sing) | Sample (Falling) | | | | | 1 | 0 | Sample (F | Falling) | Setup (Rising) | | | | | 1 | 1 | Setup (Fa | lling) | Sample (Rising) | | | | CPOLn | This bit dete | ermines the o | clock polari | ty of ACK in | synchronous or S | PI mode. | | | | 0 | TXD change | e @Rising | Edge, RXD | change @Falling I | Edge | | | | 1 | TXD change | e @Falling | Edge, RXD | change @Rising I | Edge | | | | | | | | | | | ## USInCR2 (USIn Control Register 2: For UART, SPI, and I2C mode): DAH, n = 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|--------|--------|---------|------|------|--------|-------| | DRIEn | TXCIEn | RXCIEn | WAKEIEn | TXEn | RXEn | USInEN | DBLSn | | RW |----|---------|--------------------|--------------------|---------------------------------------|----------------------------------------------------------|-----------------|---------------| | | | | | | | Initi | al value: 00H | | | DRIEn | Interrup | t enable bit for c | lata register emp | oty (only UART ar | nd SPI mode). | | | | | 0 | Interrupt from D | DREn is inhibited | l (use polling) | | | | | | 1 | When DREn is | set, request an i | interrupt | | | | | TXCIEn | Interrup | t enable bit for t | ransmit complete | e (only UART and | d SPI mode). | | | | | 0 | Interrupt from T | XCn is inhibited | (use polling) | | | | | | 1 | When TXCn is | set, request an i | nterrupt | | | | | RXCIEn | Interrup | t enable bit for r | eceive complete | (only UART and | SPI mode). | | | | | 0 | Interrupt from F | RXCn is inhibited | l (use polling) | | | | | | 1 | When RXCn is | set, request an i | interrupt | | | | | WAKEIEn | mode, if<br>UART n | RXDn goes to le | ow level an interr<br>me the DRIEn bi | wake in STOP m<br>rupt can be reque<br>it and USInST1 re | sted to wake-up | system. (only | | | | 0 | Interrupt from V | Vake is inhibited | | | | | | | 1 | When WAKEn | is set, request a | n interrupt | | | | | TXEn | Enables | the transmitter | unit (only UART | and SPI mode). | | | | | | 0 | Transmitter is o | disabled | | | | | | | 1 | Transmitter is e | enabled | | | | | | RXEn | Enables | the receiver un | it (only UART ar | nd SPI mode). | | | | | | 0 | Receiver is disa | abled | | | | | | | 1 | Receiver is ena | abled | | | | | | USInEN | Activate | USIn function b | olock by supplyin | ıg. | | | | | | 0 | USIn is disable | d | | | | | | | 1 | USIn is enabled | d | | | | | | DBLSn | This bit | selects receiver | sampling rate (d | only UART). | | | | | | 0 | Normal asynch | ronous operatior | า | | | | | | 1 | Double Speed | asynchronous op | peration | | | # USInCR3 (USIn Control Register 3: For UART, SPI, and I2C mode): DBH, n = 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|----------|----------|--------------------------------|------------------------------------|-------------------|-----------------|-----------------| | MASTERn | LOOPSn | DISSCKn | USInSSEN | FXCHn | USInSB | USInTX8 | USInRX8 | | RW R | | | | | | | | Init | ial value: 00H | | | MASTERn | | master or slave<br>of SCKn pin | e in SPI and sy | ynchronous mod | de operation an | d controls the | | | | 0 | Slave mode ope | eration (Externa | I clock for SCKn | ). | | | | | 1 | Master mode o | peration (Interna | al clock for SCKr | n). | | | | LOOPSn | Controls | the loop back r | mode of USIn for | r test mode (only | / UART and SPI | l mode) | | | | 0 | Normal operation | on | | | | | | | 1 | Loop Back mod | le | | | | | | DISSCKn | In synch | ronous mode of | f operation, sele | cts the waveforn | n of SCKn outpu | ıt | | | | 0 | ACK is free-run | ning while UAR | T is enabled in s | ynchronous ma | ster mode | | | | 1 | ACK is active w | hile any frame is | s on transferring | | | | | USInSSEN | This bit | controls the SSr | n pin operation ( | only SPI mode) | | | | | | 0 | Disable | | | | | | | | 1 | Enable | | | | | | | FXCHn | SPI port | function exchar | nge control bit (c | only SPI mode) | | | | | | 0 | No effect | | | | | | | | 1 | Exchange MOS | SIn and MISOn f | unction | | | | | USInSB | Selects | the length of sto | p bit in asynchro | onous or synchro | onous mode of o | operation. | | | | 0 | 1 Stop Bit | | | | | | | | 1 | 2 Stop Bit | | | | | | | USInTX8 | | | me in asynchror<br>ng the USInDR r | | nous mode of o | peration. Write | | | | 0 | MSB (9th bit) to | be transmitted is | s '0' | | | | | | 1 | MSB (9th bit) to | be transmitted is | s '1' | | | | | USInRX8 | | | me in asynchror | • | | peration. Read | | | | 0 | MSB (9th bit) re | ceived is '0' | | | | MSB (9th bit) received is '1' ## USInCR4 (USIn Control Register 4: For I2C mode): DCH, n = 0 c **IICnIE** | / | О | 5 | 4 | 3 | 2 | 1 | U | |---------|---|-----------|--------|--------|----------|--------|----------------| | IICnIFR | _ | TXDLYENBn | IICnIE | ACKnEN | IMASTERn | STOPCn | STARTCn | | R | _ | RW | RW | RW | R | RW | RW | | | | | | | | Init | ial value: 00H | | | | | | | | | | IICnIFR This is an interrupt flag bit for I2C mode. When an interrupt occurs, this bit becomes '1'. This bit is cleared when write any values in the USInST2. Writing "1" has no effect. 12C interrupt no generation12C interrupt generation TXDLYENBn USInSDHR register control bit Enable USInSDHR register Disable USInSDHR register Interrupt Enable bit for I2C mode 0 Interrupt from I2C is inhibited (use polling) 1 Enable interrupt for I2C ACKnEN Controls ACK signal Generation at ninth SCLn period. No ACK signal is generated (SDAn =1) ACK signal is generated (SDAn =0) NOTES: ACK signal is output (SDA =0) for the following 3 cases. 1. When received address packet equals to USInSLA bits in USInSAR. 2. When received address packet equals to value 0x00 with GCALLn enabled. 3. When I2C operates as a receiver (master or slave) IMASTERn Represent operating mode of I2C 0 I2C is in slave mode1 I2C is in master mode STOPCn When I2C is master, STOP condition generation 0 No effect 1 STOP condition is to be generated STARTCn When I2C is master, START condition generation 0 No effect 1 START or repeated START condition is to be generated #### USInST1 (USIn Status Register 1: For UART and SPI mode): E1H, n = 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|-------|---------|------|-----|-----| | DREn | TXCn | RXCn | WAKEn | USInRST | DORn | FEn | PEn | | RW | RW | R | RW | RW | R | RW | RW | Initial value: 80H DREn The DREn flag indicates if the transmit buffer (USInDR) is ready to receive new data. If DREn is '1', the buffer is empty and ready to be written. This flag can generate a DREn interrupt. - O Transmit buffer is not empty. - 1 Transmit buffer is empty. **TXCn** 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 TXCn interrupt is executed. This flag can generate a TXCn interrupt. This bit is automatically cleared. - 0 Transmission is ongoing. - 1 Transmit buffer is empty and the data in transmit shift register are shifted out completely. **RXCn** 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 RXCn flag can be used to generate an RXCn interrupt. - 0 There is no data unread in the receive buffer - 1 There are more than 1 data in the receive buffer WAKEn This flag is set when the RXDn pin is detected low while the CPU is in STOP mode. This flag can be used to generate a WAKEn interrupt. This bit is set only when in asynchronous mode of operation. This bit should be cleared by program software. (only UART mode) - 0 No WAKE interrupt is generated. - 1 WAKE interrupt is generated **USInRST** This is an internal reset and only has effect on USIn. Writing '1' to this bit initializes the internal logic of USIn and this bit is automatically cleared to '0'. - 0 No operation - 1 Reset USIn **DORn** 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 FEn 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. (only UART mode) - No Frame Error - 1 Frame Error detected PEn This bit is set if the next character in the receive buffer has a Parity Error to be received while Parity Checking is enabled. This bit is valid until the receive buffer is read. (only UART mode) - 0 No Parity Error - Parity Error detected Λ 7 ### USInST2 (USIn Status Register 2: For I2C mode): E2H, n = 0 5 6 | , | U | 3 | - | 3 | 2 | • | U | | | |--------------------|-------|--------|-------|--------|-------|--------|--------|--|--| | GCALLn | TENDn | STOPDn | SSELn | MLOSTn | BUSYn | TMODEn | RXACKn | | | | R | RW | | | Initial value: 00H | | | | | | | | | | | | | | | | | | | | | GCALLn<sup>(NOTES:</sup> This bit has different meaning depending on whether I2C is master or slave. When I2C is a master, this bit represents whether it received AACK (address ACK) from slave. 3 0 No AACK is received (Master mode) 1 AACK is received (Master mode) 1 When I2C is a slave, this bit is used to indicate general call. O General call address is not detected (Slave mode) 1 General call address is detected (Slave mode) TENDn<sup>(NOTES:</sup> This bit is set when 1-byte of data is transferred completely 0 1 byte of data is not completely transferred 1 1 byte of data is completely transferred STOPDn(NOTES: This bit is set when a STOP condition is detected. 0 No STOP condition is detected 1 STOP condition is detected SSELn<sup>(NOTES:</sup> This bit is set when I2C is addressed by other master. 0 I2C is not selected as a slave 1 I2C is addressed by other master and acts as a slave MLOSTn<sup>(NOTES:</sup> This bit represents the result of bus arbitration in master mode. 0 I2C maintains bus mastership 1 I2C maintains bus mastership during arbitration process BUSYn This bit reflects bus status. 12C bus is idle, so a master can issue a START condition 1 I2C bus is busy TMODEn This bit is used to indicate whether I2C is transmitter or receiver. 0 I2C is a receiver 1 I2C is a transmitter RXACKn This bit shows the state of ACK signal 0 No ACK is received 1 ACK is received at ninth SCL period #### NOTES: - 1. These bits can be source of interrupt. - 2. When an I2C interrupt occurs except for STOP mode, the SCLn line is hold LOW. To release SCLn, write arbitrary value to USInST2. When USInST2 is written, the TENDn, STOPDn, SSELn, MLOSTn, and RXACKn bits are cleared. # 13.25 Baud Rate setting (example) Table 32. Examples of USI0BD Settings for Commonly Used Oscillator Frequencies | Baud Rate | fx=1.00MHz | | fx=1.8432MHz | | fx=2.00MHz | | |-----------|------------|--------|--------------|--------|------------|--------| | (bps) | USI0BD | ERROR | USI0BD | ERROR | USI0BD | ERROR | | 2400 | 25 | 0.2% | 47 | 0.0% | 51 | 0.2% | | 4800 | 12 | 0.2% | 23 | 0.0% | 25 | 0.2% | | 9600 | 6 | -7.0% | 11 | 0.0% | 12 | 0.2% | | 14.4k | 3 | 8.5% | 7 | 0.0% | 8 | -3.5% | | 19.2k | 2 | 8.5% | 5 | 0.0% | 6 | -7.0% | | 28.8k | 1 | 8.5% | 3 | 0.0% | 3 | 8.5% | | 38.4k | 1 | -18.6% | 2 | 0.0% | 2 | 8.5% | | 57.6k | - | - | 1 | -25.0% | 1 | 8.5% | | 76.8k | - | - | 1 | 0.0% | 1 | -18.6% | | 115.2k | - | - | - | - | - | - | | 230.4k | - | - | - | - | - | - | Table 33. Examples of USI0BD Settings for Commonly Used Oscillator Frequencies (continued) | Baud Rate | fx=1.00MHz | | fx=1.8432MHz | | fx=2.00MHz | | | |-----------|------------|--------|--------------|--------|------------|--------|--| | (bps) | USI0BD | ERROR | USI0BD | ERROR | USI0BD | ERROR | | | 2400 | 25 | 0.2% | 47 | 0.0% | 51 | 0.2% | | | 4800 | 12 | 0.2% | 23 | 0.0% | 25 | 0.2% | | | 9600 | 6 | -7.0% | 11 | 0.0% | 12 | 0.2% | | | 14.4k | 3 | 8.5% | 7 | 0.0% | 8 | -3.5% | | | 19.2k | 2 | 8.5% | 5 | 0.0% | 6 | -7.0% | | | 28.8k | 1 | 8.5% | 3 | 0.0% | 3 | 8.5% | | | 38.4k | 1 | -18.6% | 2 | 0.0% | 2 | 8.5% | | | 57.6k | - | - | 1 | -25.0% | 1 | 8.5% | | | 76.8k | - | - | 1 | 0.0% | 1 | -18.6% | | | 115.2k | - | - | - | - | - | - | | | 230.4k | - | - | - | - | - | - | | Table 33. Examples of USI0BD Settings for Commonly Used Oscillator Frequencies (continued) | Baud Rate | fx=8.00MHz | | fx=11.0592MHz | | | | |-----------|------------|-------|---------------|-------|--|--| | (bps) | USI0BD | ERROR | USI0BD | ERROR | | | | 2400 | 207 | 0.2% | - | - | | | | 4800 | 103 | 0.2% | 143 | 0.0% | | | | 9600 | 51 | 0.2% | 71 | 0.0% | | | | 14.4k | 34 | -0.8% | 47 | 0.0% | | | | 19.2k | 25 | 0.2% | 35 | 0.0% | | | | 28.8k | 16 | 2.1% | 23 | 0.0% | | | | 38.4k | 12 | 0.2% | 17 | 0.0% | | | | 57.6k | 8 | -3.5% | 11 | 0.0% | | | | 76.8k | 6 | -7.0% | 8 | 0.0% | | | | 115.2k | 3 | 8.5% | 5 | 0.0% | | | | 230.4k | 1 | 8.5% | 2 | 0.0% | | | | 250k | 1 | 0.0% | 2 | -7.8% | | | | 0.5M | - | - | - | - | | | ## **14** USART1 #### 14.1 Overview The Universal Synchronous and Asynchronous serial Receiver and Transmitter (USART1) 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 USART1 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 USART1 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 (UDATA) and control logic. The Receiver supports the same frame formats as the Transmitter and can detect Frame Error, Data OverRun and Parity Errors. ## 14.2 Block Diagram Figure 93. USART1 Block Diagram ## 14.3 Clock Generation Figure 94. Clock Generation Block Diagram The Clock generation logic generates the base clock for the Transmitter and Receiver. The USART1 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 UCTRL1 register selects between asynchronous and synchronous operation. Asynchronous Double Speed mode is controlled by the U2X bit in the UCTRL2 register. The MASTER bit in UCTRL2 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 USART1 operates in Synchronous or SPI mode. Table below contains equations for calculating the baud rate (in bps). Table 33. Equations for Calculating Baud Rate Register Setting | 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)}$ | ## 14.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). ## 14.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 RXD1 (MISO1 in SPI mode) pin is sampled at the opposite XCK clock edge of the edge in the data output on TXD1 (MOSI1 in SPI mode) pin is changed. The UCPOL bit in UCTRL1 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 95. Synchronous Mode XCK Timing ### 14.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 USART1 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. frame format 1 data frame consists of the following bits Idle No communication on communication line (TxD1/RxD1) 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 USART1 is set by the USIZE[2:0], UPM[1:0] and USBS bits in UCTRL1 register. The Transmitter and Receiver use the same setting. ## 14.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 ### 14.8 USART1 Transmitter The USART1 Transmitter is enabled by setting the TXE bit in UCTRL1 register. When the Transmitter is enabled, the normal port operation of the TXD1 pin is overridden by the serial output pin of USART1. 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 USART1 operates in SPI mode, SS1 pin is used as SS1 input pin in slave mode or can be configured as SS1 output pin in master mode. This can be done by setting SPISS bit in UCTRL3 register. ### 14.8.1 Sending Tx data A data transmission is initiated by loading the transmit buffer (UDATA 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 UCTRL3 register before loading transmit buffer (UDATA register). ## 14.8.2 Transmitter flag and interrupt The USART1 Transmitter has 2 flags which indicate its state. One is USART1 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, USART1 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, USART1 Transmit Complete Interrupt is generated while TXC flag is set. ### 14.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. #### 14.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 TXD1 pin is used as normal General Purpose I/O (GPIO) or primary function pin. ### 14.9 USART1 Receiver The USART1 Receiver is enabled by setting the RXE bit in the UCTRL1 register. When the Receiver is enabled, the normal pin operation of the RXD1 pin is overridden by the USART1 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 USART1 operates in SPI mode, SS1 pin is used as SS1 input pin in slave mode or can be configured as SS1 output pin in master mode. This can be done by setting SPISS bit in UCTRL3 register. ### 14.9.1 Receiving Rx data When USART1 is in synchronous or asynchronous operation mode, the Receiver starts data reception when it detects a valid start bit (LOW) on RXD1 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 UDATA register. If 9-bit characters are used (USIZE[2:0] = 7), the ninth bit is stored in the RX8 bit position in the UCTRL3 register. The 9th bit must be read from the RX8 bit before reading the low 8 bits from the UDATA register. Likewise, the error flags FE, DOR, PE must be read before reading the data from UDATA register. This is because the error flags are stored in the same FIFO position of the receive buffer. #### 14.9.2 Receiver flag and interrupt The USART1 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 UCTRL2 register is set and Global Interrupt is enabled, the USART1 Receiver Complete Interrupt is generated while RXC flag is set. The USART1 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 USTAT 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 UDATA register, read the USTAT 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". NOTES: The error flags related to receive operation are not used when USART1 is in SPI mode. ### 14.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. ## 14.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 RXD1 pin is not overridden the function of USART1, so RXD1 pin becomes normal GPIO or primary function pin. ### 14.9.5 Asynchronous Data Reception To receive asynchronous data frame, the USART1 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 RXD1 pin. The Data recovery logic samples incoming bits and low pass filters them, and this removes the noise of RXD1 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 96. Start bit Sampling When the Receiver is enabled (RXE=1), the clock recovery logic tries to find a high to low transition on the RXD1 line, the start bit condition. After detecting high to low transition on RXD1 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 97. 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 RXD1 line to check a valid high to low transition is detected (start bit detection). Figure 98. Stop bit Sampling and Next Start bit Sampling ### 14.10 SPI Mode The USART1 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 (SS1) 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 RXD1 is renamed as MISO1 and TXD1 is renamed as MOSI1 for compatibility to other SPI devices. ### 14.10.1 SPI Clock formats and timing To accommodate a wide variety of synchronous serial peripherals from different manufacturers, the USART1 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 UCTRL1 register have different meanings according to the UMSEL[1:0] bits which decides the operating mode of USART1. Table below shows four combinations of UCPOL and UCPHA for SPI mode 0, 1, 2, and 3. Table 34. CPOL Functionality | 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) | Figure 99. SPI Clock Formats when UCPHA=0 When UCPHA=0, the slave begins to drive its MISO1 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 MISO1 and MOSI1 inputs, respectively. At the second XCK edge, the USART1 shifts the second data bit value out to the MOSI1 and MISO1 outputs of the master and slave, respectively. Unlike the case of UCPHA=1, when UCPHA=0, the slave's SS1 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 SS1 input. Figure 100. SPI Clock Formats when UCPHA=1 When UCPHA=1, the slave begins to drive its MISO1 output when SS1 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 MOSI1 output of the master and the MISO1 output of the slave. The next XCK edge causes both the master and slave to sample the data bit value on their MISO1 and MOSI1 inputs, respectively. At the third XCK edge, the USART1 shifts the second data bit value out to the MOSI1 and MISO1 output of the master and slave respectively. When UCPHA=1, the slave's SS1 input is not required to go to its inactive high level between transfers. Because the SPI logic reuses the USART1 resources, SPI mode of operation is similar to that of synchronous or asynchronous operation. An SPI transfer is initiated by checking for the USART1 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. ## 14.11 Receiver Time Out (RTO) This USART1 system supports the time out function. This function is occur the interrupts when stop bit are not in RX line during URTOC setting value. RTO count stops in RXD signal live state and RTO clear and start is executed by stop bit recognition. **Example1)** Condition: sysclk = 16MHz, Baud rate = 115,200 bps, Asynchronous Normal Mode (U2X = 0) Baud rate = sysclk / 16 x (UBAUD + 1) Calculated UBAUD = (1000000 / Target Baud rate) – 1 = 7.68, Error rate = 0.68 ⇒ UBAUD = 8 Real baud rate at sysclk 16MHz = 111,111 bps. 1 bit time = 9ms Maximum count time = 9ms \* 65536(16bit count) = 589.8ms Figure 101. Example for RTO in USART1 # 14.12 Register Map Table 35. USART1 Register Map | Name | Address | Direction | Default | Description | |--------|---------|-----------|---------|-----------------------------------------| | UCTRL1 | СВН | R/W | 00H | USART1 Control 1 Register | | UCTRL2 | CCH | R/W | 00H | USART1 Control 2 Register | | UCTRL3 | CDH | R/W | 00H | USART1 Control 3 Register | | UCTRL4 | 1018H | R/W | 00H | USART1 Control 4 Register | | USTAT | CFH | R | 80H | USART1 Status Register | | UBAUD | FCH | R/W | FFH | USART1 Baud Rate Generation Register | | UDATA | FDH | R/W | 00H | USART1 Data Register | | FPCR | 1019H | R/W | 00H | USART1 Floating Point Counter Register | | RTOCH | 101AH | R | 00H | Receiver Time Out Counter High Register | | RTOCL | 101BH | R | 00H | Receiver Time Out Counter Low Register | # 14.13 USART1 Register Description USART1 module consists of USART1 Control 1 Register (UCTRL1), USART1 Control 2 Register (UCTRL2), USART1 Control 3 Register (UCTRL3), USART1 Control 4 Register (UCTRL4), USART1 Floaint Point Counter (FPCR), USART1 Status Register (USTAT), USART1 Data Register (UDATA), and USART1 Baud Rate Generation Register (UBAUD). # 14.14 Register Description for USART1 # UCTRL1 (USART1 Control 1 Register): CBH | 7 | 6 | 5 | | 4 | 3 | 2 | 1 | 0 | | | |--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------|--------------------------------------|------------------|-------------------|---------------|--|--| | UMSEL1 | UMSEL0 | UPM1 | UI | PM0 | USIZE2 | USIZE1<br>UDORD | USIZE0<br>UCPHA | UCPOL | | | | R/W | R/W | R/W | F | R/W | R/W | R/W | R/W | R/W | | | | | | | | | | | Initi | al value: 00H | | | | | UMSEL[1:0] | Selects op | | | SART1 | | | | | | | | | UMSEL1 | UMSE | | Operating Mode | | | | | | | | | 0 | 0 | | Asynchronous Mo | • | • | | | | | | | 0 | 1 | | Synchronous Mo | de (Synchronou | s UART) | | | | | | | 1 | 0 | | Reserved | | | | | | | | | 1 | 1 | | SPI Mode | | | | | | | | UPM[1:0] | | - | | d Check methods | 6 | | | | | | | | UPM1 | UPM0 | | Parity mode | | | | | | | | | 0 | 0 | | No Parity | | | | | | | | | 0 | 1 | | Reserved | | | | | | | | | 1 | 0 | | Even Parity | | | | | | | | | 1 | 1 | | Odd Parity | | | | | | | | USIZE[2:0] | When in a in frame. | synchrono | us or syr | nchronous mode | of operation, se | ects the length o | of data bits | | | | | | USIZE2 | USIZE1 | USIZE | 0 Data leng | gth | | | | | | | | 0 | 0 | 0 | 5-bit | | | | | | | | | 0 | 0 | 1 | 6-bit | | | | | | | | | 0 | 1 | 0 | 7-bit | | | | | | | | | 0 | 1 | 1 | 8-bit | | | | | | | | | 1 | 0 | 0 | Reserved | t | | | | | | | | 1 | 0 | 1 | Reserved | t | | | | | | | | 1 | 1 | 0 | Reserved | t | | | | | | | | 1 | 1 | 1 | 9-bit | | | | | | | | UDORD | | a byte is | | sition with USIZE<br>ted first. When | | | | | | | | | 0 LS | B First | | | | | | | | | | | 1 MS | B First | | | | | | | | | | UCPOL | Selects po | larity of X0 | CK in syr | nchronous or SPI | mode | | | | | | | | 0 TX | D1 change | @Risin | g Edge, RXD1 cl | hange @Falling | Edge | | | | | | | 1 TX | D1 change | e @ Fallii | ng Edge, RXD1 d | change @ Risin | g Edge | | | | | | UCPHA | This bit is in the same bit position with USIZE0. In SPI mode, along with UCPOL bit, selects one of two clock formats for different kinds of synchronous serial peripherals. Leading edge means first XCK edge and trailing edge means 2 <sup>nd</sup> or last clock edge of XCK in one XCK pulse. And Sample means detecting of incoming receive bit, Setup means preparing transmit data. | | | | | | | | | | | | UCPOL | UCF | PHA | Leading Edge | Trailing Edg | е | | | | | | | 0 | 0 | ; | Sample (Rising) | Setup (Fallii | ng) | | | | | | | 0 | 1 | ; | Setup (Rising) | Sample (Fa | ling) | | | | | | | 1 | 0 | ; | Sample (Falling) | Setup (Risir | ıg) | | | | | | | | | | a | | | | | | Setup (Falling) Sample (Rising) # UCTRL2 (USART1 Control 2 Register): CCH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |-------|---------|---------------------------------------------------------------------------------------------|-------------------------------------------------|------------------------------------|---------------|---------|---------------|--|--|--|--| | UDRIE | TXCIE | RXCIE | WAKEIE | TXE | RXE | USARTEN | U2X | | | | | | R/W | | | | | | | | | | | Initi | al value: 00H | | | | | | | UDRIE | Interrupt | enable bit for US | SART1 Data Re | gister Empty. | | | | | | | | | | 0 I | nterrupt from UI | ORE is inhibited | (use polling) | | | | | | | | | | 1 \ | When UDRE is s | set, request an ir | nterrupt | | | | | | | | | TXCIE | Interrupt | enable bit for Tr | ansmit Complete | э. | | | | | | | | | | 0 I | nterrupt from TX | C is inhibited (u | se polling) | | | | | | | | | | 1 \ | 1 When TXC is set, request an interrupt | | | | | | | | | | | RXCIE | Interrupt | Interrupt enable bit for Receive Complete | | | | | | | | | | | | 0 I | 0 Interrupt from RXC is inhibited (use polling) | | | | | | | | | | | | 1 \ | When RXC is se | t, request an into | errupt | | | | | | | | | WAKEIE | | | Asynchronous W<br>OW level an inte | | | | | | | | | | | 0 1 | nterrupt from W | ake is inhibited | | | | | | | | | | | 1 \ | When WAKE is | set, request an i | nterrupt | | | | | | | | | TXE | Enables | the transmitter u | ınit. | | | | | | | | | | | 0 | Transmitter is dis | sabled | | | | | | | | | | | 1 | Transmitter is er | nabled | | | | | | | | | | RXE | Enables | the receiver unit | | | | | | | | | | | | 0 1 | Receiver is disal | oled | | | | | | | | | | | 1 I | Receiver is enab | oled | | | | | | | | | | USARTEN | Activate | USART1 module | e by supplying cl | ock. | | | | | | | | | | 0 USART1 is disabled (clock is halted) | | | | | | | | | | | | | 1 ( | JSART1 is enab | oled | | | | | | | | | | U2X | This bit only has effect for the asynchronous operation and selects receiver sampling rate. | | | | | | | | | | | | | 0 1 | Normal asynchro | onous operation | | | | | | | | | | | 1 I | Double Speed a | synchronous ope | eration | | | | | | | ## UCTRL3 (USART1 Control 3 Register): CDH RX8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |--------|--------|---------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|-------------------|--------------------|------------------|-------------------|--|--| | MASTER | LOOPS | DISXCK | SPISS | - | USBS | TX8 | RX8 | | | | R/W | R/W | R/W | R/W | - | R/W | R/W | R | | | | | | | | | | Init | ial value: 00H | | | | | MASTER | Selects m<br>of XCK p | | n SPI or Synchro | onous mode oper | ation and contro | ols the direction | | | | | | 0 5 | Slave mode operation and XCK is input pin. | | | | | | | | | | 1 N | /laster mode op | eration and XCI | K is output pin | | | | | | | LOOPS | Controls | the Loop Back r | mode of USART | 1, for test mode | | | | | | | | 0 1 | Normal operation | n | | | | | | | | | 1 L | oop Back mode | Э | | | | | | | | DISXCK | In Synchi | onous mode of | operation, selec | cts the waveform | of XCK output. | | | | | | | 0 | CK is free-runn | ning while USAR | RT is enabled in s | synchronous ma | aster mode. | | | | | | 1 > | CK is active wh | nile any frame is | on transferring. | | | | | | | SPISS | Controls | the functionality | of SS1 pin in m | naster SPI mode. | | | | | | | | 0 5 | SS1 pin is norma | al GPIO or othe | r primary functior | า | | | | | | | 1 5 | SS1 output to ot | her slave device | Э | | | | | | | USBS | Selects th | ne length of stop | bit in Asynchro | onous or Synchro | onous mode of o | peration. | | | | | | 0 1 | Stop bit | | | | | | | | | | 1 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. | | | | | | | | | | | 0 1 | MSB (9 <sup>th</sup> bit) to b | oe transmitted is | s 'O' | | | | | | | | 1 N | MSB (9 <sup>th</sup> bit) to b | oe transmitted is | s '1' | | | | | this bit first before reading the receive buffer. MSB (9<sup>th</sup> bit) received is '0' MSB (9<sup>th</sup> bit) received is '1' The ninth bit of data frame in Asynchronous or Synchronous mode of operation. Read ## UCTRL4 (USART1 Control 4 Register): 1018H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-------|-----------|------------------|----------|--------|---------|---------------| | - | - | - | RTOEN | RTO_FLAG | FPCREN | AOVSSEL | AOVSEN | | - | - | - | R/W | R/W | R/W | R/W | R/W | | | | | | | | Initi | al value: 00H | | | RTOFN | Enable re | eceiver time out | | | | | 0 Disable 1 Enable RTO\_FLAG This bit is set when RTO count overflows. Writing '0' to this bit position will clear RTO\_FLAG. RTO count dose not overflow. 1 RTO count overflow. **FPCREN** Enable baud rate compensation 0 Disable 1 Enable **AOVSEN** Enable additional oversampling rates selection Disable 1 Enable **AOVSSEL** Select additional oversampling rates Select X13 1 Select X4 ## USTAT (USART1 Status Register): CFH | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|------|-----|-----|------|---------|-----|----|----| | | UDRE | TXC | RXC | WAKE | SOFTRST | DOR | FE | PE | | Ì | R/W | R/W | R/W | R/W | R/W | 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. - O 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. - 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. $^{\rm NOTE}$ - 0 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 FE 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 **NOTES:** 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. ### UBAUD (USART Baud-Rate Generation Register): FCH 7 6 5 4 3 2 1 0 | UBAUD7 | UBAUD6 | UBAUD5 | UBAUD4 | UBAUD3 | UBAUD2 | UBAUD1 | UBAUD0 | |--------|--------|--------|--------|--------|--------|--------|--------| | R/W Initial value: FFH **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. #### UDATA (USART Data Register): FDH | 7 | 7 6 | | 6 5 | | 4 | 3 | 3 2 | | 0 | | | |------------|-----------------------------------------------------------------------------|--|---------|---------|---------|---------|----------------|--|---|--|--| | UDATA7 | IDATA7 UDATA6 UDATA 5 R/W R/W R/W | | UDATA 4 | UDATA 3 | UDATA 2 | UDATA 1 | UDATA 0<br>R/W | | | | | | R/W | | | R/W | R/W | R/W | R/W | | | | | | | Initial va | | | | | | | | | | | | **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. #### FPCR (USART Floating Point Register): 1019H | 7 | 6 5 | | 4 | 3 | 2 | 1 | 0 | | |-------|-------------|-----|-------|-------|-------|-------|----------------|--| | FPCR7 | FPCR7 FPCR6 | | FPCR4 | FPCR3 | FPCR2 | FPCR1 | FPCR0 | | | R/W | | | | | | | | Initi | ial value: 00H | | FPCR [7:0] USART Floating Point Counter 8-bit floating point counter **NOTES:** BAUD RATE compensation can be used in the following ways: Example1) Condition: sysclk = 16MHz, Baud rate = 9600 bps, Asynchronous Normal Mode (U2X = 0) Baud rate = sysclk / 16 x (UBAUD + 1) Calculated UBAUD = (1000000 / Target Baud rate) - 1 = 103.17, Error rate = 0.17 ⇒ UBAUD = 104 UCTRL4 = 0x04, Enable baudrate Compensation Calculated FPCR = (UBAUD - Calculated UBAUD) x 256 = (104 - 103.17) x 256 = 212.48 $\Rightarrow$ FPCR = 213 Example2) Condition: sysclk = 16MHz, Baud rate = 115,200 bps, Asynchronous Normal Mode (U2X = 0) Baud rate = sysclk / 16 x (UBAUD + 1) Calculated UBAUD = (1000000 / Target Baud rate) – 1 = 7.68, Error rate = 0.68 ⇒ UBAUD = 8 UCTRL4 = 0x04, Enable baudrate Compensation Calculated FPCR = (UBAUD - Calculated UBAUD) x 256 = (8 - 7.68) x 256 = $81.92 \Rightarrow$ **FPCR = 82** # RTOCH (Receiver Time Out Counter High Register): 101AH | 7 | 7 6 | | 4 | 3 | 2 | 1 | 0 | | |--------|-------------------|--|--------|--------|--------|--------|--------|--| | RTOCH7 | CH7 RTOCH6 RTOCH5 | | RTOCH4 | RTOCH3 | RTOCH2 | RTOCH1 | RTOCH0 | | | R/W | R/W R/W R/W | | R/W | R/W | R/W | R/W | R/W | | | | | | | | | 1 10 | -1 | | Initial value: 00H # RTOCL (Receiver Time Out Counter Low Register): 101BH | 7 | 6 5 | | 4 | 3 | 2 | 1 | 0 | | |--------|--------|--------|--------|--------|--------|--------|--------|--| | RTOCL7 | RTOCL6 | RTOCL5 | RTOCL4 | RTOCL3 | RTOCL2 | RTOCL1 | RTOCL0 | | | R/W | | | | | | | | | | | Initial value: 00H # 14.15 Baud Rate setting (example) Table 36. Examples of UBAUD Settings for Commonly Used Oscillator Frequencies | | fOSC=1 | .00MHz | | | fOSC=1.8432MHz | | | | fOSC=2.00MHz | | | | |------------|--------|----------|-------|--------|----------------|--------|-------|-------|----------------|--------|-------|-------| | Baud | U2X=0 | | U2X=1 | | U2X=0 | | U2X=1 | | U2X=0 | | U2X=1 | | | Rate | UBAU | ERRO | UBAU | ERRO | UBAU | ERRO | UBAU | ERRO | UBAU | ERRO | UBAU | ERRO | | | D | R | D | R | D | R | D | R | D | R | D | R | | 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.4<br>K | 3 | 8.5% | 8 | -3.5% | 7 | 0.0% | 15 | 0.0% | 8 | -3.5% | 16 | 2.1% | | 19.2<br>K | 2 | 8.5% | 6 | -7.0% | 5 | 0.0% | 11 | 0.0% | 6 | -7.0% | 12 | 0.2% | | 28.8<br>K | 1 | 8.5% | 3 | 8.5% | 3 | 0.0% | 7 | 0.0% | 3 | 8.5% | 8 | -3.5% | | 38.4<br>K | 1 | -18.6% | 2 | 8.5% | 2 | 0.0% | 5 | 0.0% | 2 | 8.5% | 6 | -7.0% | | 57.6<br>K | - | - | 1 | 8.5% | 1 | -25.0% | 3 | 0.0% | 1 | 8.5% | 3 | 8.5% | | 76.8<br>K | - | - | 1 | -18.6% | 1 | 0.0% | 2 | 0.0% | 1 | -18.6% | 2 | 8.5% | | 115.2<br>K | - | - | - | - | - | - | 1 | 0.0% | - | - | 1 | 8.5% | | 230.4<br>K | - | - | ı | 1 | - | - | - | - | - | - | - | - | | | fOSC=3 | 3.6864MH | Z | | fOSC=4.00MHz | | | | fOSC=7.3728MH: | | z | | | Baud | U2X=0 | | U2X=1 | | U2X=0 | | U2X=1 | | U2X=0 | | U2X=1 | | | Rate | UBAU | ERRO | UBAU | ERRO | UBAU | ERRO | UBAU | ERRO | UBAU | ERRO | UBAU | ERRO | | | D | R | D | R | D | R | D | R | D | R | D | R | | 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.2<br>K | 1 | 0.0% | 3 | 0.0% | 1 | 8.5% | 3 | 8.5% | 3 | 0.0% | 7 | 0.0% | | 230.4<br>K | - | - | 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 | .00MHz | | | fOSC=1 | 1.0592MF | ·lz | | fOSC=1 | 4.7456MH | łz | | | Baud | U2X=0 | | U2X=1 | | U2X=0 | | U2X=1 | | U2X=0 | | U2X=1 | | | Rate | UBAU | ERRO | UBAU | ERRO | UBAU | ERRO | UBAU | ERRO | UBAU | ERRO | UBAU | ERRO | | | D | R | D | R | D | R | D | R | D | R | D | R | | 2400 | 207 | 0.2% | - | - | - | - | - | - | - | - | - | - | | 4800 | 103 | 0.2% | 207 | 0.2% | 143 | 0.0% | - | - | 191 | 0.0% | - | - | | 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.2 | 3 | 8.5% | 8 | -3.5% | 5 | 0.0% | 11 | 0.0% | 7 | 0.0% | 15 | 0.0% | | K | 3 | 6.5% | 0 | -3.5% | 5 | 0.0% | 11 | 0.0% | ′ | 0.0% | 15 | 0.0% | | 230.4 | 1 | 8.5% | 3 | 8.5% | 2 | 0.0% | 5 | 0.0% | 3 | 0.0% | 7 | 0.0% | | K | ' | 0.5 /6 | 3 | 0.5 /6 | | 0.0 /0 | 3 | 0.0 /0 | 3 | 0.0 /0 | ′ | 0.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 | -7.8% | ## 14.16 0% Error Baud Rate This USART1 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 (fSCLK = 16MHz), integer count value must be 16.36 value (BAUD+1 = $16000000/(16\times57600)$ = 17.36). Here, the accurate BAUD value is 16.36. To realize 0% error of baud rate, floating point counter value must be 164 ((17-16.36) x 256 = 164) and BAUD value must be 17. Namely you have to write the 164(decimal number) in USART\_FPCR and 17(decimal number) in USART\_BAUD. Figure 102. 0% Error Baud Rate Block Diagram # 15 LED Driver ### 15.1 Overview LED drive contains 8 COM / 16 SEG output pins. They are also shared with Touch sensing pins. By setting LED CONTROL REGISTER 1 (LEDCON1), there are 5 modes that can be shared(or not shared) with touch sensing function. The controller consists of display data RAM memory, COM and SEG generator. COM0-COM7 are shared with SEG0-SEG7. It is selected by CSER register. SEG8~SEG15 is dedicated only SEG function in LED function. COM and SEG pin can also be used as I / O pins. COMOE, and SEGOE1,SEGOE2 registers are used to select SEG0-SEG14, COM0-COM7. During the power-on reset, reset pin, BOD reset or watchdog reset, LED are turned off. ## 15.2 Block Diagram Figure 103. LED Driver Block Diagram # 15.3 Register Map Table 37. LED Driver Register Map | Name | Address | Direction | Default | Description | |-----------|---------|-----------|---------|----------------------------------------| | COMOE | 2F00H | R/W | 00H | LED COM Output Enable Register | | SEGOE1 | 2F01H | R/W | 00H | LED SEG Output Enable 1 Register | | SEGOE2 | 2F02H | R/W | 00H | LED SEG Output Enable 2 Register | | PRESD | 2F03H | R/W | 00H | LED Prescale Data Register | | CSER | 2F04H | R/W | 00H | LED COM or SEG Enable Register | | COMPWID | 2F05H | R/W | 00H | LED COM Pulse Width Control Register | | STPD0 | 2F0AH | R/W | 00H | LED Stop Duration 0 Register | | STPD1 | 2F0BH | R/W | 00H | LED Stop Duration 1 Register | | STPD2 | 2F0CH | R/W | 00H | LED Stop Duration 2 Register | | LEDSR | 2F0DH | R/W | 01H | LED Status Register | | LEDCON3 | 2F0EH | R/W | 00H | LED Control3 Register | | LEDCON2 | 2F0FH | R/W | 00H | LED Control 2 Register | | LEDCON1 | 2F10H | R/W | 00H | LED Control 1 Register | | CCLSR | 2F30H | R/W | 01H | Constant Current level select Register | | TEST_COM | 2F7CH | R/W | 00H | COM Register for test | | TEST_SEG0 | 2F7DH | R/W | 00H | SEG Register for test | | TEST_SEG1 | 2F7EH | R/W | 00H | SEG Register for test | # 15.4 Register Description for LED Driver ## COMOE (LED COM Output Enable Register): 2F00H | 1 | 6 | 5 | 4 | 3 | 2 | 1 | U | | |--------------|--------|--------|--------|--------|--------|--------|--------|--| | COMOE7 | COMOE6 | COMOE5 | COMOE4 | COMOE3 | COMOE2 | COMOE1 | COMOE0 | | | RW | | Initial valu | | | | | | | | | initiai value: 00F | COMOE7 | COM7 Output Enable | |--------|------------------------------------------------------------------------------------------| | | 0 Disable | | | 1 Enable | | COMOE6 | COM6 Output Enable | | | 0 Disable | | | 1 Enable | | COMOE5 | COM5 Output Enable | | | 0 Disable | | | 1 Enable | | COMOE4 | COM4 Output Enable | | | 0 Disable | | | 1 Enable | | COMOE3 | COM3 Output Enable | | | | | | 0 Disable | | | <ul><li>0 Disable</li><li>1 Enable</li></ul> | | COMOE2 | 2.000.0 | | COMOE2 | 1 Enable | | COMOE2 | 1 Enable COM2 Output Enable | | COMOE2 | 1 Enable COM2 Output Enable 0 Disable | | | <ul><li>1 Enable</li><li>COM2 Output Enable</li><li>0 Disable</li><li>1 Enable</li></ul> | | | 1 Enable COM2 Output Enable 0 Disable 1 Enable COM1 Output Enable | | | 1 Enable COM2 Output Enable 0 Disable 1 Enable COM1 Output Enable 0 Disable | | COMOE1 | 1 Enable COM2 Output Enable 0 Disable 1 Enable COM1 Output Enable 0 Disable 1 Enable | ## SEGOE1 (LED SEG Output Enable 1 Register): 2F01H SEGOE1.6 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |--------------------|----------|----------|----------|----------|----------|----------|----------|--|--| | SEGOE1.7 | SEGOE1.6 | SEGOE1.5 | SEGOE1.4 | SEGOE1.3 | SEGOE1.2 | SEGOE1.1 | SEGOE1.0 | | | | RW | | | Initial value: 00H | | | | | | | | | | SEGOE1.7 SEG7 Output Enable 0 Disable1 EnableSEG6 Output Enable 0 Disable 1 Enable SEGOE1.5 SEG5 Output Enable 0 Disable 1 Enable SEGOE1.4 SEG4 Output Enable 0 Disable Enable SEGOE1.3 SEG3 Output Enable 0 Disable 1 Enable SEGOE1.2 SEG2 Output Enable 0 Disable 1 Enable SEGOE1.1 SEG1 Output Enable Disable 1 Enable SEGOE1.0 SEG0 Output Enable 0 Disable 1 Enable ## SEGOE2 (LED SEG Output Enable 2 Register): 2F02H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---------------|----------|----------|----------|----------|---------|----------|----------|--|--| | SEGOE2.7 | SEGOE2.6 | SEGOE2.5 | SEGOE2.4 | SEGOE2.3 | SEGOE22 | SEGOE2.1 | SEGOE2.0 | | | | RW | | | Initial value | | | | | | | | | | Initial value: 00H SEGOE2.7 SEG15 Output Enable 0 Disable 1 Enable SEGOE2.6 SEG14 Output Enable 0 Disable 1 Enable SEGOE2.5 SEG13 Output Enable 0 Disable Enable SEG12 Output Enable SEGOE2.4 0 Disable Enable SEGOE2.3 SEG11 Output Enable 0 Disable 1 Enable SEGOE2.2 SEG10 Output Enable 0 Disable 1 Enable SEGOE2.1 SEG9 Output Enable 0 Disable Enable 1 SEGOE2.0 SEG8 Output Enable 0 Disable 1 Enable ## PRESD (LED Prescale Data Register): 2F03H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | PRESD7 | PRESD6 | PRESD5 | PRESD4 | PRESD3 | PRESD2 | PRESD1 | PRESD0 | | RW Initial value: 00H PRESD[7:0] Prescale value of LED Clock LED Clock = fCLK / (PRESD + 1) (fCLK is a selected input clock) ## CSER (LED COM or SEG Enable Register): 2F04H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | CS_SEL7 | CS_SEL6 | CS_SEL5 | CS_SEL4 | CS_SEL3 | CS_SEL2 | CS_SEL1 | CS_SEL0 | | RW Initial value: 00H | | | Initi | |---------|------------------|-------| | CS_SEL7 | Select COM7/SEG7 | | | | 0 Select SEG7 | | | | 1 Select COM7 | | | CS_SEL6 | Select COM6/SEG6 | | | | 0 Select SEG6 | | | | 1 Select COM6 | | | CS_SEL5 | Select COM5/SEG5 | | | | 0 Select SEG5 | | | | 1 Select COM5 | | | CS_SEL4 | Select COM4/SEG4 | | | | 0 Select SEG4 | | | | 1 Select COM4 | | | CS_SEL3 | Select COM3/SEG3 | | | | 0 Select SEG3 | | | | 1 Select COM3 | | | CS_SEL2 | Select COM2/SEG2 | | | | 0 Select SEG2 | | | | 1 Select COM2 | | | CS_SEL1 | Select COM1/SEG1 | | | | 0 Select SEG1 | | | | 1 Select COM1 | | | CS_SEL0 | Select COM0/SEG0 | | | | 0 Select SEG0 | | | | 1 Select COM0 | | | | | | ## COMPWID (LED COM Pulse Width Control Register): 2F05H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------|----------|----------|----------|----------|----------|----------|----------| | COMPWID7 | COMPWID6 | COMPWID5 | COMPWID4 | COMPWID3 | COMPWID2 | COMPWID1 | COMPWID0 | | RW | | | | | | | 1 14 | | Initial value: 00H COMPWID[7:0] Maximum Pulse width for COM COM Width = LED CLK / (COMPWID + 1) (LED CLK is a Prescaler output clock) ### STPD0 (LED stop Duration 0 Register): 2F0AH | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-------|-------|-------|-------|-------|-------|-------|-------| | | STPD7 | STPD6 | STPD5 | STPD4 | STPD3 | STPD2 | STPD1 | STPD0 | | • | RW Initial value: 00H ### STPD1 (LED stop Duration 1 Register): 2F0BH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|-------|-------| | STPD15 | STPD14 | STPD13 | STPD12 | STPD11 | STPD10 | STPD9 | STPD8 | | RW Initial value: 00H ## STPD2 (LED stop Duration 2 Register): 2F0CH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|--------|--------|--------|--------| | - | - | - | - | STPD19 | STPD18 | STPD17 | STPD16 | | - | - | - | - | RW | RW | RW | RW | Initial value: 00H STPD[19:0] LED stop duration. These registers are valid in LED Stop Count mode or smart share mode. LED Stop Duration Width = fCLK / (STPD + 1) (fCLK is a selected input clock) ### LEDSR (LED Status Register): 2F0DH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|--------|---------|----------|----------| | - | - | - | - | MATCHF | LED_INT | LED_INTE | LED_ENDF | | - | - | - | - | RW | RW | RW | RW | Initial value: 01H **MATCHF** This bit is set when the value of internal counter becomes the same with STPD register. After LED display, this bit will be cleared automatically. 0 Unmatched Matched LED\_INT LED Interrupt flag when LED\_INTE is set. LED interrupt not generated LED interrupt generated 1 LED\_INTE LED Interrupt Enable Disable 1 Enable LED\_ENDF LED Operation Flag 0 Under LED Operation1 LED Operation is ended ### LEDCON3 (LED Control 3 Register): 2F0EH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------| | SET_TIME3 | SET_TIME2 | SET_TIME1 | SET_TIME0 | CLR_TIME3 | CLR_TIME2 | CLR_TIME1 | CLR_TIME0 | | RW | RW | RW | RW | R?W- | RW- | RW | RW | Initial value: 00H SET\_TIME[3:0] SEG GND Start position These bits are valid only when SRTEN(LEDCON2[3]) is High. fCLK = 16MHZ 0000 1us 0001 2us 0010 4us 0011 6us 0100 8us 0101 10us 0110 12us 0111 14us 16us 1000 1001 18us 20us 1010 22us 1011 1100 24us 26us 1101 1110 28us 1111 32us CLR\_TIME[3:0] SEG GND Start position These bits are valid only when OVERTS - 1us SRTEN(LEDCON2[3]) is High. fCLK = 16MHZ, OVERTS is bit[6:4] of LEDCON2 0000 0001 OVERTS - 2us 0010 OVERTS - 4us 0011 OVERTS - 6us 0100 OVERTS - 8us 0101 OVERTS - 10us 0110 OVERTS - 12us 0111 OVERTS - 14us 1000 OVERTS - 16us 1001 OVERTS - 18us 1010 OVERTS - 20us 1011 OVERTS - 22us 1100 OVERTS - 24us 1101 OVERTS - 26us 1110 OVERTS - 28us OVERTS - 32us 1111 ### LEDCON2 (LED Control 2 Register): 2F0FH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|-------|---|---|---| | OVERLAP | OVERTS2 | OVERTS1 | OVERTS0 | SRTEN | - | ı | - | | RW | RW | RW | RW | - | - | - | - | Initial value: 00H OVERLAP How to make Overlap Time 0 Overlap time = 3us ~ 64us @ fCLK = 16MHZ 1 Overlap time = fCLK/2 OVERTS[2:0] OVERLAP TIME SELECT. These bits are valid only when OVERLAP is LOW. 000 64us 001 32us 010 24us 011 21us 100 12us 101 9us 6us 110 3us 111 SRTEN SEG GND Select 0 non select1 Select # LEDCON1 (LED Control 1 Register): 2F10H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|-----|-----|-----|-------|-------| | - | - | - | MD2 | MD1 | MD0 | LEDEN | LEDST | | - | - | - | RW | RW | RW | RW | RW | Initial value: 00H MD[2:0] Mode Select 000 LED Auto Mode 001 Hand Shake Mode 010 LED STOP Count Mode 011 **Smart Share Mode** LED Alone Mode 1xx **LEDEN** LED Enable LED Disable LED Enable LEDST LED Start or Stop under LEDEN = 1 Stop LED Operation 1 Start LED Operation ## CCLSR (Constant Current Level Select Register): 2F30H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|------|------| | - | - | ı | ı | - | - | COA1 | COA0 | | - | - | - | - | - | - | RW | RW | Initial value: 00H COA[1:0] SEG(mA) 00 8.47mA 01 13.61mA 10 19.49mA 11 Reserved(test only) ## TEST\_COM (TEST COM Register for Test): 2F7CH | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|------|-------|-------|-------|-------|-------|-------|-------| | TC | COM7 | TCOM6 | TCOM5 | TCOM4 | TCOM3 | TCOM2 | TCOM1 | TCOM0 | | ı | RW. | RW Initial value: 00H ## TEST\_SEG0 (TEST SEG Low Byte Register for Test): 2F7DH | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|--------|--------|--------|--------|--------|--------|--------|--------| | | TSEG07 | TSEG06 | TSEG05 | TSEG04 | TSEG03 | TSEG02 | TSEG01 | TSEG00 | | • | RW Initial value: 00H ## TEST\_SEG0 (TEST SEG High Byte Register for Test): 2F7EH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | TSEG17 | TSEG16 | TSEG15 | TSEG14 | TSEG13 | TSEG12 | TSEG11 | TSEG10 | | RW Initial value: 00H # 15.5 **LED RAM** Table 38. LED RAM | Address | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|-------|-------|-------|-------|-------|-------|-------|------|------| | 2F13H | COM0L | SEG7 | SEG6 | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 | - | | 2F14H | СОМ0Н | SEG15 | SEG14 | SEG13 | SEG12 | SEG11 | SEG10 | SEG9 | SEG8 | | 2F15H | COM1L | SEG7 | SEG6 | SEG5 | SEG4 | SEG3 | SEG2 | - | SEG0 | | 2F16H | COM1H | SEG15 | SEG14 | SEG13 | SEG12 | SEG11 | SEG10 | SEG9 | SEG8 | | 2F17H | COM2L | SEG7 | SEG6 | SEG5 | SEG4 | SEG3 | - | SEG1 | SEG0 | | 2F18H | COM2H | SEG15 | SEG14 | SEG13 | SEG12 | SEG11 | SEG10 | SEG9 | SEG8 | | 2F19H | COM3L | SEG7 | SEG6 | SEG5 | SEG4 | - | SEG2 | SEG1 | SEG0 | | 2F1AH | СОМЗН | SEG15 | SEG14 | SEG13 | SEG12 | SEG11 | SEG10 | SEG9 | SEG8 | | 2F1BH | COM4L | SEG7 | SEG6 | SEG5 | - | SEG3 | SEG2 | SEG1 | SEG0 | | 2F1CH | COM4H | SEG15 | SEG14 | SEG13 | SEG12 | SEG11 | SEG10 | SEG9 | SEG8 | | 2F1DH | COM5L | SEG7 | SEG6 | - | SEG4 | SEG3 | SEG2 | SEG1 | SEG0 | | 2F1EH | COM5H | SEG15 | SEG14 | SEG13 | SEG12 | SEG11 | SEG10 | SEG9 | SEG8 | | 2F1FH | COM6L | SEG7 | - | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 | SEG0 | | 2F20H | СОМ6Н | SEG15 | SEG14 | SEG13 | SEG12 | SEG11 | SEG10 | SEG9 | SEG8 | | 2F21H | COM7L | - | SEG6 | SEG5 | SEG4 | SEG3 | SEG2 | SEG1 | SEG0 | | 2F22H | COM7H | SEG15 | SEG14 | SEG13 | SEG12 | SEG11 | SEG10 | SEG9 | SEG8 | <sup>&</sup>quot;-" means no affect to SEG output # 15.6 Example Circuit ### 15.6.1 SEG0~SEG7 Matrix Figure 104. SEG0~SEG7 Matrix ### 15.6.2 SEG8~SEG15 Matrix Figure 105. SEG8~SEG15 Matrix ## 15.7 Mode Functions By depending on how set MD values (LEDCON1[4:2]), there are fifth operation modes. ### 15.7.1 LED AUTO Mode First mode is LED auto mode irrelevant to touch sensing function that can start by write "1" LEDST by program. Below all mode is possible only after LEDEN (LEDCON1[1])is set "1". Figure 106 show the LED auto mode in case of CSER = 0100\_0001B. (k) shows the overlaptime that exists between the COM and the COM that are controllable by the program. When enabling the LED by write LEDST "1" as in (A), LED can operate continually... An interrupt occurs at point (B) where the LED 1 frame operation terminated when LED\_INTE is set. Figure 106. LED auto Mode ### 15.7.2 LED Alone Mode First mode is LED alone mode irrelevant to touch sensing function that can re-start by write "1" LEDST by program. Figure 107 show the LED alone mode in case of CSER = 0100\_0001B. (k) shows the overlaptime that exists between the COM and the COM that are controllable by the program. An interrupt occurs at point (A) where the LED operation terminated when LED\_INTE is set. When enabling the LED by rewrite LEDST "1" as in (B), LED can starts again. Figure 107. LED alone Mode #### 15.7.3 Hand Shake Mode The second mode is hand shake mode to inform the touch when the LED is finished and to make LED start again by the TOUCH\_END signal from the touch sensing. Figure 108 show the hand shake mode in the case of CSER = 0000\_0001B. Frame cycle is defined by sum of LED operation (1) and touch key scan (2). It is the minimum cycle without flicker. An interrupt occurs at point (A) where the LED operation terminated when LED\_INTE is set. Touch sensing continues to send the "1" until LED\_ENDF changes to "0" in (B), and then LED start again. Figure 108. Hand Shake Mode #### 15.7.4 LED Stop Count Mode The third mode is LED stop count mode that the beginning of the next LED operation is determined by LED stop duration register value after the previous LED operation end. It is need when deciding the period of frame that LED can operate without flicker. Figure 109 show LED STOP Count mode in case of CSER = 1000\_0000B. An interrupt occurs at point (A) here the LED operation terminated when LED\_INTE is set. At the same time, 20-bit counter starts to increase by the internal enable bit. If 20-bit LEDSTPD register is matched with the counter, MATCHF(bit3 of LEDSR) is set "1". LED\_ENDF is cleared "0", 20-bit counter is cleared "0" and LED start again as in (B). Figure 109. LED Stop Count Mode #### 15.7.5 Smart Share Mode The fourth mode is smart share mode that the beginning of the next LED operation can't do until current pending touch key scan ends although MATCHF (LEDSR[3]) generate after the previous LED operation end. It is need when as many as touch key scan want to be executed during touch key scan time. Figure 110 show smart share mode in case of CSER = 1000\_0000B. An interrupt occurs at point (A) here the LED operation terminated when LED\_INTE is set. At the same time, 20-bit counter starts to increase by the internal enable bit although 20-bit STPD register is matched with the counter and then MATCHF ( LEDSR[3]) is set "1". LED ENDF can't clear "0" and LED can't start again until the TOUCH END signal from the touch sensing is active. If any more LED display is not needed, it is highly recommended LEDEN (LEDCON1[1]) setting as "0" to be executed between the end of LED operation (A) and LED restart (B) to prevent flicker. Figure 110. Smart Share Mode # 16 20-Channel Touch Switch # 16.1 Features - 10V Conducted Susceptibility (CS) Immunity - Self-Capacitive Touch Key Sensor. - Total 20-channel Touch Key Support. - 16-bits Sensing Resolutions. - · Fast Initial Self Calibration. - Key Detection Mode : Single/Multi-Mode. - Clock Frequency during Sensing Operation: 16MHz. - The Improvement of the SNR by Bias-Calibration in Analog Sensing Block. - VDD Operating Voltage: 2.7V ~ 5.5V. - Current Consumption : T.B.D. - Current Consumption@STOPmode :< 1uA.</li> - Operation Temperature : -40 °C ~ 85 °C. # 16.2 Block Diagram Figure 111. 16-bit Touch Block Diagram ### 16.3 CAPN Port Connect the negative terminal of the reference capacitor Cs to CAPN port, and the positive terminal of the Cs capacitor to VDD. Cs capacitors must use 5% precision polyester plug-in capacitors, 10% high precision NPO or X7R chip capacitors. C0G type or Mylar Capacitors recommended for applications with severe temperature changes. Figure 112. CAPN Pin with Cs Capacitor # 16.4 Register Map Table 39. Touch Register Map | Name | Address | Direction | Default | Description | |---------------|---------|-----------|---------|---------------------------------------------------------------------| | SUM_CH0_F0_H | 2E00H | R | 00H | Touch Sensor Ch0 Freq0 Sum High-Byte Register | | SUM_CH0_F0_L | 2E01H | R | 00H | Touch Sensor Ch0 Freq0 Sum Low-Byte Register | | SUM_CH0_F1_H | 2E02H | R | 00H | Touch Sensor Ch0 Freq1 Sum High-Byte Register | | SUM_CH0_F1_L | 2E03H | R | 00H | Touch Sensor Ch0 Freq1 Sum Low-Byte Register | | | | | | | | SUM_CH19_F0_H | 2E4CH | R | 00H | Touch Sensor Ch19 Freq0 Sum High-Byte Register | | SUM_CH19_F0_L | 2E4DH | R | 00H | Touch Sensor Ch19 Freq0 Sum Low-Byte Register | | SUM_CH19_F1_H | 2E4EH | R | 00H | Touch Sensor Ch19 Freq1 Sum High-Byte Register | | SUM_CH19_F1_L | 2E4FH | R | 00H | Touch Sensor Ch19 Freq1 Sum Low-Byte Register | | SCO0_H | 2E50H | R/W | 00H | Touch Sensor Offset Capacitor Selection High-Byte Register for Ch0 | | SCO0_L | 2E51H | R/W | 00H | Touch Sensor Offset Capacitor Selection Low-Byte Register for Ch0 | | | | | | | | SCO19_H | 2E76H | R/W | 00H | Touch Sensor Offset Capacitor Selection High-Byte Register for Ch19 | | SCO19_L | 2E77H | R/W | 00H | Touch Sensor Offset Capacitor Selection Low-Byte Register for Ch19 | | TS_CON | 2E80H | R/W | 00H | Touch Sensor Control Register | | TS_MODE | 2E81H | R/W | 00H | Touch Sensor Mode Register | | TS_SUM_CNT | 2E82H | R/W | 01H | Touch Sensor Sum Repeat Count Register | | TS_CH_SELH | 2E83H | R/W | 00H | Touch Sensor Channel Selection High-Byte Register | | TS_CH_SELM | 2E84H | R/W | 00H | Touch Sensor Channel Selection Middle-Byte Register | | TS_CH_SELL | 2E85H | R/W | 00H | Touch Sensor Channel Selection Low-Byte Register | | TS_S1_WIDH | 2E86H | R/W | 15H | S1 Minimum Time Register | | TS_SLP_CON | 2E87H | R/W | 74H | Touch Sensor Low Pass Filter Control Register | | Reserved | 2E88H | | | | | TS_TRIM | 2E89B | R/W | 07H | Touch Sensor Trimming Register | | TS_CLK_CFG | 2E8AH | R/W | 02H | Touch Sensor Clock Configuration Register | | TRIM_OSC | 2E8BH | R/W | 20H | Touch Sensor RING Oscillator Trimming Selection Register | | DELTA_OSC | 2E8CH | R/W | 01H | Touch Sensor RING Oscillator Delta Register | | TLED | 2E8DH | R/W | 30H | LED stable time Register | | TS_VHS_H | 2E8EH | R/W | 02H | Touch Sensor High Sense Voltage High-Byte Register | | TS_VHS_L | 2E8FH | R/W | 80H | Touch Sensor High Sense Voltage Low-Byte Register | | TS_VREF_H | 2F90H | R/W | 02H | Touch Sensor COMP Reference Voltage High-Byte Register | | TS_VREF_L | 2F91H | R/W | 10H | Touch Sensor COMP Reference Voltage Low-Byte Register | # 16.5 Register Description for Touch Sensing SUM\_CH0\_F0\_H (Touch Sensor Ch0 Freq0 Sum High-Byte Register): 2E00H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |--------------|----------------|----------------|------------|----------------|-------|------|----------------|--|--| | | SUM_CH0_F0_H | | | | | | | | | | R | R | R | R | R | R | R | R | | | | | | | | | | Init | ial value: 00H | | | | SUM_CH0_F0 | )_L (Touch Ser | nsor Ch0 Freq( | Sum Low-By | rte Register): | 2E01H | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | SUM_CH0_F0_L | | | | | | | | | | Initial value: 00H | SUM_CH0_F1_H (Touch Sensor Ch0 Freq1 Sum High-Byte Register): | 2E02H | |---------------------------------------------------------------|-------| | SUM_CH0_F1_L (Touch Sensor Ch0 Freq1 Sum Low-Byte Register): | 2E03H | | SUM_CH1_F0_H (Touch Sensor Ch1 Freq0 Sum High-Byte Register): | 2E04H | | SUM_CH1_F0_L (Touch Sensor Ch1 Freq0 Sum Low-Byte Register): | 2E05H | | SUM_CH1_F1_H (Touch Sensor Ch1 Freq1 Sum High-Byte Register): | 2E06H | | SUM_CH1_F1_L (Touch Sensor Ch1 Freq1 Sum Low-Byte Register): | 2E07H | | SUM_CH2_F0_H (Touch Sensor Ch2 Freq0 Sum High-Byte Register): | 2E08H | | SUM_CH2_F0_L (Touch Sensor Ch2 Freq0 Sum Low-Byte Register): | 2E09H | | SUM_CH2_F1_H (Touch Sensor Ch2 Freq1 Sum High-Byte Register): | 2E0AH | | SUM_CH2_F1_L (Touch Sensor Ch2 Freq1 Sum Low-Byte Register): | 2E0BH | | SUM_CH3_F0_H (Touch Sensor Ch3 Freq0 Sum High-Byte Register): | 2E0CH | | SUM_CH3_F0_L (Touch Sensor Ch3 Freq0 Sum Low-Byte Register): | 2E0DH | | SUM_CH3_F1_H (Touch Sensor Ch3 Freq1 Sum High-Byte Register): | 2E0EH | | SUM_CH3_F1_L (Touch Sensor Ch3 Freq1 Sum Low-Byte Register): | 2E0FH | | SUM_CH3_F0_H (Touch Sensor Ch3 Freq0 Sum High-Byte Register): | 2E0CH | | SUM_CH3_F0_L (Touch Sensor Ch3 Freq0 Sum Low-Byte Register): | 2E0DH | | SUM_CH3_F1_H (Touch Sensor Ch3 Freq1 Sum High-Byte Register): | 2E0EH | | SUM_CH3_F1_L (Touch Sensor Ch3 Freq1 Sum Low-Byte Register): | 2E0FH | | | | | SUM_CH4_F0_H (Touch Sensor Ch4 Freq0 Sum High-Byte Register): | 2E10H | |-----------------------------------------------------------------|-------| | SUM_CH4_F0_L (Touch Sensor Ch4 Freq0 Sum Low-Byte Register): | 2E11H | | SUM_CH4_F1_H (Touch Sensor Ch4 Freq1 Sum High-Byte Register): | 2E12H | | SUM_CH4_F1_L (Touch Sensor Ch4 Freq1 Sum Low-Byte Register): | 2E13H | | SUM_CH5_F0_H (Touch Sensor Ch5 Freq0 Sum High-Byte Register): | 2E14H | | SUM_CH5_F0_L (Touch Sensor Ch5 Freq0 Sum Low-Byte Register): | 2E15H | | SUM_CH5_F1_H (Touch Sensor Ch5 Freq1 Sum High-Byte Register): | 2E16H | | SUM_CH5_F1_L (Touch Sensor Ch5 Freq1 Sum Low-Byte Register): | 2E17H | | SUM_CH6_F0_H (Touch Sensor Ch6 Freq0 Sum High-Byte Register): | 2E18H | | SUM_CH6_F0_L (Touch Sensor Ch6 Freq0 Sum Low-Byte Register): | 2E19H | | SUM_CH6_F1_H (Touch Sensor Ch6 Freq1 Sum High-Byte Register): | 2E1AH | | SUM_CH6_F1_L (Touch Sensor Ch6 Freq1 Sum Low-Byte Register): | 2E1BH | | SUM_CH7_F0_H (Touch Sensor Ch7 Freq0 Sum High-Byte Register): | 2E1CH | | SUM_CH7_F0_L (Touch Sensor Ch7 Freq0 Sum Low-Byte Register): | 2E1DH | | SUM_CH7_F1_H (Touch Sensor Ch7 Freq1 Sum High-Byte Register): | 2E1EH | | SUM_CH7_F1_L (Touch Sensor Ch7 Freq1 Sum Low-Byte Register): | 2E1FH | | SUM_CH8_F0_H (Touch Sensor Ch8 Freq0 Sum High-Byte Register): | 2E20H | | SUM_CH8_F0_L (Touch Sensor Ch8 Freq0 Sum Low-Byte Register): | 2E21H | | SUM_CH8_F1_H (Touch Sensor Ch8 Freq1 Sum High-Byte Register): | 2E22H | | SUM_CH8_F1_L (Touch Sensor Ch8 Freq1 Sum Low-Byte Register): | 2E23H | | SUM_CH9_F0_H (Touch Sensor Ch9 Freq0 Sum High-Byte Register): | 2E24H | | SUM_CH9_F0_L (Touch Sensor Ch9 Freq0 Sum Low-Byte Register): | 2E25H | | SUM_CH9_F1_H (Touch Sensor Ch9 Freq1 Sum High-Byte Register): | 2E26H | | SUM_CH9_F1_L (Touch Sensor Ch9 Freq1 Sum Low-Byte Register): | 2E27H | | SUM_CH10_F0_H (Touch Sensor Ch10 Freq0 Sum High-Byte Register): | 2E28H | | SUM_CH10_F0_L (Touch Sensor Ch10 Freq0 Sum Low-Byte Register): | 2E29H | | SUM_CH10_F1_H (Touch Sensor Ch10 Freq1 Sum High-Byte Register): | 2E2AH | | | | | SUM_CH10_F1_L (Touch Sensor Ch10 Freq1 Sum Low-Byte Register): | 2E2BH | |-----------------------------------------------------------------|-------| | SUM_CH11_F0_H (Touch Sensor Ch11 Freq0 Sum High-Byte Register): | 2E2CH | | SUM_CH11_F0_L (Touch Sensor Ch11 Freq0 Sum Low-Byte Register): | 2E2DH | | SUM_CH11_F1_H (Touch Sensor Ch11 Freq1 Sum High-Byte Register): | 2E2EH | | SUM_CH11_F1_L (Touch Sensor Ch11 Freq1 Sum Low-Byte Register): | 2E2FH | | SUM_CH12_F0_H (Touch Sensor Ch12 Freq0 Sum High-Byte Register): | 2E30H | | SUM_CH12_F0_L (Touch Sensor Ch12 Freq0 Sum Low-Byte Register): | 2E31H | | SUM_CH12_F1_H (Touch Sensor Ch12 Freq1 Sum High-Byte Register): | 2E32H | | SUM_CH12_F1_L (Touch Sensor Ch12 Freq1 Sum Low-Byte Register): | 2E33H | | SUM_CH13_F0_H (Touch Sensor Ch13 Freq0 Sum High-Byte Register): | 2E34H | | SUM_CH13_F0_L (Touch Sensor Ch13 Freq0 Sum Low-Byte Register): | 2E35H | | SUM_CH13_F1_H (Touch Sensor Ch13 Freq1 Sum High-Byte Register): | 2E36H | | SUM_CH13_F1_L (Touch Sensor Ch13 Freq1 Sum Low-Byte Register): | 2E37H | | SUM_CH14_F0_H (Touch Sensor Ch14 Freq0 Sum High-Byte Register): | 2E38H | | SUM_CH14_F0_L (Touch Sensor Ch14 Freq0 Sum Low-Byte Register): | 2E39H | | SUM_CH14_F1_H (Touch Sensor Ch14 Freq1 Sum High-Byte Register): | 2E3AH | | SUM_CH14_F1_L (Touch Sensor Ch14 Freq1 Sum Low-Byte Register): | 2E3BH | | SUM_CH15_F0_H (Touch Sensor Ch15 Freq0 Sum High-Byte Register): | 2E3CH | | SUM_CH15_F0_L (Touch Sensor Ch15 Freq0 Sum Low-Byte Register): | 2E3DH | | SUM_CH15_F1_H (Touch Sensor Ch15 Freq1 Sum High-Byte Register): | 2E3EH | | SUM_CH15_F1_L (Touch Sensor Ch15 Freq1 Sum Low-Byte Register): | 2E3FH | | SUM_CH16_F0_H (Touch Sensor Ch16 Freq0 Sum High-Byte Register): | 2E40H | | SUM_CH16_F0_L (Touch Sensor Ch16 Freq0 Sum Low-Byte Register): | 2E41H | | SUM_CH16_F1_H (Touch Sensor Ch16 Freq1 Sum High-Byte Register): | 2E42H | | SUM_CH16_F1_L (Touch Sensor Ch16 Freq1 Sum Low-Byte Register): | 2E43H | | SUM_CH17_F0_H (Touch Sensor Ch17 Freq0 Sum High-Byte Register): | 2E44H | | SUM_CH17_F0_L (Touch Sensor Ch17 Freq0 Sum Low-Byte Register): | 2E45H | | | | | SUM_CH17_F1_H (Touch Sensor Ch17 Freq1 Sum High-Byte Register): | 2E46H | |-----------------------------------------------------------------|-------| | SUM_CH17_F1_L (Touch Sensor Ch17 Freq1 Sum Low-Byte Register): | 2E47H | | SUM_CH18_F0_H (Touch Sensor Ch18 Freq0 Sum High-Byte Register): | 2E48H | | SUM_CH18_F0_L (Touch Sensor Ch18 Freq0 Sum Low-Byte Register): | 2E49H | | SUM_CH18_F1_H (Touch Sensor Ch18 Freq1 Sum High-Byte Register): | 2E4AH | | SUM_CH18_F1_L (Touch Sensor Ch18 Freq1 Sum Low-Byte Register): | 2E4BH | | SUM_CH19_F0_H (Touch Sensor Ch19 Freq0 Sum High-Byte Register): | 2E4CH | | SUM_CH19_F0_L (Touch Sensor Ch19 Freq0 Sum Low-Byte Register): | 2E4DH | | SUM_CH19_F1_H (Touch Sensor Ch19 Freq1 Sum High-Byte Register): | 2E4EH | | SUM_CH19_F1_L (Touch Sensor Ch19 Freq1 Sum Low-Byte Register): | 2E4FH | | O0_H (Tou | ch Sensor Offs | set Capacitor S | Selection High-l | Byte Register | for CH0): | 2E50H | | |-------------|---------------------|----------------------|------------------|-----------------|-----------|-------|----------------------------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | SCOO_H | | | | | | | | | | | RW | | | | | | | | 1141 | ا ۱۸۸ بویدای داد | | | | | | | | initi | iai vaiue. our | | O0_L (Touc | ch Sensor Offs | set Capacitor S | election Low-B | Byte Register | for CH0): | 2E51H | iai vaiue. oor | | COO_L (Touc | ch Sensor Offs<br>6 | set Capacitor S<br>5 | election Low-B | 3 gyte Register | for CH0): | | ial value: 00ŀ<br><b>0</b> | | O0_L (Touc | | · | | 3 | · | 2E51H | | | 7 RW | | · | 4 | 3 | · | 2E51H | | | SCO1_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH1): | 2E52H | |------------------------------------------------------------------------------|-------| | SCO1_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH1): | 2E53H | | SCO2_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH2): | 2E54H | | SCO2_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH2): | 2E55H | | SCO3_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH3): | 2E56H | | SCO3_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH3): | 2E57H | | SCO4_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH4): | 2E58H | | SCO4_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH4): | 2E59H | |--------------------------------------------------------------------------------|-------| | SCO5_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH5): | 2E5AH | | SCO5_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH5): | 2E5BH | | SCO6_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH6): | 2E5CH | | SCO6_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH6): | 2E5DH | | SCO7_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH7): | 2E5EH | | SCO7_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH7): | 2E5FH | | SCO8_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH8): | 2E60H | | SCO8_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH8): | 2E61H | | SCO9_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH9): | 2E62H | | SCO9_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH9): | 2E63H | | SCO10_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH10): | 2E64H | | SCO10_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH10): | 2E65H | | SCO11_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH11): | 2E66H | | SCO11_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH11): | 2E67H | | SCO12_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH12): | 2E68H | | SCO12_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH12): | 2E69H | | SCO13_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH13): | 2E6AH | | SCO13_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH13): | 2E6BH | | SCO14_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH14): | 2E6CH | | SCO14_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH14): | 2E6DH | | SCO15_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH15): | 2E6EH | | SCO15_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH15): | 2E6FH | | SCO16_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH16): | 2E70H | | SCO16_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH16): | 2E71H | | SCO17_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH17): | 2E72H | | SCO17_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH17): | 2E73H | | | | 16. 20-Channel Touch Switch A96T418 User's manual SCO18\_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH18): 2E74H SCO18\_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH18): 2E75H SCO19\_H (Touch Sensor Offset Capacitor Selection High-Byte Register for CH19): 2E76H SCO19\_L (Touch Sensor Offset Capacitor Selection Low-Byte Register for CH19): 2E77H ### TS\_CON (Touch Sensor Control Register): 2E80H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|-------|---|--------| | - | - | - | ı | - | TS_IF | ı | TS_RUN | | - | - | - | - | - | RW | - | RW | Initial value: 00H TS\_IF Touch Sensor Interrupt Flag. To start the new sensing, you must clear this bit after reading the SUM registers. If this bit is changed from 1 to 0, the SUM registers will be reset to 0s. No new sensing results 1 In normal mode, this flag indicates that the new sensing results are generated. TS\_RUN Touch Sensor Enable 0 0 Touch Sensor Disable (Default) 1 Touch Sensor Enable ## TS\_MODE (Touch Sensor Mode Register): 2E81H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---------|--------------|-------|-------|-------|-------|-------| | - | SC_GAIN | S1_SWEEP_DIS | MODE2 | MODE1 | MODE0 | PORT1 | PORT0 | | - | RW | RW | RW | - | RW | RW | RW | Initial value: 00H | SC_GAIN | Gain | Calibration Capacitor Enable | | |---------|------|------------------------------|--| | | _ | D: 11 | | 0 Disable1 Enable S1\_SWEEP\_DIS S1 width sweep disable 0 Sweep enable (Default) Sweep disable MODE[2:0] Touch Sensor mode 000 Normal sensing mode001 High sensing mode 010 Channel Adjust sensing mode 011 Offset Calibration sensing mode 100 Simultaneous sensing for all selected channels to reduce the sensing time PORT[1:0] Port Configuration During Inactive Status 00 Input Floating 01 Output Low 10 Output High ### TS\_SUM\_CNT (Touch Sensor Sum Repeat Count Register): 2E82H | <br>7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----|----|----|----|----|------|--------------| | TS_SUM_CNT | | | | | | | | | RW | | | | | | | 1:41 | al value All | Initial value: 01H ## TS\_CH\_SEL\_H (Touch Sensor Channel Selection High-Byte Register): 2E83H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|----------|----------|----------|----------| | - | - | - | - | CH19_SEL | CH18_SEL | CH17_SEL | CH16_SEL | | - | - | - | - | RW | RW | RW | RW | | | | | | | | 1 14 | | Initial value: 00H CH19\_SEL Channel 19 Enable Disable (Default) Enable Touch Key by P03 CH18\_SEL Channel 18 Enable 0 Disable (Default) Enable Touch Key by P00 CH17\_SEL Channel 17 Enable 0 Disable (Default) Enable Touch Key by P31 CH16\_SEL Channel 16 Enable Disable (Default) 1 Enable Touch Key by P27 ## TS\_CH\_SEL\_M (Touch Sensor Channel Selection Middle-Byte Register): 2E84H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |----------------------------|----------|----------|----------|----------|----------|---------|---------|--|--| | CH15_SEL | CH14_SEL | CH13_SEL | CH12_SEL | CH11_SEL | CH10_SEL | CH9_SEL | CH8_SEL | | | | RW | | | | | | | | | | | | | | CH15_SEL Channel 15 Enable | | | | | | | | | | | 0 Disable (Default) | | | | | | | | | | Enable Touch Key by P26 CH14\_SEL Channel 14 Enable Disable (Default) 1 Enable Touch Key by P25 CH13\_SEL Channel 13 Enable 0 Disable (Default) 1 Enable Touch Key by P24 CH12\_SEL Channel 12 Enable 0 Disable (Default) Enable Touch Key by P23 CH11\_SEL Channel 11 Enable 0 Disable (Default) 1 Enable Touch Key by P22 CH10\_SEL Channel 10 Enable 0 Disable (Default) 1 Enable Touch Key by P17 CH9\_SEL Channel 9 Enable 0 Disable (Default) 1 Enable Touch Key by P16 CH8\_SEL Channel 8 Enable 0 Disable (Default) 1 Enable Touch Key by P15 ### TS\_CH\_SEL\_L (Touch Sensor Channel Selection Low-Byte Register): 2E85H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---------|---------|---------|---------|---------|---------|---------| | CH7_SEL | CH6_SEL | CH5_SEL | CH4_SEL | CH3_SEL | CH2_SEL | CH1_SEL | CH0_SEL | | RW Initial value: 00H CH7\_SEL Channel 7 Enable 0 Disable (Default) 1 Enable Touch Key by P14 CH6\_SEL Channel 6 Enable 0 Disable (Default) 1 Enable Touch Key by P12 CH5\_SEL Channel 5 Enable 0 Disable (Default) 1 Enable Touch Key by P11 CH4\_SEL Channel 4 Enable 0 Disable (Default) 1 Enable Touch Key by P10 CH3\_SEL Channel 3 Enable 0 Disable (Default) 1 Enable Touch Key by P07 CH2\_SEL Channel 2 Enable 0 Disable (Default) 1 Enable Touch Key by P06 CH1\_SEL Channel 1 Enable 0 Disable (Default) 1 Enable Touch Key by P05 CH0\_SEL Channel 0 Enable 0 Disable (Default) 1 Enable Touch Key by P04 ### TS\_S1\_WIDTH (S1 Timing Register): 2E86H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |----|-------------|----|----|----|----|-------|---------------|--|--| | | TS_S1_WIDTH | | | | | | | | | | RW | | | | | | | | | Initi | al value: 20H | | | Actually, S1 width will be changed randomly from 2\*TS\_S1\_WIDTH to 4\*TS\_S1\_WIDTH. ## TS\_SLP\_CON (Touch Sensor Low Pass Filter Control Register): 2E87H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------| | SLP_C3 | SLP_C2 | SLP_C1 | SLP_C0 | SLP_R3 | SLP_R2 | SLP_R1 | SLP_R0 | | | RW Initial value: 74H SLP\_C[3:0] Capacitor Trimming for Input Low Pass Filter 0000 0.0pF 0001 1.5pF 0010 3.0pF 0011 4.5pF 0100 6.0pF 0101 7.5pF 0110 9.0pF 0111 10.5pF (Default) 1000 12.0pF 1001 13.5pF 1010 15.0pF 1011 16.5pF 1100 18.0pF 1101 19.5pF 1110 21.0pF 1111 22.5pF SLP\_R[3:0] Resistor Trimming for Input Low Pass Filter 0000 Open 0001 0K 0010 5K 0100 100K (Default) 1000 200K 0110 33K 1100 67K 1010 40K 1110 28K ### TS\_TRIM (Touch Sensor Trimming Register): 2E89H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|----|----------|----------|----------|----------| | - | - | - | HC | IB_TRIM3 | IB_TRIM2 | IB_TRIM1 | IB_TRIM0 | | - | - | - | RW | RW | RW | RW | RW | Initial value: 07H HC High Current Enable 0 Disable 1 Enable IB\_TRIM[3:0] Current Bias Trimming Value 0000 4uA(P), 1uA(N) 0001 4uA(P), 1.5uA(N) 0001 4uA(P), 1.5uA(N) 0010 0011 4uA(P), 2.5uA(N) 0100 0101 0110 0111 4uA(P), 4.5uA(N) (Default) 1000 1001 1010 1011 1100 1101 1110 4uA(P), 8.5uA(N) ### TS\_CLK\_CFG (Touch Sensor Clock Configuration Register): 2E8AH 1111 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|--------|---------|---------|---------|-----------|-----------|----------------| | SCLK_EN | PAT_EN | CLKSEL1 | CLKSEL0 | TSCLKOE | TSCLKDIV2 | TSCLKDIV1 | TSCLKDIV0 | | RW | | | | | | | Initi | ial value: 02H | SCLK\_EN Enable or disable system clock as touch clock 0 Disable (Default) 1 Enable PAT\_EN Enable or disable of using pattern for S2 & S3 0 Disable (Default) 1 Enable CLKSEL[1:0] Touch Clock source select **TSCLKOE** 00 Two touch sensor clocks will be used Touch clock A onlyTouch clock B only Divided Touch Sensor Clock Output Enable 0 Clock Output Disable (Default) 1 Clock Output Enable TSCLKDIV[2:0] Touch Sensor Clock Divider (Refer to TRIM\_OSC) 000 OSCts / 1 (16MHz, Default) 001 OSCts / 2 010 OSCts / 4 011 OSC<sub>ts</sub> / 8 100 OSCts / 16 101 OSC<sub>ts</sub> / 32 110 OSC<sub>ts</sub> / 64 111 OSCts / 128 ### TRIM\_OSC (Touch Sensor RING Oscillator Trimming Selection Register): 2E8BH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|----|----|------|------|-------|---------------| | - | - | | | TRIM | _OSC | | | | - | - | RW | RW | RW | RW | RW | RW | | | | | | | | Initi | al value: 20H | TRIM\_OSC[5:0] Touch Sensor RING Oscillator Trimming Selection 3FH +23.25% (19.72MHz) 3E +22.50% Н... ... 21H +0.75% 20H 16MHz (default) 1FH -0.75% ... 01H -23.25% 00H -24.00% (12.16HMz) Frequency of Touch clock B = 16MHz + (TRIM\_OSC - 20H) \* 0.75% ## DELTA\_OSC (Touch Sensor RING Oscillator Delta Register): 2E8CH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |----|--------------------|----|----|----|----|----|----|--|--|--| | | DELTA_OSC | | | | | | | | | | | RW | | | | | Initial value: 01H | | | | | | | | | | Frequency of Touch clock A = 16MHz + ((TRIM\_OSC + DELTA\_OSC) - 20H) \* 0.75% \*Frequency = 16MHz + 16MHz \* (((TRIM\_OSC + DELTA\_OSC) - 20H) \* 0.0075) <sup>\*</sup>Frequency = 16MHz + 16MHz \* ((TRIM\_OSC - 20H) \* 0.0075) ## TLED (LED stable time Register): 2E8DH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |----|------|----|----|----|----|-------|---------------|--|--| | | TLED | | | | | | | | | | RW | | | | | | | | | Initi | al value: 00H | | | Initial value: 00H To run touch sensing again after LED working, we need 25~30us stable time. This counter is working based on system clock. ## TS\_VHS\_H (Touch Sensor High Sense Voltage High-Byte Register): 2E8EH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|----------|----| | - | ı | ı | - | - | - | TS_VHS_H | | | - | - | - | - | - | - | RW | RW | Initial value: 02H TS\_VHS\_L (Touch Sensor High Sense Voltage Low-Byte Register): 2E8FH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------------|----------|---|---|---|---|---|---|--|--|--| | | TS_VHS_L | | | | | | | | | | | RW RW RW RW RW RW | | | | | | | | | | | Initial value: 80H ## TS\_VREF\_H (Touch Sensor COMP Reference Voltage High-Byte Register): 2E90H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|-------|-------| | - | - | - | - | - | - | TS_VI | REF_H | | - | - | - | - | - | - | RW | RW | Initial value: 02H TS\_VREF\_L(Touch Sensor COMP Reference Voltage Low-Byte Register): 2E91H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-----------|----|----|----|----|----|----|----|--|--| | TS_VREF_L | | | | | | | | | | | RW | | Initial value: 10H ## 16.6 User Programming Procedure Figure 113. User Programming Procedure 17. 12-bit A/D Converter A96T418 User's manual ## 17 12-bit A/D Converter #### 17.1 Overview The analog-to-digital converter (A/D) allows conversion of an analog input signal to corresponding 12-bit digital value. The A/D module has eight analog inputs. The output of the multiplexeris the input into the converter which generates the result through successive approximation. The A/D module has four registers which are the A/D converter control high register (ADCCRH), A/D converter control low register (ADCCRL), A/D converter data high register (ADCDRH), and A/D converter data low register (ADCDRL). The channels to be converted are selected by setting ADSEL[2:0]. To execute A/D conversion, TRIG[2:0] bits should be set to 'xxx'. The register ADCDRH and ADCDRL contains the results of the A/D conversion. When the conversion is completed, the result is loaded into the ADCDRH and ADCDRL, the A/D conversion status bit AFLAG is set to '1', and the A/D interrupt is set. During A/D conversion, AFLAG bit is read as '0'. # 17.2 Conversion Timing The A/D conversion process requires 4 steps (4 clock edges) to convert each bit and 12 clocks to set up A/D conversion. Therefore, total of 48 clocks are required to complete a 12-bit conversion: When fxx/8 is selected for conversion clock with a 12MHz fxx clock frequency, one clock cycle is 0.66 µs. Each bit conversion requires 4 clocks, the conversion rate is calculated as follows: 4 clocks/bit × 12 bits + set-up time = 60 clocks ADC Conversion Time = ADCLK \* 60 cycles #### NOTES: The A/D converter needs at least 7.5us for conversion time. So you must set the conversion time more than 7.5us. A96T418 User's manual 17. 12-bit A/D Converter # 17.3 Block Diagram Figure 114. 12-bit ADC Block Diagram Figure 115. A/D Analog Input Pin with Capacitor Figure 116. A/D Power (AVREF) Pin with Capacitor 17. 12-bit A/D Converter A96T418 User's manual # 17.4 ADC Operation Figure 117. ADC Operation for Align Bit A96T418 User's manual 17. 12-bit A/D Converter Figure 118. A/D Converter Operation Flow ## 17.5 Register Map Table 40. ADC Register Map | Name | Address | Direction | Default | Description | |--------|---------|-----------|---------|-------------------------------------| | ADCDRH | 9FH | R | 00H | A/D Converter Data High Register | | ADCDRL | 9EH | R | 00H | A/D Converter Data Low Register | | ADCCRH | 9DH | R/W | 00H | A/D Converter Control High Register | | ADCCRL | 9CH | R/W | 00H | A/D Converter Control Low Register | ## 17.6 ADC Register Description The ADC register consists of A/D converter data high register (ADCDRH), A/D converter data low register (ADCDRL), A/D converter control high register (ADCCRH) and A/D converter control low register (ADCCRL). 17. 12-bit A/D Converter A96T418 User's manual ## 17.7 Register Description for ADC ### ADCDRH (A/D Converter Data High Register):9FH | 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 Data (8-bit) ADDL[11:8] LSB align, A/D Converter High Data (4-bit) ## ADCDRL (A/D Converter Data Low Register): 9EH | 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 Data (4-bit) ADDL[7:0] LSB align, A/D Converter Low Data (8-bit) A96T418 User's manual 17. 12-bit A/D Converter ## ADCCRH (A/D Converter High Register): 9DH | 7 | 6 | 5 | 4 | 3 | | 2 | 1 | 0 | | |--------|-----------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------|------------------|--------|---------------|--| | ADCIFR | - | TRIG2 | TRIG1 | TRIG0 | | ALIGN | CKSEL1 | CKSEL0 | | | RW | RW | RW | RW | RW | | RW | RW | RW | | | | | | | | | | Init | al value: 01H | | | | ADCIFR | | When ADC interrupt occurs, this bit becomes '1'. For clearing bit, write '0' to this bit auto clear by INT_ACK signal. Writing "1" has no effect. | | | | | | | | | | 0 | ADC Inter | rupt no gen | eratio | on | | | | | | | 1 | 1 ADC Interrupt generation | | | | | | | | | TRIG[2:0] | A/D Tri | gger Signal Sel | ection | | | | | | | | | TRIG2 | TRIG1 | TRIG0 | Des | scription | | | | | | | 0 | 0 | 0 | AD | ST | | | | | | | 0 | 0 | 1 | Tim | ner 1 A match si | gnal | | | | | | 0 | 1 | 0 | Tim | ner 3 A match si | gnal | | | | | | 0 | 1 | 1 | EX | TINT0~3 | | | | | | | 1 | 0 | 0 | EX | TINT8 | | | | | | | 1 | 0 | 1 | Not | used | | | | | | | Other \ | /alues | | Not | used | | | | | | ALIGN | A/D Co | nverter data ali | gn selectior | ۱. | | | | | | | | 0 | MSB align | (ADCDRH | [7:0], | ADCDRL[7:4]) | | | | | | | 1 | 1 LSB align (ADCRDH[3:0], ADCDRL[7:0]) | | | | | | | | | CKSEL[1:0 | )] A/D Co | nverter Clock s | election | | | | | | | | | CKSEL | 1 CKSEL0 | Descripti | on | | | | | | | | 0 | 0 | fx/1 | | | | | | | | | 0 | 1 | fx/2 (defa | ault) | | | | | fx/4 fx/8 0 1 1 NOTES: fx : system clock ADC clock should use below 8MHz 17. 12-bit A/D Converter A96T418 User's manual ## ADCCRL (A/D Converter Counter Low Register): 9CH | 7 | 6 | 5 | 4 | ; | 3 | 2 | 1 | 0 | | | |------|------------|-------------|--------------------------|--------------|----------|-------------------|------------------|---------------|--|--| | STBY | ADST | REFSEL | AFLAG | | - | ADSEL2 | ADSEL1 | ADSEL0 | | | | RW | RW | RW | R | | - | RW | RW | RW | | | | | | | Initial value: 00H | | | | | | | | | | STBY | Control Op | Control Operation of A/D | | | | | | | | | | | (The ADC | module is au | tomatically | disabled | l at stop mode) | | | | | | | | 0 | ADC module | e disable | | | | | | | | | | 1 | ADC module | e enable | | | | | | | | | ADST | Control A/I | O Conversion | stop/start. | | | | | | | | | | 0 | No effect | | | | | | | | | | | 1 | ADC Conve | rsion Start | and auto | clear | | | | | | | REFSEL | A/D Conve | rter Referend | ce Selection | 1 | | | | | | | | | 0 | Internal Ref | erence (VD | D) | | | | | | | | | 1 | External Re | ference (A\ | /REF) | | | | | | | | AFLAG | | rter Operation | | | cleared to '0' wh | nen the STBY bit | is set to '0' | | | | | | 0 | During A/D | Conversion | | | | | | | | | | 1 | A/D Convers | sion finishe | d | | | | | | | | ADSEL[2:0] | A/D Conve | rter input sel | ection | | | | | | | | | | ADSEL2 | ADSEL1 | ADSEL0 | Descrip | otion | | | | | | | | 0 | 0 | 0 | AN0 | | | | | | | | | 0 | 0 | 1 | AN1 | | | | | | | | | 0 | 1 | 0 | AN2 | | | | | | | | | 0 | 1 | 1 | AN3 | | | | | | | | | 1 | 0 | 0 | AN4 | | | | | | | | | 1 | 0 | 1 | AN5 | | | | | | AN6 AN7 # 18 Power Down Operation ### 18.1 Overview The A96T418 has two power-down modes to minimize the power consumption of the device. In power down mode, power consumption is reduced considerably. The device provides three kinds of power saving functions, Main-IDLE, Sub-IDLE and STOP mode. In three modes, program is stopped. ## 18.2 Peripheral Operation in IDLE/STOP Mode Table 41. Peripheral Operation during Power Down Mode | Peripheral | IDLE Mode | STOP Mode | | | |----------------------|--------------------------------------|---------------------------------------------|--|--| | CPU | ALL CPU Operation are Disable | ALL CPU Operation are Disable | | | | RAM | Retain | Retain | | | | Basic Interval Timer | Operates Continuously | Stop (Can be operated with WDTRC OSC) | | | | Watch Dog Timer | Operates Continuously | Stop (Can be operated with WDTRC OSC) | | | | Watch Timer | Operates Continuously | Stop (Can be operated with sub clock) | | | | Timer0~4 | Operator Centinuously | Halted (Only when the Event Counter Mode is | | | | Timero~4 | Operates Continuously | Enabled, Timer operates Normally) | | | | ADC | Operates Continuously | Stop | | | | BUZ | Operates Continuously | Stop | | | | USI0/1 | Operates Continuously | Only operate with external clock | | | | Internal OSC | Oscillation | Stop when the system clock (fx) is fHSIRC | | | | (16MHz) | Oscillation | | | | | WDTRC OSC | Can be an arrated with patting walve | Can be operated programmable | | | | (128kHz) | Can be operated with setting value | | | | | Sub OSC | Oscillation | Can be appreted programmable | | | | (32.768kHz) | Oscillation | Can be operated programmable | | | | Touch OSC | Oscillation | Stan when the system clock (fx) is fUSIDC | | | | (16MHz) | Oscillation | Stop when the system clock (fx) is fHSIRC | | | | I/O Port | Retain | Retain | | | | Control Register | Retain | Retain | | | | Address Data Bus | Retain | Retain | | | | | | By RESET, Timer Interrupt (EC0, EC1, EC3), | | | | Release Method | By DESET, all Interrupts | External Interrupt, | | | | Release Method | By RESET, all Interrupts | USART by RX, WT (sub clock), WDT | | | | | | USI0/1 by RX, I2C (Slave mode) | | | ### 18.3 IDLE Mode The power control register is set to '01h' to enter the IDLE 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 IDLE mode. If using reset, because the device becomes initialized state, the registers have reset value. Figure 119. IDLE Mode Release Timing by External Interrupt #### 18.4 STOP Mode The power control register is set to '03H' to enter the STOP Mode. In the stop mode, the selected oscillator, system clock and peripheral clock is stopped, but watch timer can be continued to operate with sub clock. With the clock frozen, all functions are stopped, but the on-chip RAM and control registers are held. For example, If the internal RC oscillator (firsc) is selected for the system clock and the sub clock (fsub) is oscillated, the internal RC oscillator stops oscillation and the sub clock is continuously oscillated in stop mode. At that time, the watch timer can be operated with the sub clock. The source for exit from STOP mode is 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 120 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 prescale divide ratio to have long enough time. This guarantees that oscillator has started and stabilized. Figure 120. STOP Mode Release Timing by External Interrupt ## 18.5 Release Operation of STOP Mode After STOP mode is released, the operation begins according to content of related interrupt register just before STOP mode start (Figure 121). If the global interrupt Enable Flag (IE.EA) is set to '1', the STOP mode is released by the interrupt which each interrupt enable flag = '1' and the CPU jumps to the relevant interrupt service routine. Even if the IE. EA bit is cleared to '0', the STOP mode is released by the interrupt of which the interrupt enable flag is set to '1'. Figure 121. STOP Mode Release Flow ## 18.6 Register Map Table 42. Power Down Operation Register Map | Name | Address | Direction | Default | Description | |------|---------|-----------|---------|------------------------| | PCON | 87H | R/W | 00H | Power Control Register | ### 18.7 Power Down Operation Register Description The power down operation register consists of the power control register (PCON). ## 18.8 Register Description for Power Down Operation PCON (Power Control Register): 87H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|---|---|---|-------|-------|-------|-------| | PCON7 | _ | _ | _ | PCON3 | PCON2 | PCON1 | PCON0 | | RW | _ | - | - | RW | RW | RW | RW | Initial value: 00H PCON[7:0] Power Control 01H IDLE mode enable 03H STOP mode enable Other Normal operation Values #### NOTES: - 1. To enter IDLE mode, PCON must be set to '01H'. - 2. To enter STOP mode, PCON must be set to '03H'. - 3. The PCON register is automatically cleared by a release signal in STOP/IDLE mode. - 4. Three or more NOP instructions must immediately follow the instruction that make the device enter STOP/IDLE mode. Refer to the following examples. | Ex1) | MOV | PCON, #01H | ; IDLE mode | Ex2) | MOV | PCON, #03H | ; STOP mode | |------|-----|------------|-------------|------|-----|------------|-------------| | | NOP | | | | NOP | | | | | NOP | | | | NOP | | | | | NOP | | | | NOP | | | | | • | | | | • | | | | | • | | | | • | | | | | • | | | | • | | | 19. RESET A96T418 User's manual ## 19 RESET #### 19.1 Overview The following is the hardware setting value. On Chip Hardware Initial Value Program Counter (PC) 0000h Accumulator 00h Stack Pointer (SP) 07h Peripheral Clock On Control Register Refer to the Peripheral Registers Table 43. Reset State ## 19.2 Reset Source The A96T418 has five types of reset sources. The following is the reset sources. - External RESETB - Power ON RESET (POR) - WDT Overflow Reset (In the case of WDTEN = '1') - Low Voltage Reset (In the case of LVREN = '0') - OCD Reset ## 19.3 RESET Block Diagram Figure 122. RESET Block Diagram A96T418 User's manual 19. RESET ### 19.4 Power on RESET When rising device power, the POR (Power On Reset) has a function to reset the device. If POR is used, it executes the device RESET function instead of the RESET IC or the RESET circuits. Figure 123. Fast VDD Rising Time Figure 124. Internal RESET Release Timing On Power-Up 19. RESET A96T418 User's manual Figure 125. Configuration Timing when Power-on Figure 126. Boot Process WaveForm A96T418 User's manual 19. RESET Table 44. Boot Process Description | Process | Description | Remarks | | | |---------|--------------------------------------------------------|--------------------------------------------|--|--| | (a) | - No Operation | 0.7V~0.9V | | | | 1 | - LSIRC (128KHz) ON | 0.7 v~0.9 v | | | | 2 | -1st POR level Detection | -about 1.1V~1.3V | | | | | - (LSIRC 128KHz/32)x32h Delay section (=10ms) | | | | | 3 | -VDD input voltage must rise over than flash operating | -Slew Rate >= 0.025V/ms | | | | | voltage for Configure option read | | | | | | | -about 1.6V ~ 1.8V | | | | 4 | - Configure option read point | -Configure Value is determined by Writing | | | | | | Option | | | | ⑤ | - Rising section to Reset Release Level | -16ms point after POR or Ext_reset release | | | | | - Reset Release section (BIT overflow) | | | | | | i) after16ms, after External Reset Release (External | PIT is used for Peripheral stability | | | | 6 | reset) | - BIT is used for Peripheral stability | | | | | ii) 16ms point after POR (POR only) | | | | | 7 | -Normal operation | | | | 19. RESET A96T418 User's manual ## 19.5 External RESETB Input The External RESETB is the input to a Schmitt trigger. If RESETB pin is held with low for at least 10us over within the operating voltage range and stable oscillation, it is applied and the internal state is initialized. 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. Figure 127. Timing Diagram after RESET Figure 128. Oscillator generating waveform example #### NOTES: - 1. As shown Figure 127, the stable generating time is not included in the start-up time. - 2. The RESETB pin has a Pull-up register by hardware A96T418 User's manual 19. RESET ## 19.6 Low Voltage Reset Processor The A96T418 has an On-chip brown-out detection circuit (BOD) for monitoring the VDD level during operation by comparing it to a fixed trigger level. The trigger level for the BOD can be selected by LVRVS[3:0] bit to be 1.62V, 1.77V, 1.88V, 2.00V, 2.13V, 2.28V, 2.46V, 2.67V, 2.80V, 3.04V, 3.20V, 3.55V, 3.75V, 3.99V, 4.25V. In the STOP mode, this will contribute significantly to the total current consumption. So to minimize the current consumption, the LVREN bit is set to off by software. Figure 129. Block Diagram of LVR Figure 130. Internal Reset at the power fail situation 19. RESET A96T418 User's manual Figure 131. Configuration timing when LVR RESET A96T418 User's manual 19. RESET ## 19.7 LVI Block Diagram Figure 132. LVI Diagram ## 19.8 Register Map Table 45. Reset Operation Register Map | Name | Address | Direction | Default | Description | | | |-------|---------|-----------|---------|----------------------------------------|--|--| | RSTFR | E8H | R/W | 80H | Reset Flag Register | | | | LVRCR | D8H | R/W | 00H | Low Voltage Reset Control Register | | | | LVICR | 86H | R/W | 00H | Low Voltage Indicator Control Register | | | ## 19.9 Reset Operation Register Description The reset control register consists of the reset flag register (RSTFR), low voltage reset control register (LVRCR), and low voltage indicator control register (LVICR). 19. RESET A96T418 User's manual ## 19.10 Register Description for Reset Operation 1 #### RSTFR (Reset Flag Register): E8H | 1 | 6 | 5 | 4 | 3 | 2 | 1 | U | | | |------|-------|----------------------------------------------------------------------------------------------|--------------------|---------------------|-----------------------|--------------------|--------------|--|--| | PORF | EXTRF | WDTRF | OCDRF | LVRF | _ | 1 | _ | | | | RW | RW | RW | RW | RW | - | _ | - | | | | | | | | | | Initia | value: 80H | | | | | PORF | Power-On | Reset flag bit. Tl | he bit is reset by | writing '0' to this | bit. | | | | | | | 0 | No dete | | | | | | | | | | 1 | Detectio | n | | | | | | | | EXTRF | External Reset (RESETB) flag bit. The bit is reset by writing '0' to this bit or by F Reset. | | | | | | | | | | | 0 | No dete | ction | | | | | | | | | 1 | Detectio | n | | | | | | | | WDTRF | Watch Dog | Reset flag bit. 7 | The bit is reset by | y writing '0' to thi | s bit or by Powe | r-On Reset. | | | | | | 0 | No dete | ction | | | | | | | | | 1 | Detectio | n | | | | | | | | OCDRF | On-chip de | bugger reset flaເ | g bit. The bit rese | t by writing '0' to | this bit or by Pov | ver-On Reset | | | | | | 0 | No dete | ction | | | | | | | | | 1 | Detectio | n | | | | | | | | LVRF | Low Voltag | e Reset flag bit. | The bit is reset by | by writing '0' to the | nis bit or by Pow | er-On Reset. | | | | | | 0 | No dete | ction | | | | | | | | | | | | | | | | | #### NOTES: - 1. When the Power-On Reset occurs, the PORF bit is only set to "1", the other flag (WDTRF) bits are all cleared to "0" - 2. When the Power-On Reset occurs, the EXTRF bit is unknown, at that time, the EXTRF bit can be set to "1" when External Reset (RESETB) occurs. Detection - When the Power-On Reset occurs, the LVRF bit is unknown, at that time, the LVRF bit can be set to "1" when LVR Reset occurs. - 4. When a reset except the POR occurs, the corresponding flag bit is only set to "1", the other flag bits are kept in the previous values. A96T418 User's manual 19. RESET ## LVRCR (Low Voltage Reset Control Register): D8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|--------|--------|--------|--------|-------| | _ | _ | _ | LVRVS3 | LVRVS2 | LVRVS1 | LVRVS0 | LVREN | | _ | _ | _ | RW | RW | RW | RW | RW | Initial value: 00H | LVRVS[3:0] | LVR Volta | age Select | | | | |------------|-----------|------------|--------|--------|---------------| | | LVRVS3 | LVRVS2 | LVRVS1 | LVRVS0 | Description | | | 0 | 0 | 0 | 0 | 1.61V | | | 0 | 0 | 0 | 1 | Not available | | | 0 | 0 | 1 | 0 | 1.77V | | | 0 | 0 | 1 | 1 | 1.88V | | | 0 | 1 | 0 | 0 | 2.00V | | | 0 | 1 | 0 | 1 | 2.13V | | | 0 | 1 | 1 | 0 | 2.28V | | | 0 | 1 | 1 | 1 | 2.46V | | | 1 | 0 | 0 | 0 | 2.68V | | | 1 | 0 | 0 | 1 | 2.81V | | | 1 | 0 | 1 | 0 | 3.06V | | | 1 | 0 | 1 | 1 | 3.21V | | | 1 | 1 | 0 | 0 | 3.56V | | | 1 | 1 | 0 | 1 | 3.73V | | | 1 | 1 | 1 | 0 | 3.91V | | | 1 | 1 | 1 | 1 | 4.25V | | LVREN | LVR Oper | ration | | | | | | 0 | LVR Enab | ole | | | | | 1 | LVR Disa | ble | | | #### NOTES: - 1. The LVRVS[3:0] bits are cleared by a power-on reset but are retained by other reset signals. - 2. The LVRVS[3:0] bits should be set to '0000b' while LVREN bit is "1". 19. RESET A96T418 User's manual ### LVICR (Low Voltage Indicator Control Register): 86H LVIF **LVIEN** | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|------|-------|--------|--------|--------|---------------| | _ | _ | LVIF | LVIEN | LVILS3 | LVILS2 | LVILS1 | LVILS0 | | _ | - | RW | RW | RW | RW | RW | RW | | | | | | | | Initi | al value: 00H | Low Voltage Indicator Flag Bit No detection Detection LVI Enable/Disable Disable Enable LVIVS[3:0] LVI Level Select LVIVS3 LVIVS2 LVIVS1 LVIVS0 Description Not available Not available Not available Not available Not available Not available 2.28V 2.46V 2.68V 2.81V 3.06V3.21V 3.56V 3.73V 3.91V 4.25V ## **20** Memory Programming A96T418 has flash memory to which a program can be written, erased, and overwritten while mounted on the board. Serial ISP mode is supported. Flash of A96T418 features the followings: - Flash Size : 32Kbytes - 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 ## 20.1 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 x (FEARLx), Address Middle Register x (FEARMx), address High Register (FEARH). They are mapped to SFR area and can be accessed only in programming mode. #### 20.1.1 Register Map Table 46. Register Map | Name | Address | Direction | Default | Description | |--------|---------|-----------|---------|---------------------------------| | FEMR | 1020H | R/W | 00H | Flash Mode Register | | FECR | 1021H | R/W | 03H | Flash Control Register | | FESR | 1022H | R/W | 80H | Flash Status Register | | FETCR | 1023H | R/W | 00H | Flash Time Control Register | | FEARL1 | 1025H | R/W | 00H | Flash Address Low Register 1 | | FEARM1 | 1024H | R/W | 00H | Flash Address Middle Register 1 | | FEARL | 102AH | R/W | 00H | Flash Address Low Register | | FEARM | 1029H | R/W | 00H | Flash Address Middle Register | | FEARH | 1028H | R/W | 00H | Flash Address High Register | | FEDR | 102BH | R/W | 00H | Flash Data Register | | FETR | 102CH | R/W | 00H | Flash Test Register | #### 20.1.2 Register Description for Flash #### FEMR (Flash Mode Register): 1020H **FSEL** | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|-----|-------|-------|------|-----|------| | FSEL | ı | PGM | ERASE | PBUFF | OTPE | VFY | FEEN | | RW | - | RW | RW | RW | RW | RW | RW | Initial value: 00H | | 0 | Deselect flash memory | |-----|--------|-----------------------------------------| | | 1 | Select flash memory | | PGM | Enable | program or program verify mode with VFY | | | 0 | Disable program or program verify mode | | | 1 | Enable program or program verify mode | Select flash memory. **ERASE** Enable erase or erase verify mode with VFY 0 Disable erase or erase verify mode Enable erase or erase verify mode 1 **PBUFF** Select page buffer 0 Deselect page buffer Select page buffer **OTPE** Select OTP area instead of program memory > Deselect OTP area Select OTP area VFY Set program or erase verify mode with PGM or ERASE > Program Verify: PGM=1, VFY=1 Erase Verify: ERASE=1, VFY=1 **FEEN** Enable program and erase of Flash. When inactive, it is possible to read as normal mode 0 Disable program and erase Enable program and erase 1 ### FECR (Flash Control Register): 1021H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|---|-------|-------|-------|------|--------|--------| | AEF | - | EXIT1 | EXIT0 | WRITE | READ | nFERST | nPBRST | | RW | - | RW | RW | RW | RW | RW | RW | | Enable fla | ash bulk eras | e mode | |------------|-----------------------------|------------------------------------------------------------------| | 0 [ | Disable bulk e | erase mode of Flash memory | | 1 E | Enable bulk e | rase mode of Flash memory | | Exit from | program mo | de. It is cleared automatically after 1 clock | | EXIT1 | EXIT0 | Description | | 0 | 0 | Don't exit from program mode | | 0 | 1 | Don't exit from program mode | | 1 | 0 | Don't exit from program mode | | 1 | 1 | Exit from program mode | | Start to p | rogram or era | ase of Flash. It is cleared automatically after 1 clock | | | 0 E 1 Exit from EXIT1 0 0 1 | 1 Enable bulk e Exit from program mo EXIT1 EXIT0 0 0 0 1 1 0 1 1 | | | | 0 | No operation | | | | | |--------------|--------|-----------------------------|-----------------------------------------------------------------------|---------------------------------------------|--|--|--| | | | 1 | Start to program | or erase of Flash | | | | | | READ | Start au | Start auto-verify of Flash. It is cleared automatically after 1 clock | | | | | | | | 0 | No operation | | | | | | | | 1 | Start auto-verify | of Flash (Checksum or CRC16) | | | | | nFERST Reset | | | Flash control logic. It is set automatically after 1 clock | | | | | | | | 0 Reset Flash control logic | | | | | | | | | 1 No operation (default) | | | | | | | | nPBRST | Reset p | age buffer with P | BUFF. It is set automatically after 1 clock | | | | | | | PBUFF | nPBRST | Description | | | | | | | 0 | 0 | Page buffer reset | | | | | | | 1 | 0 | Page buffer select register reset | | | | | | | Χ | 1 | No operation (default) | | | | 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): 1022H | PEVBSY | REMAPSI | REMAPS | - | ROMINT | WMODE | EMODE | VMODE | | | |---------|---------|---------|-------------------------------------------------------------------------------------------------------------------------|------------------|-------|-------|---------------|--|--| | R | R | R | R | RW | R | R | R | | | | | | | | | | | al value: 80H | | | | | PEVBS | - 1 | Operation status flag. It is cleared automatically when operation starts. Operations are program, erase or verification | | | | | | | | | | | Busy (Oper | ation processing | )) | | | | | | | | | Complete C | peration | | | | | | | REMAPSI | | | Remapping for check the serial ID. | | | | | | | | | | 0 | 0 No operation | | | | | | | | | | 1 | 1 Remapping OTP area to 81C0~81FF. | | | | | | | | | REMAR | PS Test | Test Only. | | | | | | | | ROMINT | | | Flash interrupt request flag. Auto-cleared when program/erase/verify starts. Active in program/erase/verify completion | | | | | | | | | | 0 | No interrupt | request. | | | | | | | | | 1 | Interrupt red | quest. | | | | | | | | WMOD | E Write | e mode flag | | | | | | | ### FEARL1 (Flash Address Low Register 1): 1025H **EMODE** VMODE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|----------------| | ARL17 | ARL16 | ARL15 | ARL14 | ARL13 | ARL12 | ARL11 | ARL10 | | W | W | W | W | W | W | W | W | | | | | | | | Init | ial value: 00H | Erase mode flag Verify mode flag ARL1[7:0] Flash address low 1 #### FEARM1 (Flash Address Middle Register 1): 1024H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------| | ARM17 | ARM16 | ARM15 | ARM14 | ARM13 | ARM12 | ARM11 | ARM10 | | W | W | W | W | W | W | W | W | Initial value: 00H ARM1[7:0] Flash address middle 1 #### FEARL (Flash Address Low Register): 102AH | 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): 1029H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|------|------| | ARM7 | ARM6 | ARM5 | ARM4 | ARM3 | ARM2 | ARM1 | ARM0 | | W | W | W | W | W | W | W | W | | | | | | | | 1 14 | | Initial value: 00H ARM[7:0] Flash address middle #### FEARH (Flash Address High Register): 1028H | 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 result. When calculating flash checksum, the lower 4 bits of start address are calculated as 0x0000 and the lower 4 bits of end address as 0x1111 for protection. This device can support internal CheckSum calculation, device verification time will be decreased dramatically. CheckSum cannot detect error address or error bit, but it is quite good feature in mass product programming. Device data read out time takes few seconds. The execution time per byte is 4~5ms based on 16MHz. Figure 2 Figure 133. Read device internal CkeckSum(Full size) Figure 134. Read device internal CkeckSum(User define size) ### FETCR (Flash Time control Register): 1023H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|-------|---------------| | TCR7 | TCR6 | TCR5 | TCR4 | TCR3 | TCR2 | TCR1 | TCR0 | | RW | | | | | | | Initi | al 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 RING clock frequency (flsirc=128kHz). 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 INTRC/256 clock: (255+1) \* 2 \* (7.8125us) = 4.0ms In the case of ±10% of error rate of counter source clock, program or erase time is 3.6~4.4ms. <sup>\*</sup> Program/erase time calculation For page write or erase = Tpe = (TCON+1) \* 2 \* (f<sub>LSIRC</sub>) For bulk erase, Tbe = (TCON+1) \* 4 \* (f<sub>LSIRC</sub>) Recommended bulk erase time: FETCR = 57h Recommended program / page erase time: FETCR = AFh Table 47. Program/erase Time | | Min | Тур | Max | Unit | |--------------------|-----|-----|-----|------| | program/erase Time | 2.4 | 2.5 | 2.6 | Ms | ## 20.2 Memory Map ## 20.2.1 Flash Memory Map Program memory uses 32KBytes of Flash memory. It is read by byte and written by byte or page. One page is 64-bytes. Figure 135. Flash Memory Map Figure 136. Address Configuration of Flash Memory ## 20.3 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. ## 20.3.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] | | - | ERASE&VFY | PGM&VFY | - | - | OTPE | AEE | AEF | Figure 137. The Sequence of Page Program and Erase of Flash Memory Figure 138. The Sequence of Bulk Erase of Flash Memory ### 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. ## 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 AAH to F555H. - (2) Write 55H to FAAAH. - (3) Write A5H to F555H. - <sup>1</sup> Refer to how to enter ISP mode. - <sup>2</sup> Command sequence to activate Flash write/erase mode. It is composed of sequentially writing data of Flash memory. #### Flash write mode - Step 1. Enable program mode. - Step 2. Reset page buffer. FEMR: 1000\_0001B, FECR: 0000\_0010B - Step 3. Select page buffer. FEMR: 1000\_1001B - Step 4. Write data to page buffer. (Address automatically increases by twin.) - Step 5. Set write mode. FEMR: 1010\_0001B - Step 6. Set page address. FEARH:FEARM:FEARL=20'hx\_xxxx - Step 7. Set FETCR. - Step 8. Start program. FECR: 0000\_1011B - Step 9. Insert one NOP operation. - Step 10. Read FESR until PEVBSY is 1. - Step 11. Repeat step 2 to step 8 until all pages are written. #### Flash page erase mode - Step 1. Enable program mode. - Step 2. Reset page buffer. FEMR: 1000\_0001B, FECR: 0000\_0010B - Step 3. Select page buffer. FEMR: 1000\_1001B Step 4. Write 00H to page buffer. (Data value is not important.) Step 5. Set erase mode. FEMR: 1001\_0001B Step 6. Set page address. FEARH:FEARM:FEARL=20'hx\_xxxx Step 7. Set FETCR. Step 8. Start erase. FECR: 0000\_1011B Step 9. Insert one NOP operation Step 10. Read FESR until PEVBSY is 1. Step 11. Repeat step 2 to step 8 until all pages are erased. #### Flash bulk erase mode Step 1. Enable program mode. Step 2. Reset page buffer. FEMR: 1000\_0001B, FECR: 0000\_0010B Step 3. Select page buffer. FEMR: 1000\_1001B Step 4. Write 00H to page buffer. (Data value is not important.) Step 5. Set erase mode. FEMR: 1001\_0001B (Only main cell area is erased. For bulk erase including OTP area, select OTP area. (set FEMR to 1000\_1101B.) Step 6. Set FETCR. Step 7. Start bulk erase. FECR: 1000\_1011B Step 8. Insert one NOP operation. Step 9. Read FESR until PEVBSY is 1. #### 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\_0101B Step 5. Read data from Flash. #### Flash OTP area write mode Step 1. Enable program mode. Step 2. Reset page buffer. FEMR: 1000\_0001B, FECR: 0000\_0010B Step 3. Select page buffer. FEMR: 1000\_1001B Step 4. Write data to page buffer. (Address automatically increases by twin.) Step 5. Set write mode and select OTP area. FEMR: 1010\_0101B Step 6. Set page address. FEARH:FEARM:FEARL=20'hx\_xxxx Step 7. Set FETCR. Step 8. Start program. FECR: 0000\_1011B Step 9. Insert one NOP operation. Step 10. Read FESR until PEVBSY is 1. #### Flash OTP area erase mode Step 1. Enable program mode. Step 2. Reset page buffer. FEMR: 1000\_0001B, FECR: 0000\_0010B Step 3. Select page buffer. FEMR: 1000\_1001B Step 4. Write 00H to page buffer. (Data value is not important.) Step 5. Set erase mode and select OTP area. FEMR: 1001\_0101B Step 6. Set page address. FEARH:FEARM:FEARL=20'hx\_xxxx Step 7. Set FETCR. Step 8.Start erase. FECR: 0000\_1011B Step 9. Insert one NOP operation. Step 10. Read FESR until PEVBSY is 1. ## Flash program verify mode Step 1. Enable program mode. Step 2. Set program verify mode. FEMR: 1010\_0011B Step 3. Read data from Flash. #### OTP program verify mode Step 1. Enable program mode. Step 2. Set program verify mode. FEMR: 1010\_0111B Step 3. Read data from Flash. ### Flash erase verify mode Step 1. Enable program mode. Step 2. Set erase verify mode. FEMR: 1001\_0011B Step 3. Read data from Flash. #### Flash page buffer read Step 1. Enable program mode. Step 2. Select page buffer. FEMR: 1000\_1001B Step 3. Read data from Flash. ### Summary of Flash Program/Erase Mode #### Table 48. Operation Mode | Opera | tion mode | Description | |-------|------------------------|---------------------------------------------| | | Flash read | Read cell by byte. | | F | Flash write | Write cell by bytes or page. | | L | Flash page erase | Erase cell by page. | | Α | Flash bulk erase | Erase the whole cells. | | S | 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. | ## 20.4 Mode Entrance Method of ISP Mode ### 20.4.1 Mode Entrance Method for ISP | TARGET MODE | DSDA | DSCL | DSDA | |-------------|------|------|------| | OCD(ISP) | 'hC | 'hC | 'hC | Figure 139. ISP Mode # 20.5 Security A96T418 provides Lock bits which can be left un-programmed ("0") or can be programmed ("1") to obtain the additional features listed in Table 49. The Lock bit can only be erased to "0" with the bulk erase command and a value of more than 0x40 at FETCR. Table 49. Security policy using lock-bits | LOCK | USER MODE | | | | | | | ISP MODE | | | | | | | | | |-------|-----------|---|----|----|-----|---|----|----------|------|----|----|----|-----|---|----|----| | MODE | FLAS | Н | | | OTF | • | | | FLAS | SH | | | ОТР | | | | | 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 | | 1 | 0 | 0 | 0 | Х | Х | Х | Х | х | Х | Х | Х | 0 | 0 | Х | Х | 0 | · LOCKF: Lock bit of Flash memory R: Read W: Write PE: Page erase BE: Bulk Erase O: Operation is possible. X: Operation is impossible. # 20.6 Configure Option ### 20.6.1 Configure Option Control The data for configure option should be written in the configure option area (003EH – 003FH) by programmer (Writer tools). 20.6.2 Register Description #### CONFIGURE OPTION 2: ROM Address 0001H **PAEN** | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|--------------|---------------|------------------|---------------|-------|-------|----------------| | R_P | HL | _ | VAPEN | _ | _ | _ | RSTS | | | | | | | | Init | ial value: 00H | | | R_P | Code R | Read Protection | | | | | | | | 0 | Disable | | | | | | | | 1 | Enable | | | | | | | HL | Code V | Vrite Protection | | | | | | | | 0 | Disable | | | | | | | | 1 | Enable | | | | | | | VAPEN | Vector | area (00H~FFH | ) Protection | | | | | | | 0 | Disable Prot | ection | | | | | | | 1 | Enable Prote | ection | | | | | | RSTS | Select | RESETB pin | | | | | | | | 0 | Disable RES | SETB pin(P31) | | | | | | | 1 | Enable RES | ETB pin | | | | | CONFIGURE | OPTION 1: RO | OM Address 00 | 000H (A96T41 | 8 32K Series) | | | | | | | | - | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | _ | _ | _ | _ | PAEN | PASS2 | PASS1 | PASS0 | Initial value: 00H | | 0 | | Disable Pro | otection | |------------|---------------------|-----------|---------------|-------------------------------------| | | 1 | | Enable Pro | tection | | PASS [2:0] | Select Sp<br>NOTES: | pecific A | rea for Write | Protection | | | | 1. W | hen PAEN = | '1', it is applied. | | | PASS2 | PASS1 | 1 PASS0 | Description | | | 0 | 0 | 0 | 0.7Kbytes (Address 0100H – 03FFH) | | | 0 | 0 | 1 | 1.7Kbytes (Address 0100H – 07FFH) | | | 0 | 1 | 0 | 2.7Kbytes (Address 0100H – 0BFFH) | | | 0 | 1 | 1 | 3.7Kbytes (Address 0100H – 0FFFH) | | | 1 | 0 | 0 | 29.75Kbytes (Address 0100H – 77FFH) | | | 1 | 0 | 1 | 30.75Kbytes (Address 0100H – 7BFFH) | | | 1 | 1 | 0 | 31.25Kbytes (Address 0100H – 7DFFH) | | | 1 | 1 | 1 | 31.50Kbytes (Address 0100H – 7EFFH) | Enable Specific Area Write Protection # 21 Electrical Characteristics # 21.1 Absolute Maximum Ratings Table 50. 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 nin with respect to VSS | | | Vo | -0.3~VDD+0.3 | V | Voltage on any pin with respect to VSS | | | Іон | 42.5 | mA | Maximum current output sourced by (Іон per І/О | | | | | | pin) | | Normal Voltage Pin | ∑Іон | 112 | mA | Maximum current (∑lон) | | | I <sub>OL1</sub> | 50 | mA | Maximum current (I <sub>OL1</sub> per I/O pin) | | | $\Sigma I_{OL1}$ | 101 | mA | Maximum current (∑l <sub>OL1</sub> ) | | | I <sub>OL2</sub> | 160 | mA | Maximum current sunk by (I <sub>OL2</sub> per I/O pin) | | | ∑loL2 | 160 | mA | Maximum current by LED Drive (∑loL2) | | Total Power Dissipation | Рт | 600 | mW | - | | Storage Temperature | T <sub>STG</sub> | -65~+150 | °C | - | #### NOTES: 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. # 21.2 Recommended Operating Conditions Table 51. Recommended Operating Conditions $(T_A = -40^{\circ}C \sim 85^{\circ}C)$ | Parameter | Symbol Conditions | | MIN | TYP | MAX | Unit | |--------------------------|-------------------|---------------------------------|-----|-----|-----|------| | | | f <sub>X</sub> = 16MHz HSIRC | 2.0 | _ | 5.5 | | | On a ration of Malta and | VDD | f <sub>X</sub> = 128kHz LSIRC | 2.0 | _ | 5.5 | \ | | Operating Voltage | VDD | fx= 32 ~ 38kHz Ext. Sub Crystal | 2.0 | _ | 5.5 | V | | | | Touch, ADC, LED Driver | 2.7 | _ | 5.5 | | | Operating Temperature | T <sub>OPR</sub> | VDD=2.0~5.5V | -40 | _ | 85 | °C | 21. Electrical Characteristics A96T418 User's manual ### 21.3 Touch Sensing Characteristics Table 52. Touch Switch Characteristics | Parameter | Symbol | Condition | MIN | TYP | MAX | Unit | |------------------------|--------|--------------------|-----|-----|-----|------| | Load Capacitance | Cload | - | - | 50 | 100 | pF | | Operating Frequency | Fop | Cload=50pF(@typ.) | 2 | 4 | 4 | MHz | | | | Cload=100pF(@min.) | | | | | | High-Sense Voltage | VHS | VDD=5V | 2.6 | 3.5 | 5 | V | | COMP Reference Voltage | VCOM | VDD=5V | 2.5 | 3 | 3.5 | V | ### 21.4 A/D Converter Characteristics Table 53. A/D Converter Characteristics $(T_A=-40^{\circ}C \sim +85^{\circ}C, VDD=2.7V \sim 5.5V, VSS=0V)$ | Parameter | Symbol | Condition | ne | MIN | TYP | MAX | Unit | |------------------------------|------------------|------------|----------------|--------|-----|-------|-------| | 1 didilietei | Cyllibol | Condition | 10 | IVIIIA | 111 | IVIZX | Offic | | Resolution | _ | - | | | 12 | _ | bit | | Integral Linear Error | ILE | | | _ | - | ±6 | | | Differential Linearity Error | DLE | AVREF= | 2.7V – 5.5V | _ | _ | ±1 | LSB | | Zero Offset Error | ZOE | fx= 8MHz | Z | _ | _ | ±5 | LOD | | Full Scale Error | FSE | | | _ | - | ±5 | | | Conversion Time | tcon | 12-bit res | solution, 8MHz | 8 | - | _ | us | | Analog Input Voltage | V <sub>AN</sub> | _ | | VSS | _ | AVREF | V | | Analog Reference Voltage | AVREF | *Note 3 | | 2.7 | _ | VDD | V | | Analog Input Leakage Current | I <sub>AN</sub> | AVREF= | 5.12V | _ | _ | 2 | uA | | ADC Operating Current | | Enable | \/DD=E 43\/ | _ | 1 | 2 | mA | | ADC Operating Current | I <sub>ADC</sub> | Disable | VDD=5.12V | _ | _ | 0.1 | uA | #### NOTES: - Zero offset error is the difference between 000000000000 and the converted output for zero input voltage (VSS). - 2. Full scale error is the difference between 111111111111 and the converted output for full-scale input voltage (AVREF). - 3. When AVREF is lower than 2.7V, the ADC resolution is worse. #### 21.5 Power-On Reset Characteristics Table 54. Power-on Reset Characteristics $(T_A=-40^{\circ}C \sim +85^{\circ}C, VDD=2.0V \sim 5.5V, VSS=0V)$ | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | |-------------------------|------------------|------------|------|-----|------|------| | RESET Release Level | V <sub>POR</sub> | _ | _ | 1.2 | _ | V | | VDD Voltage Rising Time | t <sub>R</sub> | _ | 0.05 | _ | 50.0 | V/ms | | Minimum Pulse Width | t <sub>LW</sub> | _ | 100 | | | us | | POR Current | I <sub>POR</sub> | _ | _ | 0.2 | _ | uA | ### 21.6 Low Voltage Reset and Low Voltage Indicator Characteristics A96T418 User's manual 21. Electrical Characteristics Table 55. LVR and LVI Characteristics $(T_A=-40^{\circ}C \sim +85^{\circ}C, VDD=2.0V \sim 5.5V, VSS=0V)$ | Parameter | Symbol | Conditions | | MIN | TYP | MAX | Unit | |---------------------|------------------|--------------------------|---------------------------|------|------|------|------| | | | | | - | 1.61 | 1.75 | | | | | | | 1.63 | 1.77 | 1.91 | | | | | | | 1.73 | 1.88 | 2.03 | | | | | | | 1.84 | 2.00 | 2.16 | | | | | | | 1.96 | 2.13 | 2.30 | | | | | The LVD are asless all | accela lecit | 2.10 | 2.28 | 2.46 | | | | | The LVR can select all I | | 2.26 | 2.46 | 2.66 | V | | Detection Level | V <sub>LVR</sub> | LVI can select other le | • | 2.47 | 2.68 | 2.89 | | | | V <sub>LVI</sub> | | .61/1.77/1.88/2.00/2.13V. | | | 3.03 | | | | | (Falling level) | | 2.82 | 3.06 | 3.30 | | | | | | | 2.95 | 3.21 | 3.47 | | | | | | | 3.28 | 3.56 | 3.84 | | | | | | | 3.43 | 3.73 | 4.03 | | | | | | | 3.60 | 3.91 | 4.22 | | | | | | | 3.91 | 4.25 | 4.59 | | | Hysteresis | ΔV | - | | _ | 30 | 180 | mV | | Minimum Pulse Width | t <sub>LW</sub> | - | | 100 | _ | _ | us | | | | Enable (Both) | VDD= 3V, | _ | 14.0 | 24.0 | | | LVR and LVI Current | I <sub>BL</sub> | Enable (One of two) | RUN Mode | _ | 10.0 | 18.0 | uA | | | | Disable (Both) | VDD= 3V | _ | _ | 0.1 | | #### NOTES: 1. Guaranteed by design 21. Electrical Characteristics A96T418 User's manual # 21.7 High Internal RC Oscillator Characteristics Table 56. High Internal RC Oscillator Characteristics $(T_A=-40^{\circ}C \sim +85^{\circ}C, VDD=2.0V \sim 5.5V, VSS=0V)$ | Parameter | Symbol | Conditions | | MIN | TYP | MAX | Unit | |--------------------|------------------|---------------------------------|------------|-----|-----|------|------| | Frequency | firc | V <sub>DD</sub> = 2.0 – 5.5V | | _ | 16 | _ | MHz | | | | | With 0.1uF | | | | | | Tolerance | _ | T <sub>A</sub> = -40°C to +85°C | Bypass | _ | _ | ±3.0 | % | | | | | capacitor | | | | | | Clock Duty Ratio | TOD | - | | 40 | 50 | 60 | % | | Stabilization Time | T <sub>HFS</sub> | _ | | _ | _ | 100 | us | | IDC Command | | Enable | | - | 0.2 | _ | mA | | IRC Current | I <sub>IRC</sub> | Disable | | _ | _ | -0.1 | uA | #### NOTES: 1. A 0.1uF bypass capacitor should be connected to VDD and VSS. ### 21.8 Low Internal RC Oscillator Characteristics Table 57. Internal WDTRC Oscillator Characteristics $(T_A=-40^{\circ}C \sim +85^{\circ}C, VDD=2.0V \sim 5.5V, VSS=0V)$ | | | (-71 | 10 0 100 | , c, tbb <u>-</u> . | 0.01, 1 | | |--------------------|--------|-------------------------------|----------|---------------------|---------|------| | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | | Frequency | fLSIRC | T <sub>A</sub> =-40°C ~ +85°C | 102 | 128 | 154 | kHz | | Stabilization Time | TLSIRC | - | _ | _ | 1 | ms | | L CIDC Command | _ | Enable | _ | 1 | _ | | | LSIRC Current | ILSIRC | Disable | _ | _ | 0.1 | uA | ### 21.9 DC Characteristics Table 58. DC Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.0V \sim 5.5V, VSS = 0V, f_{SCLK} = 16MHz)$ | Parameter | Symbol | Conditions | • | MIN | TYP | MAX | Unit | |---------------------------------------------------|------------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------|---------|-------|--------|------| | Input High Voltage | VIH | All input pins | | 0.7VDD | _ | VDD | V | | Input Low Voltage | V <sub>IL</sub> | All input pins exce | pt V <sub>IL1</sub> | _ | _ | 0.3VDD | V | | Output High | V <sub>OH1</sub> | VDD=4.5V, I <sub>OH</sub> =-8<br>All output ports; | .57mA, | VDD-1.0 | - | - | V | | Voltage | V <sub>OH2</sub> | VDD=4.5V, I <sub>OH</sub> = -1<br>All output ports; | 19 mA, | VDD-2.0 | - | - | V | | SEG Output High<br>Voltage | V <sub>OH3</sub> | VDD=5.0V, I <sub>OH</sub> = -1<br>All SEG ports; | 13.61 mA, | VDD-3.0 | _ | - | V | | SEG Current Matching ( ISEG- ISEGAVR) / ISEGAVR ) | ITOSEG | VOH=4.5V<br>TA= 25°C | VDD=5.0V | -5 | | 5 | % | | Output Law Valtage | V <sub>OL1</sub> | | VDD=4.5V, IoL= 10mA; All output ports except VoL2 VDD=5V, IoL= 160mA; P2x High sink current output | | - | 1.0 | V | | Output Low Voltage | V <sub>OL2</sub> | · | | | 1.5 | 3 | V | | Input High Leakage<br>Current | Іін | All input ports | | | _ | 1 | uA | | Input Low Leakage<br>Current | lı. | All input ports | | -1 | _ | - | uA | | Pull-Up Resistor | R <sub>PU</sub> | VI=0V,<br>T <sub>A</sub> = 25°C<br>All Input ports | VDD=5.0V | 25 | 50 | 100 | kΩ | | OSC feedback resistor | Rx | SXIN=VDD, SXOU<br>T <sub>A</sub> = 25°C, VDD=5 | | 6.25 | 13.53 | 36.98 | МΩ | | | I <sub>DD1</sub> (RUN) | f <sub>HSI</sub> = 16MHz, VDD | = 5V±10% | 0.7 | - | 4.0 | mA | | Power Supply | I <sub>DD2</sub> | f <sub>HSIRC</sub> = 16MHz, VE | 0.5 | - | 3.0 | mA | | | Current | IDD3(STOP1) | STOP @ WDT on<br>T <sub>A</sub> = 25°C | , VDD= 5.5V±10%, | - | - | 22.0 | | | | IDD4(STOP2) | STOP @ WDT off<br>VDD= 5.5V±10%, | | - | - | 7.0 | uA | ### NOTES: - 1. Where f<sub>SUB</sub> is an external sub oscillator, the f<sub>HSIRC</sub> and f<sub>LSIRC</sub> are an internal RC oscillator, and the fx is the selected system clock. - 2. All supply current items don't include the current of an internal Watch-dog timer RC (WDTRC) oscillator and a peripheral block. - 3. All supply current items include the current of the power-on reset (POR) block. # 21.10 AC Characteristics Table 59. AC Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.0V \sim 5.5V)$ | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | |-------------------------------------------------|---------------------|----------------------------|-----|-----|-----|------| | RESETB input low width | trsL | Input, VDD= 5V | 10 | ı | 1 | us | | Interrupt input high, low width | t <sub>INTH</sub> , | All interrupt, VDD= 5V | 200 | _ | _ | | | External Counter Input High,<br>Low Pulse Width | tECWH, | ECn, VDD = 5V (n= 0, 1, 3) | 200 | ı | ı | ns | | External Counter Transition Time | tREC,<br>tFEC | ECn, VDD = 5V (n= 0, 1, 3) | 20 | _ | _ | | Figure 140. AC Timing ### 21.11 USART Characteristics Table 60. USART Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.0V \sim 5.5V, f_{SCLK} = 8MHz)$ | Parameter | Symbol | MIN | TYP | MAX | Unit | |-----------------------------------------|--------------------------------------|-----------------------|----------------------|------|------| | Serial port clock cycle time | tsck | 1800 | tcpu x 16 | 2200 | ns | | Output data setup to clock rising edge | t <sub>S1</sub> | 8100 | tcpu x 13 | _ | ns | | Clock rising edge to input data valid | ts2 | _ | _ | 590 | ns | | Output data hold after clock rising | 4 | t 50 | 4 | | | | edge | t <sub>H1</sub> | t <sub>CPU</sub> - 50 | <b>t</b> cpu | _ | ns | | Input data hold after clock rising edge | t <sub>H2</sub> | 0 | _ | _ | ns | | Serial port clock High, Low level width | t <sub>HIGH</sub> , t <sub>LOW</sub> | 720 | t <sub>CPU</sub> x 8 | 1280 | ns | Figure 141. Waveform for USART Timing Characteristics Figure 142. Timing Waveform for the USART Module ### 21.12 SPI0 Characteristics Table 61. SPI0 Characteristics $(T_A=-40^{\circ}C-+85^{\circ}C, VDD=2.0V-5.5V)$ | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | |------------------------------------|--------|------------------------------|-----|-----|-----|------| | Output Clock Pulse Period | 1001 | Internal SCK source | 200 | _ | _ | | | Input Clock Pulse Period | tsck | External SCK source | 200 | _ | _ | | | Output Clock High, Low Pulse Width | tSCKH, | Internal SCK source | 70 | _ | _ | | | Input Clock High, Low Pulse Width | tSCKL | External SCK source | 70 | _ | _ | ns | | First Output Clock Delay Time | tFOD | Internal/External SCK source | 100 | _ | _ | | | Output Clock Delay Time | tDS | - | _ | _ | 50 | | | Input Setup Time | tDIS | - | 100 | _ | _ | | | Input Hold Time | tDIH | _ | 150 | _ | _ | | Figure 143. SPI0/1/2 Timing ### 21.13 UART0 Characteristics Table 62. UART0 Characteristics $(T_A=-40^{\circ}C \sim +85^{\circ}C, VDD=2.0V \sim 5.5V, f_{SCL}=8MHz)$ | Parameter | Symbol | MIN | TYP | MAX | Unit | |------------------------------------------|-----------------|----------|-----------|------|------| | Serial port clock cycle time | tscк | 1800 | tcpu x 16 | 2200 | ns | | Output data setup to clock rising edge | ts1 | 810 | tcpu x 13 | - | ns | | Clock rising edge to input data valid | t <sub>S2</sub> | - | - | 590 | ns | | Output data hold after clock rising edge | t <sub>H1</sub> | tcpu- 50 | tcpu | - | ns | | Input data hold after clock rising edge | t <sub>H2</sub> | 0 | _ | - | ns | | Serial port clock High, Low level width | thigh, tlow | 720 | tcpu x 8 | 1280 | ns | Figure 144. Waveform for UART0 Timing Characteristics Figure 145. Timing Waveform for the UART0 Module ### 21.14 I2C0 Characteristics Table 63. I2C0 Characteristics $(T_A = -40 \degree C \sim +85 \degree C, VDD = 2.0 V \sim 5.5 V)$ | Bonomoton | Comple of | Standard | Mode | High-Spe | ed Mode | 1.1-4 | |----------------------------|-----------|----------|------|----------|---------|-------| | Parameter | Symbol | MIN | MAX | MIN | MAX | Unit | | 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 | tBF | 4.7 | _ | 1.3 | _ | | | Start Condition Setup Time | tstsu | 4.7 | _ | 0.6 | _ | | | Start Condition Hold Time | tSTHD | 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 | tVD | 0 | _ | 0 | _ | | | Data Input Hold Time | tDIH | 0 | _ | 0 | 1.0 | | | Data Input Setup Time | tDIS | 250 | _ | 100 | _ | ns | Figure 146. I2C0 Timing ### 21.15 Data Retention Voltage in Stop Mode Table 64. Data Retention Voltage in Stop Mode | | | | ( | I <sub>A</sub> =-40°C ~ | +85°C, VDL | )=2.0V ~ 5.5V) | |-------------------------------|-------------------|--------------------------|-----|-------------------------|------------|----------------| | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | | Data retention supply voltage | V <sub>DDDR</sub> | _ | 2.0 | _ | 5.5 | V | | | | VDDR= 2.0V, | | | | | | Data retention supply current | I <sub>DDDR</sub> | (T <sub>A</sub> = 25°C), | _ | _ | 1 | uA | | | | Stop mode | | | | | Figure 147. Stop Mode Release Timing when Initiated by an Interrupt Figure 148. Stop Mode Release Timing when Initiated by RESETB 21. Electrical Characteristics A96T418 User's manual ### 21.16 Internal Flash Rom Characteristics Table 65. Internal Flash Rom Characteristics $(T_A=-40^{\circ}C \sim +85^{\circ}C, VDD=2.0V \sim 5.5V, VSS=0V)$ | Parameter | Symbol | Condition | MIN | TYP | MAX | Unit | |----------------------------|------------------|-----------|-----|-----|--------|--------| | Sector Write Time | trsw | _ | _ | 2.5 | 2.7 | | | Sector Erase Time | trse | _ | - | 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 | £ | | 0.4 | | | NAL I— | | Frequency | f <sub>PGM</sub> | _ | 0.4 | _ | _ | MHz | | Endurance of Write/Erase | NF <sub>WE</sub> | _ | _ | _ | 10,000 | times | #### NOTES: 1. During a flash operation, SCLK[1:0] of SCCR must be set to "00" or "01" (INT-RC OSC for system clock). # 21.17 Input/Output Capacitance Table 66. Input / Output Capacitance $(T_A = -40 ^{\circ}C \sim +85 ^{\circ}C, VDD = 0V)$ | Parameter | Symbol | Condition | MIN | TYP | MAX | Unit | |--------------------|--------|---------------------|-----|-----|-----|------| | Input Capacitance | Cin | fx= 1MHz | | | | | | Output Capacitance | Соит | Unmeasured pins are | _ | _ | 10 | pF | | I/O Capacitance | Cio | connected to VSS | | | | | ### 21.18 Sub Clock Oscillator Characteristics Table 67. Sub Clock Oscillator Characteristics $(T_A = -40^{\circ}C \sim +85^{\circ}C, VDD = 2.0V \sim 5.5V)$ | Oscillator | Parameter | Condition | MIN | TYP | MAX | Unit | |----------------|---------------------------|-------------|-----|--------|-----|------| | Crystal | Sub oscillation frequency | 2.0V - 5.5V | 32 | 32.768 | 38 | kHz | | External Clock | SXIN input frequency | 2.00 - 5.50 | 32 | _ | 100 | kHz | Figure 149. Crystal Oscillator Figure 150. External Clock ### 21.19 Sub Oscillation Characteristics Table 68. Sub Oscillation Stabilization Characteristics $(T_A=-40^{\circ}C \sim +85^{\circ}C, VDD=2.0V \sim 5.5V)$ | Oscillator | Parameter | MIN | TYP | MAX | Unit | |----------------|--------------------------------------------------------------------|-----|-----|-----|------| | Constal | T <sub>A</sub> =-40°C ~+85°C | _ | - | 10 | S | | Crystal | T <sub>A</sub> = 25°C | | 500 | | ms | | External Clock | SXIN input high and low width (t <sub>XH</sub> , t <sub>XL</sub> ) | 5 | - | 15 | us | Figure 151. Clock Timing Measurement at SXIN # 21.20 Operating Voltage Range Figure 152. Operating Voltage Range # 21.21 Recommended Circuit and Layout Figure 153. Recommended Voltage Range # 21.22 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 154. RUN (IDD1) Current Figure 155. IDLE (IDD2) Current Figure 156. SUB RUN (IDD3) Current Figure 157. SUB IDLE (IDD4) Current Figure 158. STOP (IDD5) Current # 22 Development Tools This chapter introduces wide range of development tools for A96T418. ABOV offers software tools, debuggers, and programmers to help a user in generating right results to match target applications. ABOV supports entire development ecosystem of the customers. #### 22.1 Compiler ABOV Semiconductor does not provide compiler. It is recommended that you consult a compiler provider. It is recommended to consult a compiler provider. Since A96T376 has Mentor 8051 as its core, and ROM is smaller than 64Kbytes in size, a developer can use any standard 8051 compiler of other providers. ### 22.2 OCD(On-chip debugger) emulator and debugger The OCD emulator supports ABOV's 8051 series MCU emulation. The OCD uses two wires interfacing between PC and MCU, which is attached to user's system. The OCD can read or change the value of MCU's internal memory and I/O peripherals. In addition, the OCD controls MCU's internal debugging logic. This means OCD controls emulation, step run, monitoring and many more functions regarding debugging. The OCD debugger program runs underneath MS operating system such as MS-Windows NT/ 2000/ XP/ Vista (32-bit). If a user wants to see more details, it is recommend to refer to OCD debugger manual by visiting ABOV's website (http://www.abovsemi.com) and downloading debugger S/W and corresponding manuals. - Connection: - DSCL (A96T418 P02 port) - DSDA (A96T418 P01 port) Figure 159 shows pinouts of OCD connector. Figure 159. Debugger(OCD1/OCD2) and pin description # 22.3 Programmer #### 22.3.1 E-PGM+ E-PGM+ USB is a single programmer. A user can program A96T376 directly using the E-PGM+. - Support ABOV / ADAM devices - 2~5 times faster than S-PGM+ - Main controller: 32 bit MCU @ 72MHz - Buffer memory: 1Mbyte Figure 160. E-PGMplus (Single writer) A96T418 User's manual 22. Development Tools ## 22.4 Flash Programming #### 22.4.1 Overview The program memory of A96T418 is Flash Type. This flash is accessed by serial data format. There are four pins(DSCL, DSDA, VDD, and VSS) for programming/reading the flash. Table 69. Descriptions of pins which are used to programming/reading the Flash | Din nome | Main chip | | gramming | |-------------------|-----------|-----|---------------------------------------------------------------| | Pin name pin name | | I/O | Description | | DSCL | P02 | 1 | Serial clock pin. Input only pin. | | DSDA | P01 | I/O | Serial data pin. Output port when reading and input port when | | DSDA FUT | | 1/0 | programming. Can be assigned as input/push-pull output port. | | VDD, VSS | VDD, VSS | - | Logic power supply pin. | #### 22.4.2 On-Board Programming The A96T418 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. #### 22.4.3 Circuit Design Guide When programming flash memory, the programming tool needs 4 signal lines, DSCL, DSDA, VDD, and VSS. If a user designs a PCB circuit, the user should consider the usage of these 4 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. Figure 161. PCB design guide for on board programming The value of R1 and R2 is recommended value. It varies with circuit of system. #### 22.4.4 OCD emulator OCD emulator allows a user to write code on the device too, since OCD debugger supports ISP (In System Programming). It doesn't require additional H/W, except developer's target system. ### 22.4.5 Gang programmer E-Gang4 and E-Gang6 allows a user to program on multiple devices at a time. They run not only in PC controlled mode but also in standalone mode without PC control. USB interface is available and it is easy to connect to the handler. Figure 162. E-GANG4 and E-GANG6 (for Mass Production) ### 22.5 On-chip Debug System 22. Development Tools A96T418 User's manual A96T418supports On-Chip Debug (OCD) system. On-chip debug system of A96T418 can be used for programming the non-volatile memories and on-chip debugging. Detail descriptions for programming via the OCD interface can be found in this section. Features of the OCD is introduced in Table 70. Table 70. Descriptions of pins which are used to programming/reading the Flash | Two wire external interface | <ul><li>1 for serial clock input</li><li>1 for bi-directional serial data bus</li></ul> | | | | |-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Debugger accesses | <ul> <li>All internal peripherals</li> <li>Internal data RAM</li> <li>Program Counter</li> <li>Flash memory and data EEPROM memory</li> </ul> | | | | | Extensive On-Chip Debugging supports for Break Conditions | <ul> <li>Break instruction</li> <li>Single step break</li> <li>Program memory break points on single address</li> <li>Programming of Flash, EEPROM, Fuses, and Lock bits through the two-wire interface</li> <li>On-Chip Debugging supported by Dr. Choice®</li> </ul> | | | | | Operating frequency | The maximum frequency of a target MCU | | | | Figure 163 shows a block diagram of the OCD interface and the OCD system. Figure 163. Block Diagram of On-Chip Debug System #### 22.5.1 Two-Pin External Interface #### **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 164. 10-bit Transmission Packet 22. Development Tools A96T418 User's manual ### **Packet Transmission Timing** Figure 165. Data Transfer on the Twin Bus Figure 166. Bit Transfer on the Serial Bus Figure 167. Start and Stop Condition A96T418 User's manual 22. Development Tools Figure 168. Acknowledge on the Serial Bus Figure 169. Clock Synchronization during Wait Procedure ### **Connection of Transmission** Two-pin interface connection uses open-drain(wire-AND bidirectional I/O). Figure 170. Connection of Transmission A96T418 User's manual 23. Package Diagram # 23 Package Diagram Figure 171. 28-Pin SOP Package 23. Package Diagram A96T418 User's manual Figure 172. 24-Pin SOP Package A96T418 User's manual 23. Package Diagram Figure 173. 20-Pin SOP Package # 24 Ordering Information Table 71. Ordering Information of A96T418 | Device Name | FLASH | XRAM | IRAM | Touch<br>Switch | LED Driver | ADC | I/O<br>PORT | Package | | | | | | | | |-------------|--------------|-----------------------------|-----------|-----------------|------------|---------|-------------|---------|--------|-----|--|-------|--------|----------|----| | A96T418GD | 20-ch 8COM / | | 8COM / | 0: | 25 | 28 SOP | | | | | | | | | | | A901410GD | | | | 20-011 | 16SEG | 8inputs | 25 | 20 30F | | | | | | | | | A96T418LD* | 32Kbytes | 32Kbytes 1792bytes 256bytes | 1700h. da | 0506.4 | 17-ch | 8COM / | Oinnuto | 21 | 24 SOP | | | | | | | | A901410LD | | | ∠oobytes | 17-011 | 16SEG | 8inputs | 21 | 24 SUP | | | | | | | | | A06T449ED* | | | | | | | | | | , [ | | 12 ob | 8COM / | Oinnuto. | 17 | | A96T418FD* | | | | 13-ch | 15SEG | 8inputs | 17 | 20 SOP | | | | | | | | <sup>\*</sup> For available options or further information on the device with an "\*" mark, please contact the ABOV sales office. # **Device Nomenclature** Appendix A96T418 User's manual # **Appendix** ### **Instruction Table** Instructions are either1, 2 or 3bytes 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 | 1 4 84 | | | DA A | Decimal Adjust A | 1 | 1 | D4 | A96T418 User's manual Appendix | 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 | | ORL A,Rn | OR register to A | 1 | 1 | 48-4F | | ORL A,dir | OR direct byte to A | 2 | 1 | 45 | | ORL A,@Ri | OR indirect memory to A | 1 | 1 | 46-47 | | ORL A,#data | OR immediate to A | 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 | 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 | | CPL A | Complement A | 1 | 1 | F4 | | SWAP A | Swap Nibbles of A 1 1 | | 1 | C4 | | RL A | Rotate A left | 1 | 1 | 23 | | RLC A | Rotate A left through carry | 1 | 1 | 33 | | RR A | Rotate A right | 1 1 03 | | 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 | dir Move direct byte to A | | 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 | 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 | | A96T418 User's manual Appendix | 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 | | A2 | | | MOV bit,C | Move carry to direct bit | 2 | 2 | 92 | Appendix A96T418 User's manual | 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 | | 2 | B4 | | CJNE Rn,#d,rel | Compare register, immediate jne relative 3 2 | | 2 | B8-BF | | CJNE @Ri,#d,rel | Compare indirect, immediate jne relative | 3 | 2 | B6-B7 | | DJNZ Rn,rel | Decrement register, jnz relative | ement register, jnz relative 2 2 | | D8-DF | | DJNZ dir,rel | Decrement direct byte, jnz relative | 3 | 2 | D5 | A96T418 User's manual Appendix | 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 @(DDTD) A | M8051W/M8051EW-specific instruction supporting | 1 | 2 | A5 | | MOVC @(DPTR++),A | software download into program memory | • | | | | 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. Revision History # **Revision History** | Version | Date | Revision list | |---------|------------|--------------------| | 1.00 | 2020.08.10 | The First Release. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | A96T418 User's manual Important Notice #### Korea #### Regional Office, Seoul R&D, Marketing & Sales 8th Fl., 330, Yeongdong-daero, Gangnam-gu, Seoul, 06177, Korea Tel: +82-2-2193-2200 Fax: +82-2-508-6903 http://www.abovsemi.com/ #### **Domestic Sales Manager** Tel: +82-2-2193-2206 Fax: +82-2-508-6903 Email: sales kr@abov.co.kr #### HQ, Ochang R&D, QA, and Test Center 93, Gangni 1-gil, Ochang-eup, Cheongwonoun. Chungcheongbuk-do, 28126, Korea Tel: +82-43-219-5200 Fax: +82-43-217-3534 http://www.abovsemi.com/ #### Global Sales Manager Tel: +82-2-2193-2281 Fax: +82-2-508-6903 Email: <u>sales\_gl@abov.co.kr</u> #### China Sales Manager Tel: +86-755-8287-2205 Fax: +86-755-8287-2204 Email: sales cn@abov.co.kr #### **ABOV Disclaimer** #### **IMPORTANT NOTICE - PLEASE READ CAREFULLY** ABOV Semiconductor ("ABOV") reserves the right to make changes, corrections, enhancements, modifications, and improvements to ABOV products and/or to this document at any time without notice. ABOV does not give warranties as to the accuracy or completeness of the information included herein. Purchasers should obtain the latest relevant information of ABOV products before placing orders. Purchasers are entirely responsible for the choice, selection, and use of ABOV products and ABOV assumes no liability for application assistance or the design of purchasers' products. No license, express or implied, to any intellectual property rights is granted by ABOV herein. ABOV disclaims all express and implied warranties and shall not be responsible or liable for any injuries or damages related to use of ABOV products in such unauthorized applications. ABOV and the ABOV logo are trademarks of ABOV. All other product or service names are the property of their respective owners. Information in this document supersedes and replaces the information previously supplied in any former versions of this document. © 2020 ABOV Semiconductor – All rights reserved