

*Rev V0.90* 

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



# **AMENDMENT HISTORY**

| Version | Date      | Description  |
|---------|-----------|--------------|
| 0.90    | Apr, 2018 | New release. |



# CONTENTS

| MENDMENT HISTORY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GENERAL DESCRPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| FEATURES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| PIN ASSIGNMENT DIAGRAM 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PIN DESCRIPTIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| in Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Functional Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1. CPU Core                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1.1Accumulator (ACC)141.2B Register (B)141.3Stack Pointer (SP)141.4Dual Data Pointer (DPTRs)151.5Program Status Word (PSW)16                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2. Memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2.1       Program Memory       17         2.1.1       Program Memory Functional Partition       17         2.1.2       Flash ICP Mode       17         2.1.3       Flash IAP Mode       18         2.1.4       IAP Mode Access Routines       19         2.1.5       Flash ISP Mode       20         2.2       Data Memory       21         2.2.1       IRAM       22         2.2.2       XRAM       22         2.2.3       SFRs       22         3.       Power       24         MODE3V=0       24         MODE3V=1       24 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4.1Power on Reset264.2External Pin Reset264.3Software Reset264.4Watch Dog Timer Reset (WDT)264.5Low Voltage Reset264.6USB Plug Reset26                                                                                                                                                                                                                                                                                                                                                                                        |
| 5. Clock Circuitry & Operation Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5.1 System Clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |



| 5.2          | USB Clock                             | .28  |
|--------------|---------------------------------------|------|
| 5.3          | Operation Mode                        | . 29 |
| 6. Inte      | errupt and Wake-up                    | .30  |
| 6.1          | Interrupt Enable and Priority Control | .30  |
| 6.2          | Pin Interrupt                         |      |
| 6.3          | Idle Mode Wake up and Interrupt       | . 34 |
| 6.4          | Stop Mode Wake up and Interrupt       | .34  |
| 6.5          | USB interrupt                         | .36  |
| 7. I/O       | Ports                                 | .37  |
| 7.1          | Port1 & Port3 & P4                    | . 37 |
| 7.2          | P1.2 (DP) and P1.3 (DM)               | .40  |
| 7.3          | Port0 & Port2 & Port5.0               | .45  |
| 8. Tin       | ners                                  | . 48 |
| 8.1          | Timer0/1                              | .48  |
| 8.2          | Timer2                                | .49  |
| 8.3          | T0O and T2O Output Control            | .51  |
| 9. UA        | RT                                    | .52  |
| 10. F        | PWMs                                  | .54  |
| 10.1         | PWM0                                  | .54  |
| 10.2         | PWM1                                  |      |
| 11. A        | \DC                                   | .61  |
| 11.1         | ADC Channels                          | . 62 |
| 11.2         | ADC Conversion Time                   | . 63 |
| 12. U        | JSB Interface                         | .65  |
| 12.1         | USB Device Address                    | . 65 |
| 12.2         | Endpoint 0 Receive (SET0/OUT0)        |      |
| 12.3         | Endpoint 0 Transmit (TX0)             | .66  |
| 12.4         | Endpoint 1/2 Transmit (TX1/2)         |      |
| 12.5         | Endpoint 3 Transmit (TX3)             |      |
| 12.6         | USB Endpoint 4 Receive (RC4)          |      |
| 12.7         | USB Control and Status                |      |
| 12.8<br>12.9 | Suspend and ResumeUSB Keyboard        |      |
| 12.10        | USB PD                                |      |
|              | erial Peripheral Interface            |      |
| 13.1         | Serial Peripheral Interface (SPIA)    |      |
| 13.1         |                                       |      |
| 13.          |                                       |      |
| 13.          |                                       |      |
| 13.2         | Serial Peripheral Interface B (SPIB)  | . 81 |



|       | 13.2.1           | SPIB Functional Description                                                                                       | .81  |
|-------|------------------|-------------------------------------------------------------------------------------------------------------------|------|
|       | 13.2.2           | SPIB System Block diagram and Register Control                                                                    | .82  |
|       | 13.2.3           | SPIB Clock and Data Format                                                                                        |      |
|       | 13.2.4           | SPIB Power Circuit                                                                                                | . 85 |
|       | 13.2.5           | SPIB DMA Transfer Mode                                                                                            | .85  |
|       | 13.2.6           | SPIB Initial Sample Code                                                                                          | . 87 |
| 14.   | <b>I80 I</b>     | Peripheral Interface (I80)                                                                                        | . 88 |
| 1     | 4.1 I8           | 0 Functional Description                                                                                          | . 88 |
| 1     | 4.2 I8           | 0 System Block Diagram and Register Control                                                                       | . 88 |
| 1     |                  | 0 Clock and Data Format                                                                                           |      |
| 1     | 4.4 I8           | 0 DMA Transfer Mode                                                                                               | .90  |
| 1     | 4.5 I8           | 0 Initial Sample Code                                                                                             | .92  |
| 15.   | In C             | ircuit Emulation (ICE) Mode                                                                                       | .93  |
| SFR a | & CFGV           | V MAP                                                                                                             | .94  |
| SFR a | & CFGV           | V DESCRIPTION                                                                                                     | .97  |
| INST  | RUCTIO           | DN SET1                                                                                                           | 112  |
| ELE(  | CTRICA           | L CHARACTERISTICS1                                                                                                | 115  |
| 1.    | Absolu           | te Maximum Ratings (T <sub>A</sub> =25 <sup>°</sup> C)1                                                           | 115  |
| 2.    | DC Ch            | aracteristics (T <sub>A</sub> =25 <sup>°</sup> C, V <sub>CC</sub> =2.0V ~ 5.5V)                                   | 115  |
| 3.    | Clock '          | Fiming $(T_A = -40^{\circ}C \sim +85^{\circ}C, V_{CC} = 3.0V \sim 5.5V)$                                          | 117  |
| 4.    | Reset 7          | Timing Characteristics ( $T_A = -40^{\circ}C \sim +85^{\circ}C$ , $V_{CC} = 3.0V \sim 5.0V$ )                     | 117  |
| 5.    | ADC E            | Clectrical Characteristics (T <sub>A</sub> =25 <sup>°</sup> C, V <sub>CC</sub> =3.0V ~ 5.5V, V <sub>SS</sub> =0V) | 117  |
| 6.    | Charao           | cteristics Graphs1                                                                                                | 118  |
| PACI  | KAGE IN          | NFORMATION                                                                                                        | 121  |
| Packa | ige Infor        | mation1                                                                                                           | 122  |
| LQ    | <b>FP 48-p</b> i | in (7x7 mm) Package Dimensions                                                                                    | 122  |

\_\_\_\_\_



### **GENERAL DESCRPTION**

**TM52F3288** is version of a new, fast 8051 architecture for an 8-bit microcontroller single chip with an instruction set fully compatible with industry standard 8051, C language development platform, and retains most 8051 peripheral function block and contain the USB full speed general purpose application. Typically, the TM52 executes instruction six times faster than the traditional 8051 architecture.

The **TM52F3288** provides improved performance, lower cost and fast time-to-market by integrating features on the chip, including 16K Bytes Flash program memory, 716 Bytes SRAM, Low Voltage Reset (LVR), dual clock power saving operation mode, 2 set SPI Interface, 8051 standard UART and Timer0/1/2, 2 set (8+2)-bit PWMs, 12 channels 12-bit A/D Convert and Watchdog Timer. Its high reliability and lower power consummation feature can be widely applied in consummation and home appliance products. It can works in USB mode by using USB power or works in standalone mode by using battery power.



#### **BLOCK DIAGRAM**



### **FEATURES**

#### 1. Standard 8051 Instruction Set, fast machine cycle

- Execute instructions six times faster than standard 8051

#### 2. 16 K Bytes Flash Program Memory

- Support "In Circuit Programming" (ICP) or "In System Programming" (ISP) for the Flash Code
- Byte Write "In Application Programming" (IAP) mode is convenient as Data EEPROM access
- Code Protection Capability

#### 3. Total 716 Bytes SRAM (IRAM + XRAM)

- 256 Bytes IRAM in the 8051 internal data memory area
- 460 Bytes XRAM in the 8051 external data memory area (accessed by MOVX Instruction)

#### 4. Two System Clock type Selection

- Fast clock from Internal RC (FRC, 11.0592 MHz)
- Slow clock from Internal RC (SRC, 32KHz)
- System clock can be divided by 1/2/4/16 option

#### 5. 8051 Standard Timer -- Timer0/1/2

- 16-bit Timer0, also supports TOO clock output for Buzzer application
- 16-bit Timer1
- 16-bit Timer2, also supports T2O clock output for Buzzer application

#### 6. USB Interface

- Compliance with the Universal Serial Bus specification v2.0 Full Speed
- Support USB Power Delivery specification R2.0
- Built-in USB Transceiver 3.3V regulator
- Endpoint 0: Control SETUP /IN/OUT transfer (each 8 bytes)
- Endpoint 1: INTERRUPT IN transfer (8 bytes)
- Endpoint 2: INTERRUPT IN transfer (8 bytes)
- Endpoint 3: BULK IN transfer with Ping-Pong feature (2\*64 bytes)
- Endpoint 4: BULK OUT transfer with Ping-Pong feature (2\*64 bytes)
- USB PD transfer (38 bytes)
- USB PD receiver (38 bytes)
- 7. 12-bit ADC convert with 12 input channels
- 8. 8051 Standard UART
  - One Wire UART option can be used for ISP or other application



#### 9. Two SPI Interface

#### SPIA:

- Master or Slave mode selectable
- Programmable transmit bit rate
- Serial clock phase and polarity options
- MSB-first or LSB-first selectable

#### SPIB:

- Support Master only
- Clock rate up to 12Mbps
- Read/Write DMA mode
- Serial clock phase and polarity options
- MSB-first or LSB-first selectable

#### 10. I80 Interface (Nand-Flash Interface)

- compatible with 8-bit parallel interface
- Read/Write DMA mode

#### 11. Two independent "8+2" bits PWMs with prescaler/period-adjust

- PWM0:
  - Width differential output pair
  - Non-overlap durations adjustable
- PWM1:

3 output with different duty but share the same period

#### 12. Pin Interrupt can Wake up CPU from Power-Down (Stop) mode

- P3.2 / P3.3 (INT0 / INT1) Interrupt & Wake-up
- P4.7 (INT2) Interrupt & Wake-up
- Each Port1 pin can be defined as Interrupt & Wake-up pin (by pin change)

#### 13. 24 Sources, 4-level priority Interrupt

- Timer0/Timer1/Timer2 Interrupt
- INT0/INT1 Falling-Edge/Low-Level Interrupt
- Port1 Pin Change Interrupt
- UART TX/RX Interrupt
- P4.7 (INT2) Interrupt
- ADC End of Conversion Interrupt
- SPIA Interrupt
- USB1 Interrupt: SET0I/OUT0I/TX0I/TX1I/TX2I/SUSPI/TX3I/RC4I



- USB2 Interrupt: VDD5VRI/RSTI/RSMI/KBDI/PD\_TXI/PD\_RCI

#### 14. Max. 41 Programmable I/O pins

- CMOS Output
- Pseudo-Open-Drain, or Open-Drain Output
- Schmitt Trigger Input
- Pin Pull-up can be Enabled or Disabled
- P4.4 and P4.5 support high drive/sink current(Max. 40mA)

#### 15. Independent RC Oscillating Watchdog Timer

- 400ms/200ms/100ms/50ms Selectable WDT Timeout options

#### 16. Six type Reset

- Power on Reset
- Selectable External Pin Reset
- Selectable Watch Dog Reset
- Software Command Reset
- Selectable Battery Low Voltage Reset
- USB Plug-out Reset

#### 17. 3-level Low Voltage Reset

- 2.0V/2.3V/2.9V

#### **18. 4 Power Saving Operation Modes**

- Fast / Slow / Idle / Stop Mode

#### **19. On-chip Debug/ICE interface**

- Use P1.2/P1.3 pin or P3.6/P3.7 pin (in USB application)
- Share with ICP programming pin (P1.2/P1.3)
- 20. Operating Voltage: 4.5V~5.5V in USB application or 3.0~5.5 in non-USB application
- **21.** Operating Temperature Range
  - -40C ~+85C
- **22.** 48-pin LQFP Package (7x7x1.4mm)



### PIN ASSIGNMENT DIAGRAM





### **PIN DESCRIPTIONS**

| Name          | In/Out | Pin Description                                                                                                                |
|---------------|--------|--------------------------------------------------------------------------------------------------------------------------------|
| P0.0-P0.7     | I/O    | Bit-programmable I/O port for Schmitt-trigger input, CMOS push-pull output.                                                    |
| 10.0-10.7     | 1/0    | Pull-up resistors are assignable by software.                                                                                  |
|               |        | Bit-programmable I/O port for Schmitt-trigger input, CMOS push-pull output or                                                  |
| P1.0~P1.7     | I/O    | "open-drain" output. Pull-up resistors are assignable by software. These pin's                                                 |
|               |        | level change can wake up CPU from Idle/Stop mode                                                                               |
| P2.0~P2.7     | I/O    | Bit-programmable I/O port for Schmitt-trigger input, CMOS push-pull output.                                                    |
|               |        | Pull-up resistors are assignable by software.<br>Bit-programmable I/O port for Schmitt-trigger input, CMOS push-pull output or |
| P3.0~P3.2     | I/O    | "pseudo open drain" output. Pull-up resistors are assignable by software.                                                      |
|               |        | Bit-programmable I/O port for Schmitt-trigger input, CMOS push-pull output or                                                  |
| P3.3~P3.7     | I/O    | "open-drain" output. Pull-up resistors are assignable by software.                                                             |
|               | 7/0    | Bit-programmable I/O port for Schmitt-trigger input, CMOS push-pull output or                                                  |
| P4.0~P4.7     | I/O    | "open-drain" output. Pull-up resistors are assignable by software.                                                             |
| D5 ()         | I/O    | Bit-programmable I/O port for Schmitt-trigger input, CMOS push-pull output.                                                    |
| P5.0          | I/O    | Pull-up resistors are assignable by software.                                                                                  |
| INT0, INT1    | Ι      | External Low level or falling edge Interrupt input, Idle/Stop mode wake up input                                               |
| INT2          | Ι      | External falling edge Interrupt input, Idle/Stop mode wake up input                                                            |
| ADC11~ADC0    | Ι      | Analog to Digital Convert input pin                                                                                            |
| RXD           | I/O    | UART Mode0 transmit & receive data, Mode1/2/3 receive data                                                                     |
| TXD           | I/O    | UART Mode0 transmit clock, Mode1/2/3 transmit data. IN One Wire UART                                                           |
|               |        | mode, this pin transmits and receives serial data                                                                              |
| T0, T1, T2    | I      | Timer0, Timer1, Timer2 event count pin input                                                                                   |
| T00           | 0      | Timer0 overflow divided by 64 output                                                                                           |
| T2O<br>T2EX   | 0      | Timer2 overflow divided by 2 output                                                                                            |
| PWM0P/PWM0N   | Ι      | Timer2 external trigger input                                                                                                  |
| PWM1A/PWM1B/  | 0      | 8+2 bit PWM output                                                                                                             |
| PWM1C         | 0      | 0+2 off 1 wiw output                                                                                                           |
| MISO          | I/O    | SPIA data input for master mode, data output for slave mode                                                                    |
| MOSI          | I/O    | SPIA data output for master mode, data input for slave mode                                                                    |
| SCK           | I/O    | SPIA clock output for master or clock input for slave mode                                                                     |
| BSDI          | Ι      | SPIB data input                                                                                                                |
| BSDO          | 0      | SPIB data output                                                                                                               |
| BSCK          | 0      | SPIB clock out                                                                                                                 |
| D0~D7         | I/O    | I80 Data                                                                                                                       |
| RD            | 0      | I80 Read signal output                                                                                                         |
| WR            | 0      | I80 Write signal output                                                                                                        |
| KSI0~KSI7     | Ι      | Keyboard matrix input                                                                                                          |
| KSO0~KSO17    | 0      | Keyboard matrix output                                                                                                         |
| PC5VIN        | Ι      | USB Power input pin                                                                                                            |
| RSTn          | Ι      | External active low reset                                                                                                      |
| VDD           | Р      | 3.3V output power generate by internal regulator; need connect 1uF to Ground                                                   |
| VDDIO         | Р      | 3.3V/5V input power for I/O port; need connect 1uF to Ground                                                                   |
| VPD           | Р      | 1.1V output power generated by internal regulator; used for USB PD;                                                            |
|               |        | need connect 1uF to Ground                                                                                                     |
| VBAT          | P      | VBAT input power                                                                                                               |
| VCC/VDD5, VSS | Р      | Power input pin and Ground                                                                                                     |



# **Pin Summary**

|            |                     |      | I                      | npu     | ıt             | 0    | utp   | ut         | A   | lter | nat  | te I | Tun | ctio | n     | MISC |
|------------|---------------------|------|------------------------|---------|----------------|------|-------|------------|-----|------|------|------|-----|------|-------|------|
| Pin number | Pin Name            | Type | <b>Pull-up Control</b> | Wake up | Ext. Interrupt | P.P. | P.O.D | <b>O.D</b> | PWM | ADC  | UART | IdS  | I80 | KBD  | Timer |      |
| 1          | PWM1B/ADC4/P1.6     | I/O  | $\odot$                | •       |                | •    |       | •          | •   | •    |      |      |     |      |       |      |
| 2          | T0/T00/P3.4         | I/O  | $\odot$                |         |                | •    |       | •          |     |      |      |      |     |      | •     |      |
| 3          | KSO15/T1/P3.5       | I/O  | $\odot$                |         |                | •    |       | •          |     |      |      |      |     | •    | •     |      |
| 4          | KSO3/WR/P2.3        | I/O  | 0                      |         |                | •    |       |            |     |      |      |      | •   | •    |       |      |
| 5          | SDA1/KDO16/P3.6     | I/O  | $\odot$                |         |                | •    |       | •          |     |      |      |      |     | •    |       |      |
| 6          | SCL1/KSO17/P3.7     | I/O  | $\odot$                |         |                | •    |       | •          |     |      |      |      |     | •    |       |      |
| 7          | KSO8/AD6/P4.0       | I/O  | $\odot$                |         |                | •    |       | •          |     | •    |      |      |     | •    |       |      |
| 8          | KSO9/AD7/P4.1       | I/O  | $\odot$                |         |                | •    |       | •          |     | •    |      |      |     | •    |       |      |
| 9          | KSO10/AD8/P4.2      | I/O  | $\odot$                |         |                | •    |       | •          |     | •    |      |      |     | •    |       |      |
| 10         | NSSI/KSO11/AD9/P4.3 | I/O  | $\odot$                |         |                | •    |       | •          |     | •    |      | •    |     | •    |       |      |
| 11         | KSO12/ P4.4         | I/O  | $\odot$                |         |                | •    |       | •          |     |      |      |      |     | •    |       |      |
| 12         | KSO13/ P4.5         | I/O  | $\odot$                |         |                | •    |       | •          |     |      |      |      |     | •    |       |      |
| 13         | KSO14/ P4.6         | I/O  | $\odot$                |         |                | •    |       | •          |     |      |      |      |     | •    |       |      |
| 14         | PWM1A/AD3/ P2.7     | I/O  | 0                      |         |                | •    |       |            | •   | •    |      |      |     |      |       |      |
| 15         | KSO7/RD/P2.7        | I/O  | 0                      |         |                | •    |       |            |     |      |      |      | •   | •    |       |      |
| 16         | KSI7/D7/P0.7        | I/O  | 0                      |         |                | •    |       |            |     |      |      |      | •   | •    |       |      |
| 17         | KSI6/D6/P0.6        | I/O  | 0                      |         |                | •    |       |            |     |      |      |      | •   | •    |       |      |
| 18         | KSI5/D5/P0.5        | I/O  | 0                      |         |                | •    |       |            |     |      |      |      | •   | •    |       |      |
| 19         | KSI4/D4/P0.4        | I/O  | 0                      |         |                | •    |       |            |     |      |      |      | •   | •    |       |      |
| 20         | KSI3/D3/P0.3        | I/O  | 0                      |         |                | •    |       |            |     |      |      |      | •   | •    |       |      |
| 21         | KSI2/D2/P0.2        | I/O  | 0                      |         |                | •    |       |            |     |      |      |      | •   | •    |       |      |
| 22         | KSI1/D1/P0.1        | I/O  | 0                      |         |                | •    |       |            |     |      |      |      | •   | •    |       |      |
| 23         | KSI0/D0/P0.0        | I/O  | 0                      |         |                | •    |       |            |     |      |      |      | •   | •    |       |      |
| 24         | KSO6/ BSDO /P2.6    | I/O  | 0                      |         |                | •    |       |            |     |      |      | •    |     | •    |       |      |
| 25         | KSO5/BSCK/P2.5      | I/O  | 0                      |         |                | •    |       |            |     |      |      | •    |     | •    |       |      |
| 26         | KSO4/BSDI/P2.4      | I/O  | 0                      |         |                | •    |       |            |     |      |      | •    |     | ٠    |       |      |
| 27         | VCC                 | Р    |                        |         |                |      |       |            |     |      |      |      |     |      |       |      |
| 28         | VBAT                | Р    |                        |         |                |      |       |            |     |      |      |      |     |      |       |      |
| 29         | PC5VIN              | Ι    |                        |         |                |      |       |            |     |      |      |      |     |      |       |      |
| 30         | VPD                 | Р    |                        |         |                |      |       |            |     |      |      |      |     |      |       |      |



| 31 | VSS                | Р   |         |           |   |   |   |   |   |   |   |   |   |   |  |
|----|--------------------|-----|---------|-----------|---|---|---|---|---|---|---|---|---|---|--|
| 32 | PWM0N/P5.0         | I/O | 0       |           |   | • |   |   | • |   |   |   |   |   |  |
| 33 | PWM0P/AD2/P1.4     | I/O | $\odot$ | •         |   | • |   | • | • | • |   |   |   |   |  |
| 34 | CC1/AD10/INT0/P3.2 | I/O | $\odot$ | •         | • | ۲ | • |   |   | • |   |   |   |   |  |
| 35 | CC2/AD11/INT1/P3.3 | I/O | $\odot$ | $\bullet$ | • | ۲ |   | • |   | • |   |   |   |   |  |
| 36 | VDDIO              | Р   |         |           |   |   |   |   |   |   |   |   |   |   |  |
| 37 | VDD                | Р   |         |           |   |   |   |   |   |   |   |   |   |   |  |
| 38 | SCL0/DP/P1.2       | I/O | $\odot$ | ullet     |   | ۲ |   | • |   |   |   |   |   |   |  |
| 39 | SDA0/DM/P1.3       | I/O | $\odot$ | •         |   | ● |   | • |   |   |   |   |   |   |  |
| 40 | T2EX/AD1/P1.1      | I/O | $\odot$ | ullet     |   | ● |   | • |   | • |   |   |   | • |  |
| 41 | T2/T2O/AD0/P1.0    | I/O | $\odot$ | $\bullet$ |   | ۲ |   | • |   | • |   |   |   | • |  |
| 42 | AMOSI/KSO2/P2.2    | I/O | 0       |           |   | ۲ |   |   |   |   |   | • | • |   |  |
| 43 | ASCK/KSO1/P2.1     | I/O | 0       |           |   | ۲ |   |   |   |   |   | • | • |   |  |
| 44 | AMISO/KSO0/P2.0    | I/O | 0       |           |   | ۲ |   |   |   |   |   | • | • |   |  |
| 45 | RSTn/INT2/P4.7     | I/O | $\odot$ | $\bullet$ | • | ۲ |   | • |   |   |   |   |   |   |  |
| 46 | RXD/P3.0           | I/O | $\odot$ |           |   | • | • |   |   |   | • |   |   |   |  |
| 47 | TXD/P3.1           | I/O | $\odot$ |           |   | ۲ | • |   |   |   | ۲ |   |   |   |  |
| 48 | PWM1C/AD5/P1.7     | I/O | $\odot$ | •         |   | • |   | • | • | • |   |   |   |   |  |

Symbol:

P.P. = Push-Pull Output

O.D. = Open Drain

P.O.D. = Pseudo Open Drain

PS:

- 1.  $\odot$  Port1, Port3, Port4 theses pins control Pull up resistor by operation modes
- 2. Port0, Port2, Port5 these pins control Pull up resistor while PxOE.n=0 and Px.n=1



### **Functional Description**

#### 1. CPU Core

In the 8051 architecture, the C programming language is used as a development platform. The **TM52F3288** features a fast 8051 core in a highly integrated microcontroller, allowing designers to be able to achieve improved performance compared to a classic 8051 device. TM52 series microcontrollers provide a complete binary code with standard 8051 instruction set compatibility, ensuring an easy migration path to accelerate the development speed of system products. The CPU core includes an ALU, a program status word (PSW), an accumulator (ACC), a B register, a stack point (SP), DPTRs, a programming counter, an instruction decoder, and core special function registers (SFRs).

#### **1.1 Accumulator (ACC)**

This register provides one of the operands for most ALU operations. Accumulators are generally referred to as A or Acc and sometimes referred to as Register A. In this document, the accumulator is represented as "A" or "ACC," including the instruction table. The accumulator, as its name suggests, is used as a general register to accumulate the intermediate results of a large number of instructions. The accumulator is the most important and frequently used register to complete arithmetic and logical operations. It holds the intermediate results of most arithmetic and logic operations and assists in data transportation.

| SFR E0h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| ACC     | ACC.7 | ACC.6 | ACC.5 | ACC.4 | ACC.3 | ACC.2 | ACC.1 | ACC.0 |
| R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

E0h.7~0 **ACC:** Accumulator

#### 1.2 B Register (B)

The "B" register is very similar to the ACC and may hold a 1 Byte value. This register provides the second operand for multiply or divide instructions. Otherwise, it may be used as a scratch pad register. The B register is only used by two 8051 instructions, MUL and DIV. When A is to be multiplied or divided by another number, the other number is stored in B. For MUL and DIV instructions, it is necessary that the two operands be in A and B.

#### ex: DIV A,B

When this instruction is executed, data inside A and B are divided, and the answer is stored in A.

| SFR F0h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| В       | B.7   | B.6   | B.5   | B.4   | B.3   | B.2   | B.1   | B.0   |
| R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

F0h.7~0 **B:** B register

#### 1.3 Stack Pointer (SP)

The SP register contains the Stack Pointer. The Stack Pointer is used to load the program counter into memory during LCALL and ACALL instructions and is used to retrieve the program counter from

```
DS-TM52F3288_E
```



memory in RET and RETI instructions. The stack may also be saved or loaded using PUSH and POP instructions, which also increment and decrement the Stack Pointer. The Stack Pointer points to the top location of the stack.

| SFR 81h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |  |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|--|--|--|--|
| SP      | SP    |       |       |       |       |       |       |       |  |  |  |  |
| R/W     | R/W   |       |       |       |       |       |       |       |  |  |  |  |
| Reset   | 0     | 0     | 0     | 0     | 0     | 1     | 1     | 1     |  |  |  |  |

81h.7~0 **SP:** Stack Point

#### **1.4 Dual Data Pointer (DPTRs)**

F2261/64 has two DPTRs, which share the same SFR address. Each DPTR is 16 bits in size and consists of two registers: the DPTR high byte (DPH) and the DPTR low byte (DPL). The DPTR is used for 16bit-address external memory accesses, for offset code byte fetches, and for offset program jumps. Setting the DPSEL control bit allows the program code to switch between the two physical DPTRs.

| SFR 82h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |  |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|--|--|--|--|
| DPL     | DPL   |       |       |       |       |       |       |       |  |  |  |  |
| R/W     |       | R/W   |       |       |       |       |       |       |  |  |  |  |
| Reset   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |  |  |  |  |

82h.7~0 **DPL:** Data Point low byte

| SFR <b>83h</b> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |  |
|----------------|-------|-------|-------|-------|-------|-------|-------|-------|--|--|--|--|
| DPH            | DPH   |       |       |       |       |       |       |       |  |  |  |  |
| R/W            |       | R/W   |       |       |       |       |       |       |  |  |  |  |
| Reset          | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |  |  |  |  |

83h.7~0 **DPH:** Data Point high byte

| SFR F8h | Bit 7  | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2 | Bit 1 | Bit 0 |
|---------|--------|-------|-------|-------|---------|-------|-------|-------|
| AUX1    | CLRWDT | WI    | DTE   | ADSOC | CLRPWM0 | PDDP  | BOOTV | DPSEL |
| R/W     | R/W    | R/    | W     | R/W   | R/W     | R/W   | R/W   | R/W   |
| Reset   | 0      | 0     | 0     | 0     | 0       | 0     | u     | 0     |

F8h.0 **DPSEL:** Active DPTR Select



#### 1.5 Program Status Word (PSW)

This register contains status information resulting from CPU and ALU operations. The PSW affected by instructions is listed below.

| Instruction |   | Flag |    |   |
|-------------|---|------|----|---|
| Instruction | С | OV   | AC |   |
| ADD         | Х | X    | Х  |   |
| ADDC        | Х | Х    | Х  |   |
| SUBB        | Х | X    | Х  |   |
| MUL         | 0 | Х    |    |   |
| DIV         | 0 | Х    |    |   |
| DA          | Х |      |    |   |
| RRC         | Х |      |    | ] |
| RLC         | Х |      |    |   |
| SETB C      | 1 |      |    |   |

| Instruction |   | Flag |    |
|-------------|---|------|----|
| Instruction | С | OV   | AC |
| CLR C       | 0 |      |    |
| CPL C       | Х |      |    |
| ANL C, bit  | Х |      |    |
| ANL C. /bit | Х |      |    |
| ORL C, bit  | Х |      |    |
| ORL C, /bit | Х |      |    |
| MOV C, bit  | Х |      |    |
| CJNE        | Х |      |    |
|             |   |      |    |

A "0" means the flag is always cleared, a "1" means the flag is always set and an "X" means that the state of the flag depends on the result of the operation.

| SFR D0h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| PSW     | CY    | AC    | F0    | RS1   | RS0   | OV    | F1    | Р     |
| R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

D0h.7 **CY:** ALU carry flag

D0h.6 **AC:** ALU auxiliary carry flag

D0h.5 **F0:** General purpose user-definable flag

- D0h.4~3 **RS1, RS0:** The contents of (RS1, RS0) enable the working register banks as:
  - 00: Bank 0 (00h-07h)
  - 01: Bank 1 (08h-0Fh)
  - 10: Bank 2 (10h-17h)
  - 11: Bank 3 (18h-1Fh)
- D0h.2 **OV:** ALU overflow flag
- D0h.1 **F1:** General purpose user-definable flag
- D0h.0 **P:** Parity flag. Set/cleared by hardware each instruction cycle to indicate odd/even number of "one" bits in the accumulator.

|       | PSW   |       |       |       |       |       |       |  |  |  |
|-------|-------|-------|-------|-------|-------|-------|-------|--|--|--|
| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
| R/W   |  |  |  |
| CY    | AC    | FO    | RS1   | RS0   | OV    | F1    | Р     |  |  |  |





#### 2. Memory

#### 2.1 Program Memory

The **F3288** has a 16K Bytes Flash program memory, which can support In Circuit Programming (ICP), In Application Programming (IAP) and In System Programming (ISP) function modes. The Flash write endurance is at least 50K cycle. The Flash program memory address continuous space (0000h–3FFFh) is partitioned to several sectors for device operation.

#### 2.1.1 Program Memory Functional Partition

The last 4 bytes (3FFCh-3FFFh) of program memory is defined as chip Configuration Word (CFGW), which is loaded into the device control registers upon power on reset (POR). The address space 3F00h–3FFBh is the IAP free area, while the 0000h–005Fh is occupied by Reset/Interrupt vectors as standard 8051 definition. In the in-circuit emulation (ICE) mode, user also needs to reserve the address space 1D00h~1FFFh for ICE System communication.

| 0000h<br>Reset/Interrupt Vector<br>005Fh<br>0060h |
|---------------------------------------------------|
| 005Fh                                             |
|                                                   |
| 0060h                                             |
| 00000                                             |
| User Code area                                    |
| 1CFFh                                             |
| 1D00h                                             |
| ICE mode reserved area                            |
| 1FFFh                                             |
| 2000h                                             |
| User Code area                                    |
| 3EFFh                                             |
| 3F00h                                             |
| IAP-Free area                                     |
|                                                   |
| 3FFBh                                             |
| 3FFCh                                             |
| CFGW                                              |
| 3FFFh                                             |

#### 2.1.2 Flash ICP Mode

The Flash memory can be programmed by the tenx proprietary writer (**TWR98/TWR99**), which needs at least four wires VCC, VSS, SCL and SDA pins to connect to this chip. If the user wants to program the Flash memory on the target circuit board (In Circuit Program, ICP), these pins must be reserved sufficient freedom to be connected to the Writer. More pins connected to Writer ensure more writing efficiency and speed. SCL and SDA can be P1.2 and P1.3 or can be P3.6 and P3.7.

| Writer wire number | Pin connection                       |
|--------------------|--------------------------------------|
| 4-Wire             | VCC, VSS, SCL, SDA                   |
| 5-Wire             | VCC, VSS, SCL, SDA, P1.0             |
| 7-Wire             | VCC, VSS, SCL, SDA, P1.0, P1.1, P4.3 |

4-wire: Minimum program pin 5-Wire: add P1.0 (BUSY) 7-Wire: add P4.3 (TRIM), P1.1 (CKO)



#### 2.1.3 Flash IAP Mode

The **F3288** has "In Application Program" (IAP) capability, which allows software to read/write data from/to the Flash memory during CPU run time as conveniently as data EEPROM access. The IAP function is byte writable, meaning that the **F3288** does not need to erase one Flash page before write. The available IAP data space is 254 Bytes after chip reset, and can be re-defined by the "MVCLOCK" and "IAPALL" control register as shown below.

|       | 16K Bytes Flash<br>Program memory | Flash memory  | MVCLOCK | IAPALL | MOVC<br>Accessible | MOVX (IAP)<br>Accessible |
|-------|-----------------------------------|---------------|---------|--------|--------------------|--------------------------|
| 0000h |                                   |               | 1       | Х      | No                 | No                       |
|       | MOVC-Lock area                    | 0000h~01FFh   | 0       | 0      | Yes                | No                       |
| 01FFh |                                   |               | 0       | 1      | Yes                | Yes                      |
| 0200h | IAP-All area                      | 0200h~3EFFh   | X       | 0      | Yes                | No                       |
| 3EFFh |                                   | 020011~3EFF11 | X       | 1      | Yes                | Yes                      |
| 3F00h | IAP-Free area                     | 3F00h~3FFBh   | X       | Х      | Yes                | Yes                      |
| 3FFCh |                                   | 3FFC~3FFEh    | X       | 0      | Yes                | No                       |
|       | CFGW area                         | JELC~JEL      | Х       | 1      | Yes                | Yes                      |
| 3FFFh |                                   | 3FFFh         | Х       | Х      | Yes                | No                       |

In IAP mode, the program Flash memory is separated into four sectors: MOVC-Lock area, IAP-All area, IAP-Free area, and CFGW area. These four sectors are regulated differently.

In the **MOVC-Lock area**, IAP read/write is limited by MVCLOCK bit, which can be set to control the accessibility of the MOVC and MOVX instructions to this area. The size of this area is 512 Bytes. The lock function is made to protect the main program code against unconsciously writing Flash memory in IAP mode. Locking or unlocking the function should be performed by the tenx TWR98/99 writing to the CFGW in Flash memory.

The **IAP-All area** is protected by the IAPALL register to prevent IAP mode from writing application data to the program area, resulting in a program code error that cannot be repaired. The size of this area is 15,616 Bytes. Enabling IAPALL requires writing 65h to SFR SWCMD 97h to set the IAPALL control flag. Then, software can use MOVX instructions to write application data to flash memory from 0200h to 3EFFh. If user wants to disable IAPALL function, user can write other values to SFR SWCMD 97h to clear the IAPALL control flag. User must be careful not to overwrite program code which is already resided on the same Flash memory area.

The **IAP-Free area** has no control bit to protect. It can be used to reliably store system application data that needs to be programmed once or periodically during system operation. Other areas of Flash memory can be used to store data, but this area is usually the best. The size of this area is 252 Bytes, equivalent to an EEPROM, and Flash memory can provide byte access to read and write commands. In the past, storage of configuration data required an additional EEPROM or the other storage device. However, this functionality can now be provided by on-chip Flash, reducing the chip count of embedded applications. An external EEPROM or SRAM may not be needed.

The **CFGW area** has 4 data bytes (CFGWH1, CFGWH2, CFGWL1 and CFGWL2), which is located at the last 4 addresses of Flash memory. The CFGWH2 is not accessible to IAP, while the others can be read or written by IAP in case the IAPALL flag is set. CFGWH1(FRC Trimming value) is copied to the



SFR F7h after power on reset, software then take over CFGWH1's control capability by modifying the SFR F7h. CFGWL1(VBG Trimming value) is copied to the SFR F6h after power on reset, software then take over CFGWL1's control capability by modifying the SFR F6h. The CFGWL2 is reserved. BOOTV (CFGWH2[0]) bit is also copied to the SFR F8h[1].

#### 2.1.4 IAP Mode Access Routines

Flash IAP write is simply achieved by a "MOVX @DPTR, A" instruction while the DPTR contains the target Flash address (0–3FFEH), and the ACC contains the data being written. The F3288 accepts IAP Write command only when the IAPWE SFR is enabled. Flash IAP writing requires approximately 500uS. Meanwhile, the CPU stays in a waiting state, but all peripheral modules (Timers and others) continue running during the writing time. The software must handle the pending interrupts after an IAP write. Flash IAP writing needs higher VCC voltage, VCC>2.8V.

Because the Program memory and the IAP data space share the same entity, a Flash IAP read can be performed by the "MOVX A, @DPTR" or "MOVC" instruction as long as the target address points to the 0~3FFFh area. A Flash IAP read does not require extra CPU wait time.

| ; IAP e  | example code |                                           |
|----------|--------------|-------------------------------------------|
| ; need V | VCC > 2.8V   |                                           |
| mov      | dptr, #3f00h | ; dptr = 3f00h = target IAP address       |
| mov      | a, #5ah      | ; $a = 5ah = target IAP$ write data       |
| mov      | IAPWE, #47h  | ; IAPWE SFR write 47h to enable IAPWE     |
| movx     | @dptr, a     | ; $Flash[3f00h] = 5ah$ , after IAP write  |
|          |              | ; 200us~500us H/W writing time, CPU wait  |
|          |              | ;                                         |
| mov      | IAPWE, #00h  | ; IAPWE = $0$ immediately after IAP write |
| clr      | a            | ; a= 0                                    |
| movx     | a, @dptr     | ; a= 5ah                                  |
| clr      | а,           | ; a= 0                                    |
| movc     | a, @a+dptr   | ; a= 5ah                                  |
|          |              |                                           |

| Flash 3FFFh | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1   | Bit 0 |
|-------------|-------|-------|-------|-------|-------|--------|---------|-------|
| CFGWH2      | PROT  | XRSTE | LV    | RE    | -     | PWRSAV | MVCLOCK | BOOTV |

3FFFh.1 MVCLOCK: If 1, the MOVC & MOVX instruction's accessibility to MOVC-Lock area is limited.
3FFFh.0 BOOT vector select
0: Boot from ROM address 0000h
1: Boot from ROM address 3000h

| SFR <b>97h</b> | Bit 7                                                                                      | Bit 6          | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |
|----------------|--------------------------------------------------------------------------------------------|----------------|-------|-------|-------|-------|-------|-------|--|--|
| SWCMD          |                                                                                            | IAPALL / SWRST |       |       |       |       |       |       |  |  |
| R/W            |                                                                                            | W              |       |       |       |       |       |       |  |  |
| Reset          |                                                                                            | _              |       |       |       |       |       |       |  |  |
| 07h 7_0        | 0 IADALL (W): Write 65h to get IADALL control flag: Write other value to clear IADALL flag |                |       |       |       |       |       |       |  |  |

97h.7~0 **IAPALL (W):** Write 65h to set IAPALL control flag; Write other value to clear IAPALL flag.

97h.0 **IAPALL (R):** Flag indicates Flash memory sectors can be accessed by IAP or not. This bit combines with MVCLOCK to define the accessible IAP area.





| SFR C9h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| IAPWE   | IAPWE | IAPTO |       |       |       | -     |       |       |
| R/W     | W/R   | R     |       |       |       | -     |       |       |
| Reset   | 0     | 0     |       |       |       | -     |       |       |

C9h.7 IAPWE (W): Write 47h to set IAPWE control flag; Write other value to clear IAPWE flag.

C9h.7 IAPWE (R): IAPWE flag

#### 2.1.5 Flash ISP Mode

The "In System Program" (ISP) usage is similar to IAP, except the purpose is to refresh the Program code. User can use UART/SPI or other method to get new Program code from external host, then writes code as the same way as IAP. ISP operation is complicated; basically it needs to assign a Boot code area to the Flash which does not change during the ISP process. When BOOTV is set to high, the Boot address is changed to 3000h after chip reset. If BOOTV = 0, the Boot address is 0000h after chip reset.



#### 2.2 Data Memory

As the standard 8051, the **F3288** has both Internal and External Data Memory space. The Internal Data Memory space consists of 256 Bytes IRAM and 63 SFRs, which are accessible through a rich instruction set. The External Data Memory space consists of 460 Bytes XRAM and IAP Flash, which can be only accessed by MOVX instruction.





#### 2.2.1 IRAM

IRAM is located in the 8051 internal data memory space. The whole 256 Bytes IRAM are accessible using indirect addressing but only the lower 128 Bytes are accessible using direct addressing. There are four directly addressable register banks (switching by PSW), which occupy IRAM space from 0x00 to 0x1F. The address 0x20 to 0x2F 16 Bytes IRAM space is bit-addressable. IRAM can be used as scratch pad registers or program stack.

#### 2.2.2 XRAM

XRAM0 is located in the 8051 external data memory space (address from FF00h to FFFFh). The 256 Bytes XRAM can be only accessed by "MOVX" instruction. XRAM1/2 is located in the 8051 external data memory space (address from F100h to F17Fh). The two 64 Bytes XRAM can be accessed by "MOVX" instruction and can be accessed by USB, SPI and I80 hardware DMA module. XRAM3/4 is located in the 8051 external data memory space (address from F200h to F225 and F240h to F265h). The two 38 Bytes XRAM can be accessed by "MOVX" instruction and can be accessed by USB PD module.

#### 2.2.3 SFRs

All peripheral functional modules such as I/O ports, Timers and UART operations for the chip are accessed via Special Function Registers (SFRs). These registers occupy upper 128 Bytes of direct Data Memory space locations in the range 0x80 to 0xFF. There are 14 bit addressable SFRs (which means that eight individual bits inside a single byte are addressable), such as ACC, B register, PSW, TCON, SCON, and others. The remaining SFRs are only byte addressable. SFRs provide control and data exchange with the resources and peripherals of the **F3288**. The TM52 series of microcontrollers provides complete binary code with standard 8051 instruction set compatibility. Beside the standard 8051 SFRs, the **F3288** implements additional SFRs used to configure and access subsystems such as the USB/SPI, which are unique to the **F3288**.





|     | 8/0    | 9/1     | A/2     | B/3      | C/4     | D/5       | E/6       | F/7       |
|-----|--------|---------|---------|----------|---------|-----------|-----------|-----------|
| F8h | AUX1   |         |         |          |         |           |           |           |
| F0h | В      |         |         |          |         | AUX2      | CFGWL1    | CFGWH1    |
| E8h | P4     |         |         |          |         |           |           | ANAT      |
| E0h | ACC    |         |         |          |         |           |           |           |
| D8h | CLKCON |         | USB1IE  | USB2IE   | USBRSTM |           |           | PDCTRL    |
| D0h | PSW    | TX3CNT  | RC4CNT  | RCOREG   | I80CTRL |           | XRAMCTRL  |           |
| C8h | T2CON  | IAPWE   | RCP2L   | RCP2H    | TL2     | TH2       | TX3CTRL   | RC4CTRL   |
| C0h | P5     | USBADR  | USB1I   | USB2I    | USBCTRL | TX0CTRL   | TX1CTRL   | TX2CTRL   |
| B8h | IP     | IPH     | IP1     | IP1H     | SPACON  | SPASTA    | SPADAT    |           |
| B0h | P3     | SPBCTRL | SPBCRS  | DMALEN   | P4MODL  | P4MODH    | KBMASK    |           |
| A8h | IE     | INTE1   | ADCDL   | ADCDH    | PWMDTYL |           | CHSEL     |           |
| A0h | P2     | PWMCON  | P1MODL  | P1MODH   | P3MODL  | P3MODH    | PINMOD    | PWM0MODT  |
| 98h | SCON   | SBUF    | PWM0PRD | PWM0DTYH | PWM1PRD | PWM1ADTYH | PWM1BDTYH | PWM1CDTYH |
| 90h | P1     | POOE    |         | P2OE     | OPTION  | INTFLG    | P1WKUP    | SWCMD     |
| 88h | TCON   | TMOD    | TL0     | TL1      | TH0     | TH1       |           |           |
| 80h | P0     | SP      | DPL     | DPH      |         |           |           | PCON      |



#### 3. Power

VCC pin is the main power supply for this chip. When MODE3V=0, the voltage regulator output 3.3V (VDD) power to the internal chip circuit. When MODE3V=1, the LDO is turned off, and the internal circuit receives a power supply directly from the VCC pin. Because the LDO consumes 150uA for operation, turning off LDO by setting MODE3V=1 can reduce the chip current consumption. However, setting MODE3V=1 is only valid for an operation of VCC < 3.6V. The PWRSAV also control the LDO. When MODE3V=0 and PWRSAV=1, the LDO is turned off in STOP mode for saving power consumption. In addition, set PWRSAV will affect the LVR setting. When **F3288** is used for USB application, the LDO output must keep at 3.3V; the LDO cannot be turned off in STOP mode for saving power consumption.

| Operation    | CFGV   | VH2  |     | Function      |
|--------------|--------|------|-----|---------------|
| Mode         | PWRSAV | LVRE | LDO | Function      |
|              | Х      | 00   | ON  | LV Reset 2.9V |
| Fast         | Х      | 01   | ON  | LV Reset 2.3V |
| Slow<br>Idle | Х      | 10   | ON  | LV Reset 2.3V |
| Idic         | Х      | 11   | ON  | LV Reset 2.1V |
|              | 0      | 00   | ON  | LV Reset 2.9V |
|              | 0      | 01   | ON  | LV Reset 2.3V |
|              | 0      | 10   | ON  | LV Reset 2.3V |
| STOD         | 0      | 11   | ON  | LV Reset 2.1V |
| STOP         | 1      | 00   | OFF | LV Reset 2.9V |
|              | 1      | 01   | OFF | LV Reset 2.3V |
|              | 1      | 10   | OFF | LV Reset 2.3V |
|              | 1      | 11   | OFF | LV Reset 2.1V |

#### MODE3V=0

#### MODE3V=1

| Operation    | CFGW   | /H2  |     | Function      |
|--------------|--------|------|-----|---------------|
| Mode         | PWRSAV | LVRE | LDO | Function      |
| East         | 0      | 00   | OFF | LV Reset 2.9V |
| Fast<br>Slow | 0      | 01   | OFF | LV Reset 2.3V |
| Idle         | 0      | 10   | OFF | LV Reset 2.3V |
| Iule         | 0      | 11   | OFF | LV Reset 2.1V |
|              | 1      | 00   | OFF | LV Reset 2.1V |
|              | 1      | 01   | OFF | LV Reset 2.1V |
|              | 1      | 10   | OFF | LV Reset 2.1V |
|              | 1      | 11   | OFF | LV Reset 2.1V |
|              | 0      | 00   | OFF | LV Reset 2.9V |
|              | 0      | 01   | OFF | LV Reset 2.3V |
|              | 0      | 10   | OFF | LV Reset 2.3V |
| STOD         | 0      | 11   | OFF | LV Reset 2.1V |
| STOP         | 1      | 00   | OFF | LV Reset 2.1V |
|              | 1      | 01   | OFF | LV Reset 2.1V |
|              | 1      | 10   | OFF | LV Reset 2.1V |
|              | 1      | 11   | OFF | LV Reset 2.1V |



| Flash <b>3FFFh</b> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1   | Bit 0 |
|--------------------|-------|-------|-------|-------|-------|--------|---------|-------|
| CFGWH2             | PROT  | XRSTE | LV    | RE    | -     | PWRSAV | MVCLOCK | BOOTV |

3FFFh.2 **PWRSAV:** Power saving function control bit

1: Enable Power saving function

| SFR <b>94h</b> | Bit 7  | Bit 6  | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------|--------|--------|--------|-------|-------|-------|-------|-------|
| OPTION         | UART1W | MODE3V | WDTPSC |       | ADCKS |       | -     |       |
| R/W            | R/W    | R/W    | R/     | R/W   |       | R/W   |       | -     |
| Reset          | 0      | 0      | 0      | 0     | 0     | 0     | -     | -     |

94h.6 MODE3V:3V mode selection control bit

If this bit is set, the chip can be only operated in the condition of VCC < 3.6V, and LDO is turned off to save current



<sup>0:</sup> Disable Power saving function



#### 4. Reset

The **F3288** has six types of reset method. Resets can caused by Power on Reset (POR), External Pin Reset (XRST), Software Command Reset (SWRST), Watchdog Timer Reset (WDTR), Low Voltage Reset (LVR), or USB power plug-out/plug-in reset. The CFGW controls the Reset functionality. The SFRs are returned to their default value after Reset.

#### 4.1 Power on Reset

After Power on Reset, the device stays on Reset state for 24 ms as chip warm up time, then downloads the CFGW register from ROM's last byte (Other Reset will not reload the CFGW). The Power on Reset needs VCC pin's voltage first discharge to near VSS level, then rise beyond 2.1V.

#### 4.2 External Pin Reset

Pin Reset is active low. It needs to keep at least 2 SRC clock cycle long to be seen by the chip. Pin Reset can be disabled or enabled by CFGWH2.

#### 4.3 Software Reset

Software Reset is activated by writing the SFR 97h with data 56h.

#### 4.4 Watch Dog Timer Reset (WDT)

WDT overflow Reset is disabled or enable by SFR F8h. The WDT uses SRC as its counting time base. It runs in Fast / Slow mode and runs or stops in Idle/ Stop mode. WDT overflow speed can be defined by WDTPSC SFR. WDT is cleared by device Reset or CLRWDT SFR bit.

#### 4.5 Low Voltage Reset

The **F3288** offers three options for LVR function. The user can make a selection by CFGWH2, let LVR voltage of 2.9V, 2.3V and 1.9V be selected separately. The LVR can be disabled or enabled by CFGWH2.

#### 4.6 USB Plug Reset

The **F3288** support USB application. USB cable plugs in or out can cause chip reset. By checking the register VDD5VFLG status, the F/W can determine **F3288** is working in USB or non-USB application. When VDD5VFLG is high, which means USB cable plugs in PC5V power supply to the chip, **F3288** can work in USB application. IF VDD5VFLG is low, **F3288** can work in non-USB application.

| System Clock Frequency | 12 MHz   | 6 MHz    | 3MHz     | 0.75MHz  |
|------------------------|----------|----------|----------|----------|
| Minimum LVR level      | LVR=2.9V | LVR=2.9V | LVR=2.3V | LVR=2.1V |

| SFR F8h | Bit 7  | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2  | Bit 1 | Bit 0 |
|---------|--------|-------|-------|-------|---------|--------|-------|-------|
| AUX1    | CLRWDT | WI    | WDTE  |       | CLRPWM0 | PDADOP | BOOTV | DPSEL |
| R/W     | R/W    | R/    | R/W   |       | R/W     | R/W    | R/W   | R/W   |
| Reset   | 0      | 0     | 0     | 0     | 0       | 0      | 0     | 0     |

F8h.7 **CLRWDT**: Set to clear WDT, H/W auto clear it at next clock cycle

F8h.6~5 **WDTE:** Watchdog Timer Reset control

0x: Watchdog Timer Reset disable

10: Watchdog Timer Reset enable in Fast/Slow mode, disable in Idle/Stop mode

11: Watchdog Timer Reset always enable



| Flash <b>3FFFh</b> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1   | Bit 0 |
|--------------------|-------|-------|-------|-------|-------|--------|---------|-------|
| CFGWH2             | PROT  | XRSTE | LVRE  |       | -     | PWRSAV | MVCLOCK | BOOTV |

3FFFh.6 **XRSTE:** External Pin Reset control

0: Disable External Pin Reset

1: Enable External Pin Reset

3FFFh.5~4 LVRE: Low Voltage Reset function select

00: Set LVR at 2.9V

01: Set LVR at 2.3V

10: Reserved

11: Set LVR at 1.9V

| SFR <b>94h</b> | Bit 7  | Bit 6  | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------|--------|--------|-------|-------|-------|-------|-------|-------|
| OPTION         | UART1W | MODE3V | WD    | ГРSC  | ADCKS |       | -     |       |
| R/W            | R/W    | R/W    | R/    | R/W   |       | W     |       | -     |
| Reset          | 0      | 0      | 0     | 0     | 0     | 0     |       | _     |

94h.5~4 **WDTPSC:** Watchdog Timer pre-scaler time select

00: 400ms WDT overflow rate

01: 200ms WDT overflow rate

10: 100ms WDT overflow rate

11: 50ms WDT overflow rate

| SFR <b>97h</b> | Bit 7 | Bit 6          | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|----------------|-------|----------------|-------|-------|-------|-------|-------|-------|--|--|--|
| SWCMD          |       | IAPALL / SWRST |       |       |       |       |       |       |  |  |  |
| R/W            |       | W              |       |       |       |       |       |       |  |  |  |
| Reset          |       | _              |       |       |       |       |       |       |  |  |  |

97h.7~0 **SWRST:** Write 56h to generate S/W Reset.

| SFR F5h | Bit 7    | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1  | Bit 0 |
|---------|----------|----------|-------|-------|-------|-------|--------|-------|
| AUX2    | VDD5VFLG | VDD5FALL | _     |       |       | IAI   | VCCFLT |       |
| R/W     | R        | R/W      | _     |       |       | R/    | W      | R/W   |
| Reset   | 0        | 0        | _     |       |       | (     | )      | 0     |
|         |          |          |       |       |       |       |        |       |

F5h.7 VDD5VFLG: PC5V status 0: PC5V Low

1: PC5V High (USB plug in)

F5h.6 **VDD5FALL:** USB Plug out flag write 0 or power on reset to clear flag



#### 5. Clock Circuitry & Operation Mode

#### 5.1 System Clock

The **F3288** is designed with dual-clock system. During runtime, user can directly switch the System clock from Fast to Slow or from slow to fast. It also can directly select a clock divider of 1, 2, 4 or 16. The Fast clock is fixed to FRC (Fast Internal RC, 11.0592 MHz at VCC=5V). The Slow clock is SRC (Slow Internal RC, 32KHz). Fast mode and Slow mode are defined as the CPU running at Fast and Slow clock speeds.

After Reset, the device is running at Slow mode with 32KHz SRC. The user should select the proper clock rate for chip operation safety. The higher VCC allows the chip to run at a higher System clock frequency.

The **CLKCON** SFR controls the System clock operating. H/W automatically blocks the S/W abnormally setting for this register. Never to write both STPFCK=1 and SELFCK=1. It is recommended to write this SFR bit by bit.

#### 5.2 USB Clock

The F3288 incorporates flexible internal oscillator and clock generators, including a 24 MHz accurate to 3% over temperature and voltage. The 24 MHz can also be doubled to 48 MHz for USB application, and the Internal RC clock generators will self-tune to  $\pm 0.25\%$  accuracy when USB communication.



Clock Structure



#### **5.3 Operation Mode**

There are four operation modes for this device. Fast Mode is defined as the CPU running at Fast clock speed. Slow Mode is defined as the CPU running at Slow clock speed. When the System clock speed is lower, the power consumption is lower.

Idle Mode is entered by setting the IDL bit in PCON SFR. Both Fast and Slow clock can be set as the System clock source in Idle Mode, but Slow clock is better for power saving. In Idle mode, the CPU puts itself to sleep while the on-chip peripherals stay active. The STPPCK bit in CLKCON SFR can be set to furthermore reduce Idle mode current. If STPPCK=1, Timer0/1/2, ADC and UART are stopped in Idle mode. The slower System clock rate also helps current saving. It can be achieved by setup the CLKPSC SFR to divide System clock frequency. Idle mode is terminated by Reset or enabled Interrupts wake up.

Stop Mode is entered by setting the PD bit in PCON SFR. This mode is the so-called "Power Down" mode in standard 8051. In Stop mode, all clocks stop except the WDT is alive if it is enabled. Stop mode can be terminated by Reset or pin wake up.

*Note:* Chip cannot enter Stop Mode if INTn pin is low and wakeup is enable. (INTn=0 and EXn=1, n=0,1,2)

| SFR 87h | Bit 7                                           | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |
|---------|-------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|--|--|
| PCON    | SMOD                                            | —     | —     | —     | GF1   | GF0   | PD    | IDL   |  |  |
| R/W     | R/W                                             | —     | —     | —     | R/W   | R/W   | R/W   | R/W   |  |  |
| Reset   | 0                                               | —     | —     | —     | 0     | 0     | 0     | 0     |  |  |
| 87h.1   | <b>PD:</b> Stop bit. If 1 Stop mode is entered. |       |       |       |       |       |       |       |  |  |

87h.0

**PD:** Stop bit. If 1 Stop mode is entered. IDL: Idle bit. If 1, Idle mode is entered.

| SFR D8h | Bit 7 | Bit 6 | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|---------|-------|-------|--------|--------|--------|--------|-------|-------|
| CLKCON  | -     | -     | STPSCK | STPPCK | STPFCK | SELFCK | CLK   | PSC   |
| R/W     | -     | -     | R/W    | R/W    | R/W    | R/W    | R/    | W     |
| Reset   | -     | -     | 0      | 0      | 0      | 0      | 1     | 1     |

D8h.5 **STPSCK:** Set 1 to stop Slow clock

D8h.4 STPPCK: Set 1 to stop UART/Timer0/Timer1/Timer2/ADC clock in Idle mode

D8h.3 STPFCK: Set 1 to stop Fast clock for power saving in Slow/Idle mode. This bit can be changed only in Slow mode.

D8h.2 SELFCK: System clock source selection. This bit can be changed only when STPFCK=0. 0: Slow clock

1: Fast clock

D8h.1~0 CLKPSC: System clock prescaler.

00: System clock is Fast/Slow clock divided by 16

01: System clock is Fast/Slow clock divided by 4

10: System clock is Fast/Slow clock divided by 2

11: System clock is Fast/Slow clock divided by 1



#### 6. Interrupt and Wake-up

This **F3288** has a 25-source four-level priority interrupt structure. All enabled Interrupts can wake up CPU from Idle mode, but only the Pin Interrupts can wake up CPU from Stop mode. Each interrupt source has its own enable control bit. An interrupt event will set its individual Interrupt Flag, no matter whether its interrupt enable control bit is 0 or 1. The Interrupt vectors and flags are list below.

| Vector | Flag     | Description                                                 |
|--------|----------|-------------------------------------------------------------|
| 0003   | IE0      | INT0 external pin Interrupt (can wake up Stop mode)         |
| 000B   | TF0      | Timer0 Interrupt                                            |
| 0013   | IE1      | INT1 external pin Interrupt (can wake up Stop mode)         |
| 001B   | TF1      | Timer1 Interrupt                                            |
| 0023   | RI+TI    | Serial Port (UART) Interrupt                                |
| 002B   | TF2+EXF2 | Timer2 Interrupt                                            |
| 0033   | NMI      | Reserved for ICE mode use                                   |
| 003B   | SPAI     | SPIA Interrupt                                              |
| 0043   | P1IF     | Port1 external pin change Interrupt (can wake up Stop mode) |
| 004B   | IE2      | INT2 external pin Interrupt (can wake up Stop mode)         |
| 0053   | ADIF     | ADC Interrupt                                               |
| 005B   | USB1I    | USB1 Interrupt Vector (8 sources)                           |
| 0063   | USB2I    | USB2 Interrupt Vector (6 sources)                           |

Interrupt Vector & Flag

#### 6.1 Interrupt Enable and Priority Control

The IE and INTE1 SFRs decide whether the pending interrupt is serviced by CPU. The IP, IPH, IP1 and IP1H SFRs decide the interrupt priority. An interrupt will be serviced as long as an interrupt of equal or higher priority is not already being serviced. If an interrupt of equal or higher level priority is being serviced, the new interrupt will wait until it is finished before being serviced. If a lower priority level interrupt is being serviced, it will be stopped and the new interrupt serviced. When the new interrupt is finished, the lower priority level interrupt that was stopped will be completed.

| SFR <b>96h</b> | Bit 7 | Bit 6  | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|----------------|-------|--------|-------|-------|-------|-------|-------|-------|--|
| P1WKUP         |       | P1WKUP |       |       |       |       |       |       |  |
| R/W            |       | R/W    |       |       |       |       |       |       |  |
| Reset          | 0     | 0      | 0     | 0     | 0     | 0     | 0     | 0     |  |

96h.7~0 **P1WKUP:** P1.7~P1.0 pin individual Wake up/Interrupt enable control

0: Disable

1: Enable



| I       | -                                                                                                                                               |                                         |               |             |                 |            |              | -      |  |  |  |  |  |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------------|-------------|-----------------|------------|--------------|--------|--|--|--|--|--|
| SFR A8h | Bit 7                                                                                                                                           | Bit 6                                   | Bit 5         | Bit 4       | Bit 3           | Bit 2      | Bit 1        | Bit 0  |  |  |  |  |  |
| IE      | EA                                                                                                                                              | _                                       | ET2           | ES          | ET1             | EX1        | ET0          | EX0    |  |  |  |  |  |
| R/W     | R/W                                                                                                                                             | _                                       | R/W           | R/W         | R/W             | R/W        | R/W          | R/W    |  |  |  |  |  |
| Reset   | 0                                                                                                                                               | _                                       | 0             | 0           | 0               | 0          | 0            | 0      |  |  |  |  |  |
| A8h.7   | EA: Global                                                                                                                                      | EA: Global interrupt enable             |               |             |                 |            |              |        |  |  |  |  |  |
|         |                                                                                                                                                 | all interrupts                          |               |             |                 |            |              |        |  |  |  |  |  |
|         | 1: Each interrupt is enabled or disabled by its individual interrupt control bit                                                                |                                         |               |             |                 |            |              |        |  |  |  |  |  |
| A8h.5   | ET2: Timer2                                                                                                                                     |                                         |               |             |                 |            |              |        |  |  |  |  |  |
|         |                                                                                                                                                 | 0: Disable Timer2 interrupt             |               |             |                 |            |              |        |  |  |  |  |  |
|         |                                                                                                                                                 | 1: Enable Timer2 interrupt              |               |             |                 |            |              |        |  |  |  |  |  |
| A8h.4   |                                                                                                                                                 | ES: Serial Port (UART) interrupt enable |               |             |                 |            |              |        |  |  |  |  |  |
|         |                                                                                                                                                 | 0: Disable Serial Port (UART) interrupt |               |             |                 |            |              |        |  |  |  |  |  |
|         |                                                                                                                                                 |                                         | ART) interru  | pt          |                 |            |              |        |  |  |  |  |  |
| A8h.3   | ET1: Timer                                                                                                                                      |                                         |               |             |                 |            |              |        |  |  |  |  |  |
|         |                                                                                                                                                 | Timer1 interi                           |               |             |                 |            |              |        |  |  |  |  |  |
| 4.01.0  |                                                                                                                                                 | imer1 interr                            |               |             |                 |            |              |        |  |  |  |  |  |
| A8h.2   | EX1: INT1                                                                                                                                       |                                         |               | 1           | -               |            |              |        |  |  |  |  |  |
|         |                                                                                                                                                 |                                         |               | op mode wak |                 |            | 6 9/         | 1      |  |  |  |  |  |
|         |                                                                                                                                                 | -                                       | rrupt and Sto | p mode wake | e up, it can wa | ake up CPU | from Stop me | ode no |  |  |  |  |  |
| A8h.1   |                                                                                                                                                 | A is 0 or 1.                            | abla          |             |                 |            |              |        |  |  |  |  |  |
| Aðil. í | ET0: Timer(                                                                                                                                     |                                         |               |             |                 |            |              |        |  |  |  |  |  |
|         |                                                                                                                                                 | Timer0 intern<br>Timer0 intern          |               |             |                 |            |              |        |  |  |  |  |  |
| A8h.0   | <b>EX0:</b> INT0 1                                                                                                                              |                                         |               | ton mode wa | ke un enable    |            |              |        |  |  |  |  |  |
| A011.0  |                                                                                                                                                 |                                         |               |             |                 |            |              |        |  |  |  |  |  |
|         | 0: Disable INT0 pin Interrupt and Stop mode wake up<br>1: Enable INT0 pin Interrupt and Stop mode wake up, it can wake up CPU from Stop mode po |                                         |               |             |                 |            |              |        |  |  |  |  |  |
|         | 1: Enable INTO pin Interrupt and Stop mode wake up, it can wake up CPU from Stop mode no matter EA is 0 or 1.                                   |                                         |               |             |                 |            |              |        |  |  |  |  |  |
|         | manor L                                                                                                                                         |                                         |               |             |                 |            |              |        |  |  |  |  |  |

\_\_\_\_\_

| SFR A9h | Bit 7                        | Bit 6          | Bit 5          | Bit 4       | Bit 3          | Bit 2        | Bit 1       | Bit 0  |  |  |  |  |
|---------|------------------------------|----------------|----------------|-------------|----------------|--------------|-------------|--------|--|--|--|--|
| INTE1   | -                            | -              | U2IE           | U1IE        | ADIE           | EX2          | P1IE        | SPAIE  |  |  |  |  |
| R/W     | -                            | -              | R/W            | R/W         | R/W            | R/W          | R/W         | R/W    |  |  |  |  |
| Reset   | -                            | -              | 0              | 0           | 0              | 0            | 0           | 0      |  |  |  |  |
| A9h.5   | U2IE: USB2                   | 2 interrupt en | able           |             |                |              |             |        |  |  |  |  |
|         | 0: Disable USB2 interrupt    |                |                |             |                |              |             |        |  |  |  |  |
|         | 1: Enable USB2 interrupt     |                |                |             |                |              |             |        |  |  |  |  |
| A9h.4   | U1IE: USB1 interrupt enable  |                |                |             |                |              |             |        |  |  |  |  |
|         | 0: Disable USB1 interrupt    |                |                |             |                |              |             |        |  |  |  |  |
|         | 1: Enable USB1 interrupt     |                |                |             |                |              |             |        |  |  |  |  |
| A9h.3   | ADIE: ADC interrupt enable   |                |                |             |                |              |             |        |  |  |  |  |
|         | 0: Disable ADC interrupt     |                |                |             |                |              |             |        |  |  |  |  |
|         | 1: Enable A                  | ADC interrup   | t              |             |                |              |             |        |  |  |  |  |
| A9h.2   | EX2: INT2                    |                |                |             |                |              |             |        |  |  |  |  |
|         |                              |                | errupt and Sto |             |                |              |             |        |  |  |  |  |
|         |                              | -              | rrupt and Sto  | p mode wake | e up, it can w | ake up CPU i | from Stop m | ode no |  |  |  |  |
|         |                              | A is 0 or 1.   |                |             |                |              |             |        |  |  |  |  |
| A9h.1   | P1IE: Port1                  | 1 0            | 1              |             |                |              |             |        |  |  |  |  |
|         |                              |                | nge interrupt  |             |                |              |             |        |  |  |  |  |
|         |                              | ort1 pin cha   | 0 1            |             |                |              |             |        |  |  |  |  |
| A9h.0   | SPAIE: SPIA interrupt enable |                |                |             |                |              |             |        |  |  |  |  |
|         | 0: Disable SPIA interrupt    |                |                |             |                |              |             |        |  |  |  |  |
|         | 1: Enable SPIA interrupt     |                |                |             |                |              |             |        |  |  |  |  |



| SFR <b>B9h</b> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| IPH            | _     | —     | PT2H  | PSH   | PT1H  | PX1H  | PT0H  | PX0H  |
| R/W            | _     | _     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset          | _     | _     | 0     | 0     | 0     | 0     | 0     | 0     |
|                |       |       |       |       |       |       |       |       |
| SFR B8h        | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| IP             | _     | —     | PT2   | PS    | PT1   | PX1   | PT0   | PX0   |
| R/W            | _     | —     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset          | _     | —     | 0     | 0     | 0     | 0     | 0     | 0     |

B9h.5, B8h.5 PT2H, PT2: Timer2 interrupt priority control. (PT2H, PT2) =

00: Level 0 (lowest priority)

01: Level 1

10: Level 2

11: Level 3 (highest priority)

B9h.4, B8h.4 **PSH**, **PS**: Serial Port (UART) interrupt priority control. Definition as above.

B9h.3, B8h.3 **PT1H, PT1:** Timer1 interrupt priority control. Definition as above.

B9h.2, B8h.2 **PX1H**, **PX1**: INT1 pin interrupt priority control. Definition as above.

B9h.1, B8h.1 **PT0H**, **PT0**: Timer0 interrupt priority control. Definition as above.

B9h.0, B8h.0 **PX0H, PX0:** INTO pin interrupt priority control. Definition as above.

| SFR <b>BBh</b> | Bit 7 | Bit 6 | Bit 5   | Bit 4   | Bit 3 | Bit 2 | Bit 1 | Bit 0  |
|----------------|-------|-------|---------|---------|-------|-------|-------|--------|
| IP1H           | _     | _     | PUSB2IH | PUSB1IH | PADIH | PX2H  | PP1H  | PSPAIH |
| R/W            | _     | _     | R/W     | R/W     | R/W   | R/W   | R/W   | R/W    |
| Reset          | -     | _     | 0       | 0       | 0     | 0     | 0     | 0      |

| SFR BAh | Bit 7 | Bit 6 | Bit 5  | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|--------|--------|-------|-------|-------|-------|
| IP1     | _     | —     | PUSB2I | PUSB1I | PADI  | PX2   | PP1   | PSPAI |
| R/W     | _     | —     | R/W    | R/W    | R/W   | R/W   | R/W   | R/W   |
| Reset   | _     | _     | 0      | 0      | 0     | 0     | 0     | 0     |

BBh.5, BAh.5 **PUSB2IH, PUSB2I:** USB2 interrupt priority control. Definition as above.

BBh.4, BAh.4 PUSB1IH, PUSB1I: USB1 interrupt priority control. Definition as above.

BBh.3, BAh.3 PADIH, PADI: ADC interrupt priority control. Definition as above.

BBh.2, BAh.2 PX2H, PX2: INT2 pin interrupt priority control. Definition as above.

BBh.1, BAh.1 **PP1H**, **PP1:** Port1 pin change interrupt priority control. Definition as above.

BBh.0, BAh.0 **PSPAIH, PSPAI:** SPIA interrupt priority control. Definition as above.



#### 6.2 Pin Interrupt

Pin Interrupts include INT0 (P3.2), INT1 (P3.3), INT2 (P4.7) and Port1 Change Interrupt. These pins also have the Stop mode wake up capability. INT0 and INT1 are falling edge or low level triggered as the 8051 standard. INT2 is falling edge triggered and Port1 Change Interrupt is triggered by any Port1 pin state change.



#### Pin Interrupt & Wake up

| SFR 88h | Bit 7                                                                                | Bit 6                                          | Bit 5         | Bit 4         | Bit 3         | Bit 2         | Bit 1     | Bit 0 |  |  |  |  |  |  |
|---------|--------------------------------------------------------------------------------------|------------------------------------------------|---------------|---------------|---------------|---------------|-----------|-------|--|--|--|--|--|--|
| TCON    | TF1                                                                                  | TR1                                            | TF0           | TR0           | IE1           | IT1           | IE0       | IT0   |  |  |  |  |  |  |
| R/W     | R/W                                                                                  | R/W                                            | R/W           | R/W           | R/W           | R/W           | R/W       | R/W   |  |  |  |  |  |  |
| Reset   | 0                                                                                    | 0 0 0 0 0 0 0 0                                |               |               |               |               |           |       |  |  |  |  |  |  |
| 88h.3   | IE1: Externa                                                                         | IE1: External Interrupt 1 (INT1 pin) edge flag |               |               |               |               |           |       |  |  |  |  |  |  |
|         | Set by H/W when an INT1 pin falling edge is detected, no matter the EX1 is 0 or 1.   |                                                |               |               |               |               |           |       |  |  |  |  |  |  |
|         | It is cleared automatically when the program performs the interrupt service routine. |                                                |               |               |               |               |           |       |  |  |  |  |  |  |
| 88h.2   | IT1: External Interrupt 1 control bit                                                |                                                |               |               |               |               |           |       |  |  |  |  |  |  |
|         | 0: Low level active (level triggered) for INT1 pin                                   |                                                |               |               |               |               |           |       |  |  |  |  |  |  |
|         | 1: Falling e                                                                         | dge active (e                                  | dge triggered | 1) for INT1 p | oin           |               |           |       |  |  |  |  |  |  |
| 88h.1   | IE0: Externa                                                                         | 1 Interrupt 0                                  | (INT0 pin) e  | dge flag      |               |               |           |       |  |  |  |  |  |  |
|         | Set by H/W                                                                           | when an IN                                     | T0 pin fallin | g edge is det | ected, no mat | ter the EX0 i | s 0 or 1. |       |  |  |  |  |  |  |
|         | It is cleared                                                                        | automatical                                    | ly when the p | program perf  | orms the inte | rrupt service | routine.  |       |  |  |  |  |  |  |
| 88h.0   | <b>ITO:</b> External Interrupt 0 control bit                                         |                                                |               |               |               |               |           |       |  |  |  |  |  |  |
|         | 0: Low level active (level triggered) for INT0 pin                                   |                                                |               |               |               |               |           |       |  |  |  |  |  |  |
|         | 1: Falling edge active (edge triggered) for INTO pin                                 |                                                |               |               |               |               |           |       |  |  |  |  |  |  |



| SFR <b>95h</b> | Bit 7                                                  | Bit 6         | Bit 5         | Bit 4          | Bit 3         | Bit 2         | Bit 1          | Bit 0   |  |  |  |
|----------------|--------------------------------------------------------|---------------|---------------|----------------|---------------|---------------|----------------|---------|--|--|--|
| INTFLG         | LVD                                                    |               | -             | ADIF           | —             | IE2           | P1IF           | -       |  |  |  |
| R/W            | R                                                      |               | -             | R/W            | _             | R/W           | R/W            | -       |  |  |  |
| Reset          | _                                                      |               | -             | 0              | _             | 0             | 0              | -       |  |  |  |
| 95h.2          | IE2: External Interrupt 2 (INT2 pin) edge flag         |               |               |                |               |               |                |         |  |  |  |
|                | Set by H/W                                             | when a falli  | ng edge is de | etected on the | e INT2 pin st | ate, no matte | r the EX2 is ( | ) or 1. |  |  |  |
|                | It is cleared                                          | l automatical | ly when the p | program perfe  | orms the inte | rrupt service | routine.       |         |  |  |  |
|                | S/W can write FBh to INTFLG to clear this bit. (Note2) |               |               |                |               |               |                |         |  |  |  |
| 95h.1          | P1IF: Port1 pin change interrupt flag                  |               |               |                |               |               |                |         |  |  |  |

Set by H/W when a P1 pin state change is detected, and its interrupt enable bit is set (P1WKUP). P1IE does not affect this flag's setting.

It is cleared automatically when the program performs the interrupt service routine.

S/W can write FDh to INTFLG to clear this bit. (Note2)

*Note2:* S/W can write 0 to clear a flag in the INTFLG, but writing 1 has no effect.

#### 6.3 Idle Mode Wake up and Interrupt

Idle mode is wake up by enabled Interrupts, which means individual interrupt enable bit (ex: EX0) and EA bit must be both set to 1 to establish Idle mode wake up capability. All enabled Interrupts (Pins, Timers, ADC, SPIA, UART and USB) can wake up CPU from Idle mode. Upon Idle wake-up, Interrupt service routine is entered immediately. "The first instruction behind IDL (PCON.0) setting" is executed after interrupt service routine return.



EA=EX0=1, Idle mode wake-up and Interrupt by P3.2 (INT0)

| SFR 87h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| PCON    | SMOD  | _     | —     | —     | GF1   | GF0   | PD    | IDL   |
| R/W     | R/W   | _     | —     | —     | R/W   | R/W   | R/W   | R/W   |
| Reset   | 0     |       | _     | _     | 0     | 0     | 0     | 0     |

87h.1 **PD:** Stop bit. If 1, Stop mode is entered.

87h.0 **IDL:** Idle bit. If 1, Idle mode is entered.

#### 6.4 Stop Mode Wake up and Interrupt

Stop mode wake up is simple, as long as the individual pin interrupt enable bit (ex: EX0) is set, the pin wake up capability is asserted. Set EX0/EX1/EX2 can enable INT0/INT1/INT2 pins' Stop mode wake up capability. Set P1WKUP bit 7~0 can enable P1.7~P1.0's Stop mode wake up capability. Upon Stop wake up, " the first instruction behind PD (PCON.1) setting " is executed immediately before Interrupt service. Interrupt entry needs EA=1 (P1WKUP also needs P1IE=1) and the trigger state of the pin staying sufficiently long to be observed by the



System clock. This feature allows CPU to enter or not enter Interrupt sub-routine after Stop mode wake up.







P1.0 change (not need clock sample), Stop mode wake-up and Interrupt.









#### 6.5 USB interrupt

There are several interrupts (USB1I and USB2I) generated by USB module when **F3288** works in USB application. USB1I has 8-source interrupts and USB2I has 6-source interrupts. If USB1I or USB2I interrupt occurs, F/W need to check SFR C2h or C3h to identify which USB interrupt source is generated.

| SFR C2h | Bit 7                                                           | Bit 6         | Bit 5           | Bit 4           | Bit 3       | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|---------|-----------------------------------------------------------------|---------------|-----------------|-----------------|-------------|-------|-------|-------|--|--|--|
| USB1I   | SET0I OUT0I TX0I TX1I TX2I SUSPI TX3I RC4I                      |               |                 |                 |             |       |       |       |  |  |  |
| R/W     | R/W R/W R/W R/W R/W R/W R/W                                     |               |                 |                 |             |       |       |       |  |  |  |
| Reset   | 0 0 0 0 0 0 0 0                                                 |               |                 |                 |             |       |       |       |  |  |  |
| C2h.7   | Endpoint 0 SET0 Receive Interrupt flag, write 0 to clear flag.  |               |                 |                 |             |       |       |       |  |  |  |
| C2h.6   | Endpoint 0 OUT Receive Interrupt flag, write 0 to clear flag.   |               |                 |                 |             |       |       |       |  |  |  |
| C2h.5   | Endpoint 0 Transmit Interrupt flag, write 0 to clear flag.      |               |                 |                 |             |       |       |       |  |  |  |
| C2h.4   | Endpoint 17                                                     | Transmit Inte | rrupt flag, wi  | rite 0 to clear | flag.       |       |       |       |  |  |  |
| C2h.3   | Endpoint 27                                                     | Transmit Inte | rrupt flag, wi  | rite 0 to clear | flag.       |       |       |       |  |  |  |
| C2h.2   | USB Suspend Interrupt flag, write 0 to clear flag.              |               |                 |                 |             |       |       |       |  |  |  |
| C2h.1   | Endpoint 3 Bulk Transmit Interrupt flag, write 0 to clear flag. |               |                 |                 |             |       |       |       |  |  |  |
| C2h.0   | Endpoint 4 E                                                    | Bulk Receive  | e Interrupt fla | ng, write 0 to  | clear flag. |       |       |       |  |  |  |

| SFR C3h | Bit 7                                          | Bit 6 | Bit 5 | Bit 4 | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|---------|------------------------------------------------|-------|-------|-------|--------|--------|-------|-------|
| USB2I   | VDD5RI                                         | RSTI  | RSMI  | KBDI  | PD_TXI | PD_RCI | -     | -     |
| R/W     | R/W                                            | R/W   | R/W   | R/W   | R/W    | R/W    | -     | -     |
| Reset   | 0                                              | 0     | 0     | 0     | 0      | 0      | -     | -     |
| C3h.7   | VDD5V Rise Interrupt flag, write 0 to clear it |       |       |       |        |        |       |       |

C3h.6USB Bus Reset Interrupt flag, write 0 to clear flag.C3h.5USB Resume Interrupt flag, write 0 to clear flag.C3h.4Keyboard Interrupt flag, write 0 to clear flag.

- C3h.3 USB PD Transmit Interrupt flag, write 0 to clear flag.
- C3h.2 USB PD Receive Interrupt flag, write 0 to clear flag.



# 7. I/O Ports

The **F3288** has total 41 multi-function I/O pins. All I/O pins follow the standard 8051 "Read-Modify-Write" feature. The instructions that read the SFR rather than the Pin State are the ones that read a port or port bit value, possibly change it, and then rewrite it to the SFR. (ex: ANL P1, A; INC P2; CPL P3.0)

# 7.1 Port1 & Port3 & P4

These pins can operate in four different modes as below.

| Mode   | Port1, Port3, P4 pin functionP3.2~P3.0Others |                  | Px.n<br>SFR data  | Pin State  | Resistor<br>Pull-up | Digital<br>Input |
|--------|----------------------------------------------|------------------|-------------------|------------|---------------------|------------------|
| Mode 0 | Pseudo                                       | Onen Drein       | 0                 | Drive Low  | Ν                   | Ν                |
| Mode 0 | Open Drain                                   | Open Drain       | 1                 | Pull-up    | Y                   | Y                |
| Mode 1 | Pseudo                                       | Onen Drein       | 0                 | Drive Low  | Ν                   | Ν                |
| Mode 1 | Mode 1 Open Drain                            | Open Drain       | 1                 | Hi-Z       | Ν                   | Y                |
| Mode 2 | CMOS                                         | Output           | 0                 | Drive Low  | Ν                   | Ν                |
| Mode 2 | CMOS                                         | Output           | 1                 | Drive High | Ν                   | Ν                |
| Mode 3 | Alternative Funct                            | ion, such as ADC | X<br>(don't care) | _          | Ν                   | Ν                |

Port1, Port3, P4 I/O Pin Function Table

If a Port1 (except P1.2/P1.3), Port3 or P4 pin is used for Schmitt-trigger input, S/W must set the I/O pin to Mode0 or Mode1 and set the corresponding Port Data SFR to 1 to disable the pin's output driving circuitry.

Beside I/O port function, each Port1 (except P1.2/P1.3), Port3 and P4 pin has one or more alternative functions, such as ADC. Most of the functions are activated by setting the individual pin mode control SFR to Mode3. Port1/Port3 pins have standard 8051 auxiliary definition such as INTO/1, T0/1/2, or RXD/TXD. These pin functions need to set the pin mode SFR to Mode0 or Mode1 and keep the P1.n/P3.n SFR at 1.

| Pin Name | 8051 | Wake-up | СКО | ADC  | others | Mode3    |
|----------|------|---------|-----|------|--------|----------|
| P1.0     | T2   | Y       | T2O | AD0  |        | AD0      |
| P1.1     | T2EX | Y       |     | AD1  |        | AD1      |
| P1.2     |      | Y       |     |      | DP     |          |
| P1.3     |      | Y       |     |      | DM     |          |
| P1.4     |      | Y       |     | AD2  | PWM0P  | AD2      |
| P1.5     |      | Y       |     | AD3  | PWM1A  | AD3      |
| P1.6     |      | Y       |     | AD4  | PWM1B  | AD4      |
| P1.7     |      | Y       |     | AD5  | PWM1C  | AD5      |
| P3.0     | RXD  |         |     |      |        |          |
| P3.1     | TXD  |         |     |      |        |          |
| P3.2     | INT0 | Y       |     | AD10 |        | AD10/CC1 |
| P3.3     | INT1 | Y       |     | AD11 |        | AD11/CC2 |
| P3.4     | T0   |         | T0O |      | NSSI   |          |
| P3.5     | T1   |         |     |      | KSO15  |          |
| P3.6     |      |         |     |      | KSO16  |          |
| P3.7     |      |         |     |      | KSO17  |          |
| P4.0     |      |         |     | AD6  | KSO8   | AD6      |
| P4.1     |      |         |     | AD7  | KSO9   | AD7      |



| P4.2 |      |   | AD8 | KSO10 | AD8 |
|------|------|---|-----|-------|-----|
| P4.3 |      |   | AD9 | KSO11 | AD9 |
| P4.4 |      |   |     | KSO12 |     |
| P4.5 |      |   |     | KSO13 |     |
| P4.6 |      |   |     | KSO14 |     |
| P4.7 | INT2 | Y |     |       |     |

Port1, Port3, Port4 multi-function Table

The necessary SFR setting for Port1/Port3/Port4 pin's alternative function is list below.

| Alternative Function          | Mode | Px.n<br>SFR data | Pin State                                   | Other necessary<br>SFR setting |
|-------------------------------|------|------------------|---------------------------------------------|--------------------------------|
| T0, T1, T2, T2EX,             | 0    | 1                | Input with Pull-up                          |                                |
| INT0, INT1                    | 1    | 1                | Input                                       |                                |
| DVD TVD                       | 0    | 1                | Input with Pull-up/Pseudo Open Drain Output |                                |
| RXD, TXD                      | 1    | 1                | Input/Pseudo Open Drain Output              |                                |
|                               | 0    | Х                | Clock Open Drain Output with Pull-up        |                                |
| T0O, T2O                      | 1    | Х                | Clock Open Drain Output                     | PINMOD                         |
|                               | 2    | Х                | Clock Output (CMOS Push-Pull)               |                                |
| AD0~AD11                      | 3    | Х                | ADC Channel                                 |                                |
|                               | 0    | Х                | PWM Open Drain Output with Pull-up          |                                |
| PWM1A, PWM1B,<br>PWM1C, PWM0P | 1    | Х                | PWM Open Drain Output                       | PINMOD                         |
| r www.iviiC, r www.ivior      | 2    | Х                | PWM Output (CMOS Push-Pull)                 |                                |
| NSSI                          | 1    | 1                | SPIA Chip Selection                         | SPACON                         |
|                               | 0    | Х                | Keyboard Open Drain Output with Pull-up     |                                |
| Keyboard                      | 1    | X                | Keyboard Open Drain Output                  |                                |
|                               | 2    | Х                | Keyboard Output (CMOS Push-Pull)            |                                |
| DP,DM                         | Х    | Х                | USB I/O                                     | USBADR                         |

Mode Setting for Port1, Port3, P4.1~P4.0 Alternative Function

For tables above, a **"COMS Output"** pin means it can sink and drive at least 4mA current. It is not recommended to use such pin as input function.

An "**Open Drain**" pin means it can sink at least 4mA current but only drive a small current ( $<20\mu$ A). It can be used as input or output function and typically needs an external pull up resistor.

An 8051 standard pin is a **"Pseudo Open Drain"** pin. It can sink at least 4 mA current when output is at low level, and drives at least 4 mA current for 1~2 clock cycle when output transits from low to high, then keeps driving a small current (<20 $\mu$ A) to maintain the pin at high level. It can be used as input or output function.





P1.0 Structure





#### 7.2 P1.2 (DP) and P1.3 (DM)

These pins are similar to other Port 1, except they share the pin with USB function. When **USBE** is set to "1" these two pin are used for USB function DP/DM. The maximum power of these two pin is VDD (internal power) not VDDIO (external input power).



| DP/DM (P1.2/P1.3) Structure | DP/DM | (P1.2/P1.3 | 3) Structure |
|-----------------------------|-------|------------|--------------|
|-----------------------------|-------|------------|--------------|

| SFR <b>90h</b> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| P1             | P1.7  | P1.6  | P1.5  | P1.4  | P1.3  | P1.2  | P1.1  | P1.0  |
| R/W            | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset          | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

90h.7~0 **P1:** Port1 data

| SFR B0h | Bit 7        | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|--------------|-------|-------|-------|-------|-------|-------|-------|
| P3      | P3.7         | P3.6  | P3.5  | P3.4  | P3.3  | P3.2  | P3.1  | P3.0  |
| R/W     | R/W          | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 1            | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| DOL 7 0 | D2. Dant2 da | 4     |       |       |       |       |       |       |

B0h.7~0 **P3:** Port3 data

| SFR E8h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| P4      | P4.7  | P4.6  | P4.5  | P4.4  | P4.3  | P4.2  | P4.1  | P4.0  |
| R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

E8h.1~0 **P4:** Port 4 data

| SFR A2h | Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3  | Bit 2 | Bit 1  | Bit 0 |
|---------|-------|-------|--------|-------|--------|-------|--------|-------|
| P1MODL  | P1M   | OD3   | P1MOD2 |       | P1MOD1 |       | P1MOD0 |       |
| R/W     | R/    | W     | R/     | R/W   |        | W     | R/     | W     |
| Reset   | 0     | 0     | 0      | 0     | 0      | 0     | 0      | 0     |

A2h.7~6 **P1MOD3:** P1.3 pin control

00: Mode0

01: Mode1

10: Mode2

11: Mode3



| A2h.5~4 | P1MOD2: P1.2 pin control        |
|---------|---------------------------------|
|         | 00: Mode0                       |
|         | 01: Mode1                       |
|         | 10: Mode2                       |
|         | 11: Mode3                       |
| A2h.3~2 | P1MOD1: P1.1 pin control        |
|         | 00: Mode0                       |
|         | 01: Mode1                       |
|         | 10: Mode2                       |
|         | 11: Mode3, P1.1 is ADC input    |
| A2h.1~0 | <b>P1MOD0:</b> P1.0 pin control |
|         | 00: Mode0                       |
|         | 01: Mode1                       |
|         | 10 14 1 0                       |

- 10: Mode2
- 11: Mode3, P1.0 is ADC input

| SFR A3h | Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3  | Bit 2 | Bit 1  | Bit 0 |
|---------|-------|-------|--------|-------|--------|-------|--------|-------|
| P1MODH  | P1M   | OD7   | P1MOD6 |       | P1MOD5 |       | P1MOD4 |       |
| R/W     | R/    | W     | R/W    |       | R/     | W     | R/     | W     |
| Reset   | 0     | 0     | 0      | 0     | 0      | 0     | 0      | 0     |

| P1MOD7: P1.7 pin control     |
|------------------------------|
| 00: Mode0                    |
| 01: Mode1                    |
| 10: Mode2                    |
| 11: Mode3, P1.7 is ADC input |
| P1MOD6: P1.6 pin control     |
| 00: Mode0                    |
| 01: Mode1                    |
| 10: Mode2                    |
| 11: Mode3, P1.6 is ADC input |
| P1MOD5: P1.5 pin control     |
| 00: Mode0                    |
| 01: Mode1                    |
| 10: Mode2                    |
| 11: Mode3, P1.5 is ADC input |
| P1MOD4: P1.4 pin control     |
| 00: Mode0                    |
| 01: Mode1                    |
| 10: Mode2                    |
|                              |

11: Mode3, P1.4 is ADC input

| SFR A4h   | Bit 7  | Bit 6 | Bit 5  | Bit 4 | Bit 3  | Bit 2 | Bit 1  | Bit 0 |  |
|-----------|--------|-------|--------|-------|--------|-------|--------|-------|--|
| P3MODL    | P3MOD3 |       | P3MOD2 |       | P3MOD1 |       | P3MOD0 |       |  |
| R/W       | R/W    |       | R/     | W     | R/     | W     | R/W    |       |  |
| Reset     | 0      | 0     | 0      | 0     | 0      | 0     | 0      | 0     |  |
| A 41- 7 C |        |       |        |       |        |       |        |       |  |

A4h.7~6 **P3MOD3:** P3.3 pin control 00: Mode0

- 01: Mode1
- 10: Mode2
- 11: Mode3, P3.3 is ADC input
- A4h.5~4 **P3MOD2:** P3.2 pin control
  - 00: Mode0
  - 01: Mode1
  - 10: Mode2
  - 11: Mode3, P3.2 is ADC input



A4h.3~2 **P3MOD1:** P3.1 pin control 00: Mode0 01: Mode1 10: Mode2 11: Mode3 A4h.1~0 **P3MOD0:** P3.0 pin control 00: Mode0 01: Mode1

10: Mode2

11: Mode3

| SFR A5h | Bit 7  | Bit 6 | Bit 5  | Bit 4 | Bit 3  | Bit 2 | Bit 1  | Bit 0 |
|---------|--------|-------|--------|-------|--------|-------|--------|-------|
| P3MODH  | P3MOD7 |       | P3MOD6 |       | P3MOD5 |       | P3MOD4 |       |
| R/W     | R/W    |       | R/     | W     | R/W    |       | R/W    |       |
| Reset   | 0      | 0     | 0      | 0     | 0      | 0     | 0      | 0     |

00: Mode0

01: Mode1

10: Mode2

11: Mode3

A5h.5~4 **P3MOD6:** P3.6 pin control 00: Mode0 01: Mode1 10: Mode2 11: Mode3 A5h.3~2 **P3MOD5:** P3.5 pin control 00: Mode0 01: Mode1

10: Mode2

11: Mode3

A5h.1~0 P3MOD4: P3.4 pin control

00: Mode0

01: Mode1

- 10: Mode2
- 11: Mode3

| SFR B4h | Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3  | Bit 2 | Bit 1  | Bit 0 |
|---------|-------|-------|--------|-------|--------|-------|--------|-------|
| P4MODL  | P4M   | OD3   | P4MOD2 |       | P4MOD1 |       | P4MOD0 |       |
| R/W     | R/    | W     | R/W    |       | R/W    |       | R/W    |       |
| Reset   | 0     | 0     | 0      | 0     | 0      | 0     | 0      | 0     |

| B4h.7~6 | P4MOD3: P4.3 pin control        |
|---------|---------------------------------|
|         | 00: Mode0                       |
|         | 01: Mode1                       |
|         | 10: Mode2                       |
|         | 11: Mode3, P4.3 is ADC input    |
| B4h.5~4 | P4MOD2: P4.2 pin control        |
|         | 00: Mode0                       |
|         | 01: Mode1                       |
|         | 10: Mode2                       |
|         | 11: Mode3, P4.2 is ADC input    |
| B4h.3~2 | <b>P4MOD1:</b> P4.1 pin control |
|         | 00: Mode0                       |
|         | 01: Mode1                       |
|         | 10: Mode2                       |
|         |                                 |



#### 11: Mode3, P4.1 is ADC input

B4h.1~0 P4MOD0: P4.0 pin control

00: Mode0

01: Mode1

10: Mode2

11: Mode3, P4.0 is ADC input

| SFR <b>B5h</b> | Bit 7  | Bit 6 | Bit 5  | Bit 4 | Bit 3   | Bit 2 | Bit 1  | Bit 0 |
|----------------|--------|-------|--------|-------|---------|-------|--------|-------|
| P4MODH         | P4MOD7 |       | P4MOD6 |       | P4MOD5  |       | P4MOD4 |       |
| R/W            | R/W    |       | R/     | W     | R/W R/W |       | W      |       |
| Reset          | 0      | 0     | 0      | 0     | 0       | 0     | 0      | 0     |

B5h.7~6 **P4MOD7:** P4.7 pin control

- 00: Mode0
- 01: Mode1
- 10: Mode2
- 11: Mode3
- B5h.5~4 **P4MOD6:** P4.6 pin control
  - 00: Mode0
  - 01: Mode1
  - 10: Mode2
  - 11: Mode3
- B5h.3~2 **P4MOD5:** P4.5 pin control
  - 00: Mode0
  - 01: Mode1
  - 10: Mode2
  - 11: Mode3

# B5h.1~0 **P4MOD4:** P4.4 pin control

- 00: Mode0
- 01: Mode1
- 10: Mode2
- 11: Mode3

| SFR A6h | Bit 7                                                   | Bit 6           | Bit 5          | Bit 4 | Bit 3  | Bit 2   | Bit 1   | Bit 0   |  |  |
|---------|---------------------------------------------------------|-----------------|----------------|-------|--------|---------|---------|---------|--|--|
| PINMOD  | P5OE0                                                   | PWM0POE         | PWM0NOE        | T2OE  | TOOE   | PWM1AOE | PWM1BOE | PWM1COE |  |  |
| R/W     | R/W                                                     | R/W             | R/W            | R/W   | R/W    | R/W     | R/W     | R/W     |  |  |
| Reset   | 0                                                       | 0 0 0 0 0 0 0 0 |                |       |        |         |         |         |  |  |
| A6h.6   | <b>PWM0POE:</b> PWM0P signal output enable              |                 |                |       |        |         |         |         |  |  |
|         | 0: Disable PWM0P signal output to P1.4                  |                 |                |       |        |         |         |         |  |  |
|         | 1: Enable PWM0P signal output to P1.4                   |                 |                |       |        |         |         |         |  |  |
| A6h.4   | T2OE: Timer2 signal output enable                       |                 |                |       |        |         |         |         |  |  |
|         | 0: Disable Timer2 overflow divided by 2 output to P1.0  |                 |                |       |        |         |         |         |  |  |
|         | 1: Enable Timer2 overflow divided by 2 output to P1.0   |                 |                |       |        |         |         |         |  |  |
| A6h.3   | TOOE: Timer0 signal output enable                       |                 |                |       |        |         |         |         |  |  |
|         | 0: Disable Timer0 overflow divided by 64 output to P3.4 |                 |                |       |        |         |         |         |  |  |
|         |                                                         | Timer0 overfl   |                | • I   | o P3.4 |         |         |         |  |  |
| A6h.2   |                                                         | E: PWM1A si     | 0 1            |       |        |         |         |         |  |  |
|         |                                                         | PWM1A sigr      |                |       |        |         |         |         |  |  |
|         |                                                         | PWM1A sign      | -              |       |        |         |         |         |  |  |
| A6h.1   |                                                         | <b>PWM1B</b> si |                |       |        |         |         |         |  |  |
|         |                                                         | PWM1B sign      |                |       |        |         |         |         |  |  |
|         |                                                         | PWM1B signa     | -              |       |        |         |         |         |  |  |
| A6h.0   |                                                         | E: PWM1C si     |                |       |        |         |         |         |  |  |
|         |                                                         | PWM1C sign      | 1              |       |        |         |         |         |  |  |
|         | 1: Enable F                                             | PWM1C signa     | al output to P | 21.7  |        |         |         |         |  |  |
|         |                                                         |                 |                |       |        |         |         |         |  |  |



| SFR BCh | Bit 7 | Bit 6   | Bit 5   | Bit 4   | Bit 3    | Bit 2   | Bit 1 | Bit 0 |
|---------|-------|---------|---------|---------|----------|---------|-------|-------|
| SPACON  | SPAEN | SPAMSTR | SPACPOL | SPACPHA | SPASSDIS | SPALSBF | SPACR |       |
| R/W     | R/W   | R/W     | R/W     | R/W     | R/W      | R/W     | R/W   |       |
| Reset   | 0     | 0       | 0       | 0       | 0        | 0       | 0     | 0     |

BCh.3 SPASSDIS: SS pin disable

0: Enable SS pin, P3.4 is SPIA chip selection input.

1: Disable SS pin

| SFR C1h | Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|---------|-------|-------|--------|-------|-------|-------|-------|-------|--|
| USBADR  | USBE  |       | FUNADR |       |       |       |       |       |  |
| R/W     | R/W   |       | R/W    |       |       |       |       |       |  |
| Reset   | 0     | 0     | 0      | 0     | 0     | 0     | 0     | 0     |  |
|         |       |       |        |       |       |       |       |       |  |

C1h.7 **USBE:** USB function enable bit

0: Disable P1.2/P1.3 as USB DP/DM pin

1: Enable P1.2/P1.3 as USB DP/DM pin



### 7.3 Port0 & Port2 & Port5.0

These pins are shared with SPI, ADC, I80 and Keyboard. If a Port0/Port2/Port5.0 pin is defined as I/O pin, it can be used as CMOS push-pull output or Schmitt-trigger input. The pin's pull up function is enable while SFR bit PxOE.n=0 and Px.n=1.

| Port0, Port2,<br>Port5.0<br>pin function | PxOE.n | Px.n<br>SFR data | Pin State  | Resistor<br>Pull-up | Digital<br>Input |
|------------------------------------------|--------|------------------|------------|---------------------|------------------|
| Turnet                                   | 0      | 0                | Hi-Z       | Ν                   | Y                |
| Input                                    | 0      | 1                | Pull-up    | Y                   | Y                |
| CMOS Output                              | 1      | 0                | Drive Low  | N                   | N                |
| CMOS Output                              | 1      | 1                | Drive High | N                   | N                |

| Pin Name | I80 | Key  | SPI  |
|----------|-----|------|------|
| P0.0     | D0  | KSI0 |      |
| P0.1     | D1  | KSI1 |      |
| P0.2     | D2  | KSI2 |      |
| P0.3     | D3  | KSI3 |      |
| P0.4     | D4  | KSI4 |      |
| P0.5     | D5  | KSI5 |      |
| P0.6     | D6  | KSI6 |      |
| P0.7     | D7  | KSI7 |      |
| P2.0     |     | KSO0 | MISO |
| P2.1     |     | KSO1 | SCK  |
| P2.2     |     | KSO2 | MOSI |
| P2.3     | WR  | KSO3 |      |
| P2.4     |     | KSO4 | BSDI |
| P2.5     |     | KSO5 | BSCK |
| P2.6     |     | KSO6 | BSDO |
| P2.7     | RD  | KSO7 |      |
| P5.0     |     |      |      |

Port0, Port2, Port5.0 I/O Pin Function Table

Port0, Port2, Port5.0 multi-function Table





**P0.0 Pin Structure** 

| SFR 80h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| PO      | P0.7  | P0.6  | P0.5  | P0.4  | P0.3  | P0.2  | P0.1  | P0.0  |
| R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

<sup>80</sup>h.7~0 **P0:** Port0 data, also controls the P0.n pin's pull-up function. If the P0.n SFR data is "1" and the corresponding POOE.n=0 (input mode), the pull-up is enabled.

| SFR A0h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| P2      | P2.7  | P2.6  | P2.5  | P2.4  | P2.3  | P2.2  | P2.1  | P2.0  |
| R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

A0h.7~0 **P2:** Port2 data, also controls the P2.n pin's pull-up function. If the P2.n SFR data is "1" and the corresponding P2OE.n=0 (input mode), the pull-up is enabled.

| SFR C0h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| P5      | -     | -     | -     | -     | -     | -     | -     | P50D  |
| R/W     | -     | -     | -     | -     | -     | -     | -     | R/W   |
| Reset   | -     | -     | -     | -     | -     | -     | -     | 1     |

C0h.0 **P50D:** P5.0 data, also controls the P5.0 pin's pull-up function. If the P5.0 SFR data is "1" and the corresponding P5OE0=0 (input mode), the pull-up is enabled.



| SFR <b>91h</b> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| POOE           |       |       |       | PO    | OE    |       |       |       |
| R/W            |       |       |       | R/    | W     |       |       |       |
| Reset          | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

91h.7~0 **POOE:** Port0 CMOS Push-Pull output enable control

0: Disable 1: Enable

| SFR <b>93h</b> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| P2OE           |       |       |       | P2    | OE    |       |       |       |
| R/W            |       |       |       | R/    | W     |       |       |       |
| Reset          | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

93h.7~0 P2OE: Port2 CMOS Push-Pull output enable control

0: Disable

1: Enable

| SFR A6h | Bit 7 | Bit 6          | Bit 5          | Bit 4 | Bit 3 | Bit 2   | Bit 1   | Bit 0   |
|---------|-------|----------------|----------------|-------|-------|---------|---------|---------|
| PINMOD  | P5OE0 | <b>PWM0POE</b> | <b>PWM0NOE</b> | T2OE  | TOOE  | PWM1AOE | PWM1BOE | PWM1COE |
| R/W     | R/W   | R/W            | R/W            | R/W   | R/W   | R/W     | R/W     | R/W     |
| Reset   | 0     | 0              | 0              | 0     | 0     | 0       | 0       | 0       |

A6h.7 **P5OE0:** P5.0 CMOS Push-Pull output enable control

0: Disable

1: Enable

A6h.5 **PWM0NOE:** PWM0N signal output enable

0: Disable PWM0N signal output to P5.0

1: Enable PWM0N signal output to P5.0



# 8. Timers

Timer0, Timer1 and Timer2 are provided as standard 8051 compatible timer/counter. Compare to the traditional 12T 8051, the chip's Timer0/1/2 use 2 System clock cycle as the time base unit. That is, in timer mode, these timers increase at every "2 System clock" rate; in counter mode, T0/T1/T2 pin input pulse must be wider than 2 System clock to be seen by this device. In addition to the standard 8051 timers function. The T0O pin can output the "Timer0 overflow divided by 64" signal, and the T2O pin can output the "Timer2 overflow divided by 2" signal.

# 8.1 Timer0/1

TCON and TMOD are used to set the mode of operation and to control the running and interrupt generation of the Timer0/1, with the timer/counter values stored in two pairs of 8-bit registers (TL0, TH0, and TL1, TH1).

| SFR 88h                            | Bit 7                                                                                                                                                                                                           | Bit 6                                                                                                                                                                                                                                                                | Bit 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Bit 4                                                                                                                  | Bit 3                                                                                         | Bit 2                                      | Bit 1    | Bit 0 |  |
|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------|----------|-------|--|
| TCON                               | TF1                                                                                                                                                                                                             | TR1                                                                                                                                                                                                                                                                  | TF0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | TR0                                                                                                                    | IE1                                                                                           | IT1                                        | IE0      | ITO   |  |
| R/W                                | R/W                                                                                                                                                                                                             | R/W                                                                                                                                                                                                                                                                  | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R/W                                                                                                                    | R/W                                                                                           | R/W                                        | R/W      | R/W   |  |
| Reset                              | 0                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                      | 0                                                                                             | 0                                          | 0        | 0     |  |
| 88h.7                              | TF1: Timer1                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                        |                                                                                               |                                            |          |       |  |
|                                    |                                                                                                                                                                                                                 | Set by H/W when Timer/Counter 1 overflows.                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                        |                                                                                               |                                            |          |       |  |
|                                    | •                                                                                                                                                                                                               | H/W when C                                                                                                                                                                                                                                                           | CPU vectors i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | nto the intern                                                                                                         | upt service re                                                                                | outine.                                    |          |       |  |
| 88h.6                              | TR1: Timer                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                        |                                                                                               |                                            |          |       |  |
|                                    |                                                                                                                                                                                                                 | 0: Timer1 stops                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                        |                                                                                               |                                            |          |       |  |
| 001 5                              | 1: Timer1 runs                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                        |                                                                                               |                                            |          |       |  |
| 88h.5                              | TF0: Timer(                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                      | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                        |                                                                                               |                                            |          |       |  |
|                                    |                                                                                                                                                                                                                 | When Times<br>H/W when C                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                        | unt correioo r                                                                                | outing                                     |          |       |  |
| 88h.4                              | <b>TR0:</b> Timer                                                                                                                                                                                               |                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | nto the interi                                                                                                         | upt service it                                                                                | Juline.                                    |          |       |  |
| 0011.4                             | 0: Timer0 s                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                        |                                                                                               |                                            |          |       |  |
|                                    | 1: Timer0 r                                                                                                                                                                                                     | -                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                        |                                                                                               |                                            |          |       |  |
|                                    |                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                        |                                                                                               |                                            |          |       |  |
| SFR <b>89h</b>                     | Bit 7                                                                                                                                                                                                           | Bit 6                                                                                                                                                                                                                                                                | Bit 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Bit 4                                                                                                                  | Bit 3                                                                                         | Bit 2                                      | Bit 1    | Bit 0 |  |
| TMOD                               | GATE1                                                                                                                                                                                                           | CT1N                                                                                                                                                                                                                                                                 | TM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DD1                                                                                                                    | GATE0                                                                                         | CT0N                                       | TM       | OD0   |  |
|                                    |                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                        |                                                                                               |                                            |          |       |  |
| R/W                                | R/W                                                                                                                                                                                                             | R/W                                                                                                                                                                                                                                                                  | R/                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                        | R/W                                                                                           | R/W                                        |          |       |  |
| R/W<br>Reset                       | R/W<br>0                                                                                                                                                                                                        | R/W<br>0                                                                                                                                                                                                                                                             | R/                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | W 0                                                                                                                    | R/W<br>0                                                                                      | R/W<br>0                                   | <u> </u> | W 0   |  |
|                                    | 0<br><b>GATE1:</b> Tir                                                                                                                                                                                          | 0<br>ner1 gating c                                                                                                                                                                                                                                                   | 0<br>control bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0                                                                                                                      |                                                                                               |                                            |          |       |  |
| Reset                              | 0<br>GATE1: Tin<br>0: Timer1 e                                                                                                                                                                                  | 0<br>ner1 gating c<br>enable when '                                                                                                                                                                                                                                  | 0<br>ontrol bit<br>TR1 bit is set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                      | 0                                                                                             | 0                                          |          |       |  |
| Reset<br>89h.7                     | 0<br>GATE1: Tir<br>0: Timer1 e<br>1: Timer1 e                                                                                                                                                                   | 0<br>ner1 gating c<br>enable when '<br>enable only w                                                                                                                                                                                                                 | 0<br>control bit<br>TR1 bit is set<br>hile the INT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0<br>1 pin is high                                                                                                     | 0                                                                                             | 0                                          |          |       |  |
| Reset                              | 0<br>GATE1: Tin<br>0: Timer1 e<br>1: Timer1 e<br>CT1N: Time                                                                                                                                                     | 0<br>mer1 gating c<br>enable when '<br>enable only w<br>er1 Counter/'                                                                                                                                                                                                | 0<br>control bit<br>TR1 bit is set<br>while the INT<br>Fimer select b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0<br>1 pin is high<br>bit                                                                                              | 0<br>and TR1 bit i                                                                            | 0<br>is set                                |          |       |  |
| Reset<br>89h.7                     | 0<br>GATE1: Tin<br>0: Timer1 e<br>1: Timer1 e<br>CT1N: Time<br>0: Timer m                                                                                                                                       | 0<br>ner1 gating c<br>enable when '<br>enable only w<br>er1 Counter/1<br>ode, Timer1                                                                                                                                                                                 | 0<br>ontrol bit<br>TR1 bit is set<br>thile the INT<br>Fimer select b<br>data increase                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0<br>1 pin is high<br>bit<br>s at 2 Systen                                                                             | 0<br>and TR1 bit i<br>1 clock cycle                                                           | 0<br>is set<br>rate                        |          |       |  |
| Reset<br>89h.7<br>89h.6            | 0<br>GATE1: Tin<br>0: Timer1 e<br>1: Timer1 e<br>CT1N: Time<br>0: Timer m<br>1: Counter                                                                                                                         | 0<br>ner1 gating c<br>enable when '<br>enable only w<br>er1 Counter/7<br>ode, Timer1<br>mode, Timer                                                                                                                                                                  | 0<br>ontrol bit<br>TR1 bit is set<br>/hile the INT<br>Fimer select h<br>data increase<br>1 data increa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0<br>1 pin is high<br>bit<br>s at 2 Systen                                                                             | 0<br>and TR1 bit i<br>1 clock cycle                                                           | 0<br>is set<br>rate                        |          |       |  |
| Reset<br>89h.7                     | 0<br>GATE1: Tin<br>0: Timer1 e<br>1: Timer1 e<br>CT1N: Time<br>0: Timer m<br>1: Counter<br>TMOD1: Ti                                                                                                            | 0<br>ner1 gating c<br>enable when '<br>enable only w<br>er1 Counter/1<br>ode, Timer1<br>mode, Timer<br>mer1 mode s                                                                                                                                                   | 0<br>ontrol bit<br>TR1 bit is set<br>/hile the INT<br>Fimer select h<br>data increase<br>1 data increa<br>elect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0<br>1 pin is high<br>bit<br>s at 2 Systen<br>ses at T1 pin                                                            | 0<br>and TR1 bit i<br>a clock cycle<br>s negative ec                                          | 0<br>is set<br>rate                        |          |       |  |
| Reset<br>89h.7<br>89h.6            | 0<br>GATE1: Tin<br>0: Timer1 e<br>1: Timer1 e<br>CT1N: Time<br>0: Timer m<br>1: Counter<br>TMOD1: Ti<br>00: 8-bit tin                                                                                           | 0<br>ner1 gating c<br>enable when '<br>enable only w<br>er1 Counter/1<br>ode, Timer1<br>mode, Timer<br>mer1 mode s<br>ner/counter (                                                                                                                                  | 0<br>ontrol bit<br>TR1 bit is set<br>thile the INT<br>Timer select t<br>data increase<br>1 data increa<br>elect<br>TH1) and 5-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0<br>1 pin is high<br>bit<br>s at 2 Systen<br>ses at T1 pin                                                            | 0<br>and TR1 bit i<br>a clock cycle<br>s negative ec                                          | 0<br>is set<br>rate                        |          |       |  |
| Reset<br>89h.7<br>89h.6            | 0<br>GATE1: Tin<br>0: Timer1 e<br>1: Timer1 e<br>CT1N: Time<br>0: Timer m<br>1: Counter<br>TMOD1: Ti<br>00: 8-bit tin<br>01: 16-bit t                                                                           | 0<br>ner1 gating c<br>enable when '<br>enable only w<br>er1 Counter/I<br>ode, Timer1<br>mode, Timer<br>mer1 mode s<br>ner/counter (<br>imer/counter                                                                                                                  | 0<br>ontrol bit<br>TR1 bit is set<br>thile the INT<br>fimer select b<br>data increase<br>1 data increa<br>elect<br>TH1) and 5-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0<br>1 pin is high<br>bit<br>s at 2 Systen<br>ses at T1 pin<br>pit prescaler                                           | 0<br>and TR1 bit i<br>a clock cycle<br>'s negative ec<br>TL1)                                 | 0<br>is set<br>rate<br>dge                 |          |       |  |
| Reset<br>89h.7<br>89h.6            | 0<br>GATE1: Tin<br>0: Timer1 e<br>1: Timer1 e<br>CT1N: Time<br>0: Timer m<br>1: Counter<br>TMOD1: Ti<br>00: 8-bit tin<br>01: 16-bit t<br>10: 8-bit au                                                           | 0<br>mer1 gating c<br>enable when '<br>enable only w<br>er1 Counter/T<br>ode, Timer1<br>mode, Timer<br>mer1 mode s<br>mer/counter (<br>imer/counter<br>ito-reload tim                                                                                                | 0<br>ontrol bit<br>TR1 bit is set<br>thile the INT<br>fimer select b<br>data increase<br>1 data increa<br>elect<br>TH1) and 5-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0<br>1 pin is high<br>bit<br>s at 2 Systen<br>ses at T1 pin<br>pit prescaler                                           | 0<br>and TR1 bit i<br>a clock cycle<br>'s negative ec<br>TL1)                                 | 0<br>is set<br>rate<br>dge                 |          |       |  |
| Reset<br>89h.7<br>89h.6            | 0<br>GATE1: Tin<br>0: Timer1 e<br>1: Timer1 e<br>CT1N: Time<br>0: Timer m<br>1: Counter<br>TMOD1: Ti<br>00: 8-bit tin<br>01: 16-bit t                                                                           | 0<br>mer1 gating c<br>enable when '<br>enable only w<br>er1 Counter/I<br>ode, Timer1<br>mode, Timer<br>mer1 mode s<br>mer/counter (<br>imer/counter<br>ito-reload tim<br>stops                                                                                       | 0<br>control bit<br>TR1 bit is set<br>thile the INT<br>Fimer select t<br>data increase<br>1 data increa<br>elect<br>TH1) and 5-1<br>ner/counter (7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0<br>1 pin is high<br>bit<br>s at 2 Systen<br>ses at T1 pin<br>pit prescaler                                           | 0<br>and TR1 bit i<br>a clock cycle<br>'s negative ec<br>TL1)                                 | 0<br>is set<br>rate<br>dge                 |          |       |  |
| Reset<br>89h.7<br>89h.6<br>89h.5~4 | 0<br>GATE1: Tin<br>0: Timer1 e<br>1: Timer1 e<br>CT1N: Timer<br>0: Timer m<br>1: Counter<br>TMOD1: Ti<br>00: 8-bit tin<br>01: 16-bit t<br>10: 8-bit au<br>11: Timer1<br>GATE0: Tim                              | 0<br>mer1 gating c<br>enable when '<br>enable only w<br>er1 Counter/I<br>ode, Timer1<br>mode, Timer<br>mer1 mode s<br>mer/counter (<br>imer/counter<br>ito-reload tim<br>stops                                                                                       | 0<br>control bit<br>TR1 bit is set<br>/hile the INT<br>Fimer select h<br>data increase<br>1 data | 0<br>1 pin is high<br>bit<br>s at 2 Systen<br>ses at T1 pin<br>bit prescaler<br>FL1). Reload                           | 0<br>and TR1 bit i<br>a clock cycle<br>'s negative ec<br>TL1)                                 | 0<br>is set<br>rate<br>dge                 |          |       |  |
| Reset<br>89h.7<br>89h.6<br>89h.5~4 | 0<br>GATE1: Tin<br>0: Timer1 e<br>1: Timer1 e<br>CT1N: Timer<br>0: Timer m<br>1: Counter<br>TMOD1: Ti<br>00: 8-bit tin<br>01: 16-bit t<br>10: 8-bit au<br>11: Timer1<br>GATE0: Tin<br>0: Timer0 e               | 0<br>mer1 gating c<br>enable when '<br>enable only w<br>er1 Counter/7<br>ode, Timer1<br>mode, Timer1<br>mode, Timer<br>mer1 mode s<br>mer/counter (<br>imer/counter<br>tto-reload tim<br>stops<br>mer0 gating c                                                      | 0<br>control bit<br>TR1 bit is set<br>/hile the INT<br>fimer select h<br>data increase<br>1 data increase<br>1 data increase<br>elect<br>TH1) and 5-h<br>ner/counter (7<br>control bit<br>TR0 bit is set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0<br>1 pin is high<br>bit<br>s at 2 Systen<br>ses at T1 pin<br>bit prescaler<br>FL1). Reload                           | 0<br>and TR1 bit i<br>a clock cycle<br>'s negative ed<br>(TL1)<br>ed from TH1                 | 0<br>is set<br>rate<br>dge<br>at overflow. |          |       |  |
| Reset<br>89h.7<br>89h.6<br>89h.5~4 | 0<br>GATE1: Tin<br>0: Timer1 e<br>1: Timer1 e<br>CT1N: Time<br>0: Timer m<br>1: Counter<br>TMOD1: Ti<br>00: 8-bit tin<br>01: 16-bit t<br>10: 8-bit au<br>11: Timer1<br>GATE0: Tin<br>0: Timer0 e<br>1: Timer0 e | 0<br>mer1 gating c<br>enable when '<br>enable only w<br>er1 Counter/7<br>ode, Timer1<br>mode, Timer1<br>mode, Timer<br>mer1 mode s<br>ner/counter (<br>imer/counter (<br>imer/counter (<br>to-reload tim<br>stops<br>ner0 gating c<br>enable when '<br>enable only w | 0<br>ontrol bit<br>TR1 bit is set<br>thile the INT<br>Timer select t<br>data increase<br>1 data increase<br>elect<br>TH1) and 5-1<br>ner/counter (T<br>ontrol bit<br>TR0 bit is set<br>thile the INT<br>Timer select t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0<br>1 pin is high<br>bit<br>s at 2 Systen<br>ses at T1 pin<br>bit prescaler<br>(TL1). Reload<br>(D pin is high<br>bit | 0<br>and TR1 bit i<br>i clock cycle<br>'s negative ed<br>TL1)<br>ed from TH1<br>and TR0 bit i | 0<br>is set<br>at overflow.                |          |       |  |

1: Counter mode, Timer0 data increases at T0 pin's negative edge



89h.1~0 **TMOD0:** Timer0 mode select

00: 8-bit timer/counter (TH0) and 5-bit prescaler (TL0)

01: 16-bit timer/counter

10: 8-bit auto-reload timer/counter (TL0). Reloaded from TH0 at overflow.

11: TL0 is an 8-bit timer/counter. TH0 is an 8-bit timer/counter using Timer1's TR1 and TF1 bits.

| SFR 8Ah | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| TL0     |       |       |       | TI    | _0    |       |       |       |
| R/W     |       |       |       | R/    | W     |       |       |       |
| Reset   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

8Ah.7~0 **TL0:** Timer0 data low byte

| SFR 8Bh | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| TL1     |       |       |       | TI    | L1    |       |       |       |
| R/W     |       |       |       | R/    | W     |       |       |       |
| Reset   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

8Bh.7~0 **TL1:** Timer1 data low byte

| SFR 8Ch | Bit 7  | Bit 6                     | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|--------|---------------------------|-------|-------|-------|-------|-------|-------|
| THO     |        |                           |       | TI    | H0    |       |       |       |
| R/W     |        |                           |       | R/    | W     |       |       |       |
| Reset   | 0      | 0                         | 0     | 0     | 0     | 0     | 0     | 0     |
| 001 7 0 | THO. T | $0, 1, \dots, 1, 1, 1, 1$ | 4.    |       |       |       |       |       |

8Ch.7~0 **TH0:** Timer0 data high byte

| SFR 8Dh | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| TH1     |       |       |       | TI    | H1    |       |       |       |
| R/W     |       |       |       | R/    | W     |       |       |       |
| Reset   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

8Dh.7~0 **TH1:** Timer1 data high byte

*Note:* also refer to Section 6 for more information about Timer0/1 Interrupt enable and priority. *Note:* also refer to Section 14 for more information about T0O pin output setting.

## 8.2 Timer2

Timer2 is controlled through the TCON2 register with the low and high bytes of Timer/Counter 2 stored in TL2 and TH2 and the low and high bytes of the Timer2 reload/capture registers stored in RCAP2L and RCAP2H.

| SFR C8h | Bit 7                                                                                                                                                                              | Bit 6        | Bit 5         | Bit 4                                   | Bit 3 | Bit 2 | Bit 1 | Bit 0  |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---------------|-----------------------------------------|-------|-------|-------|--------|
| T2CON   | TF2                                                                                                                                                                                | EXF2         | RCLK          | TCLK                                    | EXEN2 | TR2   | CT2N  | CPRL2N |
| R/W     | R/W                                                                                                                                                                                | R/W          | R/W           | R/W                                     | R/W   | R/W   | R/W   | R/W    |
| Reset   | 0                                                                                                                                                                                  | 0            | 0             | 0                                       | 0     | 0     | 0     | 0      |
| C8h.7   | <b>TF2:</b> Timer2 overflow flag<br>Set by H/W when Timer/Counter 2 overflows unless RCLK=1 or TCLK=1. This bit must be cleared<br>by S/W.                                         |              |               |                                         |       |       |       |        |
| C8h.6   | <b>EXF2:</b> T2EX interrupt pin falling edge flag<br>Set when a capture or a reload is caused by a negative transition on T2EX pin if EXEN2=1. This bit<br>must be cleared by S/W. |              |               |                                         |       |       |       |        |
| C8h.5   |                                                                                                                                                                                    | er1 overflow | as receive cl | oit<br>ock for serial<br>ock for serial |       |       |       |        |



| C8h.4 | TCLK: UART transmit clock control bit                                                               |
|-------|-----------------------------------------------------------------------------------------------------|
|       | 0: Use Timer1 overflow as transmit clock for serial port in mode 1 or 3                             |
|       | 1: Use Timer2 overflow as transmit clock for serial port in mode 1 or 3                             |
| C8h.3 | EXEN2: T2EX pin enable                                                                              |
|       | 0: T2EX pin disable                                                                                 |
|       | 1: T2EX pin enable, it cause a capture or reload when a negative transition on T2EX pin is detected |
|       | if RCLK=TCLK=0                                                                                      |
| C8h.2 | TR2: Timer2 run control                                                                             |
|       | 0: Timer2 stops                                                                                     |
|       | 1: Timer2 runs                                                                                      |
| C8h.1 | CT2N: Timer2 Counter/Timer select bit                                                               |
|       | 0: Timer mode, Timer2 data increases at 2 System clock cycle rate                                   |
|       | 1: Counter mode, Timer2 data increases at T2 pin's negative edge                                    |
| C8h.0 | CPRL2N: Timer2 Capture/Reload control bit                                                           |
|       | 0: Reload mode, auto-reload on Timer2 overflows or negative transitions on T2EX pin if EXEN2=1      |
|       | 1: Capture mode, capture on negative transitions on T2EX pin if EXEN2=1                             |

If RCLK=1 or TCLK=1, CPRL2N is ignored and timer is forced to auto-reload on Timer2 overflow

| SFR CAh | Bit 7                                              | Bit 6           | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|---------|----------------------------------------------------|-----------------|-------|-------|-------|-------|-------|-------|--|--|--|
| RCP2L   |                                                    | RCP2L           |       |       |       |       |       |       |  |  |  |
| R/W     |                                                    | R/W             |       |       |       |       |       |       |  |  |  |
| Reset   | 0                                                  | 0 0 0 0 0 0 0 0 |       |       |       |       |       |       |  |  |  |
| CAh 7~0 | <b>BCP2L</b> : Timer? reload/capture data low byte |                 |       |       |       |       |       |       |  |  |  |

CAh.7~0 **RCP2L:** Timer2 reload/capture data low byte

| SFR CBh | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|--|--|--|
| RCP2H   |       | RCP2H |       |       |       |       |       |       |  |  |  |
| R/W     |       | R/W   |       |       |       |       |       |       |  |  |  |
| Reset   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |  |  |  |
|         |       |       |       |       |       |       |       |       |  |  |  |

CBh.7~0 RCP2H: Timer2 reload/capture data high byte

| SFR CCh | Bit 7                           | Bit 6           | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|---------|---------------------------------|-----------------|-------|-------|-------|-------|-------|-------|--|--|--|
| TL2     |                                 | TL2             |       |       |       |       |       |       |  |  |  |
| R/W     |                                 | R/W             |       |       |       |       |       |       |  |  |  |
| Reset   | 0                               | 0 0 0 0 0 0 0 0 |       |       |       |       |       |       |  |  |  |
| CCh 7 0 | TI 2. Timer 2. data large hasta |                 |       |       |       |       |       |       |  |  |  |

CCh.7~0 **TL2:** Timer2 data low byte

| SFR CDh | Bit 7 | Bit 6           | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |
|---------|-------|-----------------|-------|-------|-------|-------|-------|-------|--|--|
| TH2     |       | TH2             |       |       |       |       |       |       |  |  |
| R/W     |       | R/W             |       |       |       |       |       |       |  |  |
| Reset   | 0     | 0 0 0 0 0 0 0 0 |       |       |       |       |       |       |  |  |

CDh.7~0 **TH2:** Timer2 data high byte

*Note:* also refer to Section 6 for more information about Timer2 Interrupt enable and priority. *Note:* also refer to Section 7 for more information about T2O pin output setting.



## 8.3 T0O and T2O Output Control

This device can generate various frequency waveform pin output (in CMOS push pull format) for Buzzer. The TOO and T2O waveform is divided by Timer0/Timer2 overflow signal. The TOO waveform is Timer0 overflow divided by 64, and T2O waveform is Timer2 overflow divided by 2. User can control their frequency by Timers auto reload speed. Set TOOE and T2OE SFRs can output these waveforms.

| SFR A6h | Bit 7 | Bit 6          | Bit 5          | Bit 4 | Bit 3 | Bit 2   | Bit 1   | Bit 0   |
|---------|-------|----------------|----------------|-------|-------|---------|---------|---------|
| PINMOD  | P5OE0 | <b>PWM0POE</b> | <b>PWM0NOE</b> | T2OE  | T0OE  | PWM1AOE | PWM1BOE | PWM1COE |
| R/W     | R/W   | R/W            | R/W            | R/W   | R/W   | R/W     | R/W     | R/W     |
| Reset   | 0     | 0              | 0              | 0     | 0     | 0       | 0       | 0       |

A6h.4 **T2OE:** Timer2 signal output enable

0: Disable Timer2 overflow divided by 2 output to P1.0 1: Enable Timer2 overflow divided by 2 output to P1.0

A6h.3 **TOOE:** Timer0 signal output enable

0: Disable Timer0 overflow divided by 64 output to P3.4

1: Enable Timer0 overflow divided by 64 output to P3.4



# 9. UART

The UART uses SCON and SBUF SFRs. SCON is the control register, SBUF is the data register. Data is written to SBUF for transmission and SBUF is read to obtain received data. The received data and transmitted data registers are completely independent. In addition to standard 8051's full duplex mode, this chip also provides one wire mode. If the UART1W bit is set, both transmit and receive data use P3.1 pin.

| SFR 87h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| PCON    | SMOD  | _     | —     | —     | GF1   | GF0   | PD    | IDL   |
| R/W     | R/W   | _     | —     | —     | R/W   | R/W   | R/W   | R/W   |
| Reset   | 0     | —     | _     | —     | 0     | 0     | 0     | 0     |

87h.7 **SMOD:** UART double baud rate control bit

0: Disable UART double baud rate

1: Enable UART double baud rate

| SFR <b>94h</b> | Bit 7  | Bit 6  | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------|--------|--------|--------|-------|-------|-------|-------|-------|
| OPTION         | UART1W | MODE3V | WDTPSC |       | ADCKS |       | -     | -     |
| R/W            | R/W    | R/W    | R/W    |       | R/W   |       | -     | -     |
| Reset          | 0      | 0      | 0      | 0     | 0     | 0     | 0     | 0     |

94h.7 **UART1W:** One wire UART mode enable, both TXD/RXD use P3.1 pin

0: Disable one wire UART mode

<sup>1:</sup> Enable one wire UART mode

| SFR 98h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| SCON    | SM0   | SM1   | SM2   | REN   | TB8   | RB8   | TI    | RI    |
| R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

98h.7~6 SM0,SM1: Serial port mode select bit 0,1

00: Mode0: 8 bit shift register, Baud Rate= $F_{SYSCLK}/2$ 

01: Mode1: 8 bit UART, Baud Rate is variable

10: Mode2: 9 bit UART, Baud Rate=F<sub>SYSCLK</sub>/32 or /64

11: Mode3: 9 bit UART, Baud Rate is variable

98h.5 SM2: Serial port mode select bit 2 SM2 enables multiprocessor communication over a single serial line and modifies the above as follows. In Modes 2 & 3, if SM2 is set then the received interrupt will not be generated if the received ninth data bit is 0. In Mode 1, the received interrupt will not be generated unless a valid stop bit is received. In Mode 0, SM2 should be 0. 98h.4 **REN:** UART reception enable 0: Disable reception 1: Enable reception 98h.3 TB8: Transmit Bit 8, the ninth bit to be transmitted in Mode 2 and 3 98h.2 **RB8:** Receive Bit 8, contains the ninth bit that was received in Mode 2 and 3 or the stop bit in Mode 1 if SM2=0 98h.1 TI: Transmit interrupt flag Set by H/W at the end of the eighth bit in Mode 0, or at the beginning of the stop bit in other modes.

<sup>Must be cleared by S/W.
98h.0</sup> **RI:** Receive interrupt flag Set by H/W at the end of the eighth bit in Mode 0, or at the sampling point of the stop bit in other modes. Must be cleared by S/W.



| SFR <b>99h</b> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |
|----------------|-------|-------|-------|-------|-------|-------|-------|-------|--|--|
| SBUF           |       | SBUF  |       |       |       |       |       |       |  |  |
| R/W            |       | R/W   |       |       |       |       |       |       |  |  |
| Reset          | -     | _     | _     | _     | _     | _     | —     | _     |  |  |

<sup>99</sup>h.7~0 **SBUF:** UART transmit and receive data. Transmit data is written to this location and receive data is read from this location, but the paths are independent.

F<sub>SYSCLK</sub> denotes System clock frequency.

- Mode 0: Baud Rate=F<sub>SYSCLK</sub>/2
- Mode 1, 3: if using Timer1 auto reload mode Baud Rate= (SMOD+1) x F<sub>SYSCLK</sub>/ (32x2x (256–TH1))
- Mode 1, 3: if using Timer2 Baud Rate=Timer2 overflow rate/16=F<sub>SYSCLK</sub>/ (32x (65536–RCP2H, RCP2L))
- Mode 2: Baud Rate= (SMOD+1) x F<sub>SYSCLK</sub>/64

*Note:* also refer to Section 6 for more information about UART Interrupt enable and priority. *Note:* also refer to Section 8 for more information about how Timer2 controls UART clock.



# 10. PWMs

The PWM of **F3288** is a simple structure, which switches its output high and low at uniform repeatable intervals. It is widely used to control the brightness of a light, in which case the PWM circuit is used to turn on/off a power line. If the line is repeatedly turned on for 500 ms and turned off for 500 ms per every second, the PWM would have an average output of half of the voltage or run at half speeds or half brightness. The PWM has been used in a wide variety of applications, such as voltage control, current control, motor speed control, light brightness control, and as a voltage inverter.

The **F3288** has two independent PWM modules, PWM0 and PWM1. The PWM can generate a fixed frequency waveform with 1024 duty resolution on the basis of the PWM clock. The PWM clock can select FRC24MHz or  $F_{SYSCLK}$  divided by 1, 2, or 4 by PWM0CKS. A spread LSB technique allows PWM to run its frequency at the "PWM clock divided by 256" instead of at the "PWM clock divided by 1024", which means the PWM is four times faster than normal. The advantage of a higher PWM frequency is that the post RC filter can transform the PWM signal to a more stable DC voltage level. Because two PWMs have the same structure, the following describes only the functions of the PWM0.

## 10.1 PWM0

The PWM0 duty cycle can be changed by writing to PWM0DH (9Bh) and PWM0DL (Ach.7~6). The PWM0 output signal resets to a low level whenever the 8-bit base counter matches the 8-bit MSB of the PWM0 duty register PWM0DH. When the base counter rolls over, the 2-bit LSB of the PWM0 duty register PWM0DL decides whether to set the PWM0 output signal high immediately or set it high after one clock cycle delay. The PWM0 period can be set by writing the period value to the PWM0PRD (9Ah) register.





The PWM0 has two output pins and can be configured to use P1.4 and P5.0 with four different modes. The edges of the PWM0 pulse can be separated with 16 different non-overlap clocks time intervals. The PWM0 mode and non-overlap clocks time intervals are selected by PWM0CON (A7h). The default output is PWM Mode0 and the zero non-overlap clocks time intervals. User can select one of the pins as an output or let PWM0 signal output simultaneously on two output pins. The PWM0POE bit is used to select the output for PWM0P (P1.4), and the PWM0NOE bit is used to select the output for PWM0P (P1.4), and the PWM0NOE bit is used to select the output for PWM0P (P1.4), and the PWM0 control bit. If both bits are cleared, the PWM0 will be cleared and stopped, otherwise the PWM0 is running. The CLRPWM0 bit has the same function. When CLRPWM0 bit is set, the PWM0 will be cleared and held, otherwise the PWM0 is running.





The PWM0 offers 2-bit of an extension data register PWM0DL to provide an extension of the cycle of the PWM output. The extension cycle involves the placement of one extra clock period at specific intervals.





# 10.2 PWM1

The PWM1 has three outputs (PWM1A, PWM1B and PWM1C). These PWM1 outputs share the same period setting PWM1PRD (9Ch) but with the different duty setting PWM1ADTY, PWM1BDTY and PWM1CDTY.



| SFR 9Ah        | Bit 7 | Bit 6   | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|----------------|-------|---------|-------|-------|-------|-------|-------|-------|--|--|--|
| <b>PWM0PRD</b> |       | PWM0PRD |       |       |       |       |       |       |  |  |  |
| R/W            |       | R/W     |       |       |       |       |       |       |  |  |  |
| Reset          | 1     | 1       | 1     | 1     | 1     | 1     | 1     | 1     |  |  |  |

9Ah.7~0 PWM0PRD: PWM0 period

| SFR 9Bh       | Bit 7 | Bit 6  | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|---------------|-------|--------|-------|-------|-------|-------|-------|-------|--|--|--|
| <b>PWM0DH</b> |       | PWM0DH |       |       |       |       |       |       |  |  |  |
| R/W           |       | R/W    |       |       |       |       |       |       |  |  |  |
| Reset         | 1     | 0      | 0     | 0     | 0     | 0     | 0     | 0     |  |  |  |

9Bh.7~0 **PWM0DH:** PWM0 duty high byte

The PWM0 output signal is reset to a low level whenever the 8-bit base counter matches the 8-bit PWM0DH.



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

9Ch.7~0 **PWM1PRD:** PWM1 period

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

9Dh.7~0 **PWM1ADH:** PWM1A duty high byte

The PWM1A output signal is reset to a low level whenever the 8-bit base counter matches the 8-bit PWM1ADH.

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

9Eh.7~0 **PWM1BDH:** PWM1B duty high byte

The PWM1B output signal is reset to a low level whenever the 8-bit base counter matches the 8-bit PWM1BDH.

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

9Fh.7~0 **PWM1CDH:** PWM1C duty high byte

The PWM1C output signal is reset to a low level whenever the 8-bit base counter matches the 8-bit PWM1CDH.

| SFR A1h       | Bit 7   | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2 | Bit 1 | Bit 0 |
|---------------|---------|-------|-------|-------|---------|-------|-------|-------|
| <b>PWMCKS</b> | PWM1CKS |       | -     | -     | PWM0CKS |       | -     | -     |
| R/W           | R/      | R/W   |       | -     | R/W     |       | -     | -     |
| Reset         | 1       | 0     | -     | -     | 1       | 0     | -     | -     |

A1h.7~6 **PWM1CKS:** PWM1 clock source

00:  $F_{SYSCLK}/4$ 

01: F<sub>SYSCLK</sub>/2

10: F<sub>SYSCLK</sub>

11: FRC24MHz

A1h.3~2 **PWM0CKS:** PWM0 clock source

00:  $F_{SYSCLK}/4$ 

01: F<sub>SYSCLK</sub>/2

10: F<sub>SYSCLK</sub> 11: FRC24MHz

11: FRC24MHZ



| SFR A6h | Bit 7   | Bit 6          | Bit 5          | Bit 4 | Bit 3 | Bit 2   | Bit 1   | Bit 0   |
|---------|---------|----------------|----------------|-------|-------|---------|---------|---------|
| PINMOD  | P5OE0   | <b>PWM0POE</b> | PWM0NOE        | T2OE  | TOOE  | PWM1AOE | PWM1BOE | PWM1COE |
| R/W     | R/W     | R/W            | R/W            | R/W   | R/W   | R/W     | R/W     | R/W     |
| Reset   | 0       | 0              | 0              | 0     | 0     | 0       | 0       | 0       |
| A6h6    | DWMADAE | DWMOD at       | anal output of | noblo |       |         |         |         |

| Aon.o | <b>PWMOPOE:</b> PWMOP signal output enable |
|-------|--------------------------------------------|
|       | 0: Disable PWM0P signal output to P1.4     |
|       | 1: Enable PWM0P signal output to P1.4      |
| A6h.5 | <b>PWM0NOE:</b> PWM0N signal output enable |
|       | 0: Disable PWM0N signal output to P5.0     |
|       | 1: Enable PWM0N signal output to P5.0      |
| A6h.2 | <b>PWM1AOE:</b> PWM1A signal output enable |
|       | 0: Disable PWM1A signal output to P1.5     |
|       | 1: Enable PWM1A signal output to P1.5      |
| A6h.1 | <b>PWM1BOE:</b> PWM1B signal output enable |
|       | 0: Disable PWM1B signal output to P1.6     |
|       | 1: Enable PWM1B signal output to P1.6      |
| A6h.0 | <b>PWM1COE:</b> PWM1C signal output enable |
|       | 0: Disable PWM1C signal output to P1.7     |
|       | 1: Enable PWM1C signal output to P1.7      |
|       |                                            |

| SFR A7h | Bit 7 | Bit 6 | Bit 5    | Bit 4 | Bit 3    | Bit 2 | Bit 1 | Bit 0 |  |
|---------|-------|-------|----------|-------|----------|-------|-------|-------|--|
| PWM0CON | -     | -     | PWM0MODE |       | PWM0NOVT |       |       |       |  |
| R/W     | -     | -     | R/       | W     | R/W      |       |       |       |  |
| Reset   | -     | -     | 0        |       | 0        |       |       |       |  |

A7h.5~4 **PWM0MODE:** PWM0 differential output mode

00: Mode 0

01: Mode 1

10: Mode 2

11: Mode 3

A7h.3~0 **PWM0NOVT:** PWM0 non-overlap time (dead time) select

0000: 0 pwm0 clock (original PWM0) 0001: 1 pwm0 clock

0010: 2 pwm0 clock

0010: 2 pwn0 clock

0100: 4 pwm0 clock

0100: 4 pwillo clock 0101: 5 pwm0 clock

0110: 6 pwm0 clock

0111: 7 pwm0 clock

1000: 8 pwm0 clock

1001: 9 pwm0 clock

1010: 10 pwm0 clock

1011: 11 pwm0 clock

1100: 12 pwm0 clock

1101: 13 pwm0 clock

1110: 14 pwm0 clock 1111: 16 pwm0 clock

| SFR ACh | Bit 7 | Bit 6 | Bit 5   | Bit 4 | Bit 3   | Bit 2 | Bit 1   | Bit 0 |
|---------|-------|-------|---------|-------|---------|-------|---------|-------|
| PWMDL   | PWN   | 10DL  | PWM1ADL |       | PWM1BDL |       | PWM1CDL |       |
| R/W     | R/    | R/W   |         | R/W   |         | W     | R/      | W     |
| Reset   | 0     | 0     | 0       | 0     | 0       | 0     | 0       | 0     |

ACh.7~6 **PWM0DL:** PWM0 duty low byte

When the base counter rolls over, the PWM0DL decides whether to set the PWM0 output signal high immediately or set it high after one clock cycle delay



ACh.5~4 **PWM1ADL:** PWM1A duty low byte

When the base counter rolls over, the PWM1ADL decides whether to set the PWM1A output signal high immediately or set it high after one clock cycle delay

#### ACh.3~2 **PWM1BDL:** PWM1B duty low byte

When the base counter rolls over, the PWM1BDL decides whether to set the PWM1B output signal high immediately or set it high after one clock cycle delay

#### ACh.7~6 **PWM1CDL:** PWM1C duty low byte

When the base counter rolls over, the PWM1CDL decides whether to set the PWM1C output signal high immediately or set it high after one clock cycle delay

| SFR F8h | Bit 7  | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2  | Bit 1 | Bit 0 |
|---------|--------|-------|-------|-------|---------|--------|-------|-------|
| AUX1    | CLRWDT | WD    | DTE   | ADSOC | CLRPWM0 | PDADOP | BOOTV | DPSEL |
| R/W     | R/W    | R/    | W     | R/W   | R/W     | R/W    | R/W   | R/W   |
| Reset   | 0      | 0     | 0     | 0     | 0       | 0      | 0     | 0     |

F8h.3 **CLRPWM0:** PWM0 clear enable

0: PWM0 is running

1: PWM0 is cleared and held

*Note:* also refer to Section 7 for more information about PWM pin output setting.



# 11. ADC

The **F3288** offers a 12-bit ADC consisting of a 14-channel analog input multiplexer, control register, clock generator, 12-bit successive approximation register, and output data register. To use the ADC, set the ADCKS bit first to choose a proper ADC clock frequency, which must be less than 1 MHz. Then, launch the ADC conversion by setting the ADSOC bit, and H/W will automatic clear it at the end of the conversion. After the end of the conversion, H/W will set the ADIF bit and generate an interrupt if an ADC interrupt is enabled. The ADIF bit can be cleared by writing 0 to this bit or 1 to the ADSOC bit. The analog input level must remain within the range from  $V_{SS}$  to  $V_{DDIO}$ .





## 11.1 ADC Channels

The 12-bit ADC has a total of 12 channels, designated AD0~AD11, VBG, VBGO and VSS. The ADC channels are connected to the analog input pins via the analog switch multiplexer. The analog switch multiplexer is controlled by the ADCHS register. **F3288** offers up to 12 analog input pins, designated AD0~AD11. In addition, there are two analog input pins for voltage reference connections. When ADCHS is set to 1110b, the analog input will connect to V<sub>SS</sub>, and when ADCHS is set to 1100b, the analog input will connect to VBG, and when ADCHS is set to 1101b, the analog input will connect to VBGO. VBG is an internal voltage reference at 1.25V, and VBGO is also the internal voltage reference at 1.25V with OP driving. If the PDADOP =0, the analog switch multiplexer output will go through the rail to rail OP-amp otherwise the multiplexer output will bypass the rail to rail OP-amp and into the ADC.





#### **11.2** ADC Conversion Time

The conversion time is the time required for the ADC to convert the voltage. The ADC requires two ADC clock cycles to convert each bit and several clock cycles to sample and hold the input voltage. A total of 50 ADC clock cycles are required to perform the complete conversion. When the conversion time is complete, the ADIF interrupt flag is set by H/W, and the result is loaded into the ADCDH and ADCDL registers of the 12-bit A/D result.



| SFR <b>94h</b> | Bit 7  | Bit 6  | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------|--------|--------|--------|-------|-------|-------|-------|-------|
| OPTION         | UART1W | MODE3V | WDTPSC |       | ADCKS |       | -     |       |
| R/W            | R/W    | R/W    | R/     | W     | R/W   |       | -     |       |
| Reset          | 0      | 0      | 0      | 0     | 0     | 0     | -     | -     |

94h.3~2 ADCKS: ADC clock rate select

- 00: F<sub>SYSCLK</sub>/32 01: F<sub>SYSCLK</sub>/16
- $10: F_{SYSCLK}/8$
- 11: F<sub>SYSCLK</sub>/4

| SFR <b>95h</b> | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| INTFLG         | LVD   | —     | -     | ADIF  | —     | IE2   | P1IF  | -     |
| R/W            | R     | _     | -     | R/W   | _     | R/W   | R/W   | -     |
| Reset          |       | _     | -     | 0     | _     | 0     | 0     | -     |
|                |       | . ~   |       |       |       |       |       |       |

95h.4 **ADIF:** ADC interrupt flag

Set by H/W at the end of conversion. S/W writes EFh to INTFLG or sets the ADSOC bit to clear this flag.

| SFR AAh   | Bit 7   | Bit 6         | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----------|---------|---------------|-------|-------|-------|-------|-------|-------|
| ADCDL     |         | ADO           | CDL   |       | -     |       |       |       |
| R/W       |         | Ι             | R     |       |       |       | -     |       |
| Reset     | -       | _             | —     | _     |       |       | -     |       |
| 1 1 h 7 1 | ADCDL A | DC data hit 2 | Δ     |       |       |       |       |       |

AAh.7~4 ADCDL: ADC data bit 3~0

| SFR ABh | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|--|--|
| ADCDH   |       | ADCDH |       |       |       |       |       |       |  |  |
| R/W     |       | R     |       |       |       |       |       |       |  |  |
| Reset   | -     |       |       |       |       |       |       |       |  |  |



#### ABh.7~0 ADCDH: ADC data bit 11~4

| SFR AEh | Bit 7     | Bit 6         | Bit 5        | Bit 4        | Bit 3        | Bit 2 | Bit 1 | Bit 0 |
|---------|-----------|---------------|--------------|--------------|--------------|-------|-------|-------|
| CHSEL   |           | AD            | CHS          |              |              |       | -     |       |
| R/W     |           | R             | W            |              |              |       | _     |       |
| Reset   | 1         | 1             | 1            | 1            | -            | -     | -     | -     |
| AEh.7~4 | ADCHS: AI | DC channel s  | elect        |              |              |       |       |       |
|         | 0000: ADC | CO (P1.0)     |              |              |              |       |       |       |
|         | 0001: ADC | C1 (P1.1)     |              |              |              |       |       |       |
|         | 0010: ADC | C2 (P1.4)     |              |              |              |       |       |       |
|         | 0011: ADC | C3 (P1.5)     |              |              |              |       |       |       |
|         | 0100: ADC | 24 (P1.6)     |              |              |              |       |       |       |
|         | 0101: ADC | C5 (P1.7)     |              |              |              |       |       |       |
|         | 0110: ADC | C6 (P4.0)     |              |              |              |       |       |       |
|         | 0111: ADC | C7 (P4.1)     |              |              |              |       |       |       |
|         | 1000: ADC | C8 (P4.2)     |              |              |              |       |       |       |
|         | 1001: ADC | C9 (P4.3)     |              |              |              |       |       |       |
|         | 1010: ADC | C10(P3.2)     |              |              |              |       |       |       |
|         | 1011: ADC | C11(P3.3)     |              |              |              |       |       |       |
|         |           |               |              | nce voltage) |              |       |       |       |
|         | 1101: VBG | GO(internal B | andgap refer | ence voltage | with OP driv | ving) |       |       |
|         | 1110: VSS |               |              |              |              |       |       |       |

*Note:* FW must turn off Bandgap to obtain Tiny Current (ADCHS  $\neq$  0b1100/0b1101)

| SFR F8h | Bit 7  | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2  | Bit 1 | Bit 0 |
|---------|--------|-------|-------|-------|---------|--------|-------|-------|
| AUX1    | CLRWDT | WDTE  |       | ADSOC | CLRPWM0 | PDADOP | BOOTV | DPSEL |
| R/W     | R/W    | R/    | R/W   |       | R/W     | R/W    | R/W   | R/W   |
| Reset   | 0      | 0     |       | 0     | 0       | 0      |       | 0     |

F8h.4 **ADSOC:** Start ADC conversion

Set the ADSOC bit to start ADC conversion, and the ADSOC bit will be cleared by H/W at the end of conversion. S/W can also write 0 to clear this flag.

F8h.2 **PDADOP:** ADOP power down control

0: multiplexer output go through the R-to-R OP-amp

1: multiplexer output bypass the R-to-R OP-amp

*Note:* also refer to Section 6 for more information about ADC Interrupt enable and priority. *Note:* also refer to Section 7 for more information about ADC pin input setting.



# **12. USB Interface**

The USB engine includes the Serial Interface Engine (SIE), the full-speed USB I/O transceiver. The SIE block performs most of the USB interface function with only minimum support from F/W. There are 5 endpoints supported. Endpoint 0 is used to receive and transmit control (including SETUP) packets. Endpoint 1 and endpoint 2 are used for interrupt transfer. Endpoint 3 and endpoint 4 are used for bulk transfer.

The USB SIE handles the following USB bus activity independently:

- 1. Bit stuffing/unstuffing
- 2. CRC generation/checking
- 3. ACK/NAK
- 4. TOKEN type identification
- 5. Address checking

F/W handles the following tasks:

- 1. Coordinate enumeration by responding to SETUP packets
- 2. Fill and empty the FIFOs
- 3. Suspend/Resume coordination
- 4. Verify and select DATA toggle values

## 12.1 USB Device Address

The USB device address register FUNADR stores the device's address. This register is reset to all 0 after chip reset. F/W must write this register a valid value after the USB enumeration process. F/W also must to set the U2IE (A9h.5) and USB2IE (DBh.7~2) or U1IE (A9h.4) and USB1IE (DAh.7~0) to enable all of the related USB interrupt described below.

## 12.2 Endpoint 0 Receive (SET0/OUT0)

After receiving a SETUP packet and placing the data into the Endpoint 0 setup receive FIFO (SET0FIFO), **F3288** updates the Endpoint 0 status registers to record the receive status and then generates an Endpoint 0 setup receive interrupt (SET0I). The received data are always stored into SET0FIFO for DATA packets following SETUP token.

If received is a valid OUT packet, then generates Endpoint 0 out receive interrupt (OUT0I), data are stored into OUT0FIFO, F/W can read the status register USBCTRL, TX0CTRL and RC0REG for the recent transfer information, which includes the data byte count (OUT0CNT), packet toggle bit (RC0TGL) and data valid flag (RC0ERR). The data following an OUT token is written into OUT0FIFO and the OUT0CNT is updated unless Endpoint 0 STALL (EP0STALL) is set or Endpoint 0 receive ready (OUT0RDY) is not cleared. The data following an OUT token is written into the OUT0FIFO, and the OUT0CNT is updated unless Endpoint 0 STALL (EP0STALL) is set or Endpoint 0 receive ready (OUT0RDY) is cleared. The SIE clears the OUT0RDY automatically and generates OUT0I interrupt when the OUT0CNT or OUT0FIFO is updated. As long as the OUT0RDY is cleared, SIE keeps responding NAK to Host's Endpoint 0 OUT packet request. F/W should set the OUT0RDY flag after the OUT0I interrupt is asserted and OUT0FIFO is read out.



## **12.3 Endpoint 0 Transmit (TX0)**

After detecting a valid Endpoint 0 IN token, **F3288** automatically transmits the data pre-stored in the Endpoint 0 transmit FIFO (TX0FIFO) to the USB bus if the Endpoint 0 transmit ready flag (TX0RDY) is set and the EP0STALL is cleared. The number of byte to be transmitted depends on the Endpoint 0 transmit byte count register (TX0CNT). The DATA0/1 token to be transmitted depends on the Endpoint 0 transmit toggle control bit (TX0TGL). After the TX0FIFO is updated, TX0RDY should be set to 1. This enables the **F3288** to respond to an Endpoint 0 IN packet. TX0RDY is cleared and an Endpoint 0 transmit interrupt (TX0I) is generated once the USB host acknowledges the data transmission. The interrupt service routine can check TX0RDY to confirm that the data transfer is successful.

# 12.4 Endpoint 1/2 Transmit (TX1/2)

Endpoint 1 and Endpoint 2 are capable of transmit only. These endpoints are enabled when the Endpoint 1 / Endpoint 2 configuration control bit (EP1CFG/EP2CFG) is set. After detecting a valid Endpoint 1/2 IN token, **F3288** automatically transmits the data pre-stored in the Endpoint 1/2 transmit FIFO (TX1FIFO/TX2FIFO) to the USB bus if the Endpoint 1/2 transmit ready flag (TX1RDY/TX2RDY) is set and the EP1STALL/EP2STALL is cleared. The number of byte to be transmitted depends on the Endpoint 3/4 transmit byte count register (TX1CNT/TX2CNT). The DATA0/1 token to be transmitted depends on the Endpoint 1/2 transmit toggle control bit (TX1TGL/TX2TGL). After the TX1FIFO/TX2FIFO is updated, TX1RDY/TX2RDY should be set to 1. This enables the **F3288** to respond to an Endpoint 1/2 IN packet. TX1RDY/TX2RDY is cleared and an Endpoint 1/2 transmit interrupt (TX1I/TX2I) is generated once the USB host acknowledges the data transmission. The interrupt service routine can check TX1RDY/TX2RDY to confirm that the data transfer is successful.

## 12.5 Endpoint 3 Transmit (TX3)

Endpoint 3 is capable of transmit only. Register TX3CTRL, TX3CNT and XRAMCTRL are used to control this endpoint. Endpoint 3 is enabled when the configuration control bit (EP3CFG) is set. To properly use this endpoint, F/W must set XRAM1USB=1 or XRAM2USB=1 to assign exactly one XRAM (XRAM1 or XRAM2) as USB Bulk In buffer. Once this endpoint is enabled, F/W should set the Toggle bit (TX3TGL) and set the transmit byte count register (TX3CNT). After detecting a valid Endpoint 3 IN token, **F3288** automatically transmits the data pre-stored in the Endpoint 3 XRAM buffer to the USB bus if the Endpoint 3 transmits ready flag (TX3RDY) is set and the EP3STALL is cleared. The number of byte to be transmitted depends on the Endpoint 3 transmit toggle control bit (TX3TGL). Once the USB host acknowledges the data transmission, Endpoint 3 transmit interrupt (TX3I) is generated and the TX3RDY will be cleared. The interrupt service routine can check TX3RDY to confirm that the data transfer is successful.

## 12.6 USB Endpoint 4 Receive (RC4)

Endpoint 4 is capable of receive only. Register RC4CTRL, RC4CNTand XRAMCTRL are used to control this endpoint. This endpoint is enable when Endpoint 4 configured control bit (EP4CFG) is set. To properly use this endpoint, F/W must set XRAM1USB=1 or XRAM2USB=1 to assign exactly one XRAM (XRAM1 or XRAM2) as USB Bulk out buffer. After detecting a valid Endpoint 4 OUT token, the **F3288** automatically stores the bulk out data into the specified Bulk out buffer and updates RC4CNT if the Endpoint 4 receiving ready flag (RC4RDY) is set and the EP4STALL is cleared. The DATA0/DATA1 token to be checked is toggled by F/W. When an Endpoint 4 receive interrupt (RC4I) is generated, the RC4RDY is cleared. During the packet transfer stage, if data are used to check error, the result will be responded on RC4ERR.



## 12.7 USB Control and Status

Other USB control bits include the USB enable (USBE), Suspend (SUSPND), Resume output (RSMO, Device Resistor (DEVICE\_R), and corresponding interrupt enable bits. The DEVICE\_R is set to enable DP pull-up resistor. Other USB status flag includes the USB reset interrupt (RSTI), Resume input interrupt (RSMI), and USB Suspend interrupt (SUSPI).

#### 12.8 Suspend and Resume

Once the Suspend condition is asserted, F/W can set the SUSP bit to save the power consumption of USB Engine. F/W can further save the device power by forcing the CPU to go into the Power Down Mode. In the Power Down mode CPU can be waken-up by the trigger of any enabled interrupt's source or by USB bus reset or by USB bus resume. The **F3288** sends Resume signaling to USB bus when SUSPND =1 and RSMO=1.

| SFR A9h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| INTE1   | -     | -     | U2IE  | U1IE  | ADIE  | EX2   | P1IE  | SPAIE |
| R/W     | -     | -     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset   | -     | -     | 0     | 0     | 0     | 0     | 0     | 0     |

A9h.5**U2IE:** USB2 interrupt enable<br/>0: Disable USB2 interrupt<br/>1: Enable USB2 interruptA9h.4**U1IE:** USB1 interrupt enable

0: Disable USB1 interrupt

1: Enable USB1 interrupt

| SFR C1h | Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |
|---------|-------|-------|--------|-------|-------|-------|-------|-------|--|--|
| USBADR  | USBE  |       | FUNADR |       |       |       |       |       |  |  |
| R/W     | R/W   |       | R/W    |       |       |       |       |       |  |  |
| Reset   | 0     | 0     | 0      | 0     | 0     | 0     | 0     | 0     |  |  |

C1h.7 **USBE:** USB function enable bit

0: Disable P1.2/P1.3 as USB DP/DM pin

1: Enable P1.2/P1.3 as USB DP/DM pin

C1h.6~0 FUNADR: USB Function Address

| SFR C2h | Bit 7 | Bit 6                                                               | Bit 5                                                                       | Bit 4           | Bit 3          | Bit 2          | Bit 1 | Bit 0 |  |  |  |  |
|---------|-------|---------------------------------------------------------------------|-----------------------------------------------------------------------------|-----------------|----------------|----------------|-------|-------|--|--|--|--|
| USB1I   | SET0I | OUT0I                                                               | TX0I                                                                        | TX1I            | TX2I           | SUSPI          | TX3I  | RC4I  |  |  |  |  |
| R/W     | R/W   | R/W                                                                 | R/W                                                                         | R/W             | R/W            | R/W            | R/W   | R/W   |  |  |  |  |
| Reset   | 0     | 0                                                                   | 0                                                                           | 0               | 0              | 0              | 0     | 0     |  |  |  |  |
| C2h.7   | SETOI | : USB Endp                                                          | USB Endpoint 0 SET0 Receive Interrupt flag; write 0 to clear flag           |                 |                |                |       |       |  |  |  |  |
| C2h.6   | OUT0I | : USB Endpoint 0 OUT0 Receive Interrupt flag; write 0 to clear flag |                                                                             |                 |                |                |       |       |  |  |  |  |
| C2h.5   | TX0I  | : USB Endpo                                                         | : USB Endpoint 0 Transmit Interrupt flag; write 0 to clear flag             |                 |                |                |       |       |  |  |  |  |
| C2h.4   | TX1I  | : USB Endpo                                                         | oint 1 Transn                                                               | nit Interrupt f | lag; write 0 t | o clear flag   |       |       |  |  |  |  |
| C2h.3   | TX2I  | : USB Endpo                                                         | oint 2 Transn                                                               | nit Interrupt f | lag; write 0 t | o clear flag   |       |       |  |  |  |  |
| C2h.2   | SUSPI | : USB Suspe                                                         | and Interrupt                                                               | flag; write 0   | to clear flag  |                |       |       |  |  |  |  |
| C2h.1   | TX3I  | : USB Endp                                                          | <b>:</b> USB Endpoint 3 Bulk Transmit Interrupt flag; write 0 to clear flag |                 |                |                |       |       |  |  |  |  |
| C2h.0   | RC4I  | : USB Endp                                                          | oint 4 Bulk R                                                               | eceive Interr   | upt flag; writ | e 0 to clear f | lag   |       |  |  |  |  |



|                |                |                                                                                  |                 |                 |                 |              |            | 1     |  |  |  |  |
|----------------|----------------|----------------------------------------------------------------------------------|-----------------|-----------------|-----------------|--------------|------------|-------|--|--|--|--|
| SFR C3h        | Bit 7          | Bit 6                                                                            | Bit 5           | Bit 4           | Bit 3           | Bit 2        | Bit 1      | Bit 0 |  |  |  |  |
| USB2I          | VDD5VRI        | RSTI                                                                             | RSMI            | KBDI            | PD_TXI          | PD_RCI       | -          | -     |  |  |  |  |
| R/W            | R/W            | R/W                                                                              | R/W             | R/W             | R/W             | R/W          | -          | -     |  |  |  |  |
| Reset          | 0              | 0                                                                                | 0               | 0               | 0               | 0            | -          | -     |  |  |  |  |
| C3h.7          | VDD5VRI        | : VDD5V Ri                                                                       | ise Interrupt f | lag; write 0 t  | o clear flag    |              |            |       |  |  |  |  |
| C3h.6          | RSTI           | : USB Bus R                                                                      | Reset Interrup  | t flag; write ( | ) to clear flag |              |            |       |  |  |  |  |
| C3h.5          | RSMI           | SMI : USB Resume Interrupt flag; write 0 to clear flag                           |                 |                 |                 |              |            |       |  |  |  |  |
| C3h.3          | PD_TXI         |                                                                                  |                 |                 |                 |              |            |       |  |  |  |  |
| C3h.2          | PD_RCI         |                                                                                  |                 |                 |                 |              |            |       |  |  |  |  |
|                |                |                                                                                  |                 |                 |                 |              |            |       |  |  |  |  |
| SFR C4h        | Bit 7          | Bit 6                                                                            | Bit 5           | Bit 4           | Bit 3           | Bit 2        | Bit 1      | Bit 0 |  |  |  |  |
| USBCTRL        | SUSPND         | RSMO                                                                             | EP1CFG          | EP2CFG          | DEVICE_R        |              | -          | -     |  |  |  |  |
| R/W            | R/W            | R/W                                                                              | R/W             | R/W             | R/W             | R/W          | _          | -     |  |  |  |  |
| Reset          | 0              | 0                                                                                | 0               | 0               | 0               | 0            | -          | -     |  |  |  |  |
| C4h.7          |                | ÷                                                                                |                 | Ŭ               | Ű               | Ű            |            |       |  |  |  |  |
| CTII./         |                | SUSPND: USB Suspend bit<br>F/W set high to force USB interface into suspend mode |                 |                 |                 |              |            |       |  |  |  |  |
| C4h.6          | e              | F/W set high to force USB interface into suspend mode                            |                 |                 |                 |              |            |       |  |  |  |  |
| C4II.0         |                | <b>RSMO:</b> USB Resume bit                                                      |                 |                 |                 |              |            |       |  |  |  |  |
| C4h.5          | <b>EP1CFG:</b> | F/W set high to force USB interface send RESUME signal in suspend mode           |                 |                 |                 |              |            |       |  |  |  |  |
| C4II.3         |                | t Endnoint 1                                                                     | configed        |                 |                 |              |            |       |  |  |  |  |
| C4h.4          | EP2CFG:        | Write 1to set Endpoint 1 configed                                                |                 |                 |                 |              |            |       |  |  |  |  |
| C411.4         |                | t Endpoint 2                                                                     | configed        |                 |                 |              |            |       |  |  |  |  |
| C4h.3          | DEVICE_R       |                                                                                  |                 | onabla bit      |                 |              |            |       |  |  |  |  |
| C4II.5         |                | ill-up resisto                                                                   |                 | chable bit      |                 |              |            |       |  |  |  |  |
|                |                | ll-up resistor                                                                   |                 |                 |                 |              |            |       |  |  |  |  |
| C4h.2          |                |                                                                                  | ready for rec   | eive control    | hit             |              |            |       |  |  |  |  |
| 0 111.2        |                |                                                                                  | y for receive   |                 |                 |              |            |       |  |  |  |  |
|                |                |                                                                                  |                 |                 | cleared by H    | /W while OU  | T0I occurs |       |  |  |  |  |
|                | 1              |                                                                                  |                 | ,               | 5               |              |            |       |  |  |  |  |
| SFR C5h        | Bit 7          | Bit 6                                                                            | Bit 5           | Bit 4           | Bit 3           | Bit 2        | Bit 1      | Bit 0 |  |  |  |  |
| <b>FX0CTRL</b> | TX0RDY         | TX0TGL                                                                           | <b>EPOSTALL</b> | <b>IN0STALL</b> |                 | TX00         |            | ł     |  |  |  |  |
| R/W            | R/W            | R/W                                                                              | R/W             | R/W             |                 | R/           |            |       |  |  |  |  |
| Reset          | 0              | 0                                                                                | 0               | 0               | 0               | 0            | 0          | 0     |  |  |  |  |
| C5h.7          | TX0RDY: E      |                                                                                  |                 |                 |                 | Ű            | 0          | Ű     |  |  |  |  |
| 0.511.7        |                |                                                                                  | y for IN pack   |                 | li              |              |            |       |  |  |  |  |
|                |                |                                                                                  |                 |                 | leared by H/V   | W while TX0  | occurs     |       |  |  |  |  |
| C5h.6          | TX0TGL: E      | •                                                                                |                 |                 |                 | v while 1710 | loceuis    |       |  |  |  |  |
| 2011.0         | 0: DATA0       |                                                                                  |                 | г·              |                 |              |            |       |  |  |  |  |
|                | 1: DATA1.      |                                                                                  |                 |                 |                 |              |            |       |  |  |  |  |
| C5h.5          | EPOSTALL       | :                                                                                |                 |                 |                 |              |            |       |  |  |  |  |
| 2011.0         |                |                                                                                  | all OUT/IN p    | acket           |                 |              |            |       |  |  |  |  |
|                |                |                                                                                  | OUT/IN packe    |                 |                 |              |            |       |  |  |  |  |
| C5h.4          | INOSTALL:      |                                                                                  | c i, ii, puek   |                 |                 |              |            |       |  |  |  |  |
| COII. T        |                |                                                                                  | all IN packet   |                 |                 |              |            |       |  |  |  |  |
|                |                | 0 will stall I                                                                   |                 |                 |                 |              |            |       |  |  |  |  |
| C5h.3~0        |                |                                                                                  | ansmit byte co  | nunt            |                 |              |            |       |  |  |  |  |
| C311.3~0       |                |                                                                                  | e count for IN  |                 |                 |              |            |       |  |  |  |  |
|                | 17 w Set ule   | aansniit Oytt                                                                    |                 | o packet        |                 |              |            |       |  |  |  |  |
|                | D: 7           | D' f                                                                             | D: -            | D: 4            | Dia             | DIA          | D          | DIA   |  |  |  |  |
| SFR C6h        | Bit 7          | Bit 6                                                                            | Bit 5           | Bit 4           | Bit 3           | Bit 2        | Bit 1      | Bit 0 |  |  |  |  |

| SFR C6h | Bit 7  | Bit 6  | Bit 5           | Bit 4 | Bit 3  | Bit 2 | Bit 1 | Bit 0 |  |
|---------|--------|--------|-----------------|-------|--------|-------|-------|-------|--|
| TX1CTRL | TX1RDY | TX1TGL | <b>EP1STALL</b> | -     | TX1CNT |       |       |       |  |
| R/W     | R/W    | R/W    | R/W             | -     | R/W    |       |       |       |  |
| Reset   | 0      | 0      | 0               | -     | 0      | 0     | 0     | 0     |  |

DS-TM52F3288\_E



| C6h.7   | <b>TX1RDY:</b> Endpoint 1 ready for transmit control bit 0: Endpoint 1 is not ready for IN packet. |
|---------|----------------------------------------------------------------------------------------------------|
|         | 1: Endpoint 1 is ready for transmit to USB Host; cleared by H/W while TX1I occurs                  |
| C6h.6   | <b>TX1TGL:</b> Endpoint 1 transmit data type                                                       |
|         | 0: DATA0.                                                                                          |
|         | 1: DATA1.                                                                                          |
| C6h.5   | EP1STALL:                                                                                          |
|         | 0: Endpoint 1 will not stall IN packet                                                             |
|         | 1: Endpoint 1 will stall IN packet                                                                 |
| C6h.3~0 | TX1CNT: Endpoint 1 transmit byte count                                                             |

F/W set the transmit byte count for IN1 packet

| SFR C7h | Bit 7  | Bit 6  | Bit 5    | Bit 4 | Bit 3  | Bit 2 | Bit 1 | Bit 0 |
|---------|--------|--------|----------|-------|--------|-------|-------|-------|
| TX2CTRL | TX2RDY | TX2TGL | EP2STALL | -     | TX2CNT |       |       |       |
| R/W     | R/W    | R/W    | R/W      | -     | R/W    |       |       |       |
| Reset   | 0      | 0      | 0        | -     |        |       |       |       |

| C7h.7 | <b>TX2RDY:</b> Endpoint 2 ready for transmit control bit                          |
|-------|-----------------------------------------------------------------------------------|
|       | 0: Endpoint 2 is not ready for IN packet.                                         |
|       | 1: Endpoint 2 is ready for transmit to USB Host; cleared by H/W while TX2I occurs |
| C7h.6 | <b>TX2TGL:</b> Endpoint 2 transmit data type                                      |
|       | 0: DATA0                                                                          |
|       | 1: DATA.                                                                          |
| C7h.5 | EP2STALL:                                                                         |
|       | 0: Endpoint 2 will not stall IN packet                                            |
|       | 1: Endpoint 2 will stall IN packet                                                |

C7h.3~0 **TX2CNT:** Endpoint 2 transmit byte count F/W set the transmit byte count for IN2 packet

| SFR CEh | Bit 7  | Bit 6  | Bit 5    | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|--------|--------|----------|--------|-------|-------|-------|-------|
| TX3CTRL | TX3RDY | TX3TGL | EP3STALL | EP3CFG | -     | -     | -     | -     |
| R/W     | R/W    | R/W    | R/W      | R/W    | -     | -     | -     | -     |
| Reset   | 0      | 0      | 0        | 0      | -     | -     | -     | -     |

CEh.7 TX3RDY: Endpoint 3 ready for transmit control bit
 0: Endpoint 3 is not ready for IN packet.
 1: Endpoint 3 is ready for transmit to USB Host; cleared by H/W while TX3I occurs
 CEh.6 TX3TGL: Endpoint 3 transmit data type
 0: DATA0
 1: DATA1.
 CEh.5 EP3STALL:
 0: Endpoint 3 will not stall IN packet
 1: Endpoint 3 will stall IN packet
 CEh.4 EP3CFG:
 Write 1to set Endpoint 3 configed

| SFR CFh        | Bit 7  | Bit 6    | Bit 5  | Bit 4  | Bit 3  | Bit 2 | Bit 1 | Bit 0 |
|----------------|--------|----------|--------|--------|--------|-------|-------|-------|
| <b>RC4CTRL</b> | RC4RDY | EP4STALL | EP4CFG | RC4TGL | RC4ERR | -     | -     | -     |
| R/W            | R/W    | R/W      | R/W    | R      | R      | -     | -     | -     |
| Reset          | 0      | 0        | 0      | -      | -      | -     | -     | -     |

CFh.7 **RC4RDY:** Endpoint 4 ready for receive control bit

0: Endpoint 4 is not ready for OUT packet.

1: Endpoint 4 is ready for receive from USB Host; cleared by H/W while RC4I occurs

#### CFh.6 EP4STALL:

0: Endpoint 3 will not stall OUT packet

1: Endpoint 4 will stall OUT packet



| CFh.5 | EP4CFG:                                            |
|-------|----------------------------------------------------|
|       | Write 1to set Endpoint 4 configed                  |
| CFh.4 | <b>RC4TGL:</b> Endpoint 4 received data type       |
|       | 0: DATA0                                           |
|       | 1: DATA1.                                          |
| CFh.3 | RC4ERR: Endpoint 4 received data error status flag |

0: Endpoint 4 received data is correct

1: Endpoint 4 received data is error

| SFR D1h | Bit 7 | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|---------|-------|-------|--------|-------|-------|-------|-------|-------|--|
| TX3CNT  | -     |       | TX3CNT |       |       |       |       |       |  |
| R/W     | -     |       | R/W    |       |       |       |       |       |  |
| Reset   | -     | 0     | 0      | 0     | 0     | 0     | 0     | 0     |  |

D1h.6~0 **TX3CNT:** Endpoint 3 transmit byte count F/W set the transmit byte count for IN3 packet

| SFR D2h | Bit 7     | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|---------|-----------|-------|--------|-------|-------|-------|-------|-------|--|
| RC4CNT  | -         |       | RC4CNT |       |       |       |       |       |  |
| R/W     | -         |       |        |       | R     |       |       |       |  |
| Reset   | -         | -     | -      | -     | -     | -     | -     | -     |  |
|         | DOLONIE T |       |        |       |       |       |       |       |  |

D2h.6~0 **RC4CNT:** Endpoint 4 received byte count

F/W read the received byte count from OUT4 packet

| SFR D3h       | Bit 7                                        | Bit 6  | Bit 5  | Bit 4  | Bit 3   | Bit 2 | Bit 1 | Bit 0 |  |
|---------------|----------------------------------------------|--------|--------|--------|---------|-------|-------|-------|--|
| <b>RCOREG</b> | RC0TGL                                       | RC0ERR | EP0DIR | EPOSET | OUT0CNT |       |       |       |  |
| R/W           | R                                            | R      | R      | R      | R       |       |       |       |  |
| Reset         | -                                            | -      | -      | -      | -       | -     | -     | -     |  |
| D3h.7         | <b>RC0TGL:</b> Endpoint 0 received data type |        |        |        |         |       |       |       |  |

|         | 0: DATA0                                                  |
|---------|-----------------------------------------------------------|
|         | 1: DATA1.                                                 |
| D3h.6   | <b>RC0ERR:</b> Endpoint 0 received data error status flag |
|         | 0: Endpoint 0 received data is correct                    |
|         | 1: Endpoint 0 received data is error                      |
| D3h.5   | <b>EP0DIR:</b> Endpoint 0 transfer direction              |
|         | 0: OUT/SETUP transfer                                     |
|         | 1: IN transfer                                            |
| D3h.4   | <b>EP0SET:</b> Endpoint 0 SETUP Token indicator           |
|         | 0: not SETUP Token                                        |
|         | 1: SETUP Token                                            |
| D3h.3~0 | <b>OUT0CNT:</b> Endpoint 0 received OUT packet byte count |
|         | F/W read the received byte count from OUT0 packet         |
|         |                                                           |

| SFR DAh | Bit 7         | Bit 6         | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1 | Bit 0 |
|---------|---------------|---------------|-------|-------|-------|--------|-------|-------|
| USB1IE  | <b>SETOIE</b> | <b>OUT0IE</b> | TX0IE | TX1IE | TX2IE | SUSPIE | TX3IE | RC4IE |
| R/W     | R/W           | R/W           | R/W   | R/W   | R/W`  | R/W    | R/W   | R/W   |
| Reset   | 0             | 0             | 0     | 0     | 0     | 0      | 0     | 0     |

DAh.7 SETOIE: Endpoint 0 SET0 Receive Interrupt enable bit
 0: disable
 1: enable interrupt service
 DAh.6 OUT0IE: Endpoint 0 OUT0 Receive Interrupt enable bit
 0: disable
 1: enable interrupt service



| DAh.5 | <b>TX0IE:</b> Endpoint 0 Transmit Interrupt enable bit 0: disable 1: enable interrupt service            |
|-------|----------------------------------------------------------------------------------------------------------|
| DAh.4 | <b>TX1IE:</b> Endpoint 1 Transmit Interrupt enable bit<br>0: disable<br>1: enable interrupt service      |
| DAh.3 | <b>TX2IE:</b> Endpoint 2 Transmit Interrupt enable bit<br>0: disable<br>1: enable interrupt service      |
| DAh.2 | <b>SUSPIE:</b> USB Suspend Interrupt enable bit<br>0: disable<br>1: enable interrupt service             |
| DAh.1 | <b>TX3IE:</b> Endpoint 3 Bulk Transmit Interrupt enable bit<br>0: disable<br>1: enable interrupt service |
| DAh.0 | <b>RC4IE:</b> Endpoint 4 Bulk receive Interrupt enable bit<br>0: disable<br>1: enable interrupt service  |

| SFR DBh | Bit 7    | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2   | Bit 1 | Bit 0 |
|---------|----------|-------|-------|-------|---------|---------|-------|-------|
| USB2IE  | VDD5VRIE | RSTIE | RSMIE | KBDIE | PD_TXIE | PD_RCIE | -     | -     |
| R/W     | R/W      | R/W   | R/W   | R/W   | R/W     | R/W     | -     | -     |
| Reset   | 0        | 0     | 0     | 0     | 0       | 0       | -     | -     |

| VDD5VRIE: USB Bus power VDD5V Rise Interrupt enable bit |
|---------------------------------------------------------|
| 0: disable                                              |
| 1: enable interrupt service                             |
| <b>RSTIE:</b> USB Bus Reset Interrupt enable bit        |
| 0: disable                                              |
| 1: enable interrupt service                             |
| <b>RSMIE:</b> USB Resume Interrupt enable bit           |
| 0: disable                                              |
| 1: enable interrupt service                             |
|                                                         |

#### 12.9 USB Keyboard

The **F3288** supports Keyboard keyscan function. This function has a dedicated interrupt (KBDI) and can choose KSI[7:0] pin to do interrupt service, without interrupt of service to mask by KBMASK. The matrix key scan pin KSI[7:0] is shared with Port0[7:0], KSO[7:0] is shared with Port2[7:0], KSO[14:8] is shared with Port4[6:0] and KSO[17:16] is shares with Port3[7:5].

| SFR DBh | Bit 7                                     | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2   | Bit 1 | Bit 0 |
|---------|-------------------------------------------|-------|-------|-------|---------|---------|-------|-------|
| USB2IE  | VDD5VRIE                                  | RSTIE | RSMIE | KBDIE | PD_TXIE | PD_RCIE | -     | -     |
| R/W     | R/W                                       | R/W   | R/W   | R/W   | R/W     | R/W     | -     | -     |
| Reset   | 0                                         | 0     | 0     | 0     | 0       | 0       | -     | -     |
| DBh.4   | KBDIE: Keyboard Scan Interrupt enable bit |       |       |       |         |         |       |       |

0: disable

|         | 1: enable int                                             | terrupt servic | e     |       |        |        |       |       |  |
|---------|-----------------------------------------------------------|----------------|-------|-------|--------|--------|-------|-------|--|
| SFR C3h | Bit 7                                                     | Bit 6          | Bit 5 | Bit 4 | Bit 3  | Bit 2  | Bit 1 | Bit 0 |  |
| USB2I   | VDD5VRI                                                   | RSTI           | RSMI  | KBDI  | PD_TXI | PD_RCI | -     | -     |  |
| R/W     | R/W                                                       | R/W            | R/W   | R/W   | R/W    | R/W    | -     | -     |  |
| Reset   | 0                                                         | 0              | 0     | 0     | 0      | 0      | -     | -     |  |
| C21- 4  | C2h 4 VDDI + Verhand Intermet flags white 0 to along flag |                |       |       |        |        |       |       |  |

C3h.4 **KBDI** : Keyboard Interrupt flag; write 0 to clear flag



| SFR B6h | Bit 7                                                                      | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|---------|----------------------------------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|--|
| KBMASK  | KBMASK                                                                     |       |       |       |       |       |       |       |  |
| R/W     | R/W                                                                        |       |       |       |       |       |       |       |  |
| Reset   | 0                                                                          | 0     | 0     | 0     | 0     | 0     | 0     | 0     |  |
| B6h     | Mask KSI[7:0] interrupt (KBDI) function while the corresponding bit is "1" |       |       |       |       |       |       |       |  |

Mask KSI[7:0] interrupt (KBDI) function while the corresponding bit is "1"

#### 12.10 USB PD

F3288 implements USB PD physical layer to support USB Power Delivery Protocol R2.0 V1.2. USBPDEN bit must be set to high when F3288 is used in USB PD mode. The USB PD messages are transmitted or received in a USB Type-C system using a BMC signaling. The BMC signal is output/input on the same CC pin (CC1 or CC2). F3288 USB PD module starts to transmit the message when the PDTXRDY bit is set to high. F3288 MCU need to fill the PD protocol message in the XRAM3 buffer before F3288 USB PD module transmit message to the other device via CC pin and PD TXI will be generated to inform MCU that the PD message is transmitted completed.



F3288 USB PD module is ready to receive the message when the PDRXRDY bit is set to high. The received USB PD message from the other device via CC pin is stored in the XRAM4 buffer. If the received data is CRC correct, the PD\_RCI interrupt flag will be generated and inform the MCU to read the received USB PD message.



The USB PD packet shall consist of a Preamble, an SOP<sup>\*</sup>, packet data including the Message Header, a CRC and an EOP. The packet format is shown bellow. The entire packet shall be transmitted by using BMC over CC pin.

| Preamble | SOP* (Start<br>Of Packet) | Message Header<br>(16 bit) | 07 Data Object(s) | CRC | EOP (End Of<br>Packet) |
|----------|---------------------------|----------------------------|-------------------|-----|------------------------|
|----------|---------------------------|----------------------------|-------------------|-----|------------------------|

The Preamble shall consist of 64-bit sequence of alternating 0s and 1s. The Preamble shall start with a "0" and shall end with a "1".

DS-TM52F3288\_E



The SOP (Start of Packet) is used as an addressing scheme to identify whether the Communications were intended for one of the Port partners (SOP Communication) or one of the Cable Plug (SOP' / SOP'' Communication)

All Message shall be composed of a Message Header and a variable length (include zero) data portion. Every message shall start with a 16-bit Message Header. The Message Header contains basic information about the Message and the USB PD Port Capability. The Message Header may be used standalone as a Control Message when the Number of Data Object field is zero or as the first part of Data Message when the Number of Data Object field is non-zero.

| message meade |                  |                         |
|---------------|------------------|-------------------------|
| Bit(s)        | Start of Packet  | Field Name              |
| 15            | N/A              | Reserved                |
| 1412          | $\mathrm{SOP}^*$ | Number of Data Objects  |
| 119           | $\mathrm{SOP}^*$ | Message ID              |
| 8             | SOP only         | Port Power Role         |
| 0             | SOP'/ SOP''      | Cable Plug              |
| 76            | $SOP^*$          | Specification Reversion |
| 5             | SOP only         | Port Data Role          |
| 5             | SOP'/ SOP''      | Reserved                |
| 4             | N/A              | Reserved                |
| 30            | SOP*             | Message Type            |

The Message Header and data shall be protected by a 32-bit CRC. CRC-32 protects the data integrity of the data payload.CRC-32 calculation shall begin at byte 0 bit 0 and continue to bit 7 of each of the bytes of the packet.

When P3.2 (CC1) or P3.3 (CC2) worked in USB PD mode, the P3.2 or P3.3 must set to MODE3 and SCC bit is used to select CC1 (P3.2) or CC2 (P3.3) as CC pin.



DS-TM52F3288\_E



DFh.1~0 CCS: CC pin connect resistor select 00: 5.1K ohm to Ground 01: 10K ohm to VDD5 10: 22K ohm to VDD5 11: 56K ohm to VDD5

| SFR DBh        | Bit 7                                          | Bit 6                              | Bit 5                                                                                   | Bit 4          | Bit 3   | Bit 2   | Bit 1 | Bit 0     |  |
|----------------|------------------------------------------------|------------------------------------|-----------------------------------------------------------------------------------------|----------------|---------|---------|-------|-----------|--|
| USB2IE         | VDD5VRIE                                       | RSTIE                              | RSMIE                                                                                   | KBDIE          | PD_TXIE | PD_RCIE | -     | -         |  |
| R/W            | R/W                                            | R/W                                | R/W                                                                                     | R/W            | R/W     | R/W     | -     | -         |  |
| Reset          | 0                                              | 0                                  | 0                                                                                       | 0              | 0       | 0       | -     | -         |  |
| DBh.3          | PD_TXIE: U                                     | USB PD Trar                        | nsmit Interrup                                                                          | ot enable bit  |         |         |       |           |  |
|                | 0: disable                                     |                                    | 1                                                                                       |                |         |         |       |           |  |
|                | 1: enable int                                  | errupt servic                      | e                                                                                       |                |         |         |       |           |  |
| DBh.2          | PD_RCIE: U                                     | USB PD Rec                         | eive Interrupt                                                                          | t enable bit   |         |         |       |           |  |
|                | 0: disable                                     |                                    |                                                                                         |                |         |         |       |           |  |
|                | 1: enable int                                  | errupt servic                      | e                                                                                       |                |         |         |       |           |  |
|                |                                                |                                    |                                                                                         |                |         |         |       |           |  |
| SFR <b>DFh</b> | D:4 7                                          | D:4 C                              | D:45                                                                                    | D:4 4          | D:4 2   | D:4 2   | D:4 1 | D:4.0     |  |
|                | Bit 7                                          | Bit 6                              | Bit 5                                                                                   | Bit 4          | Bit 3   | Bit 2   | Bit 1 | Bit 0     |  |
| PDCTRL         |                                                | PDTXRDY                            |                                                                                         | SCC            | SCCO2   | SCCO1   |       | <u>CS</u> |  |
| R/W            | R/W                                            | R/W                                | R/W<br>0                                                                                | R/W            | R/W     | R/W     |       | /W        |  |
| Reset          | 0                                              | 0                                  | ů                                                                                       | 0              | 0       | 0       | 0     | 0         |  |
| DFh.7          | USBPDEN: USB PD mode enable bit                |                                    |                                                                                         |                |         |         |       |           |  |
|                | 0: disable                                     | SB PD mode                         |                                                                                         |                |         |         |       |           |  |
| DFh.6          |                                                |                                    | ady for transn                                                                          | nit control bi | +       |         |       |           |  |
| DI 11.0        | 0: not ready                                   |                                    | ady for transm                                                                          |                | L.      |         |       |           |  |
|                |                                                |                                    | ransmit PD m                                                                            | lessage        |         |         |       |           |  |
| DFh.5          |                                                |                                    | ady to receive                                                                          |                |         |         |       |           |  |
|                | 0: not ready                                   |                                    |                                                                                         |                |         |         |       |           |  |
|                | •                                              |                                    | ceive PD mes                                                                            | ssage          |         |         |       |           |  |
| DFh.4          | SCC: Select                                    |                                    |                                                                                         | e              |         |         |       |           |  |
|                | 0: select P3.2 (CC1) as CC pin                 |                                    |                                                                                         |                |         |         |       |           |  |
|                | 1: select P3.3 (CC2) as CC pin                 |                                    |                                                                                         |                |         |         |       |           |  |
| DFh.3          | SCCO2: Resistor connect to CC2 pin control bit |                                    |                                                                                         |                |         |         |       |           |  |
|                | 0: disconnect the resistor to CC2 pin          |                                    |                                                                                         |                |         |         |       |           |  |
|                | 1: connect the resistor to CC2 pin             |                                    |                                                                                         |                |         |         |       |           |  |
| DFh.2          |                                                |                                    |                                                                                         | control bit    |         |         |       |           |  |
|                | 0: disconnec                                   | t the resistor                     | SCCO1: Resistor connect to CC1 pin control bit<br>0: disconnect the resistor to CC1 pin |                |         |         |       |           |  |
|                |                                                | 1: connect the resistor to CC1 pin |                                                                                         |                |         |         |       |           |  |

| XRAM3 and XRAM4 can be accessed by MCU or by USB PD module depending on the register |
|--------------------------------------------------------------------------------------|
| XRAMCTRL. The data stored in XRAM3/XRAM4 is the USB PD packet.                       |

| SFR D6h  | Bit 7                                                 | Bit 6          | Bit 5         | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    |
|----------|-------------------------------------------------------|----------------|---------------|----------|----------|----------|----------|----------|
| XRAMCTRL | XRAM4UPD                                              | XRAM3UPD       | XRAM1USB      | XRAM2USB | XRAM1SPB | XRAM2SPB | XRAM1I80 | XRAM2I80 |
| R/W      | R/W                                                   | R/W            | R/W           | R/W      | R/W      | R/W      | R/W      | R/W      |
| Reset    | 0                                                     | 0              | 0             | 0        | 0        | 0        | 0        | 0        |
| D6h.7    | XRAM4UP                                               | D: XRAM4 a     | access contro | l bit    |          |          |          |          |
|          | 0: XRAM4 is access by MCU                             |                |               |          |          |          |          |          |
|          | 1: XRAM4 is access by USB PD Receive message function |                |               |          |          |          |          |          |
| D6h.6    | XRAM3UP                                               | D: XRAM3 a     | access contro | l bit    |          |          |          |          |
|          | 0: XRAM3                                              | is access by I | MCU           |          |          |          |          |          |

0: XRAM3 is access by MCU 1: XRAM3 is access by USB PD Transmit message function





#### XRAM3/XRAM4

| data description                |  |
|---------------------------------|--|
| kcode1                          |  |
| kcode2 Start of Packet Sequence |  |
| kcode3                          |  |
| kcode4                          |  |
| head0 Message Header [7:0]      |  |
| head1 Message Header[15:8]      |  |
| dat0                            |  |
| dat1 Data Object 1              |  |
| dat2                            |  |
| dat3                            |  |
| dat4                            |  |
| dat5 Data Object 2              |  |
| dat6 Data Object 2              |  |
| dat7                            |  |
| dat8                            |  |
| dat9 Data Object 3              |  |
| datio                           |  |
| dat11                           |  |
| dat12                           |  |
| dat13 Data Object 4             |  |
| dat14                           |  |
| dat15                           |  |
| dat16                           |  |
| dat17 Data Object 5             |  |
| dal18                           |  |
| dat19                           |  |
| dat20                           |  |
| dat21 Data Object 6             |  |
| dat22                           |  |
| dat23                           |  |
| dat24                           |  |
| dat25 Data Object 7             |  |
| dat26                           |  |
| dat27                           |  |
| <u>crc0</u>                     |  |
| <u>crc2</u> CRC-32              |  |
| crc3                            |  |
| crc4                            |  |

Note. Please refer to USB Power Delivery Protocol R2.0 V1.2 section 5 & section 6 for Start of Packet Sequence Note. Please refer to USB Power Delivery Protocol R2.0 V1.2 section 6 for Message Header and Data Object



## **13. Serial Peripheral Interface**

The **F3288** has two SPI modules. One SPI module (SPIA) is support for master or slave mode, the other one (SPIB) is support master mode only.

#### 13.1 Serial Peripheral Interface (SPIA)

The Serial Peripheral Interface module A (SPIA) is capable of full-duplex, synchronous, serial communication between the MCU and peripheral devices. The peripheral devices can be other MCUs, A/D converter, sensors, or flash memory, etc. The SPI runs at a clock rate up to the system clock divided by two. Firmware can read the status flags, or the operation can be interrupt driven. Following figure shows the SPI system block diagram.

The features of the SPIA module include:

- Master or Slave mode operation
- 3-wire or 4-wire mode operation
- Full-duplex operation
- Programmable transmit bit rate
- Single buffer receive
- Serial clock phase and polarity options
- MSB-first or LSB-first shifting selectable





The four signals used by SPIA are described below. The MOSI (P2.2) signal is an output from a Master Device and an input to Slave Devices. The MISO (P2.0) signal is an output from a Slave Device and an input to a Master Device. Data is transferred most-significant bit (MSB) or least-significant bit (LSB) first by setting the SPALSBF bit. The SCK (P2.1) signal is an output from a Master Device and an input to Slave Devices. It is used to synchronize the data on the MOSI and MISO lines of Master and Slave. SPIA generates the signal with eight programmable clock rates in Master mode. The SS (P3.4) signal is a low active slave select pin. In 4-wire Slave mode, the signal is ignored when the Slave is not selected (SS=1). The SS is ignored when the SPASSDIS in SPACON is set in both Master and Slave modes. In Slave mode and the SPASSDIS is clear, the SPIA active when SS stay low. For multiple-slave mode, only one slave device is selected at a time to avoid bus collision on the MISO line. In Master mode and the SSDIS is cleared, the MODF in SPASTA is set when this signal is low. For multiple-master mode, enable SS line to avoid multiple driving on MOSI and SCK lines from multiple masters.

#### 13.1.1 Master Mode

The SPIA operates in Master mode by setting the SPAMSTR bit in the SPACON. To start transmit, writing a data to the SPADAT. If the SPABSY bit is cleared, the data will be transferred to the shift register and starts shift out on the MOSI line. The data of the slave shift in from the MISO line at the same time. When the SPAIF bit in the SPASTA becomes set at the end of the transfer, the receive data is written to receiver buffer and the SPARCVBF bit in the SPASTA is set. To prevent an overrun condition, software must read the SPADAT before next byte enters the shift register. The SPABSY bit will be set when writing a data to SPADAT to start transmit, and be cleared at the end of the eighth SCK period in Master mode.

#### 13.1.2 Slave Mode

The SPIA operates in Slave mode by clearing the SPAMSTR bit in the SPACON. If the SPASSDIS is cleared, the transmission will start when the SS become low and remain low until the end of a data transfer. If the SPASSDIS is set, the transmission will start when the SPAEN bit in the SPACON is set, and don't care the SS. The data from a master will shift into the shift register through the MOSI line, and shift out from the shift register on the MISO line. When a byte enters the shift register, the data will be transferred to receiver buffer if the SPARCVBF is cleared. If the SPARCVBF is set, the newer receive data will not be transferred to receiver buffer and the SPARCVOVF bit is set. After a byte enters the shift register, the SPAIF and SPARCVBF bits are set. To prevent an overrun condition, software must read the SPADAT or write 0 to SPARCVBF before next byte enters the shift register. The maximum SCK frequency allowed in Slave mode is  $F_{SYSCLK}/4$ . In Slave mode, the SPASSDIS bit is set.

#### 13.1.3 Serial Clock

The SPI has four clock types by setting the SPACPOL and SPACPHA bits in the SPACON register. The SPACPOL bit defines the level of the SCK in SPIA idle state. The level of the SCK in idle state is low when the SPACPOL bit is cleared, and is high when the SPACPOL bit is set. The SPACPHA bit defines the edges used to sample and shift data. The SPIA sample data on the first edge of SCK period and shift data on the SPACPHA bit is cleared. The SPIA sample data on the second edge of SCK period when the SPACPHA bit is cleared. The SPIA sample data on the second edge of SCK period and shift data on first edge of SCK period when the SPACPHA bit is set. The figures below show the detail timing in Master and Slave modes. Both Master and Slave devices must be configured to use the same clock type before the SPASPEN bit is set. The SPASPCR controls the Master



mode serial clock frequency. This register is ignored when operating in Slave mode. The SPIA clock can select System clock divided by 2, 4, 8, or 16 in Master mode.







In both Master and Slave modes, the SPAIF bit is set by H/W at the end of a data transfer and generates an interrupt if SPIA interrupt is enabled. The SPAIF bit is cleared automatically when the program performs the interrupt service routines. S/W can also write 0 to clear this flag. If write data to SPADAT when the SPABSY is set, the SPAWCOL bit will be set by H/W and generates an interrupt if SPIA interrupt is enabled. When this occurs, the data write to SPADAT will be ignored, and shift register will not be written. Write 0 to this bit or when SPABSY is cleared and rewrite data to SPADAT will clear this flag. The SPAMODF bit is set when SPASSDIS is cleared and SS pin is pulled low in Master mode. If SPIA interrupt is enabled, an interrupt will be generated. When this bit is set, the SPAEN and SPAMSTR in SPACON will be cleared by H/W. Write 0 to this bit will clear this flag.

| SFR BCh | Bit 7                                       | Bit 6      | Bit 5        | Bit 4   | Bit 3    | Bit 2   | Bit 1 | Bit 0 |
|---------|---------------------------------------------|------------|--------------|---------|----------|---------|-------|-------|
| SPACON  | SPAEN                                       | SPAMSTR    | SPACPOL      | SPACPHA | SPASSDIS | SPALSBF | SPAS  | SPCR  |
| R/W     | R/W                                         | R/W        | R/W          | R/W     | R/W      | R/W     | R/    | W     |
| Reset   | 0                                           | 0          | 0            | 0       | 0        | 0       | 0     | 0     |
| BCh.7   | SPAEN: SP                                   | IA enable  |              |         |          |         |       |       |
|         | 0: SPIA dis                                 | sable      |              |         |          |         |       |       |
|         | 1: SPIA en                                  | able       |              |         |          |         |       |       |
| BCh.6   | SPAMSTR:                                    | SPIA Maste | r mode enabl | le      |          |         |       |       |
|         | 0: Slave mo                                 | ode        |              |         |          |         |       |       |
|         | 1: Master n                                 | node       |              |         |          |         |       |       |
| BCh.5   | SPACPOL: SPIA clock polarity                |            |              |         |          |         |       |       |
|         | 0: SCK is low in idle state                 |            |              |         |          |         |       |       |
|         | 1: SCK is high in idle state                |            |              |         |          |         |       |       |
| BCh.4   | SPACPHA: SPIA clock phase                   |            |              |         |          |         |       |       |
|         | 0: Data sample on first edge of SCK period  |            |              |         |          |         |       |       |
|         | 1: Data sample on second edge of SCK period |            |              |         |          |         |       |       |
|         |                                             |            |              |         |          |         |       |       |



| BCh.3   | SPASSDIS:<br>0: Enable S<br>1: Disable | 1                | ole  |  |  |  |
|---------|----------------------------------------|------------------|------|--|--|--|
| BCh.2   |                                        | SPIA LSB fi      | rst  |  |  |  |
|         | 0: MSB fir                             | st               |      |  |  |  |
|         | 1: LSB firs                            | st               |      |  |  |  |
| BCh.1~0 | <b>SPASPCR:</b>                        | SPIA clock       | rate |  |  |  |
|         | 00: F <sub>SYSCLE</sub>                | <sub>x</sub> /2  |      |  |  |  |
|         | 01: F <sub>SYSCLE</sub>                | <sub>x</sub> /4  |      |  |  |  |
|         | $10: F_{\text{SYSCLK}}/8$              |                  |      |  |  |  |
|         | 11: F <sub>SYSCL</sub>                 | <sub>x</sub> /16 |      |  |  |  |
|         |                                        |                  |      |  |  |  |
| SFR BDh | Bit 7                                  | Bit 6            | Bit  |  |  |  |

| SFR BDh | Bit 7                                                                                                | Bit 6   | Bit 5   | Bit 4     | Bit 3    | Bit 2  | Bit 1 | Bit 0 |
|---------|------------------------------------------------------------------------------------------------------|---------|---------|-----------|----------|--------|-------|-------|
| SPASTA  | SPAIF                                                                                                | SPAWCOL | SPAMODF | SPARCVOVF | SPARCVBF | SPABSY | —     | —     |
| R/W     | R/W                                                                                                  | R/W     | R/W     | R/W       | R/W      | R/W    | _     | _     |
| Reset   | 0                                                                                                    | 0       | 0       | 0         | 0        | 0      | —     | —     |
| BDh.7   | SPAIF: SPIA interrupt flag                                                                           |         |         |           |          |        |       |       |
|         | This is set by H/W at the end of a data transfer. Cleared by H/W when an interrupt is vectored into. |         |         |           |          |        |       |       |
|         | Writing 0 to this bit will clear this flag.                                                          |         |         |           |          |        |       |       |
| BDh.6   | SPAWCOL: Write collision interrupt flag                                                              |         |         |           |          |        |       |       |
|         | Set by H/W if write data to SPADAT when SPABSY is set. Write 0 to this bit or rewrite data to        |         |         |           |          |        |       |       |

Set by H/W if write data to SPADAT when SPABSY is set. Write 0 to this bit or rewrite data to SPADAT when SPABSY is cleared will clear this flag.

BDh.5 **SPAMODF:** SPIA Mode fault interrupt flag

Set by H/W when SPASSDIS is cleared and SS pin is pulled low in Master mode. Write 0 to this bit will clear this flag. When this bit is set, the SPAEN and SPAMSTR in SPACON will be cleared by H/W.

# BDh.4 SPARCVOVF: SPIA Received buffer overrun flag Set by H/W at the end of a data transfer and SPARCVBF is set. Write 0 to this bit or read SPADAT register will clear this flag. BDh.3 SPARCVBF: SPIA Receive buffer full flag

# Set by H/W at the end of a data transfer. Write 0 to this bit or read SPADAT register will clear this flag.

BDh.2 SPABSY: SPIA busy flag

Set by H/W when a SPIA transfer is in progress.

| SFR BEh | Bit 7  | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|--------|-------|-------|-------|-------|-------|-------|-------|
| SPADAT  | SPADAT |       |       |       |       |       |       |       |
| R/W     |        | R/W   |       |       |       |       |       |       |
| Reset   | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

BEh.7~0 **SPADAT:** SPIA transmit and receive data

The SPADAT register is used to transmit and receive data. Writing data to SPADAT place the data into shift register and start a transfer when in master mode. Reading SPADAT returns the contents of the receive buffer.





#### **13.2** Serial Peripheral Interface B (SPIB)

Serial Peripheral Interface B (SPIB) is a synchronous serial data protocol, which is used for communicating with one or more peripheral slave devices on short distances. The **F3288**'s SPIB module is capable of full-duplex, synchronous, serial communication between MCU and peripheral devices. The peripheral devices can be other MCUs (slave mode), LCD module, Mouse IR sensor, A/D converter, MEMS sensors, SPI EEPROM or SPI flash memory, etc... The features of the SPIB module include the Master operation, Full-duplex operation, Programmable transmit bit rate, Serial clock phase and polarity options, receive data buffers (up to 64 bytes), transmit data buffer (up to 64 bytes), data transfer DMA mode between SPI to USB or I80 interface options. DMALEN register is used to inform the H/W how many byte data will be transferred to/from XRAM1/2.

#### 13.2.1 SPIB Functional Description



Figure above is the connection diagram between SPIB master device and slave device. The master device initiates all SPI data transfers, but it must follow slave device SPI data transfer specification, otherwise it cannot communicate to slave device. During a transfer, the master device transmits data to the slave device SDI input pin, while the slave device receives data from the master device DO output pin at the same time. When the master device receives data from the slave device SDO output pin, the slave device transmits data to the master device DI input pin at the same time. The CLK signal is a clock output to slave device from the master device, whether to transmit or receive data. During the SPI transfer, data is read only on the DI pin at one CLK edge and shifted, changing the bit value on the DO pin to output data, one-half CLK cycle later.



Figure above shows that the system contains one master and at least 2 slaves, DO pin of master connects to SDI pins of all slaves, DI pin of master connects to SDO pins of all slaves, CLK pins are connected each other. CS pins of slave should be connected by GPIO pins of the master.



Master device uses F/W in GPIO pins to access these slave devices (Chip Select). The CS in slave device is controlled by master device when GPIO pin goes low. The chip select pin is necessary when master device needs to connect multiple slave devices. FW can use GPIO to select multiple slave devices in CS pin, all of slave device can be chosen at one time, and when chip select pin (CS) is set low, that means this device is chosen to do data transfer.

#### 13.2.2 SPIB System Block diagram and Register Control

The SPBMOD register indicates the IO Pin P2.6~4 is in GPIO or in SPI function. The SPIB transmit data is stored in XRAM1 or XRAM2. SPIB can select XRAM1 or XRAM2 according to XRAM1SPI bit or XRAM2SPI bit. Only one of these two bits can be set "1" at the mean time, since SPIB can access only one data source. SPIB can continuous access XRAM1 or XRAM2 until the designated length (DMALEN) is transferred completely. When SPBDIR bit is set to "1", the SPIB will receive data from SPI device and stored to XRAM1 or XRAM2 via RX Buffer. When SPBDIR bit is set to "0", the SPIB will transmit data to SPI device from XRAM1 or XRAM2 via TX Buffer. The SPBCTRL register is used to control the SPIB module. F/W sets SPBEN register to start the SPI data transmission. The SPBLSF register which indicates the SPI data transmission is LSB first or MSB first. The CLRADR register is used to clear the SPIB XRAM buffer address to 0.



| SFR <b>B1h</b> | Bit 7     | Bit 6     | Bit 5   | Bit 4   | Bit 3  | Bit 2   | Bit 1 | Bit 0  |
|----------------|-----------|-----------|---------|---------|--------|---------|-------|--------|
| SPBCTRL        | SPBMOD    | SPBEN     | SPBCPOL | SPBCPHA | SPBDIR | SPBLSBF | -     | CLRADR |
| R/W            | R/W       | R/W       | R/W     | R/W     | R/W    | R/W     | -     | R/W    |
| Reset          | 0         | 0         | 0       | 0       | 0      | 0       | -     | 0      |
| B1h.7          | SPBMOD: S | SPIB mode |         |         |        |         |       |        |

0: P2.6~4 in GPIO

1.02.64 in 0110

1: P2.6~4 in SPIB I/F function

B1h.6 **SPBEN:** SPIB transfer enable

0: automatically clears when data transfer complete

1: start transfer data and check busy state



| B1h.5 | SPBCPOL: SPIB clock polarity                 |
|-------|----------------------------------------------|
|       | 0: BSCK is low in idle state                 |
|       | 1: BSCK is high in idle state                |
| B1h.4 | SPBCPHA: SPIB clock phase                    |
|       | 0: Data sample on first edge of BSCK period  |
|       | 1: Data sample on second edge of BSCK period |
| B1h.3 | SPBDIR: SPIB transfer direction              |
|       | 0: transmit data to SPI device               |
|       | 1: receive data from SPI device              |
| B1h.2 | SPBLSBF: SPIB transfer LSB first             |
|       | 0: MSB first                                 |
|       | 1: LSB first                                 |
| B1h.0 | CLRADR: SPIB clear XRAM address              |
|       | Set 1 to clear buffer address                |

#### 13.2.3 SPIB Clock and Data Format

The **F3288**'s SPIB module can be used as master only. The clock rate and data transfer length are also adjustable. The figure below shows the SPI system block diagram. The SPIB clock output is divided by SPBCRS register. There are 6-bit prescaler to generate desired SPIB baud clock. The fastest bit rate is SPBCRS=000, it means the transfer bit rate is (FRC24M clock) / 2. The SPBCRS[6..0] is used to set SPIB clock select register.





| SFR <b>B2h</b> | Bit 7                             | Bit 6 | Bit 5         | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|----------------|-----------------------------------|-------|---------------|-------|-------|-------|-------|-------|--|--|--|
| SPBCRS         | -                                 |       | SPBCRS        |       |       |       |       |       |  |  |  |
| R/W            | -                                 |       |               |       |       |       |       |       |  |  |  |
| Reset          | -                                 | 0     | 0 0 0 0 0 0 0 |       |       |       |       |       |  |  |  |
| B2h.6~0        | B2h.6~0 SPBCRS: SPIB Clock select |       |               |       |       |       |       |       |  |  |  |

SPICRS(0): 12 MHzSPICRS(1): 6 MHzSPICRS(2):4 MHzSPICRS(3): 3 MHzSPICRS(4): 2.4 MHzSPICRS(5): 2 MHzSPICRS(6): 1.71MHzSPICRS(7): 1.5 MHz......

| SFR B3h | Bit 7                            | Bit 6 | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |  |
|---------|----------------------------------|-------|--------|-------|-------|-------|-------|-------|--|--|--|--|
| DMALEN  | -                                |       | DMALEN |       |       |       |       |       |  |  |  |  |
| R/W     | -                                |       |        |       |       |       |       |       |  |  |  |  |
| Reset   | -                                | 0     | 0      | 0     | 0     | 0     | 0     | 0     |  |  |  |  |
| B3h 6.0 | DMALEN. DMA data transfer length |       |        |       |       |       |       |       |  |  |  |  |

B3h.6~0 **DMALEN:** DMA data transfer length



The figure below shows that before transfer data needs to figure which registers in device control which functions, it also sets the clock frequency (SPBCRS), data transfer length (DMALEN), configures the clock polarity (SPBCPOL) and phase (SPBCPHA) with respect to the data. These modes control data in and out on the rising or falling edge of the data clock signal. The two modes combine polarity and phase.

#### SPIBTiming





The figure above shows the four modes of SPIB clock and data format. CS will be asserted low while a transfer is started. SPBCPOL is the BSCK pin priority select. BSCK pin is in a logic high state while not transferring if SPBCPOL=1, on the other hand, BSCK pin is in a logic low while not transferring if SPBCPOL=0.

When SPBCPHA=0, the first edge of BSCK samples the data into TX shifter. The successive bit is placed on master's DO pin at the second edge of BSCK. In summary, when SPBCPHA=0, the slave samples the data bits on odd number of BSCK clock edge, and the even number of BSCK edge is the data preparation time of the master device. When SPBCPHA=1, The DO pin is in unknown level until the first edge of BSCK is coming. When the first edge of BSCK is coming, the master device places the data output on DO. The slave device uses the second edge of BSCK to sample the data into RX shifter. The successive bit is placed on master's DO pin at the third edge of



BSCK. In summary, when SPBCPHA=1, the slave samples the data bits on even number of BSCK clock edge, while the odd number of BSCK clock edge is the data preparation time of the master.

| Mode | SPBCPOL | SPBCPHA | Description                                                                                                                      |
|------|---------|---------|----------------------------------------------------------------------------------------------------------------------------------|
| 1    | 0       | 0       | The base value of the clock is 0 and the data are captured on the clock's rising edge and data are propagated on a falling edge. |
| 2    | 0       | 1       | The base value of the clock is 0 and the data are captured on the clock's falling edge and data are propagated on a rising edge. |
| 3    | 1       | 0       | The base value of the clock is 1 and the data are captured on clock's falling edge and data are propagated on a rising edge.     |
| 4    | 1       | 1       | The base value of the clock is 1 and the data are captured on clock's rising edge and data are propagated on a falling edge.     |

When Date transfer IN/OUT on the rising or falling edge of the data clock signal calls the clock phase (SPBCPHA), the clock is idle when high or low is called at the clock polarity (SPBCPOL). The two modes combine polarity and phase.

#### **13.2.4 SPIB Power Circuit**



The **F3288** has a built-in low current output regulator (max.50mA) which is designed to provide 3.3V (VDD) from a USB 5V supply. This regulator is ideally suited output current for external device in 3.3V logic. The output capacitor is critical to maintain regulator stability, and must meet the required conditions of minimum amount of capacitance. The minimum output capacitance is required to maintain stability is  $10\mu$ F. Larger values of output capacitance will give improved transient response.

#### 13.2.5 SPIB DMA Transfer Mode

Generally, data transfer length is according to how many bytes data will be transferred. The length value is stored in **DMALEN** and the bulk transfer data is stored in the XRAM 64 bytes (XRAM1 or XRAM2). The **F3288** supports DMA mode between USB and I80



| SFR D6h                                  | Bit 7                                               | Bit 6        | Bit 5          | Bit 4         | Bit 3     | Bit 2      | Bit 1    | Bit 0    |  |  |  |
|------------------------------------------|-----------------------------------------------------|--------------|----------------|---------------|-----------|------------|----------|----------|--|--|--|
| XRAMCTRL                                 | XRAM4UPD                                            | XRAM3UPD     | XRAM1USB       | XRAM2USB      | XRAM1SPB  | XRAM2SPB   | XRAM1I80 | XRAM2I80 |  |  |  |
| R/W                                      | R/W                                                 | R/W          | R/W R/W R/W F  |               |           |            |          | R/W      |  |  |  |
| Reset                                    | 0 0 0 0 0 0 0 0                                     |              |                |               |           |            |          |          |  |  |  |
| D6h.5 XRAM1USB: XRAM1 access control bit |                                                     |              |                |               |           |            |          |          |  |  |  |
|                                          | 1: assign XRAM1 as USB Bulk transfer buffer. Note 1 |              |                |               |           |            |          |          |  |  |  |
| D6h.4                                    | XRAM2US                                             | B: XRAM2 a   | access control | l bit         |           |            |          |          |  |  |  |
|                                          | 1: assign XF                                        | RAM2 as US   | B Bulk transf  | fer buffer. A | lote 2    |            |          |          |  |  |  |
| D6h.3                                    | XRAM1SPI                                            | B: XRAM1 a   | ccess control  | bit           |           |            |          |          |  |  |  |
|                                          | 1: assign XF                                        | RAM1 as SP   | B DMA tran     | sfer buffer.  | Note 1    |            |          |          |  |  |  |
| D6h.2                                    | XRAM2SPB: XRAM2 access control bit                  |              |                |               |           |            |          |          |  |  |  |
|                                          | 1: assign XRAM2 as SPIB DMA transfer buffer. Note 2 |              |                |               |           |            |          |          |  |  |  |
| Note 1 : If MC                           | U need to acce                                      | ess XRAM1. F | W must clear   | { XRAM1USB.   | XRAM1SPB. | XRAM1180 = | 3 'b000  |          |  |  |  |

Note 1 : If MCU need to access XRAM1, F/W must clear { XRAM1USB, XRAM1SPB, XRAM180 = 5 b000

Note 2 : If MCU need to access XRAM2, F/W must clear { XRAM2USB, XRAM2SPB, XRAM2I80}=3'b000

The **XRAMCTRL** register indicates XRAM1/XRAM2 data transfer direction to USB I/F, I80 I/F and SPIB I/F. The **XRAM1SPI** bit is used to assign the XRAM1 as SPIB I/F DMA Transfer buffer. The **XRAM2SPI** is used to assign the XRAM2 as SPIB I/F DMA Transfer buffer.

Figure below shows the data transfer DMA mode between SPIB to USB or I80 interface.





#### **13.2.6 SPIB Initial Sample Code**

Figure below shows the sample code of SPIB initialization, initializes the SPIB firmware code, making it ready to communicate to the SPI Slave Device. After reset the SPIB and all registers to default state, register initialization is completed, which indicating the XRAMCTRL register stored in the XRAM1 or XRAM2.

| ipie : Sr          | PIB Samp   | le Code            |                                                            |
|--------------------|------------|--------------------|------------------------------------------------------------|
| ;=====<br>;Functio | on: maste  | er only            |                                                            |
| ,<br>Start:        |            |                    |                                                            |
|                    |            |                    |                                                            |
| CDIDT              | •          |                    |                                                            |
| SPIBTX             |            | CDDCTDI #011       | CDID and data in CDID and de                               |
|                    | mov        | SPBCTRL, #81h      | ; SPIB module in SPIB mode<br>; clear xram address to zero |
|                    |            | SPBCTRL, #80h      | , clear xrain address to zero                              |
|                    | mov        | DMALEN, #40h       | ,<br>; set DMA transfer length =40h = 64-byte              |
|                    | mov<br>mov |                    | ; XRAM1 as SPIB DMA transfer buffer                        |
|                    | CS_LO      | ARAIVICT RL, #0011 | ; enable chip-select to slave device pin                   |
|                    | mov        | SPBCTRL, #d0h      | ; SPBCPOL=0, SPBCPHA=1,                                    |
|                    | mov        | SI De I RE, "doli  | ; and start to transmit data from XRAM1 to                 |
|                    |            |                    | ; slave device                                             |
| CHKSF              | PB:        |                    |                                                            |
|                    | mov        | A, SPBCTRL         |                                                            |
|                    | jb         | A.6, CHKSPB        | ; F/W polling SPBEN register bit ,                         |
|                    | 5          |                    | ; if transfer complete, goto next instruction              |
|                    | mov        | XRAMCTRL, #04h     | ; XRAM2 as SPIB DMA transfer buffer                        |
|                    | mov        | SPBCTRL, #d0h      | ; SPBCPOL=0, SPBCPHA=1,                                    |
|                    |            |                    | ; and start to transmit data from XRAM1 to                 |
|                    |            |                    | ; slave device                                             |
| CHK2S              | SPB:       |                    |                                                            |
|                    | mov        | A, SPBCTRL         |                                                            |
|                    | jb         | A.6, CHK2SPB       | ; F/W polling SPBEN register bit ,                         |
|                    |            |                    | ; if transfer complete, goto next instruction              |
|                    | CS_HI      |                    | ; disable chip-select                                      |
|                    | •          |                    | ;                                                          |
|                    | ret        |                    |                                                            |
|                    | END        | ; e                | nd of user program                                         |





### 14. I80 Peripheral Interface (I80)

The **F3288** supports I80 interface for LCD Display module, NAND-Flash of parallel bus, NOR-Flash of parallel bus and printer of parallel bus, etc... The I80 interface is an 8-bit parallel bus with read (RD) and write (WR) control line, master only, and data transfer DMA mode.

#### 14.1 I80 Functional Description



In I80 Parallel Interface, the WR pin is used as Write selection output. The Data write operation is initiated; output this pin to low to transmit data or command on D[7:0] bus. The RD pin is used as Read selection output. The Data read operation is initiated; output this pin to low to receive the data or command on D[7:0] bus. The **F3288** uses GPIO control D/C and CS pin. The D/C is a Data and Command control pin and CS is chip enable control pin. In D/C control pin, when it is active HIGH, the input at D7-D0 is treated as Data. When active is LOW, the input at D[7:0] is transferred to the command registers. These D[7:0] are 8-bit bi-directional data bus to be connected to the slave device data bus. The **F3288**'s I80 interface is master only to send data from the MCU.

#### 14.2 I80 System Block Diagram and Register Control



The I80 interface is enabled by setting the **I80CTRL** (D4h) control register and the **DMALEN** (B3h) setting data length register. The DMALEN indicates how many bytes data will be transmitted to device



or received from device. The I80 interface has maximum 64-byte data transfer buffer XRAM. The I80CTRL contains the I80BUSY, I80EN, I80START and I80DIR control register. The **I80EN** – (D4h.2) is an enable control bit which is used to enable the I80 DMA mode. When I80EN is set to high, Port0[7:0] becomes the I80 DATA bus D[7..0] and Port 2.7 becomes the I80 RD signal and Port 2.3 becomes the I80 WR signal. The **I80DIR** (D4h.0) is the data transfer direction control bit. When I80DIR is set to low, the data will be transmitted to device, and when it is set to high, the data will be received from device. The **I80START** (D4h.1) is the read/write start control bit. When I80START is set to high, the I80 controller will start to transfer data. If the I80 completes the data transfer, the I80START will be cleared to 0. The I80BUSY (D4.3) is an I80 interface state of data transfer. If the I80BUSY is read as high, it means the I80 interface is transferring data. If it is read as low, the I80 interface is idle.

| SFR D4h | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2 | Bit 1           | Bit 0  |
|---------|-------|-------|-------|-------|---------|-------|-----------------|--------|
| I80CTRL | -     | -     | -     | -     | I80BUSY | I80EN | <b>I80START</b> | I80DIR |
| R/W     | -     | -     | -     | -     | R       | R/W   | R/W             | R/W    |
| Reset   | -     | -     | -     | -     | -       | 0     | 0               | 0      |

| <b>I80BUSY:</b> I80 Interface state of data transfer |
|------------------------------------------------------|
| 0: I80 interface is idle                             |
| 1: I80 interface is busy                             |
| I80EN: Enable I80 I/F DMA mode                       |
| 0: disable I80 DMA mode                              |
| 1: enable I80 DMA mode                               |
| <b>I80START:</b> I80 I/F data transfer start bit     |
| 0: write 0 to clear it if data transfer completes    |
| 1: write 1 to set it to start data transfer          |
| <b>I80DIR:</b> I80 I/F data transfer direction       |
| 0: write data to device                              |
| 1: read data from device                             |
|                                                      |

#### 14.3 I80 Clock and Data Format

The **F3288**'s I80 is an 8-bit Hardware Interface. When I80 interface is selected, the Write Data Format is set by I80DIR (D4h.0). The written data is expanded into 64-byte internally and then written into XRAM1 or XRAM2.







#### 14.4 I80 DMA Transfer Mode

The **F3288**'s I80 interface is a parallel 8-bit data transfer. The bulk transfer data is stored in the XRAM 64 bytes (XRAM1 or XRAM2). The **F3288** supports DMA mode between USB and I80. The **XRAM1180** register is a control bit, which is used to assign the XRAM1 as I80 I/F DMA Transfer buffer. The **XRAM2180** register is a control bit, which is used to assign the XRAM2 as I80 I/F DMA Transfer buffer.

| SFR D6h        | Bit 7                                               | Bit 6                                 | Bit 5          | Bit 4         | Bit 3     | Bit 2      | Bit 1    | Bit 0    |  |  |  |
|----------------|-----------------------------------------------------|---------------------------------------|----------------|---------------|-----------|------------|----------|----------|--|--|--|
| XRAMCTRL       | XRAM4UPD                                            | XRAM3UPD                              | XRAM1USB       | XRAM2USB      | XRAM1SPB  | XRAM2SPB   | XRAM1I80 | XRAM2I80 |  |  |  |
| R/W            | R/W                                                 | R/W R/W <b>R/W</b> R/W R/W <b>R/W</b> |                |               |           |            |          |          |  |  |  |
| Reset          | 0 0 0 0 0 0 0 0 0                                   |                                       |                |               |           |            |          |          |  |  |  |
| D6h.5          | 06h.5 XRAM1USB: XRAM1 access control bit            |                                       |                |               |           |            |          |          |  |  |  |
|                | 1: assign XRAM1 as USB Bulk transfer buffer. Note 1 |                                       |                |               |           |            |          |          |  |  |  |
| D6h.4          | XRAM2USB: XRAM2 access control bit                  |                                       |                |               |           |            |          |          |  |  |  |
|                | 1: assign XF                                        | RAM2 as US                            | B Bulk transf  | fer buffer. A | lote 2    |            |          |          |  |  |  |
| D6h.1          | <b>XRAM1I80</b>                                     | : XRAM1 ac                            | cess control l | bit           |           |            |          |          |  |  |  |
|                | 1: assign XF                                        | RAM1 as I80                           | DMA transfe    | er buffer. N  | ote 1     |            |          |          |  |  |  |
| D6h.0          | XRAM2I80                                            | : XRAM2 ac                            | cess control l | bit           |           |            |          |          |  |  |  |
|                | 1: assign XRAM2 as I80 DMA transfer buffer. Note 2  |                                       |                |               |           |            |          |          |  |  |  |
| Note 1 : If MC | U need to acce                                      | ess XRAM1, F                          | W must clear   | { XRAM1USB,   | XRAM1SPB, | XRAM1180 = | 3 'b000  |          |  |  |  |

Note 2 : If MCU need to access XRAM2, F/W must clear { XRAM2USB, XRAM2SPB, XRAM2I80}=3'b000





Figure below shows the data transfer DMA mode between I80 to USB or SPIB interface.



#### 14.5 I80 Initial Sample Code

Figure below shows the sample code of I80 initialization, initializes the I80 firmware code, making it ready to communicate to the I80 Device. After reset the I80 and all registers to default state, register initialization is completed, indicating the XRAMCTRL register stored in the XRAM1 or XRAM2. In order to receive the data packet, status and control register is set to enable command and data configuration according to hardware.

| ;Function:                             |                |                                                         |
|----------------------------------------|----------------|---------------------------------------------------------|
| ;===================================== |                |                                                         |
| mov                                    | XRAMCTRL, #02h | ; XRAM1 as I80 I/F DMA transfer buffer                  |
| mov                                    | DMALEN, #40h   | ; set DMA transfer length $=40h = 64$ -byte             |
| mov                                    | I80CTRL, #06h  | ; Enable I80 DMA, and start to transfer data to device  |
| mov                                    | I80CTRL, #04h  | ; clear start                                           |
| CHKI80W:                               |                |                                                         |
| mov                                    | A, I80CTRL     |                                                         |
| jb                                     | A.3, CHKI80W   | ; F/W polling I80BUSY register bit ,                    |
|                                        |                | ; if transfer complete, goto next instruction           |
| mov                                    | I80CTRL, #00h  | ; disable I80 I/F DMA mode                              |
| I80RX:                                 |                |                                                         |
| mov                                    | XRAMCTRL, #01h | ; XRAM2 as I80 I/F DMA transfer buffer                  |
| mov                                    | DMALEN, #40h   | ; set DMA transfer length $=40h = 64$ -byte             |
| mov                                    | I80CTRL, #07h  | ; Enable I80 DMA, and start to receive data from device |
| mov                                    | I80CTRL, #05h  | ; clear start                                           |
| CHKI80R:                               |                |                                                         |
| mov                                    | A, I80CTRL     |                                                         |
| jb                                     | A.3, CHKI80R   | ; F/W polling I80BUSY register bit,                     |
| je                                     |                | ; if transfer complete, goto next instruction           |
| mov                                    | 180CTRL, #00h  | ; disable I80 I/F DMA mode ;                            |
| ret                                    | ,,             | , , , , , , , , , , , , , , , , , , , , ,               |



## 15. In Circuit Emulation (ICE) Mode

This device can support the In Circuit Emulation Mode. To use the ICE Mode, user just needs to connect P1.2 and P1.3 or P3.6 and P3.7 pin to the tenx proprietary EV Module. The benefit is that user can emulate the whole system without changing the on board target device. But there are some limits for the ICE mode as below.

- 1. The device must be un-protect.
- 2. The device's P1.2 and P1.3 or P3.6 an P3.7 pins must work in input Mode (P1MOD2=0/1 and P1MOD3=0/1 or P3MOD6=0/1 and P3MOD7=0/1).
- 3. During Program Code download, P4.3 is controlled by T-Link unit and P1.0 sent acknowledge signal to T-Link unit. After download stage, P4.3 and P1.0 can be emulated as any other pins.
- 4. During Program Code download, P1.1 output FRC/4 and P1.4 always output Low. After download stage, P1.1 and P1.4 can be emulated as any other pins.
- 5. The Program Memory's addressing space 1D00h~1FFFh and 0033h~003Ah are occupied by tenx EV Module. So user Program cannot access these spaces.
- 6. The P1.2 and P1.3 or P3.6 and P3.7 pin's function cannot be emulated.
- When the device is used in USB application, P1.2 and P1.3 ares used as USB DP and DM, only P3.6 and P3.7 can be used for ICE communication





# SFR & CFGW MAP

| Adr | Rst                    | Name        | Bit 7   | Bit 6   | Bit 5       | Bit 4      | Bit 3       | Bit 2      | Bit 1       | Bit 0        |  |  |
|-----|------------------------|-------------|---------|---------|-------------|------------|-------------|------------|-------------|--------------|--|--|
| 80h | 1111-1111              | <b>P0</b>   | P0.7    | P0.6    | P0.5        | P0.4       | P0.3        | P0.2       | P0.1        | P0.0         |  |  |
| 81h | 0000-0111              | SP          |         |         |             | S          | Р           |            |             |              |  |  |
| 82h | 0000-0000              | DPL         |         |         |             | DI         | PL          |            |             |              |  |  |
| 83h | 0000-0000              | DPH         |         |         |             | DI         | PH          |            |             |              |  |  |
| 87h | 0xxx-0000              | PCON        | SMOD    | -       | -           | -          | GF1         | GF0        | PD          | IDL          |  |  |
| 88h | 0000-0000              | TCON        | TF1     | TR1     | TF0         | TR0        | IE1         | IT1        | IE0         | IT0          |  |  |
| 89h | 0000-0000              | TMOD        | GATE1   | CT1N    | TM          | OD1        | GATE0       | CT0N       | TM          | OD0          |  |  |
| 8Ah | 0000-0000              | TL0         |         |         |             | TI         | _0          |            |             |              |  |  |
| 8Bh | 0000-0000              | TL1         |         |         |             | TI         | L1          |            |             |              |  |  |
| 8Ch | 0000-0000              | TH0         |         |         |             | Tł         | HO          |            |             |              |  |  |
| 8Dh | 0000-0000              | TH1         |         | 1       | 1           | TI         | H1          |            | 1           | •            |  |  |
| 90h | 1111-1111              | P1          | P1.7    | P1.6    | P1.5        | P1.4       | P1.3        | P1.2       | P1.1        | P1.0         |  |  |
|     | 0000-0000              | POOE        |         |         |             | PO         | OE          |            |             |              |  |  |
| 93h | 0000-0000              | P2OE        |         | P2OE    |             |            |             |            |             |              |  |  |
| 94h | 0000-0000              | OPTION      | UART1W  | MODE3V  | WD7         | ГРSC       | AD          | CKS        | -           | -            |  |  |
| 95h | xx00-x000              | INTFLG      | LVDO    | -       | -           | ADIF       | -           | IE2        | P1IF        | -            |  |  |
| 96h | 0000-0000              | P1WKUP      |         |         |             | P1W        | KUP         |            |             |              |  |  |
| 97h | xxxx-xxx0              | SWCMD       |         |         |             | IAPALL     | / SWRST     | 1          | 1           | 1            |  |  |
| 98h | 0000-0000              | SCON        | SM0     | SM1     | SM2         | REN        | TB8         | RB8        | TI          | RI           |  |  |
| 99h | xxxx-xxxx              | SBUF        |         | SBUF    |             |            |             |            |             |              |  |  |
| 9Ah | 1111-1111              | PWM0PRD     | PWM0PRD |         |             |            |             |            |             |              |  |  |
|     |                        | PWM0DH      | PWM0DH  |         |             |            |             |            |             |              |  |  |
|     |                        | PWM1PRD     | PWM1PRD |         |             |            |             |            |             |              |  |  |
| -   |                        | PWM1ADH     |         |         |             |            | 1ADH        |            |             |              |  |  |
|     |                        | PWM1BDH     |         |         |             |            | 1BDH        |            |             |              |  |  |
|     |                        | PWM1CDH     |         | ſ       | ſ           |            | 1CDH        | 1          | 1           | 1            |  |  |
|     | 1111-1111              | P2          | P2.7    | P2.6    | P2.5        | P2.4       | P2.3        | P2.2       | P2.1        | P2.0         |  |  |
|     |                        | PWMCKS      | PWM     |         |             | -          |             | IOCKS      | -           | -            |  |  |
|     |                        | P1MODL      | P1M     |         |             | IOD2       |             | IOD1       |             | IOD0         |  |  |
|     |                        | P1MODH      | P1M     |         |             | OD6        |             | IOD5       |             | IOD4         |  |  |
|     |                        | P3MODL      | P3M     |         |             | IOD2       |             | IOD1       |             | IOD0         |  |  |
|     |                        | P3MODH      | P3M     |         |             | OD6        | -           | IOD5       |             | IOD4         |  |  |
|     |                        | PINMOD      | PSOE0   | PWM0POE |             |            | TOOE        |            |             | PWM1COE      |  |  |
|     |                        | PWM0CON     | -       | -       |             | MODE       | ET1         |            | NOVT        | EVO          |  |  |
|     | 0x00-0000<br>0000-0000 | IE<br>INTE1 | EA      | -       | ET2<br>U2IE | ES<br>U1IE | ET1<br>ADIE | EX1<br>EX2 | ET0<br>P1IE | EX0<br>SPAIE |  |  |
|     | xxxx-xxxx              | ADCDL       |         | ADO     |             | UTIE       | ADIE        | EAZ        | FIIE        | SFAIE        |  |  |
|     | xxxx-xxxx<br>xxxx-xxxx | ADCDL       |         | AD      | JDL         |            | -<br>CDH    | -          | -           | -            |  |  |
|     | 0000-0000              | PWMDL       | DWA     | 10DL    | PWM         |            |             | 1BDL       | DWM         | 1CDL         |  |  |
|     | 1111-1111              | CHSEL       | r vv Iv | AD      |             | IADL       |             | IDDL       |             |              |  |  |
| -   | 1111-1111              | P3          | P3.7    | P3.6    | P3.5        | P3.4       | P3.3        | P3.2       | - P3.1      | P3.0         |  |  |
|     | 0000-0000              |             | SPBMOD  | SPBEN   | SPBCPOL     | SPBCPHA    | SPBDIR      | SPBLSF     | -           | CLRADR       |  |  |
|     | x000-0000              | SPBCRS      | -       | 51 DEIN | SIDCIOL     | SIDCITIA   | SPBCRS      | ST DLSI    | -           | CLIADI       |  |  |
|     | x000-0000              |             | -       |         |             |            | DMALEN      |            |             |              |  |  |
|     | 0000-0000              |             |         | OD4     | DAM         | IOD2       |             | IOD1       | D/N         | IOD0         |  |  |
| в4n | 0000-0000              | F4MODL      | P4M     | 004     | P4N         | 002        | P4N         | ועטו       | P4N         | 000          |  |  |

\_\_\_\_



| Adr | Rst       | Name     | Bit 7    | Bit 6    | Bit 5           | Bit 4           | Bit 3    | Bit 2    | Bit 1    | Bit 0    |  |
|-----|-----------|----------|----------|----------|-----------------|-----------------|----------|----------|----------|----------|--|
| B5h | 0000-0000 | P4MODH   | P4M      | OD7      | P4M             | OD6             | P4M      | OD5      | P4M      | OD4      |  |
| B6h | 0000-0000 | KBMASK   |          |          |                 | KBM             | IASK     |          |          |          |  |
| B8h | xx00-0000 | IP       | -        | -        | PT2             | PS              | PT1      | PX1      | PT0      | PX0      |  |
| B9h | xx00-0000 | IPH      | -        | -        | PT2H            | PSH             | PT1H     | PX1H     | PT0H     | PX0H     |  |
| BAh | xxx0-0000 | IP1      | -        | -        | -               | PSPI            | PADTKI   | PX2      | PP1      | PT3      |  |
| BBh | xxx0-0000 | IP1H     | -        | -        | -               | PSPIH           | PADTKIH  | PX2H     | PP1H     | РТЗН     |  |
| BCh | 0000-0000 | SPACON   | SPAEN    | SPAMSTR  | SPACPOL         | SPACPHA         | SPASSDIS | SPALSBF  | SPAS     | PCR      |  |
| BDh | 0000-0xxx | SPASTA   | SPAIF    | SPAWCOL  | SPAMODF         | SPARCVOVF       | SPARCVBF | SPABSY   | -        | -        |  |
| BEh | 0000-0000 | SPADAT   |          |          |                 | SPE             | DAT      |          |          |          |  |
| C0h | 1111-1111 | P5       | -        | -        | -               | -               | -        | -        | -        | P5.0     |  |
| C1h | 0000-0000 | USBADR   | USBE     |          |                 |                 | FUNADR   |          |          |          |  |
| C2h | 0000-0000 | USB1I    | SET0I    | OUT0I    | TX0I            | TX1I            | TX2I     | SUSPI    | TX3I     | RC4I     |  |
| C3h | 0000-0000 | USB2I    | VDD5VRI  | RSTI     | RSMI            | KBDI            | PD_TXI   | PD_RCI   | -        | -        |  |
| C4h | 0000-0000 | USBCTRL  | SUSPND   | RSMO     | EP1CFG          | EP2CFG          | DEVICE_R | OUT0RDY  | -        | -        |  |
| C5h | 0000-0000 | TX0CTRL  | TX0RDY   | TX0TGL   | <b>EPOSTALL</b> | <b>IN0STALL</b> | - TX0CNT |          |          |          |  |
| C6h | 0000-0000 | TX1CTRL  | TX1RDY   | TX1TGL   | EP1STALL        | -               | TX1CNT   |          |          |          |  |
| C7h | 0000-0000 | TX2CTRL  | TX2RDY   | TX2TGL   | EP2STALL        | -               |          | TX2      | CNT      |          |  |
| C8h | 0000-0000 | T2CON    | TF2      | EXF2     | RCLK            | TCLK            | EXEN2    | TR2      | CT2N     | CPRL2N   |  |
| C9h | 0xxx-xxxx | IAPWE    | IAPWE    | IAPTO    | -               | -               | -        | -        | -        |          |  |
| CAh | 0000-0000 | RCP2L    |          |          |                 | RCI             | P2L      |          |          |          |  |
| CBh | 0000-0000 | RCP2H    |          | RCP2H    |                 |                 |          |          |          |          |  |
| CCh | 0000-0000 | TL2      |          | TL2      |                 |                 |          |          |          |          |  |
| CDh | 0000-0000 | TH2      |          |          |                 | Tł              | H2       |          |          |          |  |
| CEh | 0000-xxxx | TX3CTRL  | TX3RDY   | TX3TGL   | EP3STALL        | EP3CFG          | -        | -        | -        | -        |  |
| CFh | 000x-xxxx | RC4CTRL  | RC4RDY   | EP4STALL | EP4CFG          | RC4TGL          | RC4ERR   | -        | -        | -        |  |
| D0h | 0000-0000 | PSW      | CY       | AC       | F0              | RS1             | RS0      | OV       | F1       | Р        |  |
| D1h | x000-0000 | TX3CNT   | -        |          |                 |                 | TX3CNT   |          |          |          |  |
| D2h | xxxx-xxxx | RC4CNT   | -        |          |                 |                 | RC4CNT   |          |          |          |  |
| D3h | xxxx-xxxx | RCOREG   | RC0TGL   | RC0ERR   | EP0DIR          | EPOSET          |          | OUT(     | )CNT     |          |  |
| D4h | xxxx-x000 | I80CTRL  | -        | -        | -               | -               | I80BUSY  | I80EN    | I80START | I80DIR   |  |
| D6h | 0000-0000 | XRAMCTRL | XRAM4UPD | XRAM3UPD |                 | XRAM2USB        |          | XRAM2SPB | XRAM1I80 | XRAM2I80 |  |
|     |           | CLKCON   | -        | -        | STPSCK          | STPPCK          | STPFCK   | SELFCK   | CLK      |          |  |
|     |           | USB1IE   | SET0IE   | OUT0IE   | TX0IE           | TX1IE           | TX2IE    | SUSPIE   | TX3IE    | RC4IE    |  |
|     | 0000-00xx | USB2IE   | VDD5VRIE | RSTIE    | RSMIE           | KBDIE           | PD_TXIE  | PD_RCIE  | -        | -        |  |
| DCh | xxxx-x000 | USBRSTM  | -        | -        | -               | -               | -        | UTMEN    | UT       |          |  |
|     | 00xx-0000 | PDCTRL   | USBPDEN  | PDTXRDY  | PDRXRDY         | SCC             | SCCO2    | SCCO1    | CC       | CS       |  |
| E0h | 0000-0000 | ACC      | ACC.7    | ACC.6    | ACC.5           | ACC.4           | ACC.3    | ACC.2    | ACC.1    | ACC.0    |  |
| E8h | 1111-1111 | P4       | P4.7     | P4.6     | P4.5            | P4.4            | P4.3     | P4.2     | P4.1     | P4.0     |  |
| EFh | xxxx-x000 | ANAT     | -        | -        | -               | -               | -        | ANTOE    | SAN      | ITO      |  |
| F0h | 0000-0000 | В        | B.7      | B.6      | B.5             | B.4             | B.3      | B.2      | B.1      | B.0      |  |
| F5h | 00xx-x000 | AUX2     | VDD5VFLG | VDD5FALL | -               | -               | -        | IAF      | ТE       | VCCFLT   |  |
|     | xxxx-xxxx | VBGTM    | -        | -        | -               | -               |          | VBC      | ЭТМ      |          |  |
| F7h | xxxx-xxxx | FRCTM    | -        | -        | -               |                 |          | FRCTM    | [        |          |  |
| F8h | 0000-00x0 | AUX1     | CLRWDT   | WE       | DTE             | ADSOC           | CLRPWM0  | PDADOP   | BOOTV    | DPSEL    |  |



| Flash Address | Name   | Bit 7 | Bit 6 | Bit 5 | Bit 4                   | Bit 3   | Bit 2 | Bit 1 | Bit 0 |
|---------------|--------|-------|-------|-------|-------------------------|---------|-------|-------|-------|
| 3FFCh         | CFGWL1 | -     | -     | -     | -                       | - VBGTM |       |       |       |
| 3FFEh         | CFGWH1 | -     | -     | -     | FRCTM                   |         |       |       |       |
| 3FFFh         | CFGWH2 | PROT  | XRSTE | LV    | /RE - PWRSAV MVCLOCK BC |         |       |       | BOOTV |



# SFR & CFGW DESCRIPTION

| SFR<br>Adr | SFR Name | Bit # | Bit Name | R/W | Rst | Description                                                                                                                                                                                                                |
|------------|----------|-------|----------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 80h        | PO       | 7~0   | PO       | R/W | FFh | Port0 data, also controls the P0.n pin's pull-up function. If the P0.n SFR data is "1" and the corresponding P0OE.n=0 (input mode), the pull-up is enabled.                                                                |
| 81h        | SP       | 7~0   | SP       | R/W | 07h | Stack Point                                                                                                                                                                                                                |
| 82h        | DPL      | 7~0   | DPL      | R/W | 00h | Data Point low byte                                                                                                                                                                                                        |
| 83h        | DPH      | 7~0   | DPH      | R/W | 00h | Data Point high byte                                                                                                                                                                                                       |
|            |          | 7     | SMOD     | R/W | 0   | UART double baud rate control bit<br>0: Disable UART double baud rate<br>1: Enable UART double baud rate                                                                                                                   |
| 87h        | PCON     | 3     | GF1      | R/W | 0   | General purpose flag bit                                                                                                                                                                                                   |
|            |          | 2     | GF0      | R/W | 0   | General purpose flag bit                                                                                                                                                                                                   |
|            |          | 1     | PD       | R/W | 0   | Stop bit. If 1 Stop mode is entered.                                                                                                                                                                                       |
|            |          | 0     | IDL      | R/W | 0   | Idle bit. If 1, Idle mode is entered.                                                                                                                                                                                      |
|            |          | 7     | TF1      | R/W | 0   | Timer1 overflow flag<br>Set by H/W when Timer/Counter 1 overflows. Cleared by<br>H/W when CPU vectors into the interrupt service routine.                                                                                  |
|            |          | 6     | TR1      | R/W | 0   | Timer1 run control<br>0: Timer1 stops<br>1: Timer1 runs                                                                                                                                                                    |
|            | TCON     | 5     | TF0      | R/W | 0   | Timer0 overflow flag<br>Set by H/W when Timer/Counter 0 overflows. Cleared by<br>H/W when CPU vectors into the interrupt service routine.                                                                                  |
|            |          | 4     | TR0      | R/W | 0   | Timer0 run control<br>0: Timer0 stops<br>1: Timer0 runs                                                                                                                                                                    |
| 88h        |          | 3     | IE1      | R/W | 0   | External Interrupt 1 (INT1 pin) edge flag<br>Set by H/W when an INT1 pin falling edge is detected, no<br>matter the EX1 is 0 or 1. It is cleared automatically when<br>the program performs the interrupt service routine. |
|            |          | 2     | IT1      | R/W | 0   | External Interrupt 1 control bit<br>0: Low level active (level triggered) for INT1 pin<br>1: Falling edge active (edge triggered) for INT1 pin                                                                             |
|            |          | 1     | IE0      | R/W | 0   | External Interrupt 0 (INT0 pin) edge flag<br>Set by H/W when an INT0 pin falling edge is detected, no<br>matter the EX0 is 0 or 1. It is cleared automatically when<br>the program performs the interrupt service routine. |
|            |          | 0     | IT0      | R/W | 0   | External Interrupt 0 control bit<br>0: Low level active (level triggered) for INT0 pin<br>1: Falling edge active (edge triggered) for INT0 pin                                                                             |
|            |          | 7     | GATE1    | R/W | 0   | <ul><li>Timer1 gating control bit</li><li>0: Timer1 enable when TR1 bit is set</li><li>1: Timer1 enable only while the INT1 pin is high and TR1 bit is set</li></ul>                                                       |
| 89h        | TMOD     | 6     | CT1N     | R/W | 0   | <ul> <li>Timer1 Counter/Timer select bit</li> <li>0: Timer mode, Timer1 data increases at 2 System clock cycle rate</li> <li>1: Counter mode, Timer1 data increases at T1 pin's negative edge</li> </ul>                   |

\_\_\_\_\_



| SFR<br>Adr | SFR Name | Bit # | Bit Name | R/W | Rst                                                                                                                                                                                                                                                                                                                                     | Description                                                                                                                                                                                                                                            |
|------------|----------|-------|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          | 5~4   | TMOD1    | R/W | 00                                                                                                                                                                                                                                                                                                                                      | <ul> <li>Timer1 mode select</li> <li>00: 8-bit timer/counter (TH1) and 5-bit prescaler (TL1)</li> <li>01: 16-bit timer/counter</li> <li>10: 8-bit auto-reload timer/counter (TL1). Reloaded from TH1 at overflow.</li> <li>11: Timer1 stops</li> </ul> |
|            |          | 3     | GATE0    | R/W | 0                                                                                                                                                                                                                                                                                                                                       | Timer0 gating control bit<br>0: Timer0 enable when TR0 bit is set<br>1: Timer0 enable only while the INT0 pin is high and<br>TR0 bit is set                                                                                                            |
| 89h        | TMOD     | 2     | CT0N     | R/W | 0                                                                                                                                                                                                                                                                                                                                       | <ul> <li>Timer0 Counter/Timer select bit</li> <li>0: Timer mode, Timer0 data increases at 2 System clock cycle rate</li> <li>1: Counter mode, Timer0 data increases at T0 pin's negative edge</li> </ul>                                               |
|            | 1~0      | TMOD0 | R/W      | 00  | <ul> <li>Timer0 mode select</li> <li>00: 8-bit timer/counter (TH0) and 5-bit prescaler (TL0)</li> <li>01: 16-bit timer/counter</li> <li>10: 8-bit auto-reload timer/counter (TL0). Reloaded from TH0 at overflow.</li> <li>11: TL0 is an 8-bit timer/counter. TH0 is an 8-bit timer/counter using Timer1's TR1 and TF1 bits.</li> </ul> |                                                                                                                                                                                                                                                        |
| 8Ah        | TL0      | 7~0   | TL0      | R/W | 00h                                                                                                                                                                                                                                                                                                                                     | Timer0 data low byte                                                                                                                                                                                                                                   |
| 8Bh        | TL1      | 7~0   | TL1      | R/W | 00h                                                                                                                                                                                                                                                                                                                                     | Timer1 data low byte                                                                                                                                                                                                                                   |
| 8Ch        | TH0      | 7~0   | TH0      | R/W | 00h                                                                                                                                                                                                                                                                                                                                     | Timer0 data high byte                                                                                                                                                                                                                                  |
| 8Dh        | TH1      | 7~0   | TH1      | R/W | 00h                                                                                                                                                                                                                                                                                                                                     | Timer1 data high byte                                                                                                                                                                                                                                  |
| 90h        | P1       | 7~0   | P1       | R/W | FFh                                                                                                                                                                                                                                                                                                                                     | Port1 data                                                                                                                                                                                                                                             |
| 91h        | POOE     | 7~0   | POOE     | R/W | 00h                                                                                                                                                                                                                                                                                                                                     | Port0 CMOS Push-Pull output enable control<br>0: Disable<br>1: Enable                                                                                                                                                                                  |
| 93h        | P2OE     | 7~0   | P2OE     | R/W | 00h                                                                                                                                                                                                                                                                                                                                     | Port2 CMOS Push-Pull output enable control<br>0: Disable<br>1: Enable                                                                                                                                                                                  |
|            |          | 7     | UART1W   | R/W | 0                                                                                                                                                                                                                                                                                                                                       | One wire UART mode enable, both TXD/RXD use P3.1<br>pin<br>0: Disable one wire UART mode<br>1: Enable one wire UART mode                                                                                                                               |
|            |          | 6     | MODE3V   | R/W | 0                                                                                                                                                                                                                                                                                                                                       | 3V mode selection control bit<br>If this bit is set, the chip can be only operated in the<br>condition of V <sub>CC</sub> <3.6V, and LDO is turned off to save<br>current                                                                              |
| 94h        | OPTION   | 5~4   | WDTPSC   | R/W | 00                                                                                                                                                                                                                                                                                                                                      | Watchdog Timer pre-scalar time select<br>00: 400ms WDT overflow rate<br>01: 200ms WDT overflow rate<br>10: 100ms WDT overflow rate<br>11: 50ms WDT overflow rate                                                                                       |
|            |          | 3~2   | ADCKS    | R/W | 00                                                                                                                                                                                                                                                                                                                                      | ADC clock rate select<br>00: F <sub>SYSCLK</sub> /32<br>01: F <sub>SYSCLK</sub> /16<br>10: F <sub>SYSCLK</sub> /8<br>11: F <sub>SYSCLK</sub> /4                                                                                                        |



| SFR<br>Adr                                                                                                                | SFR Name                                                                                                                                                                                                                                                                                                                      | Bit # | Bit Name | R/W | Rst | Description                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1101                                                                                                                      |                                                                                                                                                                                                                                                                                                                               | 7     | LVDO     | R   |     | Low Voltage Detect flag<br>Set by H/W when a low voltage occurs. The flag is valid<br>when LVR is 1.9V or disabled. This flag is disabled in<br>Stop mode or if MODE3V=1 and PWRSAV=1.                                                                                                                                                                                                                             |
|                                                                                                                           |                                                                                                                                                                                                                                                                                                                               | 4     | ADIF     | R/W | 0   | ADC interrupt flag<br>Set by H/W at the end of conversion. S/W writes EFh to<br>INTFLG or sets the ADSOC bit to clear this flag.                                                                                                                                                                                                                                                                                   |
| 95h                                                                                                                       | INTFLG                                                                                                                                                                                                                                                                                                                        | 2     | IE2      | R/W | 0   | External Interrupt 2 (INT2 pin) edge flag<br>Set by H/W when a falling edge is detected on the INT2<br>pin state, no matter the EX2 is 0 or 1. It is cleared<br>automatically when the program performs the interrupt<br>service routine. S/W can write FBh to INTFLG to clear<br>this bit.                                                                                                                        |
| 1P1IFR/W0Port1 pin change<br>Set by H/W wh<br>its interrupt ena<br>affect this flag'<br>the program pe<br>can write FDh t | Port1 pin change interrupt flag<br>Set by H/W when a P1 pin state change is detected, and<br>its interrupt enable bit is set (P1WKUP). P1IE does not<br>affect this flag's setting. It is cleared automatically when<br>the program performs the interrupt service routine. S/W<br>can write FDh to INTFLG to clear this bit. |       |          |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 96h                                                                                                                       | P1WKUP                                                                                                                                                                                                                                                                                                                        | 7~0   | P1WKUP   | R/W | 00h | <ul><li>P1.7~P1.0 pin individual Wake up/Interrupt enable control</li><li>0: Disable</li><li>1: Enable</li></ul>                                                                                                                                                                                                                                                                                                   |
|                                                                                                                           |                                                                                                                                                                                                                                                                                                                               | 7~0   | SWRST    | W   |     | Write 56h to generate S/W Reset                                                                                                                                                                                                                                                                                                                                                                                    |
| 97h                                                                                                                       | SWCMD                                                                                                                                                                                                                                                                                                                         | 7~0   | IAPALL   | W   |     | Write 65h to set IAPALL control flag; Write other value to clear IAPALL flag. It is recommended to clear it immediately after IAP access.                                                                                                                                                                                                                                                                          |
|                                                                                                                           |                                                                                                                                                                                                                                                                                                                               | 0     | IAPE     | R   | 0   | Flag indicates Flash memory sectors can be accessed by IAP or not. This bit combines with MVCLOCK to define the accessible IAP area.                                                                                                                                                                                                                                                                               |
|                                                                                                                           |                                                                                                                                                                                                                                                                                                                               | 7     | SM0      | R/W | 0   | Serial port mode select bit 0,1<br>00: Mode0: 8 bit shift register, Baud Rate = $F_{SYSCLK}/2$<br>01: Mode1: 8 bit UART, Baud Rate is variable                                                                                                                                                                                                                                                                     |
|                                                                                                                           |                                                                                                                                                                                                                                                                                                                               | 6     | SM1      | R/W | 0   | 10: Mode2: 9 bit UART, Baud Rate is variable<br>11: Mode3: 9 bit UART, Baud Rate= $F_{SYSCLK}/32$ or /64<br>11: Mode3: 9 bit UART, Baud Rate is variable                                                                                                                                                                                                                                                           |
| 98h                                                                                                                       | SCON                                                                                                                                                                                                                                                                                                                          | 5     | SM2      | R/W | 0   | <ul> <li>Serial port mode select bit 2</li> <li>SM2 enables multiprocessor communication over a single serial line and modifies the above as follows. In Modes 2 &amp; 3, if SM2 is set then the received interrupt will not be generated if the received ninth data bit is 0. In Mode 1, the received interrupt will not be generated unless a valid stop bit is received. In Mode 0, SM2 should be 0.</li> </ul> |
|                                                                                                                           |                                                                                                                                                                                                                                                                                                                               | 4     | REN      | R/W | 0   | UART reception enable<br>0: Disable reception<br>1: Enable reception                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                           |                                                                                                                                                                                                                                                                                                                               | 3     | TB8      | R/W | 0   | Transmit Bit 8, the ninth bit to be transmitted in Mode 2<br>and 3                                                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                           |                                                                                                                                                                                                                                                                                                                               | 2     | RB8      | R/W | 0   | Receive Bit 8, contains the ninth bit that was received in Mode 2 and 3 or the stop bit in Mode 1 if SM2=0                                                                                                                                                                                                                                                                                                         |
|                                                                                                                           |                                                                                                                                                                                                                                                                                                                               | 1     | TI       | R/W | 0   | Transmit interrupt flag<br>Set by H/W at the end of the eighth bit in Mode 0, or at<br>the beginning of the stop bit in other modes. Must be<br>cleared by S/W.                                                                                                                                                                                                                                                    |
|                                                                                                                           |                                                                                                                                                                                                                                                                                                                               | 0     | RI       | R/W | 0   | Receive interrupt flag                                                                                                                                                                                                                                                                                                                                                                                             |

\_\_\_\_



| SFR<br>Adr | SFR Name | Bit #      | Bit Name         | R/W        | Rst | Description                                                                                                                                                 |
|------------|----------|------------|------------------|------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          |            |                  |            |     | Set by H/W at the end of the eighth bit in Mode 0, or at the sampling point of the stop bit in other modes. Must be cleared by S/W.                         |
| 99h        | SBUF     | 7~0        | SBUF             | R/W        |     | UART transmit and receive data. Transmit data is written<br>to this location and receive data is read from this location,<br>but the paths are independent. |
| 9Ah        | PWM0PRD  | 7~0        | PWM0PRD          | R/W        | FFh | PWM0 period                                                                                                                                                 |
| 9Bh        | PWM0DH   | 7~0        | PWM0DH           | R/W        | 80h | PWM0 duty high byte<br>The PWM0 output signal is reset to a low level whenever<br>the 8-bit base counter matches the 8-bit PWM0DH.                          |
| 9Ch        | PWM1PRD  | 7~0        | PWM1PRD          | R/W        | FFh | PWM1 period                                                                                                                                                 |
| 9Dh        | PWM1ADH  | 7~0        | PWM1ADH          | R/W        | 80h | PWM1A duty high byte<br>The PWM1A output signal is reset to a low level<br>whenever the 8-bit base counter matches the 8-bit<br>PWM1ADH.                    |
| 9Eh        | PWM1BDH  | 7~0        | PWM1BDH          | R/W        | 80h | PWM1B duty high byte<br>The PWM1B output signal is reset to a low level whenever<br>the 8-bit base counter matches the 8-bit PWM1BDH.                       |
| 9Fh        | PWM1CDH  | 7~0        | PWM1CDH          | R/W        | 80h | PWM1C duty high byte<br>The PWM1C output signal is reset to a low level whenever<br>the 8-bit base counter matches the 8-bit PWM1CDH.                       |
| A0h        | P2       | 7~0        | P2               | R/W        | FFh | Port2 data, also controls the P2.n pin's pull-up function. If the P2.n SFR data is "1" and the corresponding P2OE.n=0 (input mode), the pull-up is enabled. |
| A1h        | PWMCKS   | 7~6        | PWM1CKS          | R/W        | 10  | PWM1 clock source<br>00: F <sub>SYSCLK</sub> /4<br>01: F <sub>SYSCLK</sub> /2<br>10: F <sub>SYSCLK</sub><br>11: FRCx2                                       |
| AIII       | F WMCK5  | 3~2        | PWM0CKS          | R/W        | 10  | PWM0 clock source<br>00: F <sub>SYSCLK</sub> /4<br>01: F <sub>SYSCLK</sub> /2<br>10: F <sub>SYSCLK</sub><br>11: FRCx2                                       |
|            |          | 7~6        | P1MOD3           | R/W        | 00  | P1.3 pin control                                                                                                                                            |
| A2h        | P1MODL   | 5~4        | P1MOD2           | R/W        | 00  | P1.2 pin control                                                                                                                                            |
| 11211      | TIMODE   | 3~2        | P1MOD1           | R/W        | 00  | P1.1 pin control                                                                                                                                            |
|            |          | 1~0        | P1MOD0           | R/W        | 00  | P1.0 pin control                                                                                                                                            |
|            |          | 7~6        | P1MOD7           | R/W        | 00  | P1.7 pin control                                                                                                                                            |
| A3h        | P1MODH   | 5~4        | P1MOD6           | R/W        | 00  | P1.6 pin control                                                                                                                                            |
|            |          | 3~2        | P1MOD5           | R/W        | 00  | P1.5 pin control                                                                                                                                            |
|            |          | 1~0        | P1MOD4           | R/W        | 00  | P1.4 pin control                                                                                                                                            |
|            |          | 7~6<br>5~4 | P3MOD3           | R/W        | 00  | P3.3 pin control                                                                                                                                            |
| A4h        | P3MODL   | 5~4<br>3~2 | P3MOD2<br>P3MOD1 | R/W<br>R/W | 00  | P3.2 pin control<br>P3.1 pin control                                                                                                                        |
|            |          | 3~2<br>1~0 | P3MOD1<br>P3MOD0 | R/W        | 00  | P3.0 pin control                                                                                                                                            |
|            |          | 1~0<br>7~6 | P3MOD0<br>P3MOD7 | R/W        | 00  | P3.7 pin control                                                                                                                                            |
|            |          | 5~4        | P3MOD7<br>P3MOD6 | R/W        | 00  | P3.6 pin control                                                                                                                                            |
| A5h        | P3MODH   | 3~2        | P3MOD5           | R/W        | 00  | P3.5 pin control                                                                                                                                            |
|            |          | 1~0        | P3MOD4           | R/W        | 00  | P3.4 pin control                                                                                                                                            |
| L          |          | ÷          |                  |            |     | 1 · · · · ·                                                                                                                                                 |



| SFR<br>Adr | SFR Name | Bit # | Bit Name | R/W | Rst | Description                                                                                                                                                                                                                                                                |
|------------|----------|-------|----------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          | 7     | P5OE0    | R/W | 0   | P5.0 CMOS Push-Pull output enable control<br>0: Disable<br>1: Enable                                                                                                                                                                                                       |
|            |          | 6     | PWM0POE  | R/W | 0   | <ul><li>PWM0P signal output enable</li><li>0: Disable PWM0P signal output to P1.4</li><li>1: Enable PWM0APsignal output to P1.4</li></ul>                                                                                                                                  |
|            |          | 5     | PWM0NOE  | R/W | 0   | PWM0N signal output enable<br>0: Disable PWM0N signal output to P5.0<br>1: Enable PWM0N signal output to P5.0                                                                                                                                                              |
| A6h        | PINMOD   | 4     | T2OE     | R/W | 0   | Timer2 signal output enable<br>0: Disable Timer2 overflow divided by 2 output to P1.0<br>1: Enable Timer2 overflow divided by 2 output to P1.0                                                                                                                             |
|            |          | 3     | TOOE     | R/W | 0   | Timer0 signal output enable<br>0: Disable Timer0 overflow divided by 64 output to P3.4<br>1: Enable Timer0 overflow divided by 64 output to P3.4                                                                                                                           |
|            |          | 2     | PWM1AOE  | R/W | 0   | PWM1A signal output enable<br>0: Disable PWM1A signal output to P1.5<br>1: Enable PWM1A signal output to P1.5<br>PWM1B signal output anable                                                                                                                                |
|            |          | 1     | PWM1BOE  | R/W | 0   | PWM1B signal output enable<br>0: Disable PWM1B signal output to P1.6<br>1: Enable PWM1B signal output to P1.6<br>PWM1C signal output enable                                                                                                                                |
|            |          | 0     | PWM1COE  | R/W | 0   | 0: Disable PWM1C signal output to P1.7<br>1: Enable PWM1C signal output to P1.7<br>PWM0 differential output mode                                                                                                                                                           |
| A7h        | PWMCON   | 5~4   | PWM0MODE | R/W | 0   | 00: Mode 0<br>01: Mode 1<br>10: Mode 2<br>11: Mode 3                                                                                                                                                                                                                       |
|            |          | 3~0   | PWM0NOVT | R/W | 0   | PWM0 non-overlap time select;<br>0:0, 1:1, 2:2, 3:3, 4:4, 5:5, 6:6, 7:7, 8:8, 9:9,<br>10:10, 11:11, 12:12, 13:13, 14:14, 15:16 PWM0 clock                                                                                                                                  |
|            |          | 7     | EA       | R/W | 0   | <ul> <li>Global interrupt enable</li> <li>0: Disable all interrupts</li> <li>1: Each interrupt is enabled or disabled by its individual interrupt control bit</li> </ul>                                                                                                   |
|            |          | 5     | ET2      | R/W | 0   | Timer2 interrupt enable<br>0: Disable Timer2 interrupt<br>1: Enable Timer2 interrupt                                                                                                                                                                                       |
| A8h        | Ш        | 4     | ES       | R/W | 0   | Serial Port (UART) interrupt enable<br>0: Disable Serial Port (UART) interrupt<br>1: Enable Serial Port (UART) interrupt                                                                                                                                                   |
|            | IE       | 3     | ET1      | R/W | 0   | Timer1 interrupt enable<br>0: Disable Timer1 interrupt<br>1: Enable Timer1 interrupt                                                                                                                                                                                       |
|            |          | 2     | EX1      | R/W | 0   | <ul><li>INT1 pin Interrupt enable and Stop mode wake up enable</li><li>0: Disable INT1 pin Interrupt and Stop mode wake up</li><li>1: Enable INT1 pin Interrupt and Stop mode wake up, it</li><li>can wake up CPU from Stop mode no matter EA is 0 or</li><li>1.</li></ul> |
|            |          | 1     | ET0      | R/W | 0   | Timer0 interrupt enable<br>0: Disable Timer0 interrupt<br>1: Enable Timer0 interrupt                                                                                                                                                                                       |

\_\_\_\_



| SFR<br>Adr | SFR Name | Bit # | Bit Name | R/W | Rst  | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|----------|-------|----------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          | 0     | EX0      | R/W | 0    | <ul><li>INT0 pin Interrupt enable and Stop mode wake up enable</li><li>0: Disable INT0 pin Interrupt and Stop mode wake up</li><li>1: Enable INT0 pin Interrupt and Stop mode wake up, it can wake up CPU from Stop mode no matter EA is 0 or</li><li>1.</li></ul>                                                                                                                                   |
|            |          | 5     | U2IE     | R/W | 0    | USB2 interrupt enable, reference to USB2IE(DBh) for more detail                                                                                                                                                                                                                                                                                                                                      |
|            |          | 4     | U1IE     | R/W | 0    | USB1 interrupt enable, reference to USB1IE(DAh) for more detail                                                                                                                                                                                                                                                                                                                                      |
|            |          | 3     | ADIE     | R/W | 0    | ADC/Touch Key (F5284/84C Only) interrupt enable<br>0: Disable ADC/Touch Key interrupt<br>1: Enable ADC/Touch Key interrupt                                                                                                                                                                                                                                                                           |
| A9h        | INTE1    | 2     | EX2      | R/W | 0    | INT2 pin Interrupt enable and Stop mode wake up enable<br>0: Disable INT2 pin Interrupt and Stop mode wake up<br>1: Enable INT2 pin Interrupt and Stop mode wake up, it<br>can wake up CPU from Stop mode no matter EA is 0 or 1.                                                                                                                                                                    |
|            |          | 1     | P1IE     | R/W | 0    | Port1 pin change interrupt enable<br>0: Disable Port1 pin change interrupt<br>1: Enable Port1 pin change interrupt                                                                                                                                                                                                                                                                                   |
|            |          | 0     | SPAIE    | R/W | 0    | SPIA interrupt enable<br>0: Disable SPIA interrupt<br>1: Enable SPIA interrupt                                                                                                                                                                                                                                                                                                                       |
| AAh        | ADCDL    | 7~4   | ADCDL    | R   |      | ADC data bit 3~0                                                                                                                                                                                                                                                                                                                                                                                     |
| ABh        | ADCDH    | 7~0   | ADCDH    | R   |      | ADC data bit 11~4                                                                                                                                                                                                                                                                                                                                                                                    |
|            | PWM0DL   | 7~6   | PWM0DL   | R/W | 0    | PWM0 duty 1~0                                                                                                                                                                                                                                                                                                                                                                                        |
| ACh        | PWM1ADL  | 5~4   | PWM1ADL  | R/W | 0    | PWM1A duty 1~0                                                                                                                                                                                                                                                                                                                                                                                       |
| 7 ICH      | PWM1BDL  | 3~2   | PWM1BDL  | R/W | 0    | PWM1B duty 1~0                                                                                                                                                                                                                                                                                                                                                                                       |
|            | PWM1CDL  | 1~0   | PWM1CDL  | R/W | 0    | PWM1C duty 1~0                                                                                                                                                                                                                                                                                                                                                                                       |
| AEh        | CHSEL    | 7~4   | ADCHS    | R/W | 1111 | ADC channel select<br>0000: ADC0 (P1.0)<br>0001: ADC1 (P1.1)<br>0010: ADC2 (P1.4)<br>0011: ADC3 (P1.5)<br>0100: ADC4 (P1.6)<br>0101: ADC5 (P1.7)<br>0110: ADC6 (P4.0)<br>0111: ADC7 (P4.1)<br>1000: ADC8 (P4.2)<br>1001: ADC9 (P4.3)<br>1010: ADC10(P3.2)<br>1011: ADC11(P3.3)<br>1100: VBG (internal Bandgap voltage without drive)<br>1101: VBGO(internal Bandgap with voltage drive)<br>111x: VSS |
| B0h        | P3       | 7~0   | P3       | R/W | FFh  | Port3 data                                                                                                                                                                                                                                                                                                                                                                                           |
| B1h        | SPBCTRL  | 7     | SPBMOD   | R/W | 0    | SPIB Mode<br>0: P2.6~4 in GPIO<br>1: P2.6~4 in SPIB I/F function                                                                                                                                                                                                                                                                                                                                     |



| SFR<br>Adr | SFR Name | Bit # | Bit Name | R/W   | Rst | Description                                                                |
|------------|----------|-------|----------|-------|-----|----------------------------------------------------------------------------|
|            |          |       |          |       |     | SPIB transfer enable                                                       |
|            |          | 6     | SPBEN    | R/W   | 0   | 0: automatically clears when data transfer complete                        |
|            |          |       |          |       |     | 1: start transfer data and check busy state                                |
|            |          | _     |          |       | _   | SPIB clock polarity                                                        |
|            |          | 5     | SPBCPOL  | R/W   | 0   | 0: BSCK is low in idle state                                               |
|            |          |       |          |       |     | 1: BSCK is high in idle state                                              |
|            |          | 4     | SPBCPHA  | R/W   | 0   | SPIB clock phase<br>0: Data sample on first edge of BSCK period            |
|            |          | +     | SIDCITIA | IX/ W | 0   | 1: Data sample on second edge of BSCK period                               |
|            |          |       |          |       |     | SPIB transfer direction                                                    |
|            |          | 3     | SPBDIR   | R/W   | 0   | 0: transmit data to SPI device                                             |
|            |          |       |          |       |     | 1: receive data from SPI device                                            |
|            |          |       |          |       |     | SPIB transfer LSB first                                                    |
|            |          | 2     | SPBLSBF  | R/W   | 0   | 0: MSB first                                                               |
|            |          |       |          |       |     | 1: LSB first                                                               |
|            |          | 0     |          | DAV   | 0   | SPIB Clear XRAM address                                                    |
|            |          | 0     | CLRADR   | R/W   | 0   | 0: not clear SPIB buffer address<br>1: clear SPIB buffer address to 0      |
|            |          |       |          |       |     | SPIB Clock select;                                                         |
|            |          |       |          |       |     | 0: 12MHz; 1: 6MHz; 2: 4MHz; 3: 3MHz;                                       |
| B2h        | SPBCRS   | 6~0   | SPBCRS   | R/W   | 0   | 4: 2.4MHz; 5: 2MHz; 6: 1.71MHz; 7: 1.5MHz;                                 |
|            |          |       |          |       |     | SPIB clock rate = $FRC24M / (2 * (SPICRS[6:0] + 1))$                       |
| B3h        | DMALEN   | 6~0   | DMALEN   | R/W   | 0   | DMA data transfer length                                                   |
|            |          | 7~6   | P4MOD3   | R/W   | 00  | P4.3 pin control                                                           |
| B4h        | P4MODL   | 5~4   | P4MOD2   | R/W   | 00  | P4.2 pin control                                                           |
| D411       | F4MODL   | 3~2   | P4MOD1   | R/W   | 00  | P4.1 pin control                                                           |
|            |          | 1~0   | P4MOD0   | R/W   | 00  | P4.0 pin control                                                           |
|            |          | 7~6   | P4MOD7   | R/W   | 00  | P4.7 pin control                                                           |
| B5h        | P4MODH   | 5~4   | P4MOD6   | R/W   | 00  | P4.6 pin control                                                           |
| DJII       | r4MODII  | 3~2   | P4MOD5   | R/W   | 00  | P4.5 pin control                                                           |
|            |          | 1~0   | P4MOD4   | R/W   | 00  | P4.4 pin control                                                           |
| B6h        | KBMASK   | 7~0   | KBMASK   |       |     | Mask KSI[7:0] interrupt (KBDI) function while the corresponding bit is "1" |
|            |          | 5     | PT2      | R/W   | 0   | Timer2 interrupt priority low bit                                          |
|            |          | 4     | PS       | R/W   | 0   | Serial Port interrupt priority low bit                                     |
| DOI        | T        | 3     | PT1      | R/W   | 0   | Timer1 interrupt priority low bit                                          |
| B8h        | IP       | 2     | PX1      | R/W   | 0   | INT1 interrupt priority low bit                                            |
|            |          | 1     | PT0      | R/W   | 0   | Timer0 interrupt priority low bit                                          |
|            |          | 0     | PX0      | R/W   | 0   | INT0 interrupt priority low bit                                            |
|            |          | 5     | PT2H     | R/W   | 0   | Timer2 interrupt priority high bit                                         |
|            |          | 4     | PSH      | R/W   | 0   | Serial Port interrupt priority high bit                                    |
| DCI        | 1011     | 3     | PT1H     | R/W   | 0   | Timer1 interrupt priority high bit                                         |
| B9h        | IPH      | 2     | PX1H     | R/W   | 0   | INT1 interrupt priority high bit                                           |
|            |          | 1     | PT0H     | R/W   | 0   | Timer0 interrupt priority high bit                                         |
|            |          | 0     | PX0H     | R/W   | 0   | INT0 interrupt priority high bit                                           |



| SFR  | (1777) N. |          |           | -      |     |                                                                                |
|------|-----------|----------|-----------|--------|-----|--------------------------------------------------------------------------------|
| Adr  | SFR Name  | Bit #    | Bit Name  | R/W    | Rst | Description                                                                    |
|      |           | 5        | PUSB2I    | R/W    | 0   | USB2 interrupt priority low bit                                                |
|      |           | 4        | PUSB1I    | R/W    | 0   | USB1 interrupt priority low bit                                                |
| BAh  | IP1       | 3        | PADI      | R/W    | 0   | ADC interrupt priority low bit                                                 |
| DAII | 11 1      | 2        | PX2       | R/W    | 0   | INT2 interrupt priority low bit                                                |
|      |           | 1        | PP1       | R/W    | 0   | Port1 pin change interrupt priority low bit                                    |
|      |           | 0        | PSPAI     | R/W    | 0   | SPIA interrupt priority low bit                                                |
|      |           | 5        | PUSB1IH   | R/W    | 0   | USB2 interrupt priority high bit                                               |
|      |           | 4        | PUSB1IH   | R/W    | 0   | USB1 interrupt priority high bit                                               |
| DD1  | ID111     | 3        | PADIH     | R/W    | 0   | ADC interrupt priority high bit                                                |
| BBh  | IP1H      | 2        | PX2H      | R/W    | 0   | INT2 interrupt priority high bit                                               |
|      |           | 1        | PP1H      | R/W    | 0   | Port1 interrupt priority high bit                                              |
|      |           | 0        | PSPIH     | R/W    | 0   | SPIA interrupt priority high bit                                               |
|      |           |          |           |        |     | SPIA enable                                                                    |
|      |           | 7        | SPAEN     | R/W    | 0   | 0: SPIA disable                                                                |
|      |           |          |           |        |     | 1: SPIA enable                                                                 |
|      |           |          |           |        | 0   | SPIA Master mode enable                                                        |
|      |           | 6        | SPAMSTR   | R/W    |     | 0: Slave mode                                                                  |
|      |           |          |           |        |     | 1: Master mode                                                                 |
|      |           | 5        | SDACDOI   | R/W    | 0   | SPIA clock polarity<br>0: SCK is low in idle state                             |
|      |           | 5        | SPACPOL   | K/ W   | 0   | 1: SCK is high in idle state                                                   |
|      |           |          |           |        |     | SPIA clock phase                                                               |
|      |           | 4        | SPACPHA   | R/W    | 0   | 0: Data sample on first edge of SCK period                                     |
| BCh  | SPACON    |          |           | 10     | 0   | 1: Data sample on second edge of SCK period                                    |
|      |           |          |           |        |     | SS pin disable                                                                 |
|      |           | 3        | SPASSDIS  | R/W    | 0   | 0: Enable SS pin                                                               |
|      |           |          |           |        |     | 1: Disable SS pin                                                              |
|      |           |          | SPALSBF   | R/W    | 0   | SPIA LSB first                                                                 |
|      |           | 2        |           |        |     | 0: MSB first                                                                   |
|      |           |          |           |        |     | 1: LSB first                                                                   |
|      |           |          |           |        |     | SPIA clock rate                                                                |
|      |           | 1~0      | SPASPCR   | R/W    | 00  | 00: F <sub>SYSCLK</sub> /2<br>01: F <sub>SYSCLK</sub> /4                       |
|      |           | 10       | SIASICK   | 11/ 11 | 00  | 10: F <sub>SYSCLK</sub> /4                                                     |
|      |           |          |           |        |     | $11: F_{\text{sysclk}}/16$                                                     |
|      |           |          |           |        |     | SPIA interrupt flag                                                            |
|      |           | 7        | SDAIE     | DAV    | 0   | This is set by H/W at the end of a data transfer. Cleared                      |
|      |           | 7        | SPAIF     | R/W    | 0   | by H/W when an interrupt is vectored into. Writing 0 to                        |
|      |           |          |           |        |     | this bit will clear this flag.                                                 |
|      |           |          |           |        |     | Write collision interrupt flag                                                 |
|      |           | 6        | SPAWCOL   | R/W    | 0   | Set by H/W if write data to SPADAT when SPABSY is                              |
|      |           |          |           |        |     | set. Write 0 to this bit or rewrite data to SPDAT when                         |
| BDh  | SPASTA    |          |           |        |     | SPABSY is cleared will clear this flag.                                        |
|      | 51115111  | 5 SPAMOD |           |        |     | Mode fault interrupt flag<br>Set by H/W when SPASSDIS is cleared and SS pin is |
|      |           |          | SPAMODE   | R/W    | 0   | pulled low in Master mode. Write 0 to this bit will clear                      |
|      |           |          | SPAMODE   |        | 0   | this flag. When this bit is set, the SPAEN and SPAMSTR                         |
|      |           |          |           |        |     | in SPACON will be cleared by H/W.                                              |
|      |           |          |           |        |     | Received buffer overrun flag                                                   |
|      |           | 4        | SPARCVOVF | R/W    | 0   | Set by H/W at the end of a data transfer and SPARCVBF                          |
|      |           | 4        | SPARCVOVF | K/W    |     | is set. Write 0 to this bit or read SPADAT register will                       |

\_\_\_\_\_



| SFR<br>Adr | SFR Name | Bit #      | Bit Name     | R/W  | Rst                                                                                                           | Description                                                                                                     |
|------------|----------|------------|--------------|------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
|            |          |            |              |      |                                                                                                               | clear this flag.                                                                                                |
|            |          |            |              |      |                                                                                                               | Receive buffer full flag                                                                                        |
|            |          | 3          | SPARCVBF     | R/W  | 0                                                                                                             | Set by H/W at the end of a data transfer. Write 0 to this                                                       |
| BDh        | SPASTA   |            |              |      |                                                                                                               | bit or read SPADAT register will clear this flag.                                                               |
|            |          | 2          | SPABSY       | R    |                                                                                                               | SPIA busy flag                                                                                                  |
|            |          | 2          | SIADSI       | К    |                                                                                                               | Set by H/W when a SPIA transfer is in progress.                                                                 |
|            |          |            |              |      |                                                                                                               | SPIA transmit and receive data                                                                                  |
| DEI        |          | -          |              |      | 0                                                                                                             | The SPADAT register is used to transmit and receive                                                             |
| BEh        | SPADAT   | 7~0        | SPADAT       | R/W  | 0                                                                                                             | data. Writing data to SPADAT place the data into shift                                                          |
|            |          |            |              |      | register and start a transfer when in master mode. Reading SPADAT returns the contents of the receive buffer. |                                                                                                                 |
|            |          |            |              |      |                                                                                                               | SFADAT feturits the contents of the fecerve burier.                                                             |
|            |          |            |              |      |                                                                                                               | P5.0 data, also controls the P5.n pin's pull-up function. If                                                    |
| C0h        | P5       | 0          | P5.0         | R/W  | 1                                                                                                             | the P5.n SFR data is "1" and the corresponding P5OE0=0                                                          |
|            |          |            |              |      |                                                                                                               | (input mode), the pull-up is enabled.                                                                           |
|            |          |            |              |      |                                                                                                               | USB function enable bit                                                                                         |
|            |          | 7          | USBE         | R/W  | 0                                                                                                             | 0: disable P1.2/P1.3 as USB DP/DM pin                                                                           |
| C1h        | USBADR   | •          | 0.222        | 10   | Ū                                                                                                             | 1: enable P1.2/P1.3 as USB DP/DM pin                                                                            |
| -          |          | <i>c</i> 0 |              | р ли | 0                                                                                                             |                                                                                                                 |
|            |          | 6~0        | FUNADR       | R/W  | 0                                                                                                             | USB Function Address                                                                                            |
|            |          | 7          | SET0I        | R/W  | 0                                                                                                             | Endpoint 0 SET0 Receive Interrupt flag, write 0 to clear                                                        |
|            |          | /          | SEIU         | IV W | 0                                                                                                             | flag.                                                                                                           |
|            |          | 6          | OUT0I        | R/W  | 0                                                                                                             | Endpoint 0 OUT Receive Interrupt flag, write 0 to clear                                                         |
|            |          | -          |              |      |                                                                                                               | flag.                                                                                                           |
|            |          | 5          | TX0I         | R/W  | 0                                                                                                             | Endpoint 0 Transmit Interrupt flag, write 0 to clear flag.                                                      |
| C2h        | USB1I    | 4          | TX1I<br>TX2I | R/W  | 0                                                                                                             | Endpoint 1 Transmit Interrupt flag, write 0 to clear flag.                                                      |
|            |          | 3          | TX2I         | R/W  | 0                                                                                                             | Endpoint 2 Transmit Interrupt flag, write 0 to clear flag.                                                      |
|            |          | 2          | SUSPI        | R/W  | 0                                                                                                             | USB Suspend Interrupt flag, write 0 to clear flag.<br>Endpoint 3 Bulk Transmit Interrupt flag, write 0 to clear |
|            |          | 1          | TX3I         | R/W  | 0                                                                                                             | flag.                                                                                                           |
|            |          |            |              |      | -                                                                                                             | Endpoint 4 Bulk Receive Interrupt flag, write 0 to clear                                                        |
|            |          | 0          | RC4I         | R/W  | 0                                                                                                             | flag.                                                                                                           |
|            |          | 7          | VDD5VRI      | R/W  | 0                                                                                                             | VDD5V Rise Interrupt flag, write 0 to clear it                                                                  |
|            |          | 6          | RSTI         | R/W  | 0                                                                                                             | USB Bus Reset Interrupt flag, write 0 to clear flag.                                                            |
| C2h        | USDOI    | 5          | RSMI         | R/W  | 0                                                                                                             | USB Resume Interrupt flag, write 0 to clear flag.                                                               |
| C3h        | USB2I    | 4          | KBDI         | R/W  | 0                                                                                                             | Keyboard Interrupt flag, write 0 to clear flag.                                                                 |
|            |          | 3          | PD_TXI       | R/W  | 0                                                                                                             | USB PD Transmit Interrupt flag, write 0 to clear flag.                                                          |
|            |          | 2          | PD_RCI       | R/W  | 0                                                                                                             | USB PD Receive Interrupt flag, write 0 to clear flag.                                                           |
|            |          | 7          | SUSPND       | R/W  | 0                                                                                                             | F/W set high to force USB interface into suspend mode                                                           |
|            |          | 6          | RSMO         | R/W  | 0                                                                                                             | F/W set high to force USB interface send RESUME signal                                                          |
|            |          |            |              |      |                                                                                                               | in suspend mode                                                                                                 |
|            |          | 5          | EP1CFG       | R/W  | 0                                                                                                             | Write 1 to set Endpoint 1 configed                                                                              |
|            |          | 4          | EP2CFG       | R/W  | 0                                                                                                             | Write 1 to set Endpoint 2 configed                                                                              |
| C4h        | USBCTRL  | 2          | DEVICE P     | D/W  | 0                                                                                                             | USB DP pull-up resistor enable bit<br>0: disable pull-up resistor                                               |
|            |          | 3 DEVICE_R | DEVICE_K     | R/W  | 0                                                                                                             | 1: enable pull-up resistor                                                                                      |
|            |          |            |              |      |                                                                                                               | Endpoint 0 ready for receive control bit                                                                        |
|            |          | _          |              |      |                                                                                                               | 0: Endpoint 0 is not ready for receive OUT packet.                                                              |
|            |          | 2 OU7      | OUT0RDY      | R/W  | 0                                                                                                             | 1: Endpoint 0 is ready for receive from USB Host; cleared                                                       |
|            |          |            |              |      |                                                                                                               | by H/W while OUT0I occurs                                                                                       |
| C5h        | TVOCTDI  | 7          | TYODDY       |      | 0                                                                                                             | Endpoint 0 ready for transmit control bit                                                                       |
| 1 5h       | TX0CTRL  | 7          | TX0RDY       | R/W  | 0                                                                                                             | 0: Endpoint 0 is not ready for IN packet.                                                                       |



| SFR<br>Adr | SFR Name | Bit # | Bit Name | R/W | Rst | Description                                                                                                                                                                                                                   |
|------------|----------|-------|----------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          |       |          |     |     | 1: Endpoint 0 is ready for transmit to USB Host; cleared                                                                                                                                                                      |
|            |          | 6     | TX0TGL   | R/W | 0   | by H/W while TX0I occurs<br>Endpoint 0 transmit data type<br>0: DATA0<br>1: DATA1.                                                                                                                                            |
|            |          | 5     | EPOSTALL | R/W | 0   | 0: Endpoint 0 will not stall OUT/IN packet<br>1: Endpoint 0 will stall OUT/IN packet                                                                                                                                          |
|            |          | 4     | IN0STALL | R/W | 0   | 0: Endpoint 0 will not stall IN packet<br>1: Endpoint 0 will stall IN packet                                                                                                                                                  |
|            |          | 3~0   | TX0CNT   | R/W | 0   | Endpoint 0 transmit byte count<br>F/W set the transmit byte count for IN0 packet                                                                                                                                              |
|            |          | 7     | TX1RDY   | R/W | 0   | <ul><li>Endpoint 1 ready for transmit control bit</li><li>0: Endpoint 1 is not ready for IN packet.</li><li>1: Endpoint 1 is ready for transmit to USB Host; cleared by H/W while TX11 occurs</li></ul>                       |
| C6h        | TX1CTRL  | 6     | TX1TGL   | R/W | 0   | Endpoint 1 transmit data type<br>0: DATA0.<br>1: DATA1.                                                                                                                                                                       |
|            |          | 5     | EP1STALL | R/W | 0   | 0: Endpoint 1 will not stall IN packet<br>1: Endpoint 1 will stall IN packet                                                                                                                                                  |
|            |          | 3~0   | TX1CNT   | R/W | 0   | Endpoint 1 transmit byte count<br>F/W set the transmit byte count for IN1 packet                                                                                                                                              |
|            | TX2CTRL  | 7     | TX2RDY   | R/W | 0   | <ul> <li>Endpoint 2 ready for transmit control bit</li> <li>O: Endpoint 2 is not ready for IN packet.</li> <li>1: Endpoint 2 is ready for transmit to USB Host; cleared by H/W while TX2I occurs</li> </ul>                   |
| C7h        |          | 6     | TX2TGL   | R/W | 0   | Endpoint 2 transmit data type<br>0: DATA0.<br>1: DATA1.                                                                                                                                                                       |
|            |          | 5     | EP2STALL | R/W | 0   | 0: Endpoint 2 will not stall IN packet<br>1: Endpoint 2 will stall IN packet                                                                                                                                                  |
|            |          | 3~0   | TX2CNT   | R/W | 0   | Endpoint 2 transmit byte count<br>F/W set the transmit byte count for IN2 packet                                                                                                                                              |
|            |          | 7     | TF2      | R/W | 0   | Timer2 overflow flag<br>Set by H/W when Timer/Counter 2 overflows unless<br>RCLK=1 or TCLK=1. This bit must be cleared by S/W.                                                                                                |
|            |          | 6     | EXF2     | R/W | 0   | T2EX interrupt pin falling edge flag<br>Set when a capture or a reload is caused by a negative<br>transition on T2EX pin if EXEN2=1. This bit must be<br>cleared by S/W.                                                      |
| C8h        | T2CON    | 5     | RCLK     | R/W | 0   | <ul> <li>UART receive clock control bit</li> <li>0: Use Timer1 overflow as receive clock for serial port in mode 1 or 3</li> <li>1: Use Timer2 overflow as receive clock for serial port in mode 1 or 3</li> </ul>            |
|            |          | 4     | TCLK     | R/W | 0   | <ul> <li>UART transmit clock control bit</li> <li>0: Use Timer1 overflow as transmit clock for serial port<br/>in mode 1 or 3</li> <li>1: Use Timer2 overflow as transmit clock for serial port<br/>in mode 1 or 3</li> </ul> |
|            |          | 3     | EXEN2    | R/W | 0   | <ul><li>T2EX pin enable</li><li>0: T2EX pin disable</li><li>1: T2EX pin enable, it cause a capture or reload when a</li></ul>                                                                                                 |



| SFR<br>Adr | SFR Name | Bit # | Bit Name | R/W    | Rst | Description                                                                |
|------------|----------|-------|----------|--------|-----|----------------------------------------------------------------------------|
|            |          |       |          |        |     | negative transition on T2EX pin is detected if                             |
|            |          |       |          |        |     | RCLK=TCLK=0<br>Timer2 run control                                          |
|            |          | 2     | TR2      | R/W    | 0   | 0: Timer2 stops                                                            |
|            |          | 2     | 1 K2     | IX/ VV | 0   | 1: Timer2 runs                                                             |
|            |          |       |          |        |     | Timer2 Counter/Timer select bit                                            |
|            |          |       |          |        |     | 0: Timer mode, Timer2 data increases at 2 System clock                     |
|            |          | 1     | CT2N     | R/W    | 0   | cycle rate                                                                 |
|            |          |       |          |        |     | 1: Counter mode, Timer2 data increases at T2 pin's                         |
|            |          |       |          |        |     | negative edge                                                              |
|            |          |       |          |        |     | Timer2 Capture/Reload control bit                                          |
|            |          |       |          |        |     | 0: Reload mode, auto-reload on Timer2 overflows or                         |
|            |          | 0     | CDDI 2NI | DAV    | 0   | negative transitions on T2EX pin if EXEN2=1                                |
|            |          | 0     | CPRL2N   | R/W    | 0   | 1: Capture mode, capture on negative transitions on<br>T2EX pin if EXEN2=1 |
|            |          |       |          |        |     | If RCLK=1 or TCLK=1, CPRL2N is ignored and timer is                        |
|            |          |       |          |        |     | forced to auto-reload on Timer2 overflow                                   |
|            |          |       |          |        |     | (W): Write 47h to set IAPWE control flag; Write other                      |
| COL        |          | 7     | IAPWE    | R/W    | 0   | value to clear IAPWE flag                                                  |
| C9h        | IAPWE    |       |          |        |     | (R) : IAPWE flag                                                           |
|            |          | 6     | IAPTO    | R      |     | IAP TimeOut flag                                                           |
| CAh        | RCP2L    | 7~0   | RCP2L    | R/W    | 00h | Timer2 reload/capture data low byte                                        |
| CBh        | RCP2H    | 7~0   | RCP2H    | R/W    | 00h | Timer2 reload/capture data high byte                                       |
| CCh        | TL2      | 7~0   | TL2      | R/W    | 00h | Timer2 data low byte                                                       |
| CDh        | TH2      | 7~0   | TH2      | R/W    | 00h | Timer2 data high byte                                                      |
|            |          |       |          | R/W    | 0   | Endpoint 3 ready for transmit control bit                                  |
|            |          | 7     | TX3RDY   |        |     | 0: Endpoint 3 is not ready for IN packet.                                  |
|            |          | /     | TASKDT   | IX/ VV | 0   | 1: Endpoint 3 is ready for transmit to USB Host; cleared                   |
|            |          |       |          |        |     | by H/W while TX3I occurs                                                   |
| CEh        | TX3CTRL  |       | TRATICI  |        | 0   | Endpoint 3 transmit data type                                              |
|            |          | 6     | TX3TGL   | R/W    | 0   | 0: DATA0                                                                   |
|            |          |       |          |        |     | 1: DATA1.<br>0: Endpoint 3 will not stall IN packet                        |
|            |          | 5     | EP3STALL | R/W    | 0   | 1: Endpoint 3 will stall IN packet                                         |
|            |          | 4     | EP3CFG   | R/W    | 0   | Write 1 to set Endpoint 3 configed                                         |
|            |          |       |          | 10 11  | 0   | Endpoint 4 ready for receive control bit                                   |
|            |          | 7     | DCADDY   | DAV    | 0   | 0: Endpoint 4 is not ready for OUT packet.                                 |
|            |          | 7     | RC4RDY   | R/W    | 0   | 1: Endpoint 4 is ready for receive from USB Host; cleared                  |
|            |          |       |          |        |     | by H/W while RC4I occurs                                                   |
|            |          | 6     | EP4STALL | R/W    | 0   | 0: Endpoint 3 will not stall OUT packet                                    |
|            |          |       |          |        |     | 1: Endpoint 4 will stall OUT packet                                        |
| CFh        | RC4CTRL  | 5     | EP4CFG   | R/W    | 0   | Write 1to set Endpoint 4 configed                                          |
|            |          |       | DOATO    | D      |     | Endpoint 4 received data type                                              |
|            |          | 4     | RC4TGL   | R      |     | 0: DATA0<br>1: DATA1.                                                      |
|            |          |       |          |        |     | Endpoint 4 received data error status flag                                 |
|            |          | 3     | RC4ERR   | R      |     | 0: Endpoint 4 received data error status hag                               |
|            |          |       |          |        |     | 1: Endpoint 4 received data is error                                       |
|            |          | 7     | CY       | R/W    | 0   | ALU carry flag                                                             |
| D0h        | PSW      | 6     | AC       | R/W    | 0   | ALU auxiliary carry flag                                                   |
|            |          | 5     | F0       | R/W    | 0   | General purpose user-definable flag                                        |
|            |          |       | - 0      |        | 5   | purpose user astrinuoro nug                                                |



| SFR<br>Adr | SFR Name | Bit # | Bit Name | R/W | Rst | Description                                                                                                                                                     |
|------------|----------|-------|----------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |          | 4     | RS1      | R/W | 0   | The contents of (RS1, RS0) enable the working register<br>banks as:<br>00: Bank 0 (00h~07h)                                                                     |
|            |          | 3     | RS0      | R/W | 0   | 01: Bank 1 (08h~0Fh)<br>10: Bank 2 (10h~17h)<br>11: Bank 3 (18h~1Fh)                                                                                            |
|            |          | 2     | OV       | R/W | 0   | ALU overflow flag                                                                                                                                               |
|            |          | 1     | F1       | R/W | 0   | General purpose user-definable flag                                                                                                                             |
|            |          | 0     | Р        | R/W | 0   | Parity flag. Set/cleared by hardware each instruction cycle<br>to indicate odd/even number of "one" bits in the<br>accumulator.                                 |
| D1h        | TX3CNT   | 6~0   | TX3CNT   | R/W | 0   | Endpoint 3 transmit byte count<br>F/W set the transmit byte count for IN3 packet                                                                                |
| D2h        | RC4CNT   | 6~0   | RC4CNT   | R   |     | Endpoint 4 received byte count<br>F/W read the received byte count from OUT4 packet                                                                             |
|            |          | 7     | RC0TGL   | R   |     | Endpoint 0 received data type<br>0: DATA0<br>1: DATA1.                                                                                                          |
|            |          | 6     | RC0ERR   | R   |     | Endpoint 0 received data error status flag<br>0: Endpoint 0 received data is correct<br>1: Endpoint 0 received data is error                                    |
| D3h        | RCOREG   | 5     | EP0DIR   | R   |     | Endpoint 0 transfer direction<br>0: OUT/SETUP transfer<br>1: IN transfer                                                                                        |
|            |          | 4     | EPOSET   | R   |     | Endpoint 0 SETUP Token indicator<br>0: not SETUP Token<br>1: SETUP Token                                                                                        |
|            |          | 3~0   | OUT0CNT  | R   |     | Endpoint 0 received OUT packet byte count<br>F/W read the received byte count from OUT0 packet                                                                  |
|            |          | 3     | I80BUSY  | R   |     | I80 Interface state of data transfer<br>0: I80 interface is idle<br>1: I80 interface is busy                                                                    |
| DI         |          | 2     | I80EN    | R/W | 0   | Enable I80 I/F DMA mode<br>0: disable I80 DMA mode<br>1: enable I80 DMA mode                                                                                    |
| D4h        | I80CTRL  | 1     | I80START | R/W | 0   | <ul><li>I80 I/F data transfer start bit</li><li>0: write 0 to clear it if data transfer completes</li><li>1: write 1 to set it to start data transfer</li></ul> |
|            |          | 0     | I80DIR   | R/W | 0   | <ul><li>I80 I/F data transfer direction</li><li>0: write data to device</li><li>1: read data from device</li></ul>                                              |
|            | XRAMCTRL | 7     | XRAM4UPD | R/W | 0   | XRAM4 access control bit<br>0: XRAM4 is access by MCU<br>1: XRAM4 is access by USB PD Receive message<br>function                                               |
| D6h        |          | 6     | XRAM3UPD | R/W | 0   | XRAM3 access control bit<br>0: XRAM3 is access by MCU<br>1: XRAM3 is access by USB PD Transmit message<br>function                                              |
|            |          | 5     | XRAM1USB | R/W | 0   | XRAM1 access control bit<br>1: assign XRAM1 as USB Bulk transfer buffer.                                                                                        |



| SFR<br>Adr | SFR Name | Bit # | Bit Name    | R/W                                                            | Rst | Description                                                                                                                                                                                                                              |  |
|------------|----------|-------|-------------|----------------------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Au         |          | 4     | VD A MOLICD | DAV                                                            | 0   | XRAM2 access control bit                                                                                                                                                                                                                 |  |
|            |          | 4     | XRAM2USB    | R/W                                                            | 0   | 1: assign XRAM2 as USB Bulk transfer buffer.                                                                                                                                                                                             |  |
|            |          | 3     | XRAM1SPB    | R/W                                                            | 0   | XRAM1 access control bit<br>1: assign XRAM1 as SPIB DMA transfer buffer.                                                                                                                                                                 |  |
|            |          | 2     | XRAM2SPB    | R/W                                                            | 0   | XRAM2 access control bit<br>1: assign XRAM2 as SPIB DMA transfer buffer                                                                                                                                                                  |  |
|            |          | 1     | XRAM1I80    | R/W                                                            | 0   | XRAM1 access control bit<br>1: assign XRAM1 as I80 DMA transfer buffer                                                                                                                                                                   |  |
|            |          | 0     | XRAM2I80    | R/W                                                            | 0   | XRAM2 access control bit<br>1: assign XRAM2 as I80 DMA transfer buffer                                                                                                                                                                   |  |
|            |          | 5     | STPSCK      | R/W                                                            | 0   | Set 1 to stop SRC                                                                                                                                                                                                                        |  |
|            |          | 4     | STPPCK      | R/W                                                            | 0   | Set 1 to stop UART/Timer0/Timer1/Timer2/ADC clock in Idle mode                                                                                                                                                                           |  |
|            |          | 3     | STPFCK      | R/W                                                            | 0   | Set 1 to stop Fast clock for power saving in Slow / Idle mode. This bit can be changed only in Slow mode.                                                                                                                                |  |
| D8h        | CLKCON   | 2     | SELFCK      | R/W                                                            | 0   | System clock source selection. This bit can be changed<br>only when STPFCK=0.<br>0: Slow clock<br>1: Fast clock                                                                                                                          |  |
|            |          | 1~0   | CLKPSC      | R/W                                                            | 11  | System clock prescaler.<br>00: System clock is Fast/Slow clock divided by 16<br>01: System clock is Fast/Slow clock divided by 4<br>10: System clock is Fast/Slow clock divided by 2<br>11: System clock is Fast/Slow clock divided by 1 |  |
|            |          | 7     | SET0IE      | R/W                                                            | 0   | Endpoint 0 SET0 Receive Interrupt enable bit<br>0: disable<br>1: enable interrupt service                                                                                                                                                |  |
|            |          | 6     | OUT0IE      | FOIER/W0Endpoint 0 OUT0 Receive Interrupt enable bit0: disable |     | Endpoint 0 OUT0 Receive Interrupt enable bit                                                                                                                                                                                             |  |
|            |          | 5     | TX0IE       | R/W                                                            | 0   | Endpoint 0 Transmit Interrupt enable bit<br>0: disable<br>1: enable interrupt service                                                                                                                                                    |  |
|            |          | 4     | TX1IE       | R/W                                                            | 0   | Endpoint 1 Transmit Interrupt enable bit<br>0: disable<br>1: enable interrupt service                                                                                                                                                    |  |
| DAh        | USB1IE   | 3     | TX2IE       | R/W                                                            | 0   | Endpoint 2 Transmit Interrupt enable bit<br>0: disable<br>1: enable interrupt service                                                                                                                                                    |  |
|            |          |       | SUSPIE      | R/W                                                            | 0   | USB Suspend Interrupt enable bit<br>0: disable<br>1: enable interrupt service                                                                                                                                                            |  |
|            |          |       | TX3IE       | R/W                                                            | 0   | Endpoint 3 Bulk Transmit Interrupt enable bit<br>0: disable<br>1: enable interrupt service                                                                                                                                               |  |
|            |          | 0     | RC4IE       | R/W                                                            | 0   | Endpoint 4 Bulk receive Interrupt enable bit<br>0: disable<br>1: enable interrupt service                                                                                                                                                |  |
| DBh        | USB2IE   | 7     | VDD5CRIE    | R/W                                                            | 0   | USB Bus power VDD5V Rise Interrupt enable bit<br>0: disable<br>1: enable interrupt service                                                                                                                                               |  |
|            |          | 6     | RSTIE       | R/W                                                            | 0   | USB Bus Reset Interrupt enable bit                                                                                                                                                                                                       |  |

\_\_\_\_\_



| SFR<br>Adr | SFR Name | Bit # | Bit Name | R/W | Rst | Description                                                                                                                    |
|------------|----------|-------|----------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------|
|            |          |       |          |     |     | 0: disable<br>1: enable interrupt service<br>USB Resume Interrupt enable bit                                                   |
|            |          |       | RSMIE    | R/W | 0   | 0: disable<br>1: enable interrupt service                                                                                      |
|            |          | 4     | KBDIE    | R/W | 0   | Keyboard Scan Interrupt enable bit<br>0: disable<br>1: enable interrupt service                                                |
|            |          | 3     | PD_TXIE  | R/W | 0   | USB PD Transmit Interrupt enable bit<br>0: disable<br>1: enable interrupt service                                              |
|            |          | 2     | PD_RCIE  | R/W | 0   | USB PD Receive Interrupt enable bit<br>0: disable<br>1: enable interrupt service                                               |
| DCh        | USBRSTM  | 2     | UTMEN    | R/W | 0   | USB Reset Timeout enable<br>0: disable<br>1: enable                                                                            |
|            |          | 1~0   | UTMS     | R/W | 0   | USB Reset Timeout time select<br>00: 2ms; 01: 3ms; 10: 4ms; 11: 5ms                                                            |
|            |          | 7     | USBPDEN  | R/W | 0   | USB PD mode enable bit<br>0: disable<br>1: enable USB PD mode                                                                  |
|            |          | 6     | PDTXRDY  | R/W | 0   | <ul><li>SB PD ready for transmit control bit</li><li>0: not ready</li><li>1: USB PD is ready for transmit PD message</li></ul> |
|            |          | 5     | PDRXRDY  | R/W | 0   | SB PD ready to receive control bit<br>0: not ready<br>1: USB PD is ready to receive PD message                                 |
| DFh        | PDCTRL   | 4     | SCC      | R/W | 0   | Select CC1 or CC2 as CC pin<br>0: select CC1 as CC pin<br>1: select CC2 as CC pin                                              |
|            |          | 3     | SCCO2    | R/W | 0   | Resistor connect to CC2 pin control bit<br>0: disconnect the resistor to CC1 pin<br>1: connect the resistor to CC1 pin         |
|            |          | 2     | SCCO1    | R/W | 0   | Resistor connect to CC1 pin control bit<br>0: disconnect the resistor to CC1 pin<br>1: connect the resistor to CC1 pin         |
|            |          | 1~0   | CCS      | R/W | 3h  | CC pin connect resistor select<br>00: 5.1K ohm to Ground<br>01: 10K ohm to VDD5<br>10: 22K ohm to VDD5<br>11: 56K ohm to VDD5  |
| E0h        | ACC      | 7~0   | ACC      | R/W | 00h | Accumulator                                                                                                                    |
| E8h        | P4       | 7~0   | P4       | R/W | FFh | Port4 data                                                                                                                     |
|            |          | 2     | ANTOE    | R/W | 0   | Enable Analog Test pin to P4.6<br>0: disable<br>1: enable                                                                      |
| EF         | ANAT     | 1~0   | SANTO    | R/W | 0   | Select Analog Test pin source<br>00: VBG<br>01: VBGO<br>10: VPD<br>11: ADOPO                                                   |



| SFR<br>Adr | SFR Name | Bit # | Bit Name | R/W | Rst | Description                                                                                                                                                                                                                          |
|------------|----------|-------|----------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F0h        | В        | 7~0   | В        | R/W | 00h | B register                                                                                                                                                                                                                           |
|            |          | 7     | VDD5VFLG | R   |     | PC5V status<br>0: PC5V Low<br>1: PC5V High (USB plug in)                                                                                                                                                                             |
| F5h        | AUX2     | 6     | VDD5FALL | R/W | 0   | USB Plug out flag, write 0 or power on reset to clear flag                                                                                                                                                                           |
|            |          | 2~1   | IAPTE    | R/W | 0   | IAP Timeout                                                                                                                                                                                                                          |
|            |          | 0     | VCCFLT   | R/W | 0   | VCC line filter enable                                                                                                                                                                                                               |
| F6h        | VBGTM    | 3~0   | VBGTM    | R/W |     | Band-gap Voltage adjustment value, load from configuration Word after power on reset                                                                                                                                                 |
| F7h        | FRCTM    | 4~0   | FRCTM    | R/W |     | Fast RC adjustment value, load from configuration Word after power on reset                                                                                                                                                          |
|            |          | 7     | CLRWDT   | R/W | 0   | Set to clear WDT, H/W auto clear it at next clock cycle                                                                                                                                                                              |
|            | F8h AUX1 |       | WDTE     | R/W |     | <ul> <li>Watchdog Timer Reset control</li> <li>0x: Watchdog Timer Reset disable</li> <li>10: Watchdog Timer Reset enable in Fast/Slow mode,<br/>disable in Idle/Stop mode</li> <li>11: Watchdog Timer Reset always enable</li> </ul> |
| F8h        |          |       | ADSOC    | R/W | 0   | Start ADC conversion<br>Set the ADSOC bit to start ADC conversion, and the<br>ADSOC bit will be cleared by H/W at the end of<br>conversion. S/W can also write 0 to clear this flag.                                                 |
| 1 011      |          |       | CLRPWM0  | R/W | 0   | PWM0 clear enable<br>0: PWM0 is running<br>1: PWM0 is cleared and held                                                                                                                                                               |
|            |          |       | PDADOP   | R/W | 0   | ADC input bypass ADCOP<br>0: ADC input through ADCOP<br>1: ADC input bypass ADCOP                                                                                                                                                    |
|            |          | 1     | BOOTV    | R/W | 0   | BOOT vector select; load from Configuration Word<br>0: Boot from ROM address 0000h<br>1: BootT from ROM address 3000h                                                                                                                |
|            |          | 0     | DPSEL    | R/W | 0   | Active DPTR Select                                                                                                                                                                                                                   |

| Flash<br>Adr | Bit # | Name   | Description                                                                                                            |
|--------------|-------|--------|------------------------------------------------------------------------------------------------------------------------|
| 3FFCh        | 3~0   | VBGTM  | Band-gap Voltage adjustment                                                                                            |
| 3FFEh        | 4~0   | FRCTM  | Fast RC frequency adjustment                                                                                           |
|              | 7     | PROT   | Flash Memory Code Protect<br>0: Disable protect<br>1: Enable protect                                                   |
|              | 6     | XRSTE  | External Pin Reset control<br>0: Disable External Pin Reset<br>1: Enable External Pin Reset                            |
| 3FFFh        | 5~4   | LVRE   | Low Voltage Reset function select<br>00: Set LVR at 2.9V<br>01: Set LVR at 2.3V<br>10: reserved<br>11: Set LVR at 2.1V |
|              | 2     | PWRSAV | Power save function control bit<br>0: Disable Power save function<br>1: Enable Power save function                     |



|   | 1 | MVCLOCK | If 1, the MOVC & MOVX instruction's accessibility to MOVC-Lock area is limited.        |
|---|---|---------|----------------------------------------------------------------------------------------|
|   | 0 | BOOTV   | BOOT vector select<br>0: Boot from ROM address 0000h<br>1: Boot from ROM address 3000h |
| L |   |         | 1. Boot noin Kow address 5000ii                                                        |

### **INSTRUCTION SET**

Instructions are 1, 2 or 3 Bytes long as listed in the 'byte' column below. Each instruction takes 2~8 System clock cycles to execute as listed in the 'cycle' column below.

|               | ARITHMETIC                                  | ARITHMETIC |       |        |  |  |  |  |  |
|---------------|---------------------------------------------|------------|-------|--------|--|--|--|--|--|
| Mnemonic      | Description                                 | byte       | cycle | opcode |  |  |  |  |  |
| ADD A, Rn     | Add register to A                           | 1          | 2     | 28-2F  |  |  |  |  |  |
| ADD A, dir    | Add direct byte to A                        | 2          | 2     | 25     |  |  |  |  |  |
| ADD A, @Ri    | Add indirect memory to A                    | 1          | 2     | 26-27  |  |  |  |  |  |
| ADD A, #data  | Add immediate to A                          | 2          | 2     | 24     |  |  |  |  |  |
| ADDC A, Rn    | Add register to A with carry                | 1          | 2     | 38-3F  |  |  |  |  |  |
| ADDC A, dir   | Add direct byte to A with carry             | 2          | 2     | 35     |  |  |  |  |  |
| ADDC A, @Ri   | Add indirect memory to A with carry         | 1          | 2     | 36-37  |  |  |  |  |  |
| ADDC A, #data | Add immediate to A with carry               | 2          | 2     | 34     |  |  |  |  |  |
| SUBB A, Rn    | Subtract register from A with borrow        | 1          | 2     | 98-9F  |  |  |  |  |  |
| SUBB A, dir   | Subtract direct byte from A with borrow     | 2          | 2     | 95     |  |  |  |  |  |
| SUBB A, @Ri   | Subtract indirect memory from A with borrow | 1          | 2     | 96-97  |  |  |  |  |  |
| SUBB A, #data | Subtract immediate from A with borrow       | 2          | 2     | 94     |  |  |  |  |  |
| INC A         | Increment A                                 | 1          | 2     | 04     |  |  |  |  |  |
| INC Rn        | Increment register                          | 1          | 2     | 08-0F  |  |  |  |  |  |
| INC dir       | Increment direct byte                       | 2          | 2     | 05     |  |  |  |  |  |
| INC @Ri       | Increment indirect memory                   | 1          | 2     | 06-07  |  |  |  |  |  |
| DEC A         | Decrement A                                 | 1          | 2     | 14     |  |  |  |  |  |
| DEC Rn        | Decrement register                          | 1          | 2     | 18-1F  |  |  |  |  |  |
| DEC dir       | Decrement direct byte                       | 2          | 2     | 15     |  |  |  |  |  |
| DEC @Ri       | Decrement indirect memory                   | 1          | 2     | 16-17  |  |  |  |  |  |
| INC DPTR      | Increment data pointer                      | 1          | 4     | A3     |  |  |  |  |  |
| MUL AB        | Multiply A by B                             | 1          | 8     | A4     |  |  |  |  |  |
| DIV AB        | Divide A by B                               | 1          | 8     | 84     |  |  |  |  |  |
| DA A          | Decimal Adjust A                            | 1          | 2     | D4     |  |  |  |  |  |

|                | LOGICAL                           |      |       |        |  |  |  |
|----------------|-----------------------------------|------|-------|--------|--|--|--|
| Mnemonic       | Description                       | byte | cycle | opcode |  |  |  |
| ANL A, Rn      | AND register to A                 | 1    | 2     | 58-5F  |  |  |  |
| ANL A, dir     | AND direct byte to A              | 2    | 2     | 55     |  |  |  |
| ANL A, @Ri     | AND indirect memory to A          | 1    | 2     | 56-57  |  |  |  |
| ANL A, #data   | AND immediate to A                | 2    | 2     | 54     |  |  |  |
| ANL dir, A     | AND A to direct byte              | 2    | 2     | 52     |  |  |  |
| ANL dir, #data | AND immediate to direct byte      | 3    | 4     | 53     |  |  |  |
| ORL A, Rn      | OR register to A                  | 1    | 2     | 48-4F  |  |  |  |
| ORL A, dir     | OR direct byte to A               | 2    | 2     | 45     |  |  |  |
| ORL A, @Ri     | OR indirect memory to A           | 1    | 2     | 46-47  |  |  |  |
| ORL A, #data   | OR immediate to A                 | 2    | 2     | 44     |  |  |  |
| ORL dir, A     | OR A to direct byte               | 2    | 2     | 42     |  |  |  |
| ORL dir, #data | OR immediate to direct byte       | 3    | 4     | 43     |  |  |  |
| XRL A, Rn      | Exclusive-OR register to A        | 1    | 2     | 68-6F  |  |  |  |
| XRL A, dir     | Exclusive-OR direct byte to A     | 2    | 2     | 65     |  |  |  |
| XRL A, @Ri     | Exclusive-OR indirect memory to A | 1    | 2     | 66-67  |  |  |  |



|                | LOGICAL                               |      |       |        |  |  |  |
|----------------|---------------------------------------|------|-------|--------|--|--|--|
| Mnemonic       | Description                           | byte | cycle | opcode |  |  |  |
| XRL A, #data   | Exclusive-OR immediate to A           | 2    | 2     | 64     |  |  |  |
| XRL dir, A     | Exclusive-OR A to direct byte         | 2    | 2     | 62     |  |  |  |
| XRL dir, #data | Exclusive-OR immediate to direct byte | 3    | 4     | 63     |  |  |  |
| CLR A          | Clear A                               | 1    | 2     | E4     |  |  |  |
| CPL A          | Complement A                          | 1    | 2     | F4     |  |  |  |
| SWAP A         | Swap Nibbles of A                     | 1    | 2     | C4     |  |  |  |
| RL A           | Rotate A left                         | 1    | 2     | 23     |  |  |  |
| RLC A          | Rotate A left through carry           | 1    | 2     | 33     |  |  |  |
| RR A           | Rotate A right                        | 1    | 2     | 03     |  |  |  |
| RRC A          | Rotate A right through carry          | 1    | 2     | 13     |  |  |  |

\_\_\_\_

|                 | DATA TRANSFER                         |        |       |        |
|-----------------|---------------------------------------|--------|-------|--------|
| Mnemonic        | Description                           | byte   | cycle | opcode |
| MOV A, Rn       | Move register to A                    | 1      | 2     | E8-EF  |
| MOV A, dir      | Move direct byte to A                 | 2      | 2     | E5     |
| MOV A, @Ri      | Move indirect memory to A             | 1      | 2     | E6-E7  |
| MOV A, #data    | Move immediate to A                   | 2      | 2     | 74     |
| MOV Rn, A       | Move A to register                    | 1      | 2     | F8-FF  |
| MOV Rn, dir     | Move direct byte to register          | 2      | 4     | A8-AF  |
| MOV Rn, #data   | Move immediate to register            | 2      | 2     | 78-7F  |
| MOV dir, A      | Move A to direct byte                 | 2      | 2     | F5     |
| MOV dir, Rn     | Move register to direct byte          | 2      | 4     | 88-8F  |
| MOV dir, dir    | Move direct byte to direct byte       | 3      | 4     | 85     |
| MOV dir, @Ri    | Move indirect memory to direct byte   | 2<br>3 | 4     | 86-87  |
| MOV dir, #data  | Move immediate to direct byte         | 3      | 4     | 75     |
| MOV @Ri, A      | Move A to indirect memory             | 1      | 2     | F6-F7  |
| MOV @Ri, dir    | Move direct byte to indirect memory   | 2<br>2 | 4     | A6-A7  |
| MOV @Ri, #data  | Move immediate to indirect memory     |        | 2     | 76-77  |
| MOV DPTR, #data | Move immediate to data pointer        | 3      | 4     | 90     |
| MOVC A, @A+DPTR | Move code byte relative DPTR to A     | 1      | 4     | 93     |
| MOVC A, @A+PC   | Move code byte relative PC to A       | 1      | 4     | 83     |
| MOVX A, @Ri     | Move external data (A8) to A          | 1      | 4     | E2-E3  |
| MOVX A, @DPTR   | Move external data (A16) to A         | 1      | 4     | E0     |
| MOVX @Ri, A     | Move A to external data (A8)          | 1      | 4     | F2-F3  |
| MOVX @DPTR, A   | Move A to external data (A16)         | 1      | 4     | F0     |
| PUSH dir        | Push direct byte onto stack           | 2      | 4     | C0     |
| POP dir         | Pop direct byte from stack            | 2      | 4     | D0     |
| XCH A, Rn       | Exchange A and register               | 1      | 2     | C8-CF  |
| XCH A, dir      | Exchange A and direct byte            | 2      | 2     | C5     |
| XCH A, @Ri      | Exchange A and indirect memory        | 1      | 2     | C6-C7  |
| XCHD A, @Ri     | Exchange A and indirect memory nibble | 1      | 2     | D6-D7  |

| BOOLEAN    |                         |      |       |        |  |  |
|------------|-------------------------|------|-------|--------|--|--|
| Mnemonic   | Description             | byte | cycle | opcode |  |  |
| CLR C      | Clear carry             | 1    | 2     | C3     |  |  |
| CLR bit    | Clear direct bit        | 2    | 2     | C2     |  |  |
| SETB C     | Set carry               | 1    | 2     | D3     |  |  |
| SETB bit   | Set direct bit          | 2    | 2     | D2     |  |  |
| CPL C      | Complement carry        | 1    | 2     | B3     |  |  |
| CPL bit    | Complement direct bit   | 2    | 2     | B2     |  |  |
| ANL C, bit | AND direct bit to carry | 2    | 4     | 82     |  |  |



| ANL C, /bit              | AND direct bit inverse to carry                      | 2             | 4 | B0       |  |  |  |  |  |
|--------------------------|------------------------------------------------------|---------------|---|----------|--|--|--|--|--|
| ORL C, bit               | OR direct bit inverse to early                       | 2             | 4 | D0<br>72 |  |  |  |  |  |
| ORL C, /bit              | OR direct bit inverse to carry                       | $\frac{2}{2}$ | 4 | A0       |  |  |  |  |  |
| MOV C, bit               | Move direct bit to carry                             | 2             | 2 | A2       |  |  |  |  |  |
| MOV C, bit<br>MOV bit, C | Move carry to direct bit                             | $\frac{2}{2}$ | 4 | 92       |  |  |  |  |  |
|                          | BRANCHING                                            |               |   |          |  |  |  |  |  |
| Mnemonic                 |                                                      |               |   |          |  |  |  |  |  |
| ACALL addr 11            | Absolute jump to subroutine                          | 2             | 4 | 11-F1    |  |  |  |  |  |
| LCALL addr 16            | Long jump to subroutine                              | 3             | 4 | 12       |  |  |  |  |  |
| RET                      | Return from subroutine                               | 1             | 4 | 22       |  |  |  |  |  |
| RETI                     | Return from interrupt                                | 1             | 4 | 32       |  |  |  |  |  |
| AJMP addr 11             | Absolute jump unconditional                          | 2             | 4 | 01-E1    |  |  |  |  |  |
| LJMP addr 16             | Long jump unconditional                              | 3             | 4 | 02       |  |  |  |  |  |
| SJMP rel                 | Short jump (relative address)                        | 2             | 4 | 80       |  |  |  |  |  |
| JC rel                   | Jump on carry=1                                      | 2             | 4 | 40       |  |  |  |  |  |
| JNC rel                  | Jump on carry=0                                      | 2             | 4 | 50       |  |  |  |  |  |
| JB bit, rel              | Jump on direct bit=1                                 | 3             | 4 | 20       |  |  |  |  |  |
| JNB bit, rel             | Jump on direct bit=0                                 | 3             | 4 | 30       |  |  |  |  |  |
| JBC bit, rel             | Jump on direct bit=1 and clear                       | 3             | 4 | 10       |  |  |  |  |  |
| JMP @A+DPTR              | Jump indirect relative DPTR                          | 1             | 4 | 73       |  |  |  |  |  |
| JZ rel                   | Jump on accumulator=0                                | 2             | 4 | 60       |  |  |  |  |  |
| JNZ rel                  | Jump on accumulator 0                                | 2<br>3        | 4 | 70       |  |  |  |  |  |
| CJNE A, dir,rel          | Compare A, direct, jump not equal relative           | 3             | 4 | B5       |  |  |  |  |  |
| CJNE A, #data, rel       | Compare A, immediate, jump not equal relative        | 3             | 4 | B4       |  |  |  |  |  |
| CJNE Rn, #data, rel      | Compare register, immediate, jump not equal relative | 3             | 4 | B8-BF    |  |  |  |  |  |
| CJNE @Ri, #data, rel     | Compare indirect, immediate, jump not equal relative | 3             | 4 | B6-B7    |  |  |  |  |  |
| DJNZ Rn, rel             | Decrement register, jump not zero relative           | 2             | 4 | D8-DF    |  |  |  |  |  |
| DJNZ dir, rel            | Decrement direct byte, jump not zero relative        | 3             | 4 | D5       |  |  |  |  |  |

| MISCELLANEOUS |              |      |       |        |  |  |
|---------------|--------------|------|-------|--------|--|--|
| Mnemonic      | Description  | byte | cycle | opcode |  |  |
| NOP           | No operation | 1    | 2     | 00     |  |  |

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-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.



## **ELECTRICAL CHARACTERISTICS**

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

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

#### 2. DC Characteristics ( $T_A=25^{\circ}C$ , $V_{CC}=2.0V \sim 5.5V$ )

| Parameter                              | Symbol           | Cone                                       | ditions                                                                   | Min.        | Typ. | Max.        | Unit |
|----------------------------------------|------------------|--------------------------------------------|---------------------------------------------------------------------------|-------------|------|-------------|------|
|                                        |                  | Fast mode, F <sub>SYS</sub>                | <sub>CLK</sub> =11.0592 MHz                                               | 2.9         | _    | 5.5         |      |
| Q                                      |                  | Fast mode, F <sub>SYSCLK</sub> =5.5296 MHz |                                                                           | 1.9         | _    | 5.5         |      |
| Operating<br>Voltage                   | V <sub>CC</sub>  | Fast mode, F <sub>SYS</sub>                | <sub>SCLK</sub> =2.7648 MHz                                               | 1.4         | -    | 5.5         | V    |
| voltage                                |                  | Fast mode, F <sub>SYS</sub>                | <sub>SCLK</sub> =0.6912 MHz                                               | 1.3         | -    | 5.5         |      |
|                                        |                  | Slow m                                     | ode, SRC                                                                  | 1.3         | -    | 5.5         |      |
|                                        |                  | All Input, except                          | V <sub>CC</sub> =5V                                                       | $0.6V_{CC}$ | -    | -           |      |
| Input High                             | $V_{IH}$         | P1.2, P1.3                                 | V <sub>CC</sub> =3V                                                       | $0.6V_{CC}$ | -    | -           | V    |
| Voltage                                | V IH             | P1.2, P1.3                                 | V <sub>CC</sub> =5V                                                       | $0.8V_{CC}$ | -    | _           | v    |
|                                        |                  | F1.2, F1.5                                 | V <sub>CC</sub> =3V                                                       | $0.8V_{CC}$ | -    | -           |      |
| Input Low                              | V <sub>IL</sub>  | All Input                                  | V <sub>CC</sub> =5V                                                       | -           |      | $0.2V_{CC}$ | V    |
| Voltage                                | v IL             | An Input                                   | V <sub>CC</sub> =3V                                                       | -           |      | $0.2V_{CC}$ |      |
|                                        |                  | All Output, except                         | V <sub>CC</sub> =5V<br>V <sub>OH</sub> =0.9V <sub>CC</sub>                | 4           | 8    |             | mA   |
| I/O Port Source                        | T                | P4.4, P4.5                                 | V <sub>CC</sub> =3V                                                       | 2           | 4    |             |      |
| Current                                | I <sub>OH</sub>  | P4.4, P4.5                                 | $\frac{V_{OH}=0.9V_{CC}}{V_{CC}=5V}$ $V_{OH}=0.9V_{CC}$                   | 30          | 40   |             |      |
|                                        |                  |                                            | $\frac{V_{OH}=0.9V_{CC}}{V_{CC}=3V}$ $\frac{V_{OH}=0.9V_{CC}}{V_{CC}=5V}$ | 15          | 20   |             |      |
|                                        |                  | All Output, except<br>P4.4, P4.5           | $V_{OL}=0.1V_{CC}$                                                        | 8           | 16   | —           |      |
| I/O Port Sink                          | I <sub>OL</sub>  |                                            | $V_{CC}=3V$<br>$V_{OL}=0.1V_{CC}$                                         | 4           | 8    | _           | mA   |
| Current                                | IOL              | D4 4 D4 5                                  | $V_{CC}=5V$<br>$V_{OL}=0.1V_{CC}$                                         | 30          | 40   |             | mΑ   |
|                                        |                  | P4.4, P4.5                                 | V <sub>CC</sub> =3V<br>V <sub>OL</sub> =0.1V <sub>CC</sub>                | 20          | 25   |             |      |
| Input Leakage<br>Current<br>(pin high) | I <sub>ILH</sub> | All Input                                  | $V_{in} = V_{CC}$                                                         | _           | _    | 1           | μΑ   |



| Input Leakage<br>Current<br>(pin low) | I <sub>ILL</sub>                             | All Input                                                                                    | V <sub>in</sub> =0V                        | _          | _                                                   | -1         |        |     |
|---------------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------|--------------------------------------------|------------|-----------------------------------------------------|------------|--------|-----|
|                                       |                                              | Fast, V <sub>CC</sub> =5V<br>LVR enable                                                      | FRC= 11.0592MHz<br>FRC= 5.5296MHz          |            | 7.0<br>5.5                                          | -          |        |     |
|                                       |                                              | MODE3V=0                                                                                     | FRC= 2.7648 MHz                            | _          | 4.5                                                 | _          |        |     |
|                                       |                                              | Fast, V <sub>CC</sub> =3V                                                                    | FRC= 11.0592MHz                            | -          | 5.5                                                 | _          |        |     |
|                                       |                                              | LVR enable                                                                                   | FRC= 5.5296MHz                             | -          | 4.5                                                 | _          | mA     |     |
|                                       |                                              | MODE3V=0                                                                                     | FRC= 2.7648 MHz                            | _          | 3.4                                                 | _          |        |     |
|                                       |                                              | Fast, V <sub>CC</sub> =3V                                                                    | FRC= 11.0592MHz                            | _          | 5.5                                                 | _          |        |     |
|                                       |                                              | LVR enable<br>MODE3V=1                                                                       | FRC = 5.5296 MHz                           | —          | 4.5                                                 | _          |        |     |
|                                       |                                              |                                                                                              | FRC= 2.7648 MHz                            | _          | 3.4                                                 | _          |        |     |
|                                       |                                              | Slow, V <sub>CC</sub> =5V<br>LVR enable<br>MODE3V=0                                          | SRC=32 KHz                                 | _          | 2.5                                                 | _          |        |     |
|                                       |                                              | Slow, V <sub>CC</sub> =3V<br>LVR enable<br>MODE3V=0                                          | SRC=32 KHz                                 | _          | 1.9                                                 | _          |        |     |
|                                       |                                              | Slow, V <sub>CC</sub> =3V<br>MODE3V=1<br>PWRSAV=1                                            | SRC=32 KHz                                 | _          | 1.3                                                 | _          | mA     |     |
| Supply Current I <sub>CC</sub>        | I <sub>CC</sub>                              | Slow, V <sub>CC</sub> =3V<br>MODE3V=1<br>PWRSAV=0                                            | SRC=32 KHz                                 | _          | 1.8                                                 | _          |        |     |
|                                       | -                                            | Idle, V <sub>CC</sub> =5V<br>LVR enable<br>MODE3V=0                                          | SRC=32 KHz                                 | _          | 820                                                 | _          |        |     |
|                                       |                                              |                                                                                              |                                            |            | Idle, V <sub>CC</sub> =3V<br>LVR enable<br>MODE3V=0 | SRC=32 KHz | _      | 430 |
|                                       |                                              | Idle, V <sub>CC</sub> =3V<br>MODE3V=1<br>PWRSAV=1                                            | SRC=32 KHz                                 | _          | 60                                                  | _          |        |     |
|                                       |                                              | Idle, V <sub>CC</sub> =3V<br>MODE3V=1<br>PWRSAV=0                                            | MODE3V=1                                   | SRC=32 KHz | _                                                   | 350        | _      | uA  |
|                                       |                                              | Stop, V <sub>CC</sub> =5V                                                                    | PWRSAV=1                                   | _          | 10                                                  | _          |        |     |
|                                       |                                              | MODE3V=0                                                                                     | PWRSAV=0                                   | _          | 800                                                 | _          |        |     |
|                                       | Stop, V <sub>CC</sub> =3V<br>MODE3V=0        | Stop $V = 2V$                                                                                | PWRSAV=1                                   | _          | 3                                                   | _          |        |     |
|                                       |                                              |                                                                                              | MODE3V=0                                   | PWRSAV=0   | _                                                   | 400        | _      |     |
|                                       | ļ                                            |                                                                                              | $V_{\rm CC}=5V$                            | _          | 11.0592                                             |            |        |     |
| System Clock<br>Frequency             | F <sub>SYSCLK</sub>                          | V <sub>CC</sub> >LVR <sub>th</sub>                                                           | $V_{CC}=3V$<br>$V_{CC}=4V$                 | _          | 11.0592                                             | -          | MHz    |     |
|                                       | 1 SYSCLK                                     | $\begin{array}{c c} CLK & V_{CC} > L V R_{th} & V_{CC} = 4 \\ \hline V_{CC} = 3 \end{array}$ |                                            | _          | 11.0592                                             | -          | 191112 |     |
|                                       | eference V <sub>UUP</sub> T <sub>-25°C</sub> |                                                                                              | _                                          | 2.9        | _                                                   |            |        |     |
| LVR Reference<br>Voltage              |                                              | $V_{LVR}$ $T_A=25^{\circ}C$                                                                  | =25°C                                      | _          | 2.3                                                 | -          | v      |     |
| -                                     |                                              | A                                                                                            |                                            | -          | 2.1                                                 | -          |        |     |
| LVR Hysteresis<br>Voltage             | V <sub>HYST</sub>                            | T <sub>A</sub> =25°C                                                                         |                                            | _          | ±0.1                                                | _          | V      |     |
| Pull-Up Resistor                      | R <sub>P</sub>                               | V <sub>IN</sub> =0V<br>All except P1.2, P1.3                                                 | V <sub>CC</sub> =5V<br>V <sub>CC</sub> =3V | _          | 26<br>48                                            | _          | KΩ     |     |



|  | V <sub>IN</sub> =0V<br>P1.2, P1.3 | V <sub>CC</sub> =3V | _ | 120 | _ |  |
|--|-----------------------------------|---------------------|---|-----|---|--|
|--|-----------------------------------|---------------------|---|-----|---|--|

#### 3. Clock Timing $(T_A = -40^{\circ}C \sim +85^{\circ}C, V_{CC} = 3.0V \sim 5.5V)$

| Parameter     | Conditions                                | Min.  | Тур.    | Max.  | Unit |
|---------------|-------------------------------------------|-------|---------|-------|------|
|               | 25°C, V <sub>CC</sub> =3.0 ~ 5.5V         | -1.6% | 11.0592 | +1.6% |      |
| FRC Frequency | 0°C~ 70°C, V <sub>CC</sub> =3.0 ~ 5.5V    | -3.8% | 11.0592 | +3.0% | MHz  |
|               | –40°C ~ 85°C, V <sub>CC</sub> =3.0 ~ 5.5V | -8.0% | 11.0592 | +3.0% |      |

## 4. Reset Timing Characteristics ( $T_A = -40^{\circ}C \sim +85^{\circ}C$ , $V_{CC} = 3.0V \sim 5.0V$ )

| Parameter                    | Conditions                       |    | Тур. | Max. | Unit |
|------------------------------|----------------------------------|----|------|------|------|
| <b>RESET</b> Input Low width | Input $V_{CC}$ =5.0V ±10 %       | 30 | -    | -    | μs   |
| WDT wakeup time              | V <sub>CC</sub> =5.0V, WDTPSC=11 | -  | 150  | Ι    | ms   |

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

| Parameter Conditions                |                        | Min.            | Тур. | Max.            | Unit |
|-------------------------------------|------------------------|-----------------|------|-----------------|------|
| Total Accuracy                      |                        |                 | ±2.5 | $\pm 4$         | LCD  |
| Integral Non-Linearity              | $V_{CC}=5V, V_{SS}=0V$ | _               | ±3.2 | ±5              | LSB  |
| Max Input Clock (f <sub>ADC</sub> ) | _                      | _               | _    | 1               | MHz  |
| Conversion Time                     | $f_{ADC}=1MHz$         | -               | 50   | _               | μs   |
| BandGap Voltage Reference           | V <sub>CC</sub> =3V    | 1.14            | 1.22 | 1.30            | V    |
|                                     | V <sub>CC</sub> =5V    | 1.15            | 1.25 | 1.35            | v    |
| Input Voltage                       | -                      | V <sub>SS</sub> | -    | V <sub>CC</sub> | V    |





#### 6. Characteristics Graphs

















### **PACKAGE INFORMATION**

## **Ordering Information**

| Ordering Number  | Package               |
|------------------|-----------------------|
| TM52F5284-MTP    | Wafer/Dice blank chip |
| TM52F5284-COD    | Wafer/Dice with code  |
| TM52F5284-MTP-72 | LQFP 48-pin (7x7 mm)  |



#### **Package Information**

#### LQFP 48-pin (7x7 mm) Package Dimensions



| SYMBOL | MIN                | NOM          | MAX         | MIN   | NOM       | MAX         |
|--------|--------------------|--------------|-------------|-------|-----------|-------------|
| А      | -                  | -            | 1.60        | -     | -         | 0.063       |
| A1     | 0.05               | 0.10         | 0.15        | 0.001 | 0.004     | 0.006       |
| A2     | 1.35               | 1.40         | 1.45        | 0.053 | 0.055     | 0.057       |
| В      | 0.17               | 0.22         | 0.27        | 0.007 | 0.009     | 0.011       |
| C      | 0.09               | 0.15         | 0.20        | 0.004 | 0.006     | 0.008       |
| D      | 9.00 BSC 0.354 BSC |              |             |       |           |             |
| D1     |                    | 7.00 BSC     |             |       | 0.276 BSC |             |
| Е      |                    | 9.00 BSC     |             |       | 0.354 BSC |             |
| E1     |                    | 7.00 BSC     |             |       | 0.276 BSC |             |
| e      |                    | 0.50 BSC     |             |       | 0.020 BSC |             |
| L      | 0.45               | 0.60         | 0.75        | 0.018 | 0.024     | 0.030       |
| θ      | 0°                 | 3.5°         | $7^{\circ}$ | 0°    | 3.5°      | $7^{\circ}$ |
| JEDEC  |                    | MS-026 (BBC) |             |       |           |             |

\* NOTES : DIMENSION "D1 " AND "E1 " DO NOT INCLUDE MOLD

PROTRUSIONS. ALLOWABLE PROTRUSIONS IS 0.25 mm PER SIDE. "D1 " AND " E1 " ARE MAXIMUM PLASTIC BODY SIZE DIMENSIONS

INCLUDING MOLD MISMACH.