

# SC92F7302/7301/7300

High-speed 1T 8051-based Flash MCU, 512 bytes SRAM, 8 Kbytes Flash, 128 bytes independent EEPROM, 12-bit ADC, 6-channel 8-bit PWM Outputs, 3 Timer/Counters, UART

# **1** General Description

The SC92F7302/7301/7300 (hereinafter referred to as the SC92F730X) is a series of enhanced 1T 8051based industrial Flash Microcontroller unit (MCU), in which the instruction system is completely compatible with standard 8051 product series.

The SC92F730X integrates 8K bytes Flash ROM, 512 bytes SRAM, 128 bytes EEPROM, up to 18 General-purpose I/Os (GPIO), 8 IO external interrupters, three 16-bit timers, 9-channel 12-bit high-precision ADC, 6-channel independent 8-bit PWM,IO drive level control (P0 and P2 ports), internal ±1% high-precision 24/12/6/2MHz highfrequency oscillator and low-frequency 32KHz oscillator, UART, and other communication interfaces. То improve the reliability and simplify the circuit design, the SC92F730X also integrates 4-level optional LVR, 2.4V ADC reference voltage, WDT and other high-reliability circuits.

The SC92F730X features excellent anti-interference performance, which make it possible to be widely applied to IoT control, such as intelligent home appliances, home automation, charger, power supply aviation model, intercom, wireless communication, gaming machines.

# 2 Features

Operating Voltage: 2.4V ~ 5.5V

Operating Temperature: -40 ~ 85°C

EMS

- ESD
  - HBM: MIL-STD-883J Class 3B
  - MM: JEDEC EIA/JESD22-A115 Class C
  - CDM: ANSI/ESDA/JEDEC JS-002-2018 Class C3
- EFT
  - EN61000-4-4 Level 4

#### Package:

SOP20/TSSOP20/QFN20

SOP16

SOP8

Core: High speed 1T 8051

**Flash ROM:** 8K bytes Flash ROM (MOVC) prohibited addressing 0000H ~ 00FFH) can be rewritten for 10, 000 times

IAP:

- Can be Code option into 0K, 0.5K, 1K or 8K
- When the user performs IAP operations on the Flash ROM, the LVR should be set to 3.7V or higher, and the VDD voltage should be set between 3.7V and 5.5V
- When the user performs IAP operations on the EEPROM, the VDD voltage should be set between 2.4V and 5.5V

# Attention: The programming voltage can only be 5V, when the chip is being programmed by users!

**EEPROM:** Independent 128 bytes, EEPROM can be rewritten for 100, 000 times. The data written-in has more than 10-year preservation life.

SRAM: Internal 256 bytes + external 256 bytes

#### System Clock (f<sub>SYS</sub>):

- Built-in high-frequency 24MHz oscillator (fHRC):
  - The system clock source of IC can be set to one of the four types of frequency division by programmer selection:24MHz@3.7~5.5V, 12/6/2MHz@2.4~5.5V
  - Frequency Error: no more than ±1% of frequency error in 2.4V ~ 5.5V and -40 ~ 85°C application environment

#### Built-in Low-Frequency 32kHz Oscillator (LRC):

- Clock source of Base Timer (BTM), which can wake up the SC92F730X from stop mode
- Clock source of Watchdog (WDT)

#### Low-voltage Reset (LVR):

4-level LVR voltage options: 4.3V, 3.7V, 2.9V, 2.3V



• The default is the Code Option value selected by the user

#### Flash Programming and Emulation:

• 2-wire JTAG programming and emulation interface

#### Interruption (INT):

- 9 interrupt sources: Timer0, Timer1, Timer2, INT0, INT2, ADC, PWM, UART, Base Timer
- 2 external interrupt vectors shared by 8 interrupt ports, all of which can be defined in rising-edge, falling-edge or dual-edge trigger mode
- Two-level interrupt priority capability

#### **Digital Peripheral:**

- Up to 18 bidirectional independently controllable I/O interfaces, able to configure pull-high resistor independently
- P0/P2 ports with 4-level drive capability
- All I/Os equipped with sink current drive capability (70 mA)
- 11-bit WDT with optional clock division ratio

- 3 standard 80C51 Timer/Counters: Timer0, Timer1 and Timer2
- 6-channel 8-bit PWM output channels with variable period and individual duty cycle
- 5 I/Os as output of the 1/2-bias LCD COM
- 1 independent UART communication interface

#### **Analog Peripheral:**

- 9-channel 12-bit ADC
  - Built-in 2.4V reference voltage
  - 2 options for ADC reference voltage: V<sub>DD</sub> and internal 2.4V
  - Internal one-channel ADC, where VDD can be measured directly
  - ADC conversion completion interrupt

#### **Power Saving Mode:**

- IDLE Mode: can be woken up by any interrupt.
- STOP Mode: can be woken up by INT0, INT2、 Base Timer



# Naming Rules for 92 Series Products

| Name | SC | 92 | F | 7 | 3 | 0 | 2 | Х | М | 20 | U   |
|------|----|----|---|---|---|---|---|---|---|----|-----|
| S/R  | 1  | 2  | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | (1) |

| S/R  | Meaning                                                                                                  |
|------|----------------------------------------------------------------------------------------------------------|
| 1    | SinOne Chip abbreviation                                                                                 |
| 2    | Name of product series                                                                                   |
| 3    | Product Type (F: Flash MCU)                                                                              |
| 4    | Serial Number: 7: GP Series, 8: TK series                                                                |
| \$   | ROM Size: 1 for 2K, 2 for 4K, 3 for 8K, 4 for 16K and 5 for 32K                                          |
| 6    | Subseries Number.: 0 ~ 9, A ~ Z                                                                          |
| Ø    | Number of Pins: 0: 8pin, 1: 16pin, 2: 20pin, 3: 28pin, 5: 32pin, 6: 44pin, 7: 48pin, 8: 64pin, 9: 100pin |
| 8    | Version Number: (default, B, C, D)                                                                       |
| 9    | Package Type: (D: DIP; M: SOP; X: TSSOP; N: NSOP, F: QFP; P: LQFP; Q: QFN; K: SKDIP)                     |
| 10   | Number of Pins.                                                                                          |
| (11) | Packaging Mode: (U: Tube; R: Tray; T: Reel)                                                              |



# Contents

| 1 GENERAL DESCRIPTION                                          | 1  |
|----------------------------------------------------------------|----|
| 2 FEATURES                                                     | 1  |
| NAMING RULES FOR 92 SERIES PRODUCTS                            | 3  |
| CONTENTS                                                       | 4  |
| 3 PIN DESCRIPTION                                              |    |
| 3.1 Pin Configuration                                          | 7  |
| 3.2 Pin Definition                                             | 9  |
| 4 INNER BLOCK DIAGRAM                                          | 11 |
| 5 FLASH ROM AND SRAM STRUCTURE                                 | 12 |
| 5.1 Flash ROM                                                  | 12 |
| 5.2 Customer Option Memory (User Programming Setting)          | 13 |
| 5.2.1 Customer-Option-related Registers Operation Instructions | 16 |
| 5.3 SRAM                                                       |    |
| 5.3.1 Internal 256 bytes SRAM                                  |    |
| 5.3.2 External 256 bytes SRAM                                  |    |
| 6 SPECIAL FUNCTION REGISTER (SFR)                              | 19 |
| 6.1 SFR Mapping                                                | 19 |
| 6.2 SFR Instructions                                           | 20 |
| 6.2.1 C51 Core SFRs                                            |    |
| 7 POWER, RESET AND SYSTEM CLOCK                                | 25 |
| 7.1 Power Circuit                                              | 25 |
| 7.2 Power-on Reset                                             | 25 |
| 7.2.1 Reset Stage                                              |    |
| 7.2.2 Loading Information Stage                                |    |
| 7.2.3 Normal Operating Stage                                   | 25 |
| 7.3 Reset Modes                                                |    |
| 7.3.1 External Reset                                           |    |
| 7.3.2 Low-voltage Reset (LVR)                                  |    |
| 7.3.3 Power-on Reset (POR)<br>7.3.4 Watchdog Reset (WDT)       |    |
| 7.3.5 Register Reset Value                                     |    |
|                                                                |    |



| 7.4 High-speed RC Oscillator             |    |
|------------------------------------------|----|
| 7.5 Low-speed RC Oscillator              |    |
| 7.6 Power Saving Modes                   |    |
| 8 CPU AND FUNCTION SYSTEM                | 35 |
| 8.1 CPU                                  |    |
| 8.2 Addressing Mode                      |    |
| 8.2.1 Immediate Addressing               |    |
| 8.2.2 Direct Addressing                  |    |
| 8.2.3 Indirect Addressing                |    |
| 8.2.4 Register Addressing                |    |
| 8.2.5 Relative Addressing                |    |
| 8.2.6 Indexed Addressing                 |    |
| 8.2.7 Bits Addressing                    |    |
| 9 INTERRUPT                              |    |
| 9.1 Interrupt Source and Vector          |    |
| 9.2 Interrupt Structure Diagram          |    |
| 9.3 Interrupt Priority                   |    |
| 9.4 Interrupt Processing Flow            |    |
| 9.5 Interrupt-related Registers          |    |
| 10 TIMER/COUNTER TO AND T1               | 46 |
| 10.1 T0 and T1-related Registers         |    |
| 10.2 T0 Operating Modes                  |    |
| 10.3 T1 Operating Modes                  |    |
| 11 TIMER/COUNTER T2                      | 55 |
| 11.1 T2-related Registers                |    |
| 11.2 T2 Operating Modes                  |    |
| 12 PWM                                   | 60 |
|                                          |    |
| 12.1 PWM block Diagram                   | 61 |
| 12.2 PWM-related Registers               | 61 |
| 12.3 PWM General Configuration Registers |    |
| 12.4 PWM Waveforms and Directions        |    |



| 13 GENERAL-PURPOSE I/O (GPIO)                                                                                         | 70 |
|-----------------------------------------------------------------------------------------------------------------------|----|
| 13.1 GPIO Structure Diagram                                                                                           | 70 |
| 13.2 I/O Port-related Registers                                                                                       | 71 |
| 14 SOFTWARE LCD DRIVER                                                                                                | 75 |
| 14.1 Software LCD Drives-related Registers                                                                            | 75 |
| 15 UART                                                                                                               | 76 |
| 15.1 UART-related Registers                                                                                           |    |
| 15.2 Baud Rate of Serial Communication                                                                                |    |
| 16 ANALOG-TO-DIGITAL CONVERTER (ADC)                                                                                  |    |
| 16.1 ADC-related Registers                                                                                            |    |
| 16.2 ADC Conversion Steps                                                                                             |    |
| 17 EEPROM AND IAP OPERATIONS                                                                                          | 84 |
| 17.1 EEPROM / IAP Operating-related Registers                                                                         | 84 |
| 17.2 EEPROM / IAP Operating Procedures:                                                                               |    |
| 20.2.1 128 bytes Independent EEPROM Operating Demo program<br>20.2.2 16K bytes Code memory IAP Operating Demo program |    |
| 18 ELECTRICAL CHARACTERISTICS                                                                                         | 91 |
| 18.1 Absolute Maximum Ratings                                                                                         | 91 |
| 18.2 Recommended Operating Conditions                                                                                 | 91 |
| 18.3 DC Characteristics                                                                                               | 91 |
| 18.4 AC Characteristics                                                                                               | 94 |
| 18.5 ADC Characteristics                                                                                              | 95 |
| 19 ORDERING INFORMATION                                                                                               | 96 |
| 20 PACKAGING INFORMATION                                                                                              | 97 |
| 21 REVISION HISTORY                                                                                                   |    |
| IMPORTANT NOTICE                                                                                                      |    |



# **3 Pin Description**

### **3.1 Pin Configuration**



The SC92F7302 Pin Diagram Suitable for QFN20 package





Suitable for SOP8 package



### 3.2 Pin Definition

| Pi    | Pin number |      | Pin Name              | Turno | Description                                                                                                                                                            |  |  |
|-------|------------|------|-----------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 20PIN | 16PIN      | 8PIN | Fin Name              | Туре  | Description                                                                                                                                                            |  |  |
| 1     | 1          | 8    | VDD                   | Power | Power                                                                                                                                                                  |  |  |
| 2     | 2          | 1    | VSS                   | Power | Ground                                                                                                                                                                 |  |  |
| 3     | 3          | -    | P1.0/INT00            | I/O   | P1.0: GPIO P1.0<br>INT00: Input 0 of external interrupt 0                                                                                                              |  |  |
| 4     | 4          | -    | P1.1/INT01/RST        | I/O   | P1.1: GPIO P1.1<br>INT01: Input 1 of external interrupt 0<br>RST: Reset Pin                                                                                            |  |  |
| 5     | 5          | 2    | P1.2/INT02/T0/RX/tCK  | I/O   | P1.2: GPIO P1.2<br>INT02: Input 2 of external interrupt 0<br>T0: Timer/Counter 0 External Input<br>RX0: UART0 Receiver<br>tCK: Programming and Emulation Clock Pin     |  |  |
| 6     | 6          | 3    | P1.3/INT03/T1/TX/tDIO | I/O   | P1.3: GPIO P1.3<br>INT03: Input 3 of external interrupt 0<br>T1: Timer/Counter 1 External Input<br>TX0: UART 0 Transmitter<br>tDIO: Programming and Emulation Data Pin |  |  |
| 7     | 7          |      | P1.6/AIN9             | I/O   | P1.6: GPIO P1.6<br>AIN9: ADC Input Channel 9                                                                                                                           |  |  |
| 8     | 8          | -    | P1.7/AIN8             | I/O   | P1.7: GPIO P1.7<br>AIN8: ADC Input Channel 8                                                                                                                           |  |  |
| 9     | -          | 4    | P2.7/PWM5/AIN7        | I/O   | P2.7: GPIO P2.7<br>PWM5: PWM5 Output<br>AIN7: ADC Input Channel 7                                                                                                      |  |  |
| 10    | -          | 5    | P2.6/PWM4/AIN6        | I/O   | P2.6: GPIO P2.6<br>PWM4: PWM4 Output<br>AIN6: ADC Input Channel 6                                                                                                      |  |  |



|    | r  | r |                 |     |                                                                                              |
|----|----|---|-----------------|-----|----------------------------------------------------------------------------------------------|
| 11 | 9  | - | P2.5/PWM3/AIN5  | I/O | P2.5: GPIO P2.5<br>PWM3: PWM3 Output<br>AIN5: ADC Input Channel 5                            |
| 12 | 10 | - | P2.4/AIN4       | I/O | P2.4: GPIO P2.4<br>AIN4: ADC Input Channel 4                                                 |
| 13 | 11 | 6 | P2.1/INT25/AIN1 | I/O | P2.1: GPIO P2.1<br>INT25: Input 5 of external interrupt 2<br>AIN1: ADC Input Channel 1       |
| 14 | 12 | 7 | P2.0/INT24/AIN0 | I/O | P2.0: GPIO P2.0<br>INT24: Input 4 of external interrupt 2<br>AIN0: ADC Input Channel 0       |
| 15 | -  | - | P0.5/INT21      | I/O | P0.5: GPIO P0.5<br>INT21: Input 1 of external interrupt 2                                    |
| 16 | -  | - | P0.4/INT20/COM4 | 1/0 | P0.5: GPIO P0.5<br>INT21: Input 1 of external interrupt 2<br>COM4: LCD common drive output 4 |
| 17 | 13 | - | P0.3/COM3       | 1/0 | P0.3: GPIO P0.3<br>COM3: LCD common drive output 3                                           |
| 18 | 14 | - | P0.2/PWM2/COM2  | I/O | P0.2: GPIO P0.2<br>PWM2: PWM2 Output<br>COM2: LCD common drive output 2                      |
| 19 | 15 | - | P0.1/PWM1/COM1  | I/O | P0.1: GPIO P0.1<br>PWM1: PWM1 Output<br>COM1: LCD common drive output 1                      |
| 20 | 16 | - | P0.0/PWM0/COM0  | I/O | P0.0: GPIO P0.0<br>PWM0: PWM0 Output<br>COM0: LCD common drive output 0                      |



# 4 Inner Block Diagram



SC92F730X BLOCK DIAGRAM



# **5 Flash ROM and SRAM Structure**

The structures of the SC92F730X Flash ROM and SRAM are shown as follows:



Flash ROM and SRAM Structure Diagram

### 5.1 Flash ROM

The SC92F730X provides 8 Kbytes of Flash ROM with the ROM address of 0000H ~ 1FFFH. These 8 Kbytes of Flash ROM can be rewritten 10,000 times, which is able to program and erase by specialized ICP programming device (SC LINK/SC LINK PRO) provided by SinOne.

The MOVC instruction is non-addressable within 256 bytes. That is to say, it is unable to read the contents of the 256 bytes region by program, so as to realize the encryption function of chip program. For more details, refer to "SinOne SC92F Series MCU Application Guide".

EEPROM is a data memory separated from 8K bytes ROM with the address of 00H ~ 7FH, which can be accessed by single-byte reading and writing operations in the program; for more details, refer to <u>17 EEPROM and IAP</u> <u>Operations</u>. Note: The number of erasure of EEPROM is 100,000 times. The user should not exceed the rated burn number of EEPROM, otherwise there will be an exception!

User ID area: The user ID is written when leave the factory, and the user can only perform reading operations in this area. For more details, refer to <u>17 EEPROM and IAP Operations</u>. The SC92F730X 8 Kbytes Flash ROM provide Empty Check, Program, Verify and Erase function other than Read function. This Flash ROM and EEPROM usually needs no Erase operation before writing. Directly writing data can realize coverage of new data.



#### Attention:

1. Users should set LVR to 3.7V or higher and ensure VDD is between 3.7V and 5.5V when performing IAP operations on Flash ROM

#### 2. Users should ensure VDD is between 2.4V and 5.5V when performing IAP operations on EEPRON

The SC92F730X Flash ROM can be programmed by tDIO, tCK, VDD and VSS, with its specific connection shown as follows:



ICP Mode Flash Writer Programming Connection Diagram

Attention: The programming voltage can only select 5V, when the user is programming the chip

### 5.2 Customer Option Memory (User Programming Setting)

A separate Flash data memory is embedded inside the SC92F730X, called Code Option area, to save the user's presets. These presets will be written into IC when programming and loaded into SFR as default values during reset.

**Option-related SFR Operating Instructions:** 

Reading and writing operations to option-related SFR are controlled by both register OPINX and register OPREG, with its respective address of Option SFR depending on register OPINX, as shown below:

| Symbol  | Address | Description                                    | 7             | 6      | 5      | 4    | 3      | 2      | 1 | 0 |
|---------|---------|------------------------------------------------|---------------|--------|--------|------|--------|--------|---|---|
| OP_HRCR | 83H@FFH | System Clock Change Register                   | OP_HRCR[7: 0] |        |        |      |        |        |   |   |
| OP_CTM0 | C1H@FFH | Customer Option Register 0 ENWDT - SCLKS[1: 0] |               | DISRST | DISLVR | LVRS | [1: 0] |        |   |   |
| OP_CTM1 | C2H@FFH | Customer Option Register 1                     | VREFS         | -      | -      | -    | IAPS   | [1: 0] | - | - |

#### OP\_HRCR (83H@FFH) System Clock Change Register (Read/Write)



| Bit Number      | 7             | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
|-----------------|---------------|-----|---|---|---|---|---|---|
| Bit<br>Mnemonic | OP_HRCR[7: 0] |     |   |   |   |   |   |   |
| R/W             |               | R/W |   |   |   |   |   |   |
| POR             | n             | n   | n | n | n | n | n | n |

| Bit Number | Bit Mnemonic  | Description                                                                                                                                                                                |
|------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 ~ 0      | OP_HRCR[7: 0] | Internal high-frequency RC frequency adjustment<br>Central value 10000000b corresponds to HRC central frequency, the<br>larger the value is, the faster the frequency will be, vice versa. |

#### OP\_CTM0 (C1H@FFH) Customer Option Register0 (Read/Write)

| Bit Number      | 7     | 6 | 5          | 4 | 3      | 2      | 1          | 0 |
|-----------------|-------|---|------------|---|--------|--------|------------|---|
| Bit<br>Mnemonic | ENWDT | - | SCLKS[1:0] |   | DISRST | DISLVR | LVRS[1: 0] |   |
| R/W             | R/W   | - | R/W        |   | R/W    | R/W    | R/W        |   |
| POR             | n     | х | n          |   | n      | n      | n          |   |
|                 |       |   |            |   |        |        |            |   |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                                                |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | ENWDT        | <ul> <li>Watchdog (WDT) control bit (This bit is transferred by the system to the value set by the user Code Option)</li> <li>0: WDT invalid</li> <li>1: WDT valid (WDT stops counting during IAP execution)</li> </ul>                                                                    |
| 5~4        | SCLKS[1: 0]  | System clock frequency selection bits<br>00: System clock frequency is HRC frequency divided by 1;<br>01: System clock frequency is HRC frequency divided by 2;<br>10: System clock frequency is HRC frequency divided by 4;<br>11: System clock frequency is HRC frequency divided by 12; |
| 3          | DISRST       | IO/RST selection bit<br>0: configure P1.1 as External Reset input pin<br>1: configure P1.1 as GPIO                                                                                                                                                                                         |
| 2          | DISLVR       | LVR enable bit<br>0: LVR enable<br>1:LVR disable                                                                                                                                                                                                                                           |



| Bit Number | Bit Mnemonic | Description                                  |  |  |  |  |  |
|------------|--------------|----------------------------------------------|--|--|--|--|--|
|            |              | LVR voltage selection bits<br>11: 4.3V reset |  |  |  |  |  |
| 1 ~ 0      | LVRS [1: 0]  | 10: 3.7 V reset                              |  |  |  |  |  |
|            |              | 01: 2.9V reset                               |  |  |  |  |  |
|            |              | 00: 2.3 V reset                              |  |  |  |  |  |
| 6          | -            | Reserved                                     |  |  |  |  |  |

#### OP\_CTM1 (C2H@FFH) Customer Option Register1 (Read/Write)

| Bit Number      | 7     | 6 | 5 | 4 | 3          | 2   | 1 | 0 |
|-----------------|-------|---|---|---|------------|-----|---|---|
| Bit<br>Mnemonic | VREFS | - | - | - | IAPS[1: 0] |     | - | - |
| R/W             | R/W   | - | - | - | R/W        | R/W | - | - |
| POR             | n     | х | х | x | n          | n   | x | х |
|                 |       |   |   |   |            |     |   |   |

| Bit Number   | Bit Mnemonic | Description                                                                                                                                                                                                                                                                                                                       |
|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7            | VREFS        | Reference voltage selection bit (Initial values are configured by the user and loaded from Code Options)<br>0: Configure ADC VREF as V <sub>DD</sub><br>1: Configure ADC VREF as internally correct 2.4V                                                                                                                          |
| 3~2          | IAPS[1: 0]   | EEPROM and IAP Area Selection Bits<br>00: Code memory prohibits IAP operations, only EEPROM data<br>memory is used for data storage<br>01: last 0.5k code memory allows IAP operation (3E00H ~ 3FFFH)<br>10: Last 1k code memory allows IAP operation (3C00H ~ 3FFFH)<br>11: All code memory allows IAP operation (0000H ~ 3FFFH) |
| 6 ~ 4, 1 ~ 0 | -            | Reserved                                                                                                                                                                                                                                                                                                                          |



#### 5.2.1 Customer-Option-related Registers Operation Instructions

Option-related SFRs reading and writing operations are controlled by both OPINX and OPREG registers, with their respective position of Option SFR depending on OPINX and its value written to option-related SFR depending on register OPREG:

| Symbol | Address | Description     | 7           | 6 | 5   | 4   | 3    | 2 | 1        | 0 | POR     |
|--------|---------|-----------------|-------------|---|-----|-----|------|---|----------|---|---------|
| OPINX  | FEH     | Option Pointer  | OPINX[7: 0] |   |     |     |      |   | 0000000b |   |         |
| OPREG  | FFH     | Option Register |             | 0 | PRE | G[7 | : 0] |   |          |   | nnnnnnb |

When operating Option-related SFRs, register OPINX stores the address of option-related registers and register OPREG stores corresponding value.

For example: To configure OP HRCR as 0x01, specific operation method is shown below:

C program example:

OPREG = 0x01: //Write 0x01 into OPREG register (the value to be written into OP\_HRCR register)

Assembler program example:

| MOV OPINX, #83H | ;Write OP_HRCR address into OPINX register                                      |
|-----------------|---------------------------------------------------------------------------------|
| MOV OPREG, #01H | ;Write 0x01 into OPREG register (the value to be written into OP_HRCR register) |

Note: It is forbidden to write any value beyond SFR address of Customer Option region into OPINX register! Or else, it may cause abnormal system operation.

### 5.3 SRAM

The SC92F730X Microcontroller Unit, which integrates SRAM of 512 bytes, is divided into internal 256 bytes RAM and external 256 bytes RAM. The address of Internal RAM range from 00H to FFH, including high 128 bytes (address of from 80H to FFH) only addressed indirectly and low 128 bytes (address of from 00H to 7FH) addressed both directly and indirectly).

The address of SFRs is also from 80H to FFH. But the difference between SFR and internal high 128 bytes SRAM is that the former is addressed directly but the latter addressed indirectly only.

The address of External RAM from 000H to 0FFH, which is addressed by MOVX instruction.

#### 5.3.1 Internal 256 bytes SRAM

Low 128 bytes SRAM area is divided into three parts:

① Register bank 0 ~ 3, address from 00H to 1FH. The active bank is selected by bits RS1 and RS0 of PSW register. Using Register bank 0 ~ 3 can accelerate arithmetic speed;

2 Bit addressing area, 20H ~2FH; user can use it as normal RAM or bitwise addressing RAM; for the latter, the



bit address is from 00H to 7FH (bitwise addressing is different from normal SRAM byte-oriented addressing), which can be distinguished by instructions in program;

③ User RAM and stack area, the 8-bit stack pointer will point to stack area after the SC92F730X reset; in general, users can set initial value in initializer, which is recommended to configure in the unit interval from E0H to FFH.



256 bytes RAM Structure Diagram



Low 128 bytes RAM structure is shown below:



SRAM Structure Diagram

#### 5.3.2 External 256 bytes SRAM

The external 256 bytes RAM (SRAM) can be accessed by instruction "MOVX @DPTR" or instruction MOVX A ,@Ri or MOVX @Ri,A.



# 6 Special Function Register (SFR)

### 6.1 SFR Mapping

The SC92F730X provides some registers equipped with special functions, called SFR. The address of such SFRs is from 80H to FFH, some are bit-addressable, and others are not. It is very convenient for these bit addressable registers to change the value of single bit, of which the address is end up with figure "0" or "8". All SFR shall use direct addressing for addressing.

The name and address of the SC92F730X special function registers are shown in the table below:

|     | 0/8   | 1/9    | 2/A    | 3/В     | 4/C     | 5/D     | 6/E     | 7/F     |
|-----|-------|--------|--------|---------|---------|---------|---------|---------|
| F8h | -     | -      | -      | -       |         |         | OPINX   | OPREG   |
| F0h | В     | IAPKEY | IAPADL | IAPADH  | IAPADE  | IAPDAT  | IAPCTL  | -       |
| E8h | -     | -      | -      |         |         | -       | -       | -       |
| E0h | ACC   | -      | -      |         | -       | -       | -       | -       |
| D8h | -     | -      |        | -       | -       | PWMDTY3 | PWMDTY4 | PWMDTY5 |
| D0h | PSW   | -      | PWMCON | PWMPRD  | -       | PWMDTY0 | PWMDTY1 | PWMDTY2 |
| C8h | T2CON | -      | RCAP2L | RCAP2H  | TL2     | TH2     | BTMCON  | WDTCON  |
| C0h |       |        | -      | -       | -       | -       | INT2F   | INT2R   |
| B8h | IP    | IP1    | INTOF  | INTOR   | -       | -       | -       | -       |
| B0h | -     | -      | -      | -       | -       | -       | -       | -       |
| A8h | IE    | IE1    | -      | ADCCFG0 | ADCCFG1 | ADCCON  | ADCVL   | ADCVH   |
| A0h | P2    | P2CON  | P2PH   | -       | -       | -       | -       | -       |
| 98h | SCON  | SBUF   | P0CON  | P0PH    | P0VO    | -       | -       | -       |
| 90h | P1    | P1CON  | P1PH   | -       | -       | -       | -       | IOHCON  |



| 88h | TCON            | TMOD | TLO                 | TL1 | THO | TH1 | TMCON | OTCON |  |  |  |  |
|-----|-----------------|------|---------------------|-----|-----|-----|-------|-------|--|--|--|--|
| 80h | P0              | SP   | DPL                 | DPH | -   | -   | -     | PCON  |  |  |  |  |
|     | Bit Addressable |      | Not Bit Addressable |     |     |     |       |       |  |  |  |  |

Note: Hollow space of SFR refers to the fact that there is no such register RAM, it is not recommended for user to use.

### 6.2 SFR Instructions

For a description of each SFR, see the following table:

| Mnemonic | Add | Description                             | 7                 | 6         | 5    | 4      | 3        | 2      | 1    | 0        | POR       |
|----------|-----|-----------------------------------------|-------------------|-----------|------|--------|----------|--------|------|----------|-----------|
| P0       | 80H | P0 Data Register                        | -                 | -         | P05  | P04    | P03      | P02    | P01  | P00      | 0000000b  |
| SP       | 81H | Stack Pointer                           |                   |           |      | SP     | P[7: 0]  |        |      |          | 00000111b |
| DPL      | 82H | Data Pointer Low byte                   |                   |           |      | DPI    | L[7: 0]  |        |      |          | 0000000b  |
| DPH      | 83H | Data Pointer High byte                  |                   |           |      | DPI    | H[7: 0]  |        |      |          | 0000000b  |
| PCON     | 87H | Power Management Control<br>Register    | SMOD              | -         | -    | -      | -        | -      | STOP | IDL      | 0xxxxx00b |
| TCON     | 88H | Timer Control Register                  | TF1               | TR1       | TF0  | TR0    | -        | -      | -    | -        | 0000xxxxb |
| TMOD     | 89H | Timer Operating Mode<br>Register        | 1                 | C/T1      | M11  | M01    | -        | C/T0   | M10  | M00      | x000x000b |
| TLO      | 8AH | Timer0 Low 8 bits                       |                   | TL0[7: 0] |      |        |          |        |      |          | 00000000b |
| TL1      | 8BH | Timer1 Low 8 bits                       |                   | TL1[7: 0] |      |        |          |        |      |          | 0000000b  |
| тно      | 8CH | Timer0 High 8 bits                      |                   | ТН0[7: 0] |      |        |          |        |      |          | 0000000b  |
| TH1      | 8DH | Timer1 High 8 bits                      |                   | TH1[7: 0] |      |        |          |        |      | 0000000b |           |
| TMCON    | 8EH | Timer Frequency Control Register        | -                 | -         | -    | -      | -        | T2FD   | T1FD | T0FD     | xxxxx000b |
| OTCON    | 8FH | Output Control Register                 | -                 | -         | -    | -      | VOIR     | S[1:0] | -    | -        | xxxx00xxb |
| P1       | 90H | P1 Data Register                        | P17               | P16       | -    | -      | P13      | P12    | P11  | P10      | 00xx0000b |
| P1CON    | 91H | P1 I/O Control Register                 | P1C7              | P1C6      | -    | -      | P1C3     | P1C2   | P1C1 | P1C0     | 00xx0000b |
| P1PH     | 92H | P1 Pull-up Resistor Control<br>Register | P1H7              | P1H6      | -    | -      | P1H3     | P1H2   | P1H1 | P1H0     | 00xx0000b |
| IOHCON   | 97H | IOH Setup Register                      | P2H[ <sup>,</sup> | 1: 0]     | P2L  | [1: 0] | P0H      | [1: 0] | POL  | _[1: 0]  | 0000000b  |
| SCON     | 98H | Serial Port Control Register            | SM0               | SM1       | SM2  | REN    | TB8      | RB8    | TI   | RI       | 0000000b  |
| SBUF     | 99H | Serial Port Data Cache<br>Register      |                   |           |      | SBU    | IF[7: 0] |        |      |          | 0000000b  |
| P0CON    | 9AH | P0 I/O Control Register                 | -                 | -         | P0C5 | P0C4   | P0C3     | P0C2   | P0C1 | P0C0     | xx000000b |
| P0PH     | 9BH | P0 Pull-up Resistor Control<br>Register | -                 | -         | P0H5 | P0H4   | P0H3     | P0H2   | P0H1 | P0H0     | xx000000b |



| Mnemonic | Add | Description                                     | 7     | 6     | 5       | 4             | 3         | 2            | 1         | 0         | POR       |
|----------|-----|-------------------------------------------------|-------|-------|---------|---------------|-----------|--------------|-----------|-----------|-----------|
| P0VO     | 9CH | P0 Port LCD Voltage<br>Output Register          | -     | -     | -       | P04VO         | P03VO     | P02VO        | P01VO     | P00VO     | xxx00000b |
| P2       | A0H | P2 Data Register                                | P27   | P26   | P25     | P24           | -         | -            | P21       | P20       | 0000xx00b |
| P2CON    | A1H | P2 I/O Control Register                         | P2C7  | P2C6  | P2C5    | P2C4          | -         | -            | P2C1      | P2C0      | 0000xx00b |
| P2PH     | A2H | P2 Pull-up Resistor Control<br>Register         | P2H7  | P2H6  | P2H5    | P2H4          | -         | -            | P2H1      | P2H0      | 0000xx00b |
| IE       | A8H | Interrupt Enable Register                       | EA    | EADC  | ET2     | EUART         | ET1       | -            | ET0       | EINTO     | 00000x00b |
| IE1      | A9H | Interrupt Enable Register 1                     | -     | -     | -       | -             | EINT2     | EBTM         | EPWM      | •         | xxxx000xb |
| ADCCFG0  | ABH | ADC Configuration Register<br>0                 | EAIN7 | EAIN6 | EAIN5   | EAIN4         | -         | -            | EAIN1     | EAINO     | 0000xx00b |
| ADCCFG1  | ACH | ADC Configuration Register<br>1                 | -     | -     | -       | -             | -         |              | EAIN9     | EAIN8     | xxxxxx00b |
| ADCCON   | ADH | ADC Control Register                            | ADCEN | ADCS  | LOWSP   | EOC/<br>ADCIF |           | ADCIS[3:0]   |           |           | 0000000b  |
| ADCVL    | AEH | ADC Result Register                             |       | ADC   | V[3: 0] |               | ·         |              | 0000xxxxb |           |           |
| ADCVH    | AFH | ADC Result Register                             |       |       |         | ADC'          | V[11: 4]  |              | 0000000b  |           |           |
| IP       | B8H | Interrupt Priority Control<br>Register          | -     | IPADC | IPT2    | IPUART        | IPT1      | -            | IPT0      | IPINT0    | x0000x00b |
| IP1      | B9H | Interrupt Priority Control<br>Register 1        | -     | -     |         | -             | IPINT2    | IPBTM        | IPPWM     | -         | xxxx000xb |
| INTOF    | BAH | INT0 Falling Edge Interrupt<br>Control Register | -     |       | -       | •             | INT0F3    | INT0F2       | INT0F1    | INT0F0    | xxxx0000b |
| INTOR    | BBH | INT0 Rising Edge Interrupt<br>Control Register  | 1     | -     | -       | -             | INT0R3    | INT0R2       | INT0R1    | INT0R0    | xxxx0000b |
| INT2F    | С6Н | INT2 Falling Edge Interrupt<br>Control Register | -     | -     | INT2F5  | INT2F4        | -         | -            | INT2F1    | INT2F0    | xx00xx00b |
| INT2R    | С7Н | INT2 Rising Edge Interrupt<br>Control Register  | -     | -     | INT2R5  | INT2R4        | -         | -            | INT2R1    | INT2R0    | xx00xx00b |
| T2CON    | C8H | Timer2 Control Register                         | TF2   | -     | RCLK    | TCLK          | -         | TR2          | -         | -         | 0x00x0xxb |
| RCAP2L   | CAH | Timer2 Reload Low 8 bits                        |       |       |         | RCAF          | P2L[7: 0] |              |           |           | 0000000b  |
| RCAP2H   | СВН | Timer2 Reload High 8 bits                       |       |       |         | RCAF          | 2H[7: 0]  |              |           |           | 0000000b  |
| TL2      | ссн | Timer2 Low 8 bits                               |       |       |         | TL2           | 2[7: 0]   |              |           |           | 0000000b  |
| TH2      | CDH | Timer2 High 8 bits                              |       |       |         | TH            | 2[7: 0]   |              |           |           | 0000000b  |
| BTMCON   | СЕН | Low-Frequency Timer<br>Control Register         | ENBTM | BTMIF | -       | -             |           | BTMF         | FS[3: 0]  |           | 00xx0000b |
| WDTCON   | CFH | WDT Control Register                            | -     | -     | -       | CLRWDT        | -         | WDTCKS[2: 0] |           | xxx0x000b |           |
| PSW      | D0H | Program Status Word<br>Register                 | CY    | AC    | F0      | RS1           | RS0       | OV           | F1        | Ρ         | 0000000b  |
| PWMCFG0  | D1H | PWM Setup Register 0                            | -     | -     | INV2    | INV1          | INV0      | ENPWM5       | ENPWM4    | ENPWM3    | xx000000b |
| PWMCON   | D2H | PWM Control Register                            | ENPWM | PWMIF | ENPWM2  | ENPWM1        | ENPWM0    |              | PWMCKS[2: | 0]        | 0000000b  |
| PWMPRD   | D3H | PWM Period Setting<br>Register                  |       | 1     | 1       | PWM           | PRD[7:0]  | 1            |           |           | 0000000b  |
|          |     |                                                 |       |       |         |               |           |              |           |           |           |



| Mnemonic | Add | Description                         | 7           | 6            | 5    | 4     | 3        | 2          | 1        | 0       | POR       |
|----------|-----|-------------------------------------|-------------|--------------|------|-------|----------|------------|----------|---------|-----------|
| PWMCFG1  | D4H | PWM Setup Register 1                | -           | -            | INV5 | INV4  | INV3     | -          | -        | -       | xx000xxxb |
| PWMDTY0  | D5H | PWM0 duty cycle setting<br>register |             |              |      | PDT   | 0[7:0]   |            |          |         | 0000000b  |
| PWMDTY1  | D6H | PWM1 duty cycle setting<br>register |             |              |      | PDT   | 1[7:0]   |            |          |         | 0000000b  |
| PWMDTY2  | D7H | PWM2 duty cycle setting<br>register |             |              |      | PDT   | 2[7:0]   |            |          |         | 0000000b  |
| PWMDTY3  | DDH | PWM3 duty cycle setting<br>register |             | PDT3[7:0]    |      |       |          |            |          |         | 0000000b  |
| PWMDTY4  | DEH | PWM4 duty cycle setting<br>register |             | PDT4[7:0]    |      |       |          |            |          |         | 0000000b  |
| PWMDTY5  | DFH | PWM5 duty cycle setting<br>register |             | PDT5[7:0]    |      |       |          |            |          |         | 0000000b  |
| ACC      | E0H | Accumulator                         |             | ACC[7: 0]    |      |       |          |            |          |         | 0000000b  |
| В        | F0H | B Register                          |             |              |      | B[    | 7: 0]    |            | F        | ,       | 0000000b  |
| IAPKEY   | F1H | IAP Protection Register             |             |              |      | IAPK  | EY[7: 0] |            |          |         | 0000000b  |
| IAPADL   | F2H | IAP Address Low byte<br>Register    |             |              |      | IAPAI | DR[7: 0] |            |          |         | 0000000b  |
| IAPADH   | F3H | IAP Address High byte<br>Register   | -           | -            | i    |       |          | IAPADR[12: | 8]       |         | xxx00000b |
| IAPADE   | F4H | IAP Extended Address<br>Register    |             |              |      | IAPAD | ER[7: 0] |            |          |         | 0000000b  |
| IAPDAT   | F5H | IAP Data Register                   |             | IAPDAT[7: 0] |      |       |          |            |          |         | 0000000b  |
| IAPCTL   | F6H | IAP Control Register                | -           | -            | -    | -     | PAYTIN   | 1ES[1:0]   | CM       | D[1: 0] | xxxx0000b |
| OPINX    | FEH | Option Pointer                      | OPINX[7: 0] |              |      |       |          |            | 0000000b |         |           |
| OPREG    | FFH | Option Register                     |             |              |      | OPRE  | EG[7: 0] |            |          |         | nnnnnnb   |

#### 6.2.1 C51 Core SFRs

#### Program Counter (PC)

PC does not belong to SFR .16-bit PC is the register used to control instruction execution sequence. After poweron or reset of microcontroller unit, PC value is 0000H, that is to say, the microcontroller unit is to execute program from 0000H.

#### Accumulator ACC (E0H)

Accumulator ACC is one of the commonly-used registers in 8051-based microcontroller unit, using A as mnemonic symbol in the instruction system. It is usually used to store operand and results for calculation or logical operations.

#### B Register (F0H)

B Register shall be used together with Accumulator A in multiplication and division operations. For example, instruction "MUL A, B" is used to multiply 8-bit unsigned numbers of Accumulator A and Register B. As for the acquired 16-bit product, low byte is placed in A and High byte in B. As for "DIV A, B" is used to divide A by B, place integer quotient in A and remainder in B. Register B can also be used as common temporary register.

#### Stack Pointer SP (81H)



Stack pointer is an 8-bit specialized register, it indicates the address of top stack in common RAM. After resetting of microcontroller unit, the initial value of SP is 07H, and the stack will increase from 08H. 08H  $\sim$  1FH is address of register banks 1  $\sim$  3.

#### PSW (D0H) Program Status Word Register (Read/Write)

| Bit Number      | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----------------|-----|-----|-----|-----|-----|-----|-----|-----|
| Bit<br>Mnemonic | 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 |
| POR             | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

| Bit Number | Bit Mnemonic |                                                                                                                                                                                                                                                                  | Description |                                               |  |  |  |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------------------------|--|--|--|
| 7          | CY           | Carry Flag bit<br>1: The top digit of add operation has carry bit or the top digit of<br>subtraction operation has the borrow digit<br>0: The top digit of add operation has no carry bit or the top digit of<br>subtraction operation has no borrow digit       |             |                                               |  |  |  |
| 6          | AC           | <ul> <li>Carry-bit auxiliary flag bit (adjustable upon BCD code add and subtraction operations)</li> <li>1: There is carry bit in bit 3 upon add operation and borrow bit in bit 3 upon subtraction operation</li> <li>0: No borrow bit and carry bit</li> </ul> |             |                                               |  |  |  |
| 5          | F0           | User flag bit                                                                                                                                                                                                                                                    |             |                                               |  |  |  |
| 4~3        | RS1、RS0      | Register banks selection bitsRS1RS0Current Selected Register banks 0 ~ 300Group 0 (00H ~ 07H)01Group 1 (08H ~ 0FH)10Group 2 (10H ~ 17H)11Group 3 (18H ~ 1FH)                                                                                                     |             |                                               |  |  |  |
| 2          | ov           | Overflow flag                                                                                                                                                                                                                                                    | bit         |                                               |  |  |  |
| 1          | F1           | F1 flag bit<br>User customized flag                                                                                                                                                                                                                              |             |                                               |  |  |  |
| 0          | Р            | Parity flag bit.<br>accumulator A                                                                                                                                                                                                                                |             | bit is the parity value of the number of 1 in |  |  |  |



| 1: Odd number of number of 1 in ACC                |
|----------------------------------------------------|
| 0: Even number of number of 1 in ACC (including 0) |

#### Data Pointer DPTR (82H, 83H)

The Data pointer DPTR is a 16-bit dedicated register, which is composed of Low byte DPL (82H) and High byte DPH (83H). DPTR is the only register in the traditional 8051-based MCU that can directly conduct 16-bit operation, which can also conduct operations on DPL and DPH by byte.



# 7 Power, Reset and System Clock

### 7.1 Power Circuit

The SC92F730X Power includes circuits such as BG, LDO, POR and LVR, which are able to reliably work within the scope of 2.4V ~ 5.5V. Besides, a calibrated 2.4V voltage is built in the IC, which is used as ADC internal reference voltage. The user can search for specific configuration contents in <u>16 Analog-to-digital converter (ADC)</u>.

### 7.2 Power-on Reset

After the SC92F730X power-on, the processes carried out before execution of client software are as follows:

- Reset stage
- Loading information stage
- Normal operation stage

#### 7.2.1 Reset Stage

The SC92F730X will always be in reset mode. There will not be a valid clock until the voltage supplied to the SC92F730X is higher than certain voltage. The duration of reset stage is related to rising speed of external power. Once the external supply voltage is up to built-in POR voltage, the reset stage would be completed.

#### 7.2.2 Loading Information Stage

There is a preheating counter inside the SC92F730X. During the reset stage, this preheating counter is always reset as zero. After the voltage is higher than POR voltage, internal RC oscillator starts to oscillate and this preheating counter starts to count. When internal preheating counter counts up to certain number, one byte data will be read from IFB of Flash ROM (including Code Option) for every certain number of HRC clock, which is saved to internal system registers. After the preheating is completed, such reset signal will end.

#### 7.2.3 Normal Operating Stage

After the loading information stage has been completed, the SC92F730X starts to read instruction code from Flash and enters normal operating stage. At this time, LVR voltage is the set value of Code Option written by user.

### 7.3 Reset Modes

The SC92F730X has 4 kinds of reset modes:

External RST reset

- 2 Low-voltage reset (LVR)
- ③ Power-on reset (POR)



(4) Watchdog (WDT) reset.

#### 7.3.1 External Reset

External reset is to supply a certain width reset pulse signal to the SC92F730X from the RST pin to realize the SC92F730X reset.

RST/INT01/P1.1 have reset function, user can configure P1.1 pin as RST (reset pin) or not in Customer Option via PC program software before programming.

#### 7.3.2 Low-voltage Reset (LVR)

The SC92F730X provides a low-voltage reset circuit. There are 4-level LVR voltage options: 4.3V, 3.7V, 2.9V and 2.3V. The default is the Option value written by user. When the VDD voltage is lower than the threshold voltage of the low voltage reset and the duration is longer than TLVR(TLVR is the shaking time of LVR, about 30µs), a reset is generated.

#### OP\_CTM0 (C1H@FFH) Customer Option Register 0 (Read/Write)

| Bit Number      | 7     | 6 | 5          | 4 | 3      | 2      | 1          | 0 |
|-----------------|-------|---|------------|---|--------|--------|------------|---|
| Bit<br>Mnemonic | ENWDT | - | SCLKS[1:0] |   | DISRST | DISLVR | LVRS[1: 0] |   |
| R/W             | R/W   | - | R/W        |   | R/W    | R/W    | R/W        |   |
| POR             | n     | x | ľ          | n | n      | n      | r          | 1 |

| Bit Number | Bit Mnemonic | Description                                                                                            |
|------------|--------------|--------------------------------------------------------------------------------------------------------|
| 2          | DISLVR       | LVR enable bit<br>0: LVR enable<br>1: LVR disable                                                      |
| 1 ~ 0      | LVRS [1: 0]  | LVR voltage selection bits<br>11: 4.3 V reset<br>10: 3.7 V reset<br>01: 2.9 V reset<br>00: 2.3 V reset |



The Circuit Diagram of the SC92F730X Resetting Part is shown below:



The SC92F730X Reset Diagram

#### 7.3.3 Power-on Reset (POR)

The SC92F730X provides a power-on reset circuit. When power voltage VDD is up to POR reset voltage, the system will be reset automatically.

#### 7.3.4 Watchdog Reset (WDT)

The SC92F730X has a WDT, the clock source of which is the internal 128 kHz oscillator. User can select whether to enable Watchdog Reset function by programmer Code Option.

#### OP\_CTM0 (C1H@FFH) Customer Option Register 0 (Read/Write)

| Bit Number      | 7     | 6 | 5          | 4 | 3      | 2      | 1          | 0 |
|-----------------|-------|---|------------|---|--------|--------|------------|---|
| Bit<br>Mnemonic | ENWDT |   | SCLKS[1:0] |   | DISRST | DISLVR | LVRS[1: 0] |   |
| R/W             | R/W   | - | R/W        |   | R/W    | R/W    | R/W        |   |
| POR             | n     | x | n          |   | n      | n      | n          |   |

| Bit Number | Bit Mnemonic | Description                                                                                                                           |
|------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 7          | ENWDT        | WDT control bit (This bit is transferred by the system to the value set<br>by the user Code Option)<br>1: WDT valid<br>0: WDT invalid |

#### WDTCON (CFH) WDT Control Register (Read/Write)



| Bit Number      | 7 | 6 | 5 | 4      | 3 | 2            | 1 | 0  |
|-----------------|---|---|---|--------|---|--------------|---|----|
| Bit<br>Mnemonic | - | - | - | CLRWDT | - | WDTCKS[2: 0] |   | D] |
| R/W             | - | - | - | R/W    | - | R/W          |   |    |
| POR             | х | х | х | 0      | х | 0            | 0 | 0  |

| Bit Number | Bit Mnemonic  | Description                                                                                |                   |  |  |  |  |
|------------|---------------|--------------------------------------------------------------------------------------------|-------------------|--|--|--|--|
| 4          | CLRWDT        | Clear WDT (Only valid when set to 1)<br>1: WDT counter restart, cleared by system hardware |                   |  |  |  |  |
|            |               | WDT clock selection                                                                        | on bits           |  |  |  |  |
|            |               | WDTCKS[2: 0]                                                                               | WDT overflow time |  |  |  |  |
|            |               | 000                                                                                        | 500ms             |  |  |  |  |
|            |               | 001                                                                                        | 250ms             |  |  |  |  |
|            |               | 010                                                                                        | 125ms             |  |  |  |  |
| 2 ~ 0      | WDTCKS [2: 0] | 011                                                                                        | 62.5ms            |  |  |  |  |
|            |               | 100                                                                                        | 31.5ms            |  |  |  |  |
|            |               | 101                                                                                        | 15.75ms           |  |  |  |  |
|            |               | 110 7.88ms                                                                                 |                   |  |  |  |  |
|            |               | 111                                                                                        | 3.94ms            |  |  |  |  |
| 7 ~ 5, 3   |               | Reserved                                                                                   |                   |  |  |  |  |

#### 7.3.5 Register Reset Value

During reset, most registers are set to their initial values and the WDT remains disable. The register of PORT is FFh. The initial value of program counter (PC) is 0000h, and the initial value of stack pointer SP is 07h. Reset of "Hot Start" (such as WDT, LVR, etc.) will not influence SRAM which always keep the value before resetting. The SRAM contents will be retained until the power voltage is too low to keep RAM alive.

The initial value of power-on reset in SFRs is shown in the table below:

| Mnemonic | Reset value | Mnemonic | Reset value |
|----------|-------------|----------|-------------|
| ACC      | 0000000b    | P0PH     | xx000000b   |
| В        | 0000000b    | P0VO     | xxx00000b   |
| PSW      | 0000000b    | P1       | 00xx0000b   |



| Mnemonic | Reset value | Mnemonic | Reset value |  |
|----------|-------------|----------|-------------|--|
| SP       | 00000111b   | P1CON    | 00xx0000b   |  |
| DPL      | 0000000b    | P1PH     | 00xx0000b   |  |
| DPH      | 0000000b    | P2       | 0000xx00b   |  |
| PCON     | 0xxxxx00b   | P2CON    | 0000xx00b   |  |
| ADCCFG0  | 0000xx00b   | P2PH     | 0000xx00b   |  |
| ADCCFG1  | xxxxxx00b   | PWMCFG0  | xx000000b   |  |
| ADCCON   | 0000000b    | PWMCFG1  | xx000xxxb   |  |
| ADCVH    | 0000000b    | PWMCON   | 0000000b    |  |
| ADCVL    | 0000xxxxb   | PWMDTY0  | 0000000b    |  |
| BTMCON   | 00xx0000b   | PWMDTY1  | 0000000b    |  |
| IAPADE   | 0000000b    | PWMDTY2  | 0000000b    |  |
| IAPADH   | xxx00000b   | PWMDTY3  | 0000000b    |  |
| IAPADL   | 0000000b    | PWMDTY4  | 0000000b    |  |
| IAPCTL   | xxxx0000b   | PWMDTY5  | 0000000b    |  |
| IAPDAT   | 0000000b    | PWMPRD   | 0000000b    |  |
| IAPKEY   | 0000000b    | RCAP2H   | 0000000b    |  |
| IE       | 00000x00b   | RCAP2L   | 0000000b    |  |
| IE1      | xxxx000xb   | SBUF     | 0000000b    |  |
| INTOR    | xxxx0000b   | SCON     | 0000000b    |  |
| INT2R    | xx00xx00b   | TCON     | 0000xxxxb   |  |
| INTOF    | xxxx0000b   | TMCON    | xxxxx000b   |  |
| INT2F    | xx00xx00b   | TMOD     | x000x000b   |  |
| IP       | x0000x00b   | TH0      | 0000000b    |  |
| IP1      | xxxx000xb   | TLO      | 0000000b    |  |
| OTCON    | xxxx00xxb   | TH1      | 0000000b    |  |
| OPINX    | 0000000b    | TL1      | 0000000b    |  |
| OPREG    | nnnnnnb     | T2CON    | 0x00x0xxb   |  |
| IOHCON   | 0000000b    | TH2      | 0000000b    |  |



| Mnemonic | Reset value | Mnemonic | Reset value |
|----------|-------------|----------|-------------|
| P0       | xx000000b   | TL2      | 0000000b    |
| P0CON    | xx000000b   | WDTCON   | xxx0x000b   |

### 7.4 High-speed RC Oscillator

The SC92F730X has a built-in adjustable high-precision HRC. HRC is precisely calibrated to 24 MHz@5V/25°C when delivery. The user can set system clock as 24/12/6/2MHz by programmer Code Option. The calibration process is to filter the influence of processing deviation on precision. There will be certain drifting of this HRC depending on operating temperature and voltage. As for voltage drifting (2.4V ~ 5.5V) and temperature drifting (- $40^{\circ}C \sim 85^{\circ}C$ ), the deviation is within ±1%.

#### OP\_CTM0 (C1H@FFH) Customer Option Register 0 (Read/Write)

| Bit Number      | 7     | 6 | 5          | 4 | 3      | 2      | 1         | 0 |
|-----------------|-------|---|------------|---|--------|--------|-----------|---|
| Bit<br>Mnemonic | ENWDT | - | SCLKS[1:0] |   | DISRST | DISLVR | LVRS[1:0] |   |
| R/W             | R/W   | - | R/W        |   | R/W    | R/W    | R/W       |   |
| POR             | n     | х |            | ı | n      | n      | ľ         | 1 |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                                                          |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 ~ 4      | SCLKS[1:0]   | System clock frequency selection bits:<br>00: reserved; System clock frequency is HRC frequency divided by1;<br>01: system clock frequency is HRC frequency divided by 2;<br>10: system clock frequency is HRC frequency divided by 4;<br>11: system clock frequency is HRC frequency divided by 12; |

The SC92F730X has a special function: the user can modify SFR value to adjust frequency of HRC within certain scope.

#### OP\_HRCR (83H@FFH) System Clock Change Register (Read/Write)

| Bit Number      | 7 | 6             | 5 | 4 | 3 | 2 | 1 | 0 |
|-----------------|---|---------------|---|---|---|---|---|---|
| Bit<br>Mnemonic |   | OP_HRCR[7: 0] |   |   |   |   |   |   |
| R/W             |   | R/W           |   |   |   |   |   |   |
| POR             | n | n             | n | n | n | n | n | n |



| Bit Number | Bit Mnemonic  |                                              | Description                                                                                                                                                                  |
|------------|---------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |               | HRC frequency change                         | e register                                                                                                                                                                   |
|            |               | precisely works at 24/12                     | [7:0] when power-on can make sure HRC<br>/6/2MHz (according to Code Option), there<br>_HRCR[s] of each IC .User can change HRC<br>of this register.                          |
|            |               |                                              | _HRCR[s], IC system clock works at<br>change of 1 for OP_HRCR [7: 0], the change<br>@12MHz.                                                                                  |
|            |               | The relationship betwee is shown as follows: | n OP_HRCR [7: 0] and output frequency HRC                                                                                                                                    |
|            |               | OP_HRCR [7:0]                                | HRC actual output frequency (taking 12M as an example)                                                                                                                       |
|            |               | OP_HRCR [s]-n                                | 12000* (1-0.23%*n)kHz                                                                                                                                                        |
|            |               |                                              |                                                                                                                                                                              |
|            |               | OP_HRCR [s]-2                                | 12000* (1-0.23%*2) = 11944.8kHz                                                                                                                                              |
| 7 ~ 0      | OP_HRCR[7: 0] | OP_HRCR [s]-1                                | 12000* (1-0.23%*1) = 11972.4kHz                                                                                                                                              |
|            |               | OP_HRCR [s]                                  | 12000kHz                                                                                                                                                                     |
|            |               | OP_HRCR [s]+1                                | 12000* (1+0.23%*1) = 12027.6kHz                                                                                                                                              |
|            |               | OP_HRCR [s]+2                                | 12000* (1+0.23%*2) = 12055.2kHz                                                                                                                                              |
|            |               |                                              |                                                                                                                                                                              |
|            |               | OP_HRCR [s]+n                                | 12000* (1+0.23%*n)kHz                                                                                                                                                        |
|            |               | Note:                                        |                                                                                                                                                                              |
|            |               | the value of HRC f<br>modify the value o     | IRCR[7:0] after each power-on of the IC is<br>requency closest to 24MHz; the user can<br>of HRC after each power-on by means of<br>HRC work at the frequency the user needs; |
|            |               | 2. To guarantee IC of of IC shall not exc    | perating reliably, the operating frequency<br>eed 24MHz;                                                                                                                     |
|            |               | 3. The user shall con<br>influence other fur | firm the change of HRC frequency will not nctions.                                                                                                                           |

## 7.5 Low-speed RC Oscillator

The SC92F730X is equipped with a built-in 32kHz RC oscillation circuit, which can be set as clock source of low-frequency clock timer Base Timer and WDT. This 32kHz low-frequency oscillator can be activated by enable Base Timer or WDT.



Base Timer, a low-frequency clock timer which can wake up CPU from STOP mode and generate interrupt.

#### BTMCON (CEH) Low-Frequency Timer Control Register (Read/Write)

| Bit Number      | 7     | 6     | 5 | 4 | 3 | 2    | 1       | 0 |
|-----------------|-------|-------|---|---|---|------|---------|---|
| Bit<br>Mnemonic | ENBTM | BTMIF | - | - |   | BTMF | S[3: 0] |   |
| R/W             | R/W   | R/W   | - | - |   | R    | W       |   |
| POR             | 0     | 0     | х | х | 0 | 0    | 0       | 0 |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | ENBTM        | Low-frequency Base Timer start control bit<br>0: Base Timer not start<br>1: Base Timer start                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6          | BTMIF        | Base Timer interrupt application flag bit<br>When CPU receives Base Timer interrupt, this flag will be cleared<br>automatically by hardware and cleared manually by software.                                                                                                                                                                                                                                                                                                                                                                           |
| 3~0        | BTMFS [3: 0] | Low-frequency clock interrupt frequency selection bits<br>0000: an interrupt is generated for every 15.625ms<br>0001: an interrupt is generated for every 31.25ms<br>0010: an interrupt is generated for every 62.5ms<br>0011: an interrupt is generated for every 125ms<br>0100: an interrupt is generated for every 0.25s<br>0101: an interrupt is generated for every 0.5s<br>0110: an interrupt is generated for every 1.0s<br>0111: an interrupt is generated for every 2.0s<br>1000: an interrupt is generated for every 4.0s<br>Others: reserved |
| 5~4        | -            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |



Base timer structure is shown as follows:



### 7.6 Power Saving Modes

The SC92F730X provides a SFR PCON, the user can configure bit 0 and bit 1 of this register to control MCU to enter different operating modes.

When PCON.1 = 1, internal high-frequency system clock would stop and system enter STOP mode to save power. In STOP mod, the user can wake up SC92F730X by external interrupt INT0, INT2, and low frequency clock interrupt, user also can wake up STOP by external reset.

When PCON.0 = 1, the program would stop running and System enter IDLE mode. But the external equipment and clock will continue running, CPU will keep all states before entering IDLE mode. The system can be woken up from IDLE by any interrupt.

| Bit Number      | 7    | 6 | 5 | 4 | 3 | 2 | 1    | 0   |
|-----------------|------|---|---|---|---|---|------|-----|
| Bit<br>Mnemonic | SMOD | - | - | - | - | - | STOP | IDL |
| R/W             | W    |   | - | - | - | - | W    | W   |
| POR             | 0    | x | х | х | х | х | 0    | 0   |

#### PCON (87H) Power Management Control Register (only for write, \*unreadable\*)

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                 |
|------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | STOP         | STOP mode control bit<br>0: normal operating mode<br>1: stop mode, high-frequency oscillator stops operating, low-frequency<br>oscillator and WDT can select to work based on configuration |
| 0          | IDL          | IDLE mode control bit<br>0: normal operating mode<br>1: IDLE mode, the program stops operating, but external equipment                                                                      |



| Bit Number | Bit Mnemonic | Description                                                                          |
|------------|--------------|--------------------------------------------------------------------------------------|
|            |              | and clock continue to operate and all CPU states are saved before entering IDLE mode |

Note: When Configure MCU to enter STOP or IDLE mode, the instruction of configuring PCON register should be followed by 8 "NOP" instructions rather than other instructions. Or else, it will be unable to execute following instructions normally after wake-up!

For example, configure MCU to enter STOP mode:

| C program example: |
|--------------------|
|--------------------|

#include"intrins.h"

| PCON  = 0x02;         | //Set PCON bit1 STOP bit to 1, configure MCU to enter STOP mode  |
|-----------------------|------------------------------------------------------------------|
| _nop_ ();             | //At least 8 _nop_ () required                                   |
| _nop_ ();             |                                                                  |
|                       |                                                                  |
| Assembly program exam | nple:                                                            |
| ORL PCON, #02H        | ; Set PCON bits1 STOP bit to 1, configure MCU to enter STOP mode |
| NOP                   | ; At least 8 NOP required                                        |
| NOP                   |                                                                  |
| NOP                   |                                                                  |
| NOP                   |                                                                  |
| NOP                   |                                                                  |

NOP

NOP

NOP

. . . . . .



# 8 CPU and Function System

### 8.1 CPU

CPU used by the SC92F730X is the high-speed 1T standard 8051 core, whose instructions are completely compatible with traditional 8051 core microcontroller unit.

### 8.2 Addressing Mode

The addressing mode of the SC92F730X 1T 8051 CPU instructions includes: ①Immediate Addressing ② Direct Addressing ③ Indirect Address ④ Register Addressing ⑤ Relative Addressing ⑥ Indexed Addressing ⑦ Bit Addressing

#### 8.2.1 Immediate Addressing

Immediate addressing is also called immediate operand addressing, which is the operand given to participate in operation in instruction, the instruction is illustrated as follows:

MOV A, #50H (This instruction is to move immediate operand 50H to Accumulator A)

#### 8.2.2 Direct Addressing

In direct addressing mode, the instruction operand field indicates the address to participate in operation operand. Direct addressing can only be used to address SFRs, internal data registers and bit address space. The SFRs and bit address space can only be accessed by direct addressing. For example:

ANL 50H, #91H (The instruction indicates the data in 50H unit AND immediate operand 91H, and the results are stored in 50H unit. 50H refers to direct address, indicating one unit in internal data register RAM.)

#### 8.2.3 Indirect Addressing

Indirect addressing is expressed as adding "@" before R0 or R1. Suppose the data in R1 is 40H and the data of internal data register 40H unit is 55H, then the instruction will be

MOV A, @R1 (Move the data 55h to Accumulator A).

#### 8.2.4 Register Addressing

Register addressing is to operate the data in the selected registers R7 ~ R0, Accumulator A, general-purpose register B, address registers and carry bit C. The registers R7-R0 is indicated by lower 3 bits of instruction code. ACC, B, DPTR and carry bit C are implied in the instruction code. Therefore, register addressing can also include an implied addressing mode. The selection of register operating area depends on RS1 and RS0 of PSW. The registers indicated by instruction operand refers to the registers in current operating area.

INC R0 refers to (R0)  $+1 \rightarrow R0$ 

#### 8.2.5 Relative Addressing



Relative addressing is to add current value in program counter (PC) and the data in the second byte of the instruction, whose result shall be taken as the jump address of jump instruction. The Jump address is the target jump address, the current value in PC is the base address and the data in the second byte of the instruction is the offset address. Because the target jump address is relative to base address in PC, such addressing mode is called relative addressing. The offset is signed number, which ranges from +127 to -128, such addressing mode is mainly applied to jump instruction.

JC \$+50H

It indicates that if the carry bit C is 0, the contents in program counter PC remain the same, meaning no jump. On the contrary, if the carry bit C is 1, take the sum of the current value in PC and base address as well as offset 50H as the target jump address of this jump instruction.

#### 8.2.6 Indexed Addressing

In indexed addressing mode, the instruction operand is to develop an indexed register to store indexed base address. Upon indexed addressing, the result by adding offset and indexed base address is taken as the address of operation operand. The indexed registers include PC and address register DPTR.

MOVC A, @A+DPTR

It indicates Accumulator A is used as offset register. Take the sum of the value in A and that in the address register DPTR as the address of operand. Then take the figure in the address out and transmit it to Accumulator A.

#### 8.2.7 Bits Addressing

Bit addressing is a kind of addressing mode when conducting bit operation on internal data storage RAM and SFRs which are able to carry out bit operations. Upon bit operations, by taking carry bit C as bit operation accumulator, the instruction operand will give the address of this bit directly, then execute bit operation based on the nature of operation code.



# 9 Interrupt

The SC92F730X provides 9 interrupt sources: Timer0, Timer1, Timer2, INT0, INT2, ADC, PWM, UART, and Base Timer. These 9 interrupt sources are equipped with 2-level interrupt priority-capability and each interrupt source can be individually configured in high priority or low priority. As for two external interrupts, the triggering condition of each interrupt source can be set as rising edge, falling edge or dual-edge trigger. Each interrupt is equipped with independent priority setting bit, interrupt flag, interrupt vector and enable bit. Global interrupt enable bit EA can enable or disable all interrupts.

## 9.1 Interrupt Source and Vector

Lists for the SC92F730X interrupt source, interrupt vector and related control bit are shown below:

| Interrupt<br>Source | Interrupt<br>condition                                  | Interrupt Flag | Interrupt<br>Enable<br>Control | Interrupt<br>Priority<br>Control | Interrupt<br>Vector | Query<br>Priority | Interrupt<br>Number<br>(C51) | Flag Clear<br>Mode            | Capability of<br>Waking up<br>STOP |
|---------------------|---------------------------------------------------------|----------------|--------------------------------|----------------------------------|---------------------|-------------------|------------------------------|-------------------------------|------------------------------------|
| INTO                | Compliant with<br>External<br>interrupt 0<br>conditions | -              | EINTO                          | IPINT0                           | 0003H               | 1 (high)          | 0                            | -                             | Yes                                |
| Timer0              | Timer0 overflow                                         | TF0            | ET0                            | IPT0                             | 000BH               | 2                 | 1                            | H/W Auto                      | No                                 |
| Timer1              | Timer1 overflow                                         | TF1            | ET1                            | IPT1                             | 001BH               | 3                 | 3                            | H/W Auto                      | No                                 |
| UART                | Receiving or<br>transmitting<br>completed               | RI/TI          | EUART                          | IPUART                           | 0023H               | 4                 | 4                            | Must be<br>cleared by<br>user | No                                 |
| Timer2              | Timer2 overflow                                         | TF2            | ET2                            | IPT2                             | 002BH               | 5                 | 5                            | Must be<br>cleared by<br>user | No                                 |
| ADC                 | ADC<br>conversion<br>completed                          | ADCIF          | EADC                           | IPADC                            | 0033H               | 6                 | 6                            | Must be<br>cleared by<br>user | No                                 |
| PWM                 | PWM overflow                                            | PWMIF          | EPWM                           | IPPWM                            | 0043H               | 7                 | 8                            | Must be<br>cleared by<br>user | No                                 |
| BTM                 | Base timer<br>overflow                                  | BTMIF          | EBTM                           | IPBTM                            | 004BH               | 8                 | 9                            | H/W Auto                      | Yes                                |
| INT2                | External<br>interrupt 2<br>conditions<br>compliant      | -              | EINT2                          | IPINT2                           | 0053H               | 9                 | 10                           | -                             | Yes                                |

Under the circumstance where the master interrupt control bit EA and the respective interrupt control bit have been enable, the interrupt occurrence is shown below:

Timer Interrupt: Interrupt generates when Timer0 or Timer1 overflows and the interrupt flag TF0 or TF1 is set to



"1". When the microcontroller unit responds to the timer interrupt, the interrupt flag TF0 or TF1 is reset automatically by hardware. Interrupt generates when Timer2 overflows and the interrupt flag TF2 is set to "1". Once Timer2 interrupt generates, the hardware would not automatically clear TF2 bit, which must be cleared by the user's software.

**UART Interrupt:** When a frame of data is completed in UART reception or transmission, the RI or TI bit will be automatically set to "1" by hardware, and a UART interrupt will be generated. After a UART interrupt occurs, the hardware will not automatically clear the RI/TI bit, and this bit must be cleared by software

**ADC Interrupt:** After ADC conversion is completed, ADC interrupt generates, whose interrupt flag is the ADC conversion completion flag EOC/ADCIF (ADCCON.4). When user starts ADCS conversion, EOC will be reset automatically by hardware. Once conversion completes, EOC would be set to "1" automatically by hardware. User should clear the ADC interrupt flag by software when the interrupt service routine is executed after ADC interrupt generates.

**PWM Interrupt**: When PWM counter overflows (beyond PWMPD), The PWMIF bit will be set to 1 automatically by hardware, PWM interrupt generates. After a PWM interrupt occurs, the hardware will not automatically clear the PWMIF bit, and this bit must be cleared by software

**External Interrupt INTO and INT2:** When any external interrupt pin meets the interrupt conditions, external interrupt generates. There are 4 external interrupt sources for INT0 and 4 external interrupt sources for INT2, which can be set in rising edge, falling edge or dual edge interrupt trigger mode by setting SFRs (INTxF and INTxR). User can set the priority level of each interrupt through IP register. Besides, external interrupt INT0 and INT2 can also wake up STOP mode of microcontroller unit.



## 9.2 Interrupt Structure Diagram

The SC92F730X interrupt structure is shown in the figure below:



The SC92F730X Interrupt Structure and Vector

## 9.3 Interrupt Priority

The SC92F730X microcontroller unit has two-level interrupt priority capability. The interrupt requests of these interrupt sources can be programmed as high-priority interrupt or low-priority interrupt, which is to realize the nesting of two levels of interrupt service programs. One interrupt can be interrupted by a higher priority interrupt request when being responded to, which can not be interrupted by another interrupt request at the same priority level, until such response to the first-come interrupt ends up with the instruction "RETI". Exist the interrupt service routine and return to main program, the system would execute one more instruction before responding to new interrupt request.



That is to say:

- 1 A lower priority interrupt can be interrupted by a higher priority interrupt request, but not vice verse;
- (2) Any kind of interrupt being responded to can not be interrupted by another interrupt request at the same priority level.

Interrupt query sequence: As for the sequence of that the SC92F730X microcontroller unit responds to the same priority interrupts which occur in the meantime, the priority sequence of interrupt response shall be the same as the interrupt query number in C51, which is to preferentially respond to the interrupt with smaller query number then the interrupt with bigger query number.

## 9.4 Interrupt Processing Flow

When any interrupt generates and is responded by CPU, the operation of main program will be interrupted to carry out the following operations:

- ① Complete execution of instruction being currently executed;
- 2 Push the PC value into stack for site protection;
- ③ Load Interrupt vector address into program counter (PC);
- (4) Carry out corresponding interrupt service program;
- (5) End Interrupt service program ends and execute RETI;
- (6) Pop PC value from stack and return to the program before responding to the interrupt.

During this process, the system will not immediately respond to other interrupts at the same priority level, but it will keep all interrupt requests having occurred and respond to new interrupt requests upon completing handling of the current interrupt.

## 9.5 Interrupt-related Registers

| Bit Number      | 7   | 6    | 5   | 4     | 3   | 2 | 1   | 0     |
|-----------------|-----|------|-----|-------|-----|---|-----|-------|
| Bit<br>Mnemonic | EA  | EADC | ET2 | EUART | ET1 | - | ET0 | EINTO |
| R/W             | R/W | R/W  | R/W | R/W   | R/W | - | R/W | R/W   |
| POR             | 0   | 0    | 0   | 0     | 0   | х | 0   | 0     |

#### IE (A8H) Interrupt Enable Register (Read/Write)

| Bit Number | Bit Mnemonic | Description |
|------------|--------------|-------------|
|            |              |             |



| 7 | EA    | Global interrupt enable control bit<br>0: Disable all interrupts<br>1: Enable all interrupts                            |
|---|-------|-------------------------------------------------------------------------------------------------------------------------|
| 6 | EADC  | ADC interrupt enable control bit<br>0: Disable ADC interrupts<br>1: Interrupt is allowed upon completing ADC conversion |
| 5 | ET2   | Timer2 interrupt enable control bit<br>0: Disable Timer2 interrupt<br>1: Enable Timer2 interrupt                        |
| 4 | EUART | UART interrupt enable control bit<br>0: Disable UART interrupt<br>1: Enable UART interrupt                              |
| 3 | ET1   | Timer1 interrupt enable control bit<br>0: Disable Timer1 interrupt<br>1: Enable Timer1 interrupt                        |
| 1 | ET0   | Timer0 interrupt enable control bit<br>0: Disable Timer0 interrupt<br>1: Enable Timer0 interrupt                        |
| 0 | EINTO | External interrupt 0 enable control bit<br>0: Disable INT0 interrupt<br>1: Enable INT0 interrupt                        |
| 2 | -     | Reserved                                                                                                                |

### IP (B8H) Interrupt Priority Control Register (Read/Write)

| Bit Number      | 7 | 6     | 5    | 4      | 3    | 2 | 1    | 0      |
|-----------------|---|-------|------|--------|------|---|------|--------|
| Bit<br>Mnemonic | - | IPADC | IPT2 | IPUART | IPT1 | - | IPT0 | IPINT0 |
| R/W             | - | R/W   | R/W  | R/W    | R/W  | - | R/W  | R/W    |
| POR             | х | 0     | 0    | 0      | 0    | х | 0    | 0      |

| Bit Number | Bit Mnemonic | Description                                                              |
|------------|--------------|--------------------------------------------------------------------------|
| 6          | IPADC        | ADC interrupt priority selection bit<br>0: ADC interrupt priority is low |



| Bit Number | Bit Mnemonic | Description                                                                                                             |
|------------|--------------|-------------------------------------------------------------------------------------------------------------------------|
|            |              | 1: ADC interrupt priority is high                                                                                       |
| 5          | IPT2         | Timer2 interrupt priority selection bit<br>0: Timer2 interrupt priority is low<br>1: Timer2 interrupt priority is high  |
| 4          | IPUART       | UART interrupt priority selection bit<br>0: UART interrupt priority is low<br>1: UART interrupt priority is high        |
| 3          | IPT1         | Timer1 interrupt priority selection bit<br>0: Timer1 interrupt priority is low<br>1: Timer1 interrupt priority is high  |
| 1          | IPT0         | Timer 0 interrupt priority selection bit<br>0: Timer0 interrupt priority is low<br>1: Timer0 interrupt priority is high |
| 0          | IPINT0       | INT0 interrupt priority selection bit<br>0: INT0 interrupt priority is low<br>1: INT0 interrupt priority is high        |
| 7,2        | -            | Reserved                                                                                                                |

### IE1 (A9H) Interrupt Enable Register 1 (Read/Write)

| Bit Number      | 7 | 6 | 5 | 4 | 3     | 2    | 1    | 0 |
|-----------------|---|---|---|---|-------|------|------|---|
| Bit<br>Mnemonic | - | - | - | - | EINT2 | EBTM | EPWM | - |
| R/W             | - | - | - | - | R/W   | R/W  | R/W  | - |
| POR             | x | x | х | х | 0     | 0    | 0    | х |

| Bit Number | Bit Mnemonic | Description                                                                                                    |  |  |
|------------|--------------|----------------------------------------------------------------------------------------------------------------|--|--|
| 3          | EINT2        | External interrupt 2 enabling control bit<br>0: Disable External interrupt 2<br>1: Enable External interrupt 2 |  |  |
| 2          | EBTM         | Base Timer interrupt enabling control bit<br>0: Disable Base Timer interrupt<br>1: Enable Base Timer interrupt |  |  |



| Bit Number | Bit Mnemonic | Description                                                                                                                               |
|------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | EPWM         | PWM interrupt enabling control bit<br>0: Disable PWM interrupt<br>1: Enable interrupt upon PWM counting overflows (counting to<br>PWMPRD) |
| 7 ~ 4,0    | -            | Reserved                                                                                                                                  |

### IP1 (B9H) Interrupt Priority Control Register 1 (Read/Write)

| IP1 (B9H) Inte  | rrupt Priorit | ty Control R | egister 1 (R | lead/Write) |        |       |       |   |
|-----------------|---------------|--------------|--------------|-------------|--------|-------|-------|---|
| Bit Number      | 7             | 6            | 5            | 4           | 3      | 2     | 1     | 0 |
| Bit<br>Mnemonic | -             | -            | -            | -           | IPINT2 | IPBTM | IPPWM | - |
| R/W             | -             | -            | -            | -           | R/W    | R/W   | R/W   | - |
| POR             | х             | х            | х            | x           | 0      | 0     | 0     | х |
|                 |               |              |              |             |        |       |       |   |

| Bit Number | Bit Mnemonic | Description                                                                                                                        |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------|
| 3          | IPINT2       | INT2 interrupt priority selection bit<br>0: INT2 interrupt priority is low<br>1: INT2 interrupt priority is high                   |
| 2          | IPBTM        | Base Timer interrupt priority selection bit<br>0: Base Timer interrupt priority is low<br>1: Base Timer interrupt priority is high |
| 1          | IPPWM        | PWM interrupt priority selection bit<br>0: PWM interrupt priority is low<br>1: PWM interrupt priority is high                      |
| 7 ~ 4,0    | -            | Reserved                                                                                                                           |

### INTOF (BAH) INTO Falling Edge Interrupt Control Register (Read/Write)

| Bit Number      | 7 | 6 | 5 | 4 | 3      | 2      | 1      | 0      |
|-----------------|---|---|---|---|--------|--------|--------|--------|
| Bit<br>Mnemonic | - | - | - | - | INT0F3 | INT0F2 | INT0F1 | INT0F0 |
| R/W             | - | - | - | - | R/W    | R/W    | R/W    | R/W    |
| POR             | х | х | х | х | 0      | 0      | 0      | 0      |



| Bit Number | Bit Mnemonic        | Description                                                                                                                  |
|------------|---------------------|------------------------------------------------------------------------------------------------------------------------------|
| 3 ~ 0      | INT0Fn<br>(n=0 ~ 3) | INT0 falling edge interrupt control bit<br>0: INT0n falling edge interrupt disable<br>1: INT0n falling edge interrupt enable |
| 7 ~ 4      | -                   | Reserved                                                                                                                     |

### INTOR (BBH) INTO Rising Edge Interrupt Control Register (Read/Write)

| Bit Number      | 7 | 6 | 5 | 4 | 3      | 2      | 1      | 0      |
|-----------------|---|---|---|---|--------|--------|--------|--------|
| Bit<br>Mnemonic | - | - | - | - | INT0R3 | INT0R2 | INT0R1 | INT0R0 |
| R/W             | - | - | - | - | R/W    | R/W    | R/W    | R/W    |
| POR             | х | х | х | x | 0      | 0      | 0      | 0      |

| Bit Number | Bit Mnemonic        | Description                                                                                                               |
|------------|---------------------|---------------------------------------------------------------------------------------------------------------------------|
| 3 ~ 0      | INT0Rn<br>(n=0 ~ 3) | INT0 rising edge interrupt control bit<br>0: INT0n rising edge interrupt disable<br>1: INT0n rising edge interrupt enable |
| 7 ~ 4      | -                   | Reserved                                                                                                                  |

### INT2F (C6H) INT2 Falling Edge Interrupt Control Register (Read/Write)

| Bit Number      | 7   | 6 | 5      | 4      | 3 | 2 | 1      | 0      |
|-----------------|-----|---|--------|--------|---|---|--------|--------|
| Bit<br>Mnemonic | ) - | - | INT2F5 | INT2F4 | - | - | INT2F1 | INT2F0 |
| R/W             | -   | - | R/W    | R/W    | - | - | R/W    | R/W    |
| POR             | х   | х | 0      | 0      | х | х | 0      | 0      |

| Bit Number  | Bit Mnemonic              | Description                                                                                                                  |
|-------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------|
| 5 ~ 4,2 ~ 1 | INT2Fn<br>(n=1 ~ 2,4 ~ 5) | INT2 falling edge interrupt control bit<br>0: INT2n falling edge interrupt disable<br>1: INT2n falling edge interrupt enable |
| 7 ~ 6,3 ~ 2 | -                         | Reserved                                                                                                                     |



### INT2R (C7H) INT2 Rising Edge Interrupt Control Register (Read/Write)

| Bit Number      | 7 | 6 | 5      | 4      | 3 | 2 | 1      | 0      |
|-----------------|---|---|--------|--------|---|---|--------|--------|
| Bit<br>Mnemonic | - | - | INT2R5 | INT2R4 | - | - | INT2R1 | INT2R0 |
| R/W             | - | - | R/W    | R/W    | - | - | R/W    | R/W    |
| POR             | х | х | 0      | 0      | х | х | 0      | 0      |

| Bit Number  | Bit Mnemonic              | Description                                                                                                               |
|-------------|---------------------------|---------------------------------------------------------------------------------------------------------------------------|
| 5 ~ 4,1 ~ 0 | INT2Rn<br>(n=0 ~ 1,4 ~ 5) | INT2 rising edge interrupt control bit<br>0: INT2n rising edge interrupt disable<br>1: INT2n rising edge interrupt enable |
| 7 ~ 6,3 ~ 2 | -                         | Reserved                                                                                                                  |



# 10 Timer/Counter T0 and T1

The SC92F730X has two 16-bit Timer/Counters, Timer0 (T0) and Time1 (T1), with two operating modes: counter mode and timer mode. There is a control bit C/Tx which can select T0 and T1 as a timer or a counter. They are both essentially an addition counter, just the source of the count is different. The source of timer generated from system clock or frequency division clock, but the source of counters is the input pulse to external pin. Only when TRx = 1, will T0 and T1 be enabled on for counting.

In counter mode, each input pulse on P1.2/T0 and P1.3/T1 pin will make the count value of T0 and T1 increase by 1 respectively.

In timer mode, users can select  $f_{SYS}/12$  or  $f_{SYS}$  ( $f_{SYS}$  is the system clock) as counting source of T0 and T1 by configuring SFR TMCON.

Timer/Counter T0 has 4 operating modes, and Timer/Counter T1 has 3 operating modes (Mode 3 does not exist):

- (1) Mode 0: 13-bit Timer/Counter mode
- 2 Mode 1: 16-bit Timer/Counter mode
- 3 Mode 2: 8-bit automatic reload mode
- (4) Mode 3: Two 8-bit timers/counters mode

In above modes, modes 0, 1 and 2 of T0 and T1 are the same, and mode 3 is different.

## 10.1 T0 and T1-related Registers

| Mnemonic | Add | Description                         | 7                                       | 6         | 5         | 4    | 3      | 2    | 1    | 0    | POR       |
|----------|-----|-------------------------------------|-----------------------------------------|-----------|-----------|------|--------|------|------|------|-----------|
| TCON     | 88H | Timer Control Register              | TF1                                     | TR1       | TF0       | TR0  | -      | -    | -    | -    | 0000xxxxb |
| TMOD     | 89H | Timer Operating Mode<br>Register    | ting Mode - C/T1 M11 M01 - C/T0 M10 M00 |           | x000x000b |      |        |      |      |      |           |
| TLO      | 8AH | Timer0 Low byte                     |                                         | TL0[7: 0] |           |      |        |      |      |      |           |
| TL1      | 8BH | Timer1 Low byte                     |                                         |           |           | TL1[ | [7: 0] |      |      |      | 0000000b  |
| тно      | 8CH | Timer0 High byte                    |                                         |           |           | THO  | [7: 0] |      |      |      | 0000000b  |
| TH1      | 8DH | Timer1 High byte                    |                                         | TH1[7: 0] |           |      |        |      |      |      | 0000000b  |
| TMCON    | 8EH | Timer Frequency Control<br>Register | -                                       | -         | -         | -    | -      | T2FD | T1FD | T0FD | xxxxx000b |

Register instructions are shown below:

#### TCON (88H) Timer Control Register (Read/Write)



| Bit Number      | 7   | 6   | 5   | 4   | 3 | 2 | 1 | 0 |
|-----------------|-----|-----|-----|-----|---|---|---|---|
| Bit<br>Mnemonic | TF1 | TR1 | TF0 | TR0 | - | - | - | - |
| R/W             | R/W | R/W | R/W | R/W | - | - | - | - |
| POR             | 0   | 0   | 0   | 0   | х | х | х | х |

| Bit Number | Bit Mnemonic | Description                                                                                                                                    |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | TF1          | Timer1 overflow flag bit<br>Set by hardware on Timer/Counter overflow. Cleared by hardware<br>when the processor vectors to interrupt routine. |
| 6          | TR1          | Timer1 run control bit<br>Set/cleared by software to turn Timer/Counter on/off.                                                                |
| 5          | TF0          | Timer0 overflow flag bit<br>Set by hardware on Timer/Counter overflow. Cleared by hardware<br>when the processor vectors to interrupt routine. |
| 4          | TR0          | Timer0 run control bit<br>Set/cleared by software to turn Timer/Counter on/off.                                                                |
| 3 ~ 0      | -            | Reserved                                                                                                                                       |

### TMOD (89H) Timer Operating Mode Register (Read/Write)

| Bit Number      | 7 | 6    | 5   | 4   | 3 | 2    | 1   | 0   |
|-----------------|---|------|-----|-----|---|------|-----|-----|
| Bit<br>Mnemonic | - | C/T1 | M11 | M01 | - | С/Т0 | M10 | M00 |
| R/W             | - | R/W  | R/W | R/W | - | R/W  | R/W | R/W |
| POR             | х | 0    | 0   | 0   | х | 0    | 0   | 0   |
|                 |   | Т    | 1   | •   |   | Т    | 0   |     |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                           |  |  |  |
|------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 6          | С/Т1         | <ul><li>Timer or Counter selector 1</li><li>0: Cleared for Timer operation (input from internal system clock fsys).</li><li>1: Set for Counter operation (input from external pin T1/P1.3).</li></ul> |  |  |  |



| Bit Number | Bit Mnemonic |                       |           |          | Description                                                                                      |  |  |
|------------|--------------|-----------------------|-----------|----------|--------------------------------------------------------------------------------------------------|--|--|
|            |              | Timer1                | operating | g mode   |                                                                                                  |  |  |
|            |              | Mode                  | M11       | M01      | Operation                                                                                        |  |  |
|            |              | 0                     | 0         | 0        | 13-bit TIMER/Counter, TL1 high 3 bits invalid                                                    |  |  |
| 5 ~ 4      | M11, M01     | 1                     | 0         | 1        | 16-bit Timer/Counter,both TL1 and TH1 are valid.                                                 |  |  |
|            |              |                       |           |          | 8-bit Auto-Reload Mode.                                                                          |  |  |
|            |              | 2                     | 1         | 0        | TH1 holds a value which is reloaded into 8-<br>bit Timer/CounterTL1 each time it<br>overflows.   |  |  |
|            |              | 3                     | 1         | 1        | Timer/Counter 1 stop counting                                                                    |  |  |
| 2          | С/Т0         |                       | ed for Ti | mer opei | r 0<br>ration (input from internal system clock fsys).<br>ion (input from external pin T0/P1.2). |  |  |
|            |              | Timer0 operating mode |           |          |                                                                                                  |  |  |
|            |              | Mode                  | M10       | M00      | Operation                                                                                        |  |  |
|            |              | 0                     | 0         | 0        | 13-bit TIMER/Counter, TL0 high 3 bits invalid                                                    |  |  |
|            |              | 1                     | 0         | 1        | 16-bit Timer/Counter,both TL0 and TH0 are valid.                                                 |  |  |
|            |              |                       |           |          | 8-bit Auto-Reload Mode.                                                                          |  |  |
| 1 ~ 0      | M10, M00     | 2                     | 1         | 0        | TH0 holds a value which is reloaded into 8-<br>bit Timer/Counter TL0 each time it<br>overflows.  |  |  |
|            |              |                       |           |          | Split Timer Mode.                                                                                |  |  |
|            |              |                       |           |          | Timer 0 now acts as a dual 8-bit timer/counter                                                   |  |  |
|            |              | 3                     | 1         | 1        | TL0 is an 8-bit Timer/Counter controlled by the standard Timer0 control bits.                    |  |  |
|            |              |                       |           |          | TH0 is only an 8-bit timer controlled by<br>Timer1 control bits                                  |  |  |
| 7, 3       | -            | Reserve               | d         |          |                                                                                                  |  |  |

TMOD[0] ~ TMOD[2] of TMOD register is to set operating mode of T0; TMOD[4] ~ TMOD[6] is to set the operating mode of T1.

The function of timer and counter Tx is selected by the control bit C/Tx of SFR TMOD, and it's operating mode selected by M0x and M1x. Only when TRx, the switch of T0 and T1, is set to 1, will T0 and T1 be enabled



### TMCON (8EH) Timer Frequency Control Register (Read/Write)

| Bit Number      | 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0    |
|-----------------|---|---|---|---|---|------|------|------|
| Bit<br>Mnemonic | - | - | - | - | - | T2FD | T1FD | T0FD |
| R/W             | - | - | - | - | - | R/W  | R/W  | R/W  |
| POR             | х | х | х | х | х | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                                                      |
|------------|--------------|----------------------------------------------------------------------------------------------------------------------------------|
| 1          | T1FD         | T1 input frequency selection control bit<br>0: T1 clock source is f <sub>SYS</sub> /12<br>1: T1 clock source is f <sub>SYS</sub> |
| 0          | T0FD         | T0 input frequency selection control bit<br>0: T0 clock source is fsys/12<br>1: T0 clock source is fsys                          |

## IE (A8H) Interrupt Enable Register (Read/Write)

| Bit Number      | 7   | 6    | 5   | 4     | 3   | 2 | 1   | 0     |
|-----------------|-----|------|-----|-------|-----|---|-----|-------|
| Bit<br>Mnemonic | EA  | EADC | ET2 | EUART | ET1 | - | ET0 | EINTO |
| R/W             | R/W | R/W  | R/W | R/W   | R/W | - | R/W | R/W   |
| POR             | 0   | 0    | 0   | 0     | 0   | х | 0   | 0     |

| Bit Number | Bit Mnemonic | Description                                                                                      |
|------------|--------------|--------------------------------------------------------------------------------------------------|
| 3          | ET1          | Timer1 interrupt enable control bit<br>0: Disable Timer1 interrupt<br>1: Enable Timer1 interrupt |
| 1          | ET0          | Timer0 interrupt enable control bit<br>0: Disable Timer0 interrupt<br>1: Enable Timer0 interrupt |



### IP (B8H) Interrupt Priority Control Register (Read/Write)

| Bit Number      | 7 | 6     | 5    | 4      | 3    | 2 | 1    | 0      |
|-----------------|---|-------|------|--------|------|---|------|--------|
| Bit<br>Mnemonic | - | IPADC | IPT2 | IPUART | IPT1 | - | IPT0 | IPINT0 |
| R/W             | - | R/W   | R/W  | R/W    | R/W  | - | R/W  | R/W    |
| POR             | х | 0     | 0    | 0      | 0    | х | 0    | 0      |

| Bit Number | Bit Mnemonic | Description                                                                                                                                    |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | IPT1         | Timer1 interrupt priority selection bit<br>0: Configure Timer1 interrupt priority as "low"<br>1: Configure Timer1 interrupt priority as "high" |
| 1          | IPT0         | Timer0 interrupt priority selection bit<br>0: Configure Timer0 interrupt priority as "low"<br>1: Configure Timer0 interrupt priority as "high" |

## **10.2 T0 Operating Modes**

Timer0 can be configured in one of four operating modes by setting the bit pairs (M10, M00) in the TMOD register.

### Operating mode 0: 13-bit Timer/Counter

TH0 register is to store the high 8 bits (TH0.7 ~ TH0.0) of 13-bit Timer/Counter and TL0 is to store the low 5 bits (TL0.4 ~ TL0.0). The high three bits of TL0 (TL0.7 ~ TL0.5) are filled with uncertain values, they shall be omitted upon reading. When 13-bit Timer/Counter overflows with count increment, the system will set timer overflow flag TF0 to 1. An interrupt will be generated if the timer0 interrupt is enabled.

C/T0 bit selects the clock input source of Timer/Counter. If C/T0=1, the level fluctuation from high to low of Counter 0 input pin T0 (P1.2) will make Counter 0 data register add 1. If C/T0=0, the frequency division of system clock is the clock source of Timer0.

When TR0 = 1, Timer 0 is enabled. Setting TR0 would not reset the timer forcibly. It means that the timer register will start to count from the value of last clearing of TR0. Therefore, before enable the timer, it is required to configure the initial value of timer register.

When configured as a timer, the SFR T0FD is used to select fractional frequency ratio of clock source.





Operating mode 0: 13-bit Timer/Counter

#### Operating Mode 1: 16 Counter/Timer

Except for using 16 bits of (valid for all 8 bits of TL0) Timer/Counter, in mode 1 and mode 0, the operating mode, opening and configuration method are the same.



Operating mode 1: 16-bit Timer/Counter

#### **Operating Mode 2: 8 Automatic Reload Counter/Timer**

In operating mode 2, Timer0 is 8-bit automatic reload Timer/Counter. TL0 is to store counting value and TH0 is to store the reload value. When the counter in TL0 overflows and turn to 0x00, the overflow flag of Timer TF0 will be set to 1, and the data in register TH0 will be reloaded into register TL0. If the timer interrupt enabled, setting TF0 to 1 will generate an interrupt, but the reloaded value in TH0 will remain the same. Before starting the Timer to count correctly, TL0 shall be initialized to the required value.

Except for automatic reloaded function, the enabling and configuration mode of Timer/Counter in operating mode 2 shall be the same as that in mode 0 and mode 1.

When configured as a timer, the SFR TMCON bit 0 (T0FD) is used to select fractional frequency ratio of system clock fsys.





Operating Mode 2: 8 Automatic Reload Counter/Timer

#### Operating Mode 3: Two 8-bit Counter/Timer (only for Timer0)

In operating mode 3, Timer0 is used as two independent 8-bit Timer/Counters, respectively controlled by TL0 and TH0. TL0 is controlled by control bit (in TCON) and status bit (in TMOD) of Timer0 (TR0), C/T0, TF0. Timer0 is selected as Timer or Counter by TMOD bit 2 (C/T0).

TH0 is only limited to in Timer Mode, which is unable to configure as a Counter by TMOD.2 (C/T0). TH0 is enabled by set the timer control bit TR1 to 1. When overflow occurs and interrupt is discovered, set TF1 to 1 and proceed the interrupt as T1 interrupt.

When T0 is configured in Operating Mode 3, TH0 Timer occupies T1 interrupt resources and TCON register and the 16-bit counter of T1 will stop counting, equivalently "TR1=0". When adopting TH0 timer, it is required to configure TR1=1.

## 10.3 T1 Operating Modes

Timer1 can be configured in one of three operating modes by setting the bit pairs (M11, M01) in the TMOD register.

#### Operating mode 0: 13-bit Timer/Counter

TH1 register is to store high 8-bit (TH1.7 ~ TH1.0) of 13-bit Timer/Counter and TL1 is to store low 5-bit (TL1.4 ~ TL1.0). The high 3-bit of TL1 (TL1.7 ~ TL1.5) are uncertain values, they shall be omitted upon reading. When 13-bit Timer/Counter overflow with count increment, the system will set timer overflow flag TF1 to 1. An interrupt will be generated if the timer1 interrupt is enabled. C/T1 bit selects the clock input source of Timer/Counter.

If C/T1=1, the level fluctuation from high to low of timer1 input pin T1 (P1.3) will make timer1 data register add 1. If C/T1=0, the frequency division of system clock is the clock source of timer1.

When TR1 is set to 1 and the timer is enabled. Setting TR1 does not force to reset timer counters, it means, if set TR1 to 1, the timer register will start to count from the value of last clearing of TR1. Therefore, before allowing timer, it is required to configure the initial value of timer register.

When configured as timer, the SFR T1FD is used to select fractional frequency ratio of clock source.





Operating mode 0: 13-bit Timer/Counter

#### **Operating Mode 1: 16 Counter/Timer**

Except for using 16-bit (valid for 8-bit data of TL1) Timer/Counter, the operating mode of mode 1 and mode 0 is the same. And the opening and configuration mode of both are also the same.



Operating mode 0: 16-bit Timer/Counter

#### **Operating Mode 2: 8 Automatic Reload Counter/Timer**

In operating mode 2, Timer1 is 8-bit automatic reload Timer/Counter. TL1 is to store counting value and TH1 is to store the reload value. When the counter in TL1 overflows 0x00, the overflow flag of Timer TF1 will be set to 1, and the value of register TH1 will be reloaded into register TL1. If enable the timer interrupt, setting TF1 to 1 will generate an interrupt, but the reloaded value in TH1 will remain unchanged. Before allowing Timer to correctly count, TL1 shall be initialized to the required value.

Except for automatic reloaded function, the enabling and configuration mode of Timer/Counter in operating mode 2 shall be the same as that of mode 0 and mode 1.

When configured as timer, the SFR TMCON bit 4 (T1FD) is used to select the ratio of clock source of timer to fractional frequency of system clock fsys.





Operating Mode 2: 8 Automatic Reload Counter/Timer



# 11 Timer/Counter T2

Timer2 inside the SC92F730X microcontroller unit works as Timer and it is an adding counter in nature. The clock source of T2 comes from system clock or frequency division clock. TR2 is the counting switch of Timer T2. Only when TR2 = 1, will T2 be enabled for counting.

In timer mode, users can select f<sub>SYS</sub>/12 or f<sub>SYS</sub> as counting source of T2 by configuring SFR TMCON.

Timer/Counter T2 has 2 operating modes:

- ① Mode 1: 16-bit automatic reload timer mode
- 2 Mode 2: Baud rate generator mode

## 11.1 T2-related Registers

| Mnemonic | Add | Description                         | 7   | 6            | 5    | 4    | 3 | 2    | 1    | 0        | POR       |
|----------|-----|-------------------------------------|-----|--------------|------|------|---|------|------|----------|-----------|
| T2CON    | C8H | Timer2 Control Register             | TF2 | -            | RCLK | TCLK | - | TR2  | -    | -        | 0x00x0xxb |
| RCAP2L   | CAH | Timer2 Reload Low Byte              |     | RCAP2L[7: 0] |      |      |   |      |      |          | 0000000b  |
| RCAP2H   | CBH | Timer2 Reload High Byte             |     | RCAP2H[7: 0] |      |      |   |      |      |          | 0000000b  |
| TL2      | ССН | Timer2 Low Byte                     |     | TL2[7: 0]    |      |      |   |      |      |          | 0000000b  |
| TH2      | CDH | Timer2 High Byte                    |     | TH2[7: 0]    |      |      |   |      |      | 0000000b |           |
| TMCON    | 8EH | Timer Frequency Control<br>Register | -   | -            | -    | -    | - | T2FD | T1FD | T0FD     | xxxxx000b |

Register instructions are shown below:

### T2CON (C8H) Timer2 Control Register (Read/Write)

| Bit Number      | 7   | 6 | 5    | 4    | 3 | 2   | 1 | 0 |
|-----------------|-----|---|------|------|---|-----|---|---|
| Bit<br>Mnemonic | TF2 | - | RCLK | TCLK | - | TR2 | - | - |
| R/W             | R/W | - | R/W  | R/W  | - | R/W | - | - |
| POR             | 0   | х | 0    | 0    | х | 0   | х | x |

| Bit Number | Bit Mnemonic | Description                                                                                                                          |  |  |  |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7          | TF2          | Timer2 overflow flag bit<br>0: No overflow (must be cleared by software)<br>1: Overflow (if RCLK=0 and TCLK=0, set to 1 by hardware) |  |  |  |



| Bit Number | Bit Mnemonic | Description                                                                                                                     |
|------------|--------------|---------------------------------------------------------------------------------------------------------------------------------|
| 5          | RCLK         | UART receiving clock control bit<br>0: Timer1 generates receiving baud rate<br>1: Timer2 generates receiving baud rate          |
| 4          | TCLK         | UART transmitting clock control bit<br>0: Timer1 generates transmitting baud rate<br>1: Timer2 generates transmitting baud rate |
| 2          | TR2          | Timer2 start/stop control bit<br>0: Stop Timer2<br>1: Start Timer2                                                              |
| 6,3,1 ~ 0  | -            | Fix at 0                                                                                                                        |

### TMCON (8EH) Timer Frequency Control Register (Read/Write)

| Bit Number      | 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0    |
|-----------------|---|---|---|---|---|------|------|------|
| Bit<br>Mnemonic | - | - | - |   |   | T2FD | T1FD | TOFD |
| R/W             | - | - | - | - | - | R/W  | R/W  | R/W  |
| POR             | х | x | x | x | х | 0    | 0    | 0    |

| Bit Number | Bit Mnemonic | Description                                                                                                                      |
|------------|--------------|----------------------------------------------------------------------------------------------------------------------------------|
| 2          | T2FD         | T2 input frequency selection control bit<br>0: T2 clock source is f <sub>SYS</sub> /12<br>1: T2 clock source is f <sub>SYS</sub> |

### IE (A8H) Interrupt Enable Register (Read/Write)

| Bit Number      | 7   | 6    | 5   | 4     | 3   | 2 | 1   | 0     |
|-----------------|-----|------|-----|-------|-----|---|-----|-------|
| Bit<br>Mnemonic | EA  | EADC | ET2 | EUART | ET1 | - | ET0 | EINTO |
| R/W             | R/W | R/W  | R/W | R/W   | R/W | - | R/W | R/W   |
| POR             | 0   | 0    | 0   | 0     | 0   | Х | 0   | 0     |



| Bit Number | Bit Mnemonic Description |                                                                                                  |
|------------|--------------------------|--------------------------------------------------------------------------------------------------|
| 5          | ET2                      | Timer2 interrupt enable control bit<br>0: Disable TIMER2 interrupt<br>1: Enable TIMER2 interrupt |

### IP (B8H) Interrupt Priority Control Register (Read/Write)

| Bit Number      | 7 | 6     | 5    | 4      | 3    | 2 | 1    | 0      |
|-----------------|---|-------|------|--------|------|---|------|--------|
| Bit<br>Mnemonic | - | IPADC | IPT2 | IPUART | IPT1 | - | IPT0 | IPINTO |
| R/W             | - | R/W   | R/W  | R/W    | R/W  | - | R/W  | R/W    |
| POR             | х | 0     | 0    | 0      | 0    | x | 0    | 0      |

| Bit Number | Bit Mnemonic | Description                                                                                                                                    |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 5          | IPT2         | Timer2 interrupt priority selection bit<br>0: Configure Timer2 interrupt priority as "low"<br>1: Configure Timer2 interrupt priority as "high" |

## 11.2 T2 Operating Modes

The operating mode and configuration mode of Timer2 are shown in the table below:

| TR2 | RCLK | TCLK |   | Mode                          |  |
|-----|------|------|---|-------------------------------|--|
| 1   | 0    | 0    | 1 | 16-bit automatic reload timer |  |
|     | 1    | Х    | 2 | Baud Rate Generator           |  |
| I   | Х    | 1    | 2 | Baud Rate Generator           |  |
| 0   | Х    | Х    | Х | Timer2 stops                  |  |

### **Operating Mode 1: 16-bit Automatic Reload Timer**

In the 16-bit automatic reload mode, Timer2 will increase to 0xFFFFH and set TF2 bit after overflow. Meanwhile, the timer will load 16-bit value in registers RCAP2H and RCAP2L written by user software into registers TH2 and TL2 automatically.





Operating Mode 1: 16-bit Automatic Reload Timer DCEN = 0

### **Operating Mode 2: Baud Rate Generator**

Configure TCLK and RCLK in T2CON register to select Timer2 as baud rate generator. The baud rate of receiver and transmitter can be different. If Timer2 is taken as either one between receiver and transmitter, Timer1 will be taken as another.

Configure TCLK and RCLK in T2CON register to make Timer2 in baud rate generator mode. Such mode is similar to automatic reload mode

Overflow of Timer2 can make the value in registers RCAP2H and RCAP2L reloaded into the Timer2 and counting, but no interrupt will occur.

The baud rate of UART mode 1 and mode 3 depends on overflow rate of Timer2 and the following formula:

$$BaudRate = \frac{1}{16} \times \frac{fn2}{(65536 - [RCAP2H, RCAP2L]) \times 2}$$

Including, fn2 is the clock frequency of Timer2

$$fn2 = \frac{fsys}{12}; \quad T2FD = 0$$
  
fn2 = fsys; T2FD = 1

The schematic diagram of Timer2 as baud rate generator is shown as follows:







Note:

- 1. TF2 can be set by software, and only software and hardware reset can clear IT
- 2. When EA = 1 and ET2 = 1, setting up TF2 to 1 can arouse interrupt of Timer2;
- 3. When Timer2 is taken as baud rate generator, the value written in TH2/TL2 or RCAP2H/RCAP2L may influence the accuracy of baud rate and thus result in error of communication.

Page 59 of 103



# 12 PWM

The SC92F730X provides an independent counter, which is able to support 6-channel PWM output: PWM0 ~ 5.

The SC92F730X PWM has the following functions:

- 1 8-bit precision;
- ② PWM0 ~ 5 shared the same clock cycle, but the duty cycle of each PWM channel can be configured separately;
- ③ Output can be configured in forward or reverse direction;
- (4) Provide one PWM overflow interrupt.

The PWM of SC92F730X supports adjustable cycle and duty cycle. The PWM-related settings for PWM0~5 are controlled by register PWMCON. PWMCFG0 and PWMCFG1 determine the polarity of PWM output waveforms and select the output IO. PWMPRD sets the common cycle for PWM, while PWMDTY05 respectively control the duty cycle for PWM0~5



## 12.1 PWM block Diagram



The SC92F730X PWM block Diagram

# 12.2 PWM-related Registers

| Mnemonic | Add | Description                               | 7     | 6             | 5      | 4      | 3      | 2      | 1        | 0        | POR       |
|----------|-----|-------------------------------------------|-------|---------------|--------|--------|--------|--------|----------|----------|-----------|
| PWMCFG0  | D1H | PWM Configuration<br>Register 0           | -     | -             | INV2   | INV1   | INV0   | ENPWM5 | ENPWM4   | ENPWM3   | xx000000b |
| PWMCON   | D2H | PWM Control Register                      | ENPWM | PWMIF         | ENPWM2 | ENPWM1 | ENPWM0 | Р      | WMCKS[2: | 0]       | 0000000b  |
| PWMPRD   | D3H | PWM Period Setting<br>Register            |       | PWMPRD[7 : 0] |        |        |        |        |          |          | 0000000b  |
| PWMCFG1  | D4H | PWM Configuration<br>Register 1           | -     | -             | INV5   | INV4   | INV3   | -      | -        | -        | xx000xxxb |
| PWMDTY0  | D5H | PWM0 Duty Cycle<br>Configuration Register |       | PDT0[7:0]     |        |        |        |        |          | 0000000b |           |
| PWMDTY1  | D6H | PWM1 Duty Cycle<br>Configuration Register |       | PDT1[7:0]     |        |        |        |        |          | 0000000b |           |
| PWMDTY2  | D7H | PWM2 Duty Cycle<br>Configuration Register |       | PDT2[7 : 0]   |        |        |        |        |          |          | 0000000b  |



| Mnemonic | Add | Description                               | 7 | 6           | 5 | 4 | 3      | 2     | 1     | 0         | POR       |
|----------|-----|-------------------------------------------|---|-------------|---|---|--------|-------|-------|-----------|-----------|
| PWMDTY3  |     | PWM3 Duty Cycle<br>Configuration Register |   | PDT3[7 : 0] |   |   |        |       |       |           | 00000000b |
| PWMDTY4  |     | PWM4 Duty Cycle<br>Configuration Register |   | PDT4[7 : 0] |   |   |        |       |       | 00000000b |           |
| PWMDTY5  |     | PWM5 Duty Cycle<br>Configuration Register |   | PDT5[7 : 0] |   |   |        |       |       |           | 0000000b  |
| IE1      | A9H | Interrupt Enable<br>register 1            | - | -           | - | - | EINT2  | EBTM  | EPWM  | -         | xxxx000xb |
| IP1      |     | Interrupt Priority<br>Control Register 1  | - | -           | - | - | IPINT2 | IPBTM | IPPWM |           | xxxx000xb |

# **12.3 PWM General Configuration Registers**

### PWMCON (D2H) PWM Control Register (Read/Write)

| Bit<br>Number   | 7     | 6     | 5      | 4      | 3      | 2 | 1          | 0 |
|-----------------|-------|-------|--------|--------|--------|---|------------|---|
| Bit<br>Mnemonic | ENPWM | PWMIF | ENPWM2 | ENPWM1 | ENPWM0 | Р | WMCKS[2:0] |   |
| R/W             | R/W   | R/W   | R/W    | R/W    | R/W    |   | R/W        |   |
| POR             | 0     | 0     | 0      | 0      | 0      | 0 | 0          | 0 |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                                                                         |
|------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | ENPWM        | <ul> <li>PWM module switch control bit (Enable PWM)</li> <li>1: Enable Clock to enter PWM unit and PWM starts to work</li> <li>0: PWM unit stops operating and PWM counter resets to zero. PWMn still connects to output pin. If using other functions multiplexed with PWMn output pin, set ENPWMn to 0</li> </ul> |
| 6          | PWMIF        | PWM interrupt flag<br>When PWM counter overflows (that is to say, the figure exceeds<br>PWMPRD), this bit will be automatically set to 1 by hardware. If at this<br>time IE1[1] (EPWM) is set to 1 as well, PWM interrupt generates.<br>Note: Six PWMs share the same period and the same PWM<br>interrupt vector.  |
| 5          | ENPWM2       | PWM2 functional switch control bit<br>0: PWM2 do not output to IO<br>1: PWM2 output to IO                                                                                                                                                                                                                           |
| 4          | ENPWM1       | PWM1 functional switch control bit                                                                                                                                                                                                                                                                                  |



| Bit Number | Bit Mnemonic | Description                        |  |  |  |  |  |
|------------|--------------|------------------------------------|--|--|--|--|--|
|            |              | 0: PWM1 do not output to IO        |  |  |  |  |  |
|            |              | 1: PWM1 output to IO               |  |  |  |  |  |
|            |              | PWM0 functional switch control bit |  |  |  |  |  |
| 3          | ENPWM0       | 0: PWM0 do not output to IO        |  |  |  |  |  |
|            |              | 1: PWM0 output to IO               |  |  |  |  |  |
|            |              | PWM (PWM clock source selector)    |  |  |  |  |  |
|            |              | 000: fsys                          |  |  |  |  |  |
|            |              | 001: fsys/2                        |  |  |  |  |  |
|            |              | 010: f <sub>SYS</sub> /4           |  |  |  |  |  |
| 2 ~ 0      | PWMCKS[2:0]  | 011: fsys/8                        |  |  |  |  |  |
|            |              | 100: fsys/32                       |  |  |  |  |  |
|            |              | 101: f <sub>SYS</sub> /64          |  |  |  |  |  |
|            |              | 110: fsys/128                      |  |  |  |  |  |
|            |              | 111: fsys/256                      |  |  |  |  |  |

PWMPRD[7:0] serves as the shared cycle setting controller for the 6 PWM channels. Whenever the PWM counter reaches the pre-set value of PWMPRD[7:0], the next PWM CLK arrival causes the counter to reset to 00h. In other words, the cycle for PWM0~5 is calculated as (PWMPRD[7:0] + 1) multiplied by the PWM clock.

The counting time of the PWM counter is controlled by PWMCKS[2:0], which allows the selection of different numbers of system clocks to count one unit (pre-scaler selector). That means choosing the divisor for the PWM counter clock source, where the source is the system clock fSYS divided by the specified divisor. Additionally, PWM05 can be configured for inverted PWM output using INV05 in PWMCFG0 and PWMCFG1

#### PWMPRD (D3H) PWM Period Configuration Register (Read/Write)

| Bit Number      | 7   | 6             | 5   | 4   | 3   | 2   | 1   | 0   |
|-----------------|-----|---------------|-----|-----|-----|-----|-----|-----|
| Bit<br>Mnemonic |     | PWMPRD[7 : 0] |     |     |     |     |     |     |
| R/W             | R/W | R/W           | R/W | R/W | R/W | R/W | R/W | R/W |
| POR             | 0   | 0             | 0   | 0   | 0   | 0   | 0   | 0   |

| Bit Number | Bit Mnemonic  | Description                                                                                                                                                                                                                           |
|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 ~ 0      | PWMPRD[7 : 0] | The shared period setting for the 6 PWM channels;<br>These value represents the (period - 1) of the PWM waveforms for<br>PWM0~5. In other words, the actual period of the PWM output is<br>calculated as :(PWMPRD[7:0] + 1)*PWM clock |



### PWMCFG0 (D1H) PWM Configuration Register 0 (Read/Write)

| Bit Number      | 7 | 6 | 5    | 4    | 3    | 2      | 1      | 0      |
|-----------------|---|---|------|------|------|--------|--------|--------|
| Bit<br>Mnemonic | - | - | INV2 | INV1 | INV0 | ENPWM5 | ENPWM4 | ENPWM3 |
| R/W             | - | - | R/W  | R/W  | R/W  | R/W    | R/W    | R/W    |
| POR             | х | х | 0    | 0    | 0    | 0      | 0      | 0      |

| Bit Number | Bit Mnemonic | Description                                                                               |
|------------|--------------|-------------------------------------------------------------------------------------------|
| 5          | INV2         | PWM2 output reverse control bit     0: PWM2 output not invert     1: PWM2 output reverse  |
| 4          | INV1         | PWM1 output reverse control bit<br>0: PWM1 output not invert<br>1: PWM1 output reverse    |
| 3          | INVO         | PWM0 output reverse control bit<br>0: PWM0 output not invert<br>1: PWM0 output reverse    |
| 2          | ENPWM5       | PWM5 functional switch control bit<br>0: PWM5 do not output to IO<br>1: PWM5 output to IO |
| 1          | ENPWM4       | PWM4 functional switch control bit<br>0: PWM4 do not output to IO<br>1: PWM4 output to IO |
| 0          | ENPWM3       | PWM3 functional switch control bit<br>0: PWM3 do not output to IO<br>1: PWM3 output to IO |
| 7 ~ 6      | -            | Reserved                                                                                  |

### PWMCFG1 (D4H) PWM Configuration Register 1 (Read/Write)

| Bit Number      | 7 | 6 | 5    | 4    | 3    | 2 | 1 | 0 |
|-----------------|---|---|------|------|------|---|---|---|
| Bit<br>Mnemonic | - | - | INV5 | INV4 | INV3 | - | - | - |
| R/W             | - | - | R/W  | R/W  | R/W  | - | - | - |



| Bit Number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|---|---|---|---|---|---|---|---|
| POR        | x | х | 0 | 0 | 0 | х | х | x |

| Bit Number  | Bit Mnemonic | Description                                                                              |
|-------------|--------------|------------------------------------------------------------------------------------------|
| 5           | INV5         | PWM5 output reverse control bit<br>0: PWM5 output not invert<br>1: PWM5 output reverse   |
| 4           | INV4         | PWM4 output reverse control bit     0: PWM4 output not invert     1: PWM4 output reverse |
| 3           | INV3         | PWM3 output reverse control bit<br>0: PWM3 output not invert<br>1: PWM3 output reverse   |
| 7 ~ 6,2 ~ 0 | -            | Reserved                                                                                 |

### PWMDTY0 (D5H) PWM0 Duty Cycle Configuration Register (Read/Write)

| Bit Number      | 7   | 6           | 5   | 4   | 3   | 2   | 1   | 0   |  |
|-----------------|-----|-------------|-----|-----|-----|-----|-----|-----|--|
| Bit<br>Mnemonic |     | PDT0[7 : 0] |     |     |     |     |     |     |  |
| R/W             | R/W | R/W         | R/W | R/W | R/W | R/W | R/W | R/W |  |
| POR             | 0   | 0           | 0   | 0   | 0   | 0   | 0   | 0   |  |

| Bit Number | Bit Mnemonic | Description                                                                                                  |
|------------|--------------|--------------------------------------------------------------------------------------------------------------|
| 7~0        | PDT0[7 : 0]  | PWM0 duty cycle length configuration of high 8 bits:<br>High level width of PWM0 is (PDT0[7: 0]) PWM clocks. |

### PWMDTY1 (D6H) PWM1 Duty Cycle Configuration Register (Read/Write)

| Bit Number      | 7   | 6         | 5   | 4   | 3   | 2   | 1   | 0   |  |
|-----------------|-----|-----------|-----|-----|-----|-----|-----|-----|--|
| Bit<br>Mnemonic |     | PDT1[7:0] |     |     |     |     |     |     |  |
| R/W             | R/W | R/W       | R/W | R/W | R/W | R/W | R/W | R/W |  |
| POR             | 0   | 0         | 0   | 0   | 0   | 0   | 0   | 0   |  |



| Bit Number | Bit Mnemonic | Description                                                                                                  |
|------------|--------------|--------------------------------------------------------------------------------------------------------------|
| 7 ~ 0      | PDT1[7 : 0]  | PWM1 duty cycle length configuration of high 8 bits:<br>High level width of PWM1 is (PDT1[7: 0]) PWM clocks. |

### PWMDTY2 (D7H) PWM2 Duty Cycle Configuration Register (Read/Write)

| Bit Number      | 7   | 6           | 5   | 4   | 3   | 2   | 1   | 0   |
|-----------------|-----|-------------|-----|-----|-----|-----|-----|-----|
| Bit<br>Mnemonic |     | PDT2[7 : 0] |     |     |     |     |     |     |
| R/W             | R/W | R/W         | R/W | R/W | R/W | R/W | R/W | R/W |
| POR             | 0   | 0           | 0   | 0   | 0   | 0   | 0   | 0   |

| Bit Number | Bit Mnemonic | Description                                                                                                  |
|------------|--------------|--------------------------------------------------------------------------------------------------------------|
| 7 ~ 0      | PDT2[7 : 0]  | PWM2 duty cycle length configuration of high 8 bits:<br>High level width of PWM2 is (PDT2[7: 0]) PWM clocks. |

### PWMDTY3 (DDH) PWM3 Duty Cycle Configuration Register (Read/Write)

| Bit Number      | 7   | 6   | 5   | 4    | 3     | 2   | 1   | 0   |
|-----------------|-----|-----|-----|------|-------|-----|-----|-----|
| Bit<br>Mnemonic |     |     |     | PDT3 | [7:0] |     |     |     |
| R/W             | R/W | R/W | R/W | R/W  | R/W   | R/W | R/W | R/W |
| POR             | 0   | 0   | 0   | 0    | 0     | 0   | 0   | 0   |

| Bit Number | Bit Mnemonic | Description                                                                                                  |
|------------|--------------|--------------------------------------------------------------------------------------------------------------|
| 7 ~ 0      | PDT3[7 : 0]  | PWM3 duty cycle length configuration of high 8 bits:<br>High level width of PWM3 is (PDT3[7: 0]) PWM clocks. |

### PWMDTY4 (DEH) PWM4 Duty Cycle Configuration Register (Read/Write)

| Bit Number      | 7 | 6 | 5 | 4    | 3     | 2 | 1 | 0 |
|-----------------|---|---|---|------|-------|---|---|---|
| Bit<br>Mnemonic |   |   |   | PDT4 | [7:0] |   |   |   |



| R/W |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| POR | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

| Bit Number | Bit Mnemonic | Description                                                                                                  |
|------------|--------------|--------------------------------------------------------------------------------------------------------------|
| 7 ~ 0      | PDT4[7 : 0]  | PWM4 duty cycle length configuration of high 8 bits:<br>High level width of PWM4 is (PDT4[7: 0]) PWM clocks. |

### PWMDTY5 (DFH) PWM5 Duty Cycle Configuration Register (Read/Write)

| Bit Number      | 7   | 6   | 5   | 4    | 3     | 2   | 1   | 0   |
|-----------------|-----|-----|-----|------|-------|-----|-----|-----|
| Bit<br>Mnemonic |     |     |     | PDT5 | [7:0] |     |     |     |
| R/W             | R/W | R/W | R/W | R/W  | R/W   | R/W | R/W | R/W |
| POR             | 0   | 0   | 0   | 0    | 0     | Ő   | 0   | 0   |
|                 |     |     |     |      |       |     |     |     |

| Bit Number | Bit Mnemonic | Description                                                                                                                       |
|------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 7 ~ 0      | PDT5[7 : 0]  | Independent Mode:<br>PWM5 duty cycle length configuration of high 8 bits;<br>High level width of PWM5 is (PDT5[7: 0]) PWM clocks. |

### IE1 (A9H) Interrupt Enable Register (Read/Write)

| Bit Number      | 7 | 6 | 5 | 4 | 3     | 2    | 1    | 0 |
|-----------------|---|---|---|---|-------|------|------|---|
| Bit<br>Mnemonic | - | - | - | - | EINT2 | EBTM | EPWM | - |
| R/W             | - | - | - | - | R/W   | R/W  | R/W  | - |
| POR             | х | x | х | х | 0     | 0    | 0    | х |

| Bit Number | Bit Mnemonic | Description                                                                                                                     |  |  |  |
|------------|--------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 1          | EPWM         | PWM Interrupt Control Bit<br>0: Clear to disable the PWM interrupt<br>1: Set to enable the interrupt when PWM counter overflows |  |  |  |



### IP1 (B9H) Interrupt Priority Register 1 (Read/Write)

| Bit Number      | 7 | 6 | 5 | 4 | 3      | 2     | 1     | 0 |
|-----------------|---|---|---|---|--------|-------|-------|---|
| Bit<br>Mnemonic | - | - | - | - | IPINT2 | IPBTM | IPPWM | - |
| R/W             | - | - | - | - | R/W    | R/W   | R/W   | - |
| POR             | х | х | х | х | 0      | 0     | 0     | x |

| Bit Number | Bit Mnemonic | Description                                                                                                                                           |
|------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | IPPWM        | PWM interrupt priority selection bit<br>0: Clear to configure PWM interrupt priority as "low"<br>1: Set to configure PWM interrupt priority as "high" |

Note:

- 4. The ENPWM bit controls whether the PWM module is operational
- 5. The ENPWMn bit selects whether PWMn is used as GPIO or as PWMn output
- 6. The EPWM bit controls whether PWM is allowed to generate interrupts
- 7. If ENPWM is set to 1, the PWM module is activated, but if ENPWMn is set to 0, PWM output is turned off and used as a GPIO. In this case, the PWM module can be used as an 8-bit timer, and if EPWM is set to 1, PWM interrupts will still occur
- 8. All 6 PWM channels share the same cycle, and an overflow generates a PWM interrupt with the same interrupt vector

### **12.4 PWM Waveforms and Directions**

The influence of changing various SFR parameters on PWM waveform is shown as follows:

1 Diagram for Duty Cycle Change features

When PWMn outputs waveform, if it is required to change the duty cycle, users can change the value of high level configuration registers (PDTn). But note that changing the value of PDTn will change the duty cycle immediately.

#### ② Period Change features





#### **Diagram for Period Change Features**

When PWMn outputs waveform, if it is required to change the period, the user can change the value of period configuration registers PWMPRD. Unlike changing the duty cycle, change the value of PWMPRD will not change the period immediately. It is required to wait until the end of this period and change in the next period. Refer to the figure above.

#### ③ Relationship between Period and Duty cycle



Diagram for Relationship between Period and Duty cycle

The relationship between period and duty cycle is shown in the figure above. The precondition of this result is the PWMn output reverse control (INVn) is initialized to 0; if it is required to get the contrary result, set INVn to 1.



# 13 General-purpose I/O (GPIO)

The SC92F730X offers up to 18 bidirectional controllable GPIOs, input and output control registers are used to control the input and output state of various ports, when the port is used as input, each I/O port is equipped with internal pull-up resistor controlled by PxPHy. Such 18 IOs are shared with other functions, including P0.0 ~ P0.4 can be used as LCD COM driver by configuring output voltage as  $1/2 V_{DD}$ . Under output state, what I/O port read from the value of port data register is the actual state value of the port.

Note: Unused IO port or IO port with no package pin shall be configured as strong push-pull output mode.

## 13.1 GPIO Structure Diagram

#### Strong Push-pull Output Mode

In strong push-pull output mode, it is able to provide continuous high current drive: high output for the current larger than 22mA and low output for the current larger than 70mA

The port structure diagram for strong push-pull output mode is shown below:





### Pull-up Input Mode

In pull-up input mode, a pull-up resistor is connected on the input port, only when the level on the input port is pulled down, low level signal can be detected.

The port structure diagram for pull-up input mode is shown below:







High- impedance Input Mode

## 13.2 I/O Port-related Registers

| Bit Number      | 7 | 6 | 5    | 4    | 3    | 2    | 1    | 0    |
|-----------------|---|---|------|------|------|------|------|------|
| Bit<br>Mnemonic | - | - | P0C5 | P0C4 | P0C3 | P0C2 | P0C1 | P0C0 |
| R/W             | - | - | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| POR             | x | x | 0    | 0    | 0    | 0    | 0    | 0    |

P0CON (9AH) P0 I/O Control Register (Read/Write)

### P0PH (9BH) P0 Pull-up Resistor Control Register (Read/Write)

| Bit Number      | 7 | 6 | 5    | 4    | 3    | 2    | 1    | 0    |
|-----------------|---|---|------|------|------|------|------|------|
| Bit<br>Mnemonic | - | - | P0H5 | P0H4 | P0H3 | P0H2 | P0H1 | P0H0 |
| R/W             | - | - | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| POR             | х | х | 0    | 0    | 0    | 0    | 0    | 0    |



### P1CON (91H) P1 I/O Control Register (Read/Write)

| Bit Number      | 7    | 6    | 5 | 4 | 3    | 2    | 1    | 0    |
|-----------------|------|------|---|---|------|------|------|------|
| Bit<br>Mnemonic | P1C7 | P1C6 | - | - | P1C3 | P1C2 | P1C1 | P1C0 |
| R/W             | R/W  | R/W  | - | - | R/W  | R/W  | R/W  | R/W  |
| POR             | 0    | 0    | х | х | 0    | 0    | 0    | 0    |

### P1PH (92H) P1 Pull-up Resistor Control Register (Read/Write)

| Bit Number      | 7    | 6    | 5 | 4 | 3    | 2    | 1    | 0    |
|-----------------|------|------|---|---|------|------|------|------|
| Bit<br>Mnemonic | P1H7 | P1H6 | - | - | P1H3 | P1H2 | P1H1 | P1H0 |
| R/W             | R/W  | R/W  | - | - | R/W  | R/W  | R/W  | R/W  |
| POR             | 0    | 0    | х | x | 0    | 0    | 0    | 0    |

### P2CON (A1H) P2 I/O Control Register (Read/Write)

| Bit Number      | 7    | 6    | 5    | 4    | 3 | 2 | 1    | 0    |
|-----------------|------|------|------|------|---|---|------|------|
| Bit<br>Mnemonic | P2C7 | P2C6 | P2C5 | P2C4 | - | - | P2C1 | P2C0 |
| R/W             | R/W  | R/W  | R/W  | R/W  | - | - | R/W  | R/W  |
| POR             | 0    | 0    | 0    | 0    | х | х | 0    | 0    |

### P2PH (A2H) P2 Pull-up Resistor Control Register (Read/Write)

| Bit Number      | 7    | 6    | 5    | 4    | 3 | 2 | 1    | 0    |
|-----------------|------|------|------|------|---|---|------|------|
| Bit<br>Mnemonic | P2H7 | P2H6 | P2H5 | P2H4 | - | - | P2H1 | P2H0 |
| R/W             | R/W  | R/W  | R/W  | R/W  | - | - | R/W  | R/W  |
| POR             | 0    | 0    | 0    | 0    | х | х | 0    | 0    |

| Bit Number | Bit Mnemonic               | Description                                                                                                       |
|------------|----------------------------|-------------------------------------------------------------------------------------------------------------------|
| 7 ~ 0      | PxCy<br>(x=0 ~ 2, y=0 ~ 7) | Px port input/output control bits<br>0: Pxy in input mode(default at power-up)<br>1: Pxy in strong push-pull mode |



# SC92F7302/7301/7300

### High-speed 1T 8051-based Flash MCU

| Bit Number | Bit Mnemonic               | Description                                                                                                                                                    |
|------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 ~ 0      | PxHy<br>(x=0 ~ 2, y=0 ~ 7) | Px port pull-up resister enable bit<br>0: Pxy in high-impedance input mode(default at power-up), pull-up<br>resister disable<br>1: Pxy pull-up resister enable |

#### P0 (80H) P0 Data Register (Read/Write)

| Bit Number      | 7 | 6 | 5    | 4    | 3    | 2    | 1    | 0    |
|-----------------|---|---|------|------|------|------|------|------|
| Bit<br>Mnemonic | - | - | 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  |
| POR             | х | х | 0    | 0    | 0    | 0    | 0    | 0    |

#### P1 (90H) P1 Data Register (Read/Write)

| Bit Number      | 7    | 6    | 5 | 4 | 3    | 2    | 1    | 0    |
|-----------------|------|------|---|---|------|------|------|------|
| Bit<br>Mnemonic | P1.7 | P1.6 | - | - | P1.3 | P1.2 | P1.1 | P1.0 |
| R/W             | R/W  | R/W  | - | - | R/W  | R/W  | R/W  | R/W  |
| POR             | 0    | 0    | x | x | 0    | 0    | 0    | 0    |

#### P2 (A0H) P2 Data Register (Read/Write)

| Bit Number      | 7    | 6    | 5    | 4    | 3 | 2 | 1    | 0    |
|-----------------|------|------|------|------|---|---|------|------|
| Bit<br>Mnemonic | P2.7 | P2.6 | P2.5 | P2.4 | - | - | P2.1 | P2.0 |
| R/W             | R/W  | R/W  | R/W  | R/W  | - | - | R/W  | R/W  |
| POR             | 0    | 0    | 0    | 0    | х | х | 0    | 0    |
|                 |      |      |      | •    |   | • | •    |      |

#### IOHCON (97H) IOH Configuration Register (Read/Write)

| Bit Number      | 7   | 6      | 5         | 4   | 3         | 2   | 1         | 0   |
|-----------------|-----|--------|-----------|-----|-----------|-----|-----------|-----|
| Bit<br>Mnemonic | P2H | [1: 0] | P2L[1: 0] |     | P0H[1: 0] |     | P0L[1: 0] |     |
| R/W             | R/W | R/W    | R/W       | R/W | R/W       | R/W | R/W       | R/W |



| Bit Number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|---|---|---|---|---|---|---|---|
| POR        | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                  |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 ~ 6      | P2H[1: 0]    | P2 high 4-bit IOH configuration bits<br>00: Set P2 high 4-bit IOH level 0 (Maximum value);<br>01: Set P2 high 4-bit IOH level 1;<br>10: Set P2 high 4-bit IOH level 2;<br>11: Set P2 high 4-bit IOH level 3 (Minimum value); |
| 5 ~ 4      | P2L[1: 0]    | P2 low 4-bit IOH configuration bits<br>00: Set P2 low 4-bit IOH level 0 (Maximum value);<br>01: Set P2 low 4-bit IOH level 1;<br>10: Set P2 low 4-bit IOH level 2;<br>11: Set P2 low 4-bit IOH level 3 (Minimum value);      |
| 3 ~ 2      | P0H[1: 0]    | P0 high 4-bit IOH configuration bits<br>00: Set P0 high 4-bit IOH level 0 (Maximum value);<br>01: Set P0 high 4-bit IOH level 1;<br>10: Set P0 high 4-bit IOH level 2;<br>11: Set P0 high 4-bit IOH level 3 (Minimum value); |
| 1 ~ 0      | P0L[1: 0]    | P0 low 4-bit IOH configuration bits<br>00: Set P0 low 4-bit IOH level 0 (Maximum value);<br>01: Set P0 low 4-bit IOH level 1;<br>10: Set P0 low 4-bit IOH level 2;<br>11: Set P0 low 4-bit IOH level 3 (Minimum value);      |
|            |              |                                                                                                                                                                                                                              |



# **14 Software LCD Driver**

The P0.0 ~ P0.4 of the SC92F730X can be used as the COM port of the software LCD. In addition to the normal IO functions, these IOs can also output 1/2VDD. The user can select the corresponding IO as the LCD driver COM according to the usage.

### 14.1 Software LCD Drives-related Registers

LCD Driver Related SFR Register Description:

#### P0VO (9CH) P0 port LCD voltage output register (Read/Write)

| Bit Number      | 7 | 6 | 5 | 4     | 3     | 2     | 1     | 0     |
|-----------------|---|---|---|-------|-------|-------|-------|-------|
| Bit<br>Mnemonic | - | - | - | P04VO | P03VO | P02VO | P01VO | P00VO |
| R/W             | - | - | - | R/W   | R/W   | R/W   | R/W   | R/W   |
| POR             | х | х | х | 0     | 0     | 0     | 0     | 0     |

| P0yVO (y=0 ~ 4) | P0y | P0y selection output port                       |
|-----------------|-----|-------------------------------------------------|
| 0               | Х   | Ordinary IO port                                |
| 1               | 1   | The output voltage of P0y port is $1/2V_{DD}$ . |

#### OTCON (8FH) Output Control Register (Read/Write)

| Bit Number      | 7 | 6 | 5 | 4 | 3    | 2       | 1 | 0 |
|-----------------|---|---|---|---|------|---------|---|---|
| Bit<br>Mnemonic | - |   | - | - | VOIR | S[1: 0] | - | - |
| R/W             | - | - | - | - | R/W  | R/W     | - | - |
| POR             | x | x | х | х | 0    | 0       | х | х |

| Bit Number | Bit Mnemonic | Description                                                                                                              |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------------|
|            |              | Selection bits of voltage dividing resistance of LCD voltage output port (suitable driving according to LCD screen size) |
|            |              | 00: Disable internal voltage divider resistor. (Energy saving)                                                           |
| 3 ~ 2      | VOIRS[1: 0]  | 01: Set the internal partial resistance to 12.5K                                                                         |
|            |              | 10: Set the internal partial resistance to 37.5K                                                                         |
|            |              | 11: Set the internal partial resistance to 87.5K                                                                         |



### 15 UART

### **15.1 UART-related Registers**

#### SCON (98H) Serial Port Control Register (Read/Write)

| Bit Number      | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----------------|-----|-----|-----|-----|-----|-----|-----|-----|
| Bit<br>Mnemonic | 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 |
| POR             | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
|                 |     |     |     |     |     |     |     |     |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                         |
|------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |              | Serial communication mode control bits                                                                                                                                                                                                                              |
|            |              | 00: Mode 0, 8-bit half-duplex synchronous communication mode.<br>Serial data is received and transmitted on RX pin. TX pin is used to<br>transmit shift clock. Receive and transmit 8 bits for each frame, and<br>low bits will be received or transmitted firstly; |
| 7 ~ 6      | SM0 ~ 1      | 01: Mode 1, 10-bit full-duplex asynchronous communication composing of 1 starting bit, 8 data bits and 1 stopping bit, with communication baud rate changeable;                                                                                                     |
|            |              | 10: Mode 2, 11-bit full-duplex asynchronous communication composing of 1 starting bit, 8 data bits 1 programmable 9 <sup>th</sup> bit and 1 stopping bit;                                                                                                           |
|            |              | <ul> <li>11: Mode 3, 11-bit full-duplex asynchronous communication, composing of 1 starting bit, 8 data bits and 1 programmable 9<sup>th</sup> bit and 1 stopping bit, with communication baud rate changeable.</li> </ul>                                          |
|            |              | Serial communication mode control bit 2, this control bit is only valid for mode 2 and 3                                                                                                                                                                            |
| 5          | SM2          | 0: RI is set upon receiving a complete data frame to generate interrupt request;                                                                                                                                                                                    |
|            |              | 1: When receiving a complete data frame, only when RB8=1, will RI be set to generate interrupt request.                                                                                                                                                             |
|            |              | Receive allowing control bit                                                                                                                                                                                                                                        |
| 4          | REN          | 0: Receiving data not allowed;                                                                                                                                                                                                                                      |
|            |              | 1: Receiving data allowed.                                                                                                                                                                                                                                          |
| 3          | TB8          | Only valid for mode 2 and 3, 9 <sup>th</sup> bit of receiving data                                                                                                                                                                                                  |
| 2          | RB8          | Only valid for mode 2 and 3, 9 <sup>th</sup> bit of receiving data                                                                                                                                                                                                  |
| 1          | ТІ           | Transmission interrupt flag bit                                                                                                                                                                                                                                     |
| 0          | RI           | Reception interrupt flag bit                                                                                                                                                                                                                                        |



#### SBUF (99H) Serial Data Cache Register (Read/Write)

| Bit Number      | 7   | 6          | 5   | 4   | 3   | 2   | 1   | 0   |
|-----------------|-----|------------|-----|-----|-----|-----|-----|-----|
| Bit<br>Mnemonic |     | SBUF[7: 0] |     |     |     |     |     |     |
| R/W             | R/W | R/W        | R/W | R/W | R/W | R/W | R/W | R/W |
| POR             | 0   | 0          | 0   | 0   | 0   | 0   | 0   | 0   |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                                                         |
|------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 ~ 0      | SBUF[7: 0]   | Serial Port Data Cache Register<br>SBUF contains two registers: one for transmitting shift register and<br>one for receiving latch; data written into SBUF will be transmitted to<br>shift register and initiate transmitting process; reading SBUF will return<br>the contents of receiving latch. |

#### PCON (87H) Power Management Control Register (only readable, \* unreadable\*)

| Bit Number      | 7    | 6 | 5 | 4 | 3 | 2 | 1    | 0      |
|-----------------|------|---|---|---|---|---|------|--------|
| Bit<br>Mnemonic | SMOD | - | - | - | - | - | STOP | IDL    |
| R/W             | W    | - | - | - | - | - | VV   | $\vee$ |
| POR             | 0    | x | x | x | х | х | 0    | 0      |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                                                                                                                        |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | SMOD         | Baud rate multiplying power configuration bit<br>0: When SM0~1 = 00, serial port operates under clock of 1/12 system<br>clock; when SM0~1 = 10, serial port operates under clock of 1/64<br>system clock<br>1: When SM0~1 = 00, serial port operates under clock of 1/4 system<br>clock; when SM0~1 = 10, serial port operates under clock of 1/32<br>system clock |

### **15.2 Baud Rate of Serial Communication**

In mode 0, baud rate can be programmed as 1/12 or 1/4 of system clock and determined by SMOD (PCON.7) bit. When SMOD is set to 0, the serial port operates in 1/12 of system clock. When SMOD is set to 1, serial port operates in 1/4 of system clock.

In mode 1 and mode 3, the user can select overflow rate of Timer1 or Timer2 as baud rate by configuration.



Set TCLK (T2CON.4) and RCLK (T2CON.5) bit to configure Timer2 as TX and RX clock source of baud rate (Refer to the timer section for details). No matter TCLK or RCLK is set to logic 1, Timer2 can be in the mode of baud rate generator. If TCLK and RCLK are set to logic 0, Timer1 can be baud clock source of Tx and Rx.

Mode 1 and Mode 3 baud rate formula is shown below, including that TH1 is the 8-bit auto-reload registers of Timer1, SMOD is the baud rate multiplier of UART, and [RCAP2H、RCAP2L] are the 16-bit reload registers of Timer2.

1. When Timer1 is used as baud rate generator, it works in Mode 2:

$$BaudRate = \frac{2^{SMOD}}{[TH1, TL1]} \times \frac{fn1}{(256 - TH1) \times 2}$$

fn1 is the clock frequency of Timer1:

$$fn1 = \frac{fsys}{12}; \quad T1FD = 0$$
  
fn1 = fsys; 
$$T1FD = 1$$

2. When Timer2 is used as baud rate generator:

$$BaudRate = \frac{1}{16} \times \frac{fn2}{(65536 - [RCAP2H, RCAP2L] \times 2)}$$

fn2 is the clock frequency of Timer2:

$$fn2 = \frac{fsys}{12};$$
 T2FD = 0  
fn2 = fsys; T2FD = 1

The schematic diagrams for baud rate generators in mode 1 and mode 3 are as follows:



In Mode 2, the baud rate is fixed at either 1/32 or 1/64 of the system clock, determined by the state of the SMOD bit (PCON.7). When the SMOD bit is 0, the baud rate is set to 1/64 of the system clock. When the SMOD bit is 1, the baud rate is set to 1/32 of the system clock



# 16 Analog-to-Digital Converter (ADC)

The SC92F730X has a 12-bit high-precision successive approximation ADC with 9-channel, the external 8 ADC channel is multiplexing with other IO ports. Cooperating with the internal 2.4V reference voltage, one internal channel connected to  $1/4 V_{DD}$  can be used for measuring  $V_{DD}$  voltage.

There are 2 options for ADC reference voltage:

- ① VDD pin (internal VDD);
- 2 Precise 2.4V reference output from internal Regulator

Note: Users are advised to use the interrupt method when converting ADC, check the DEMO for details.

### **16.1 ADC-related Registers**

#### ADCCON (ADH) ADC Control Register (Read/Write)

| Bit<br>Number   | 7     | 6    | 5     | 4             | 3   | 2     | 1       | 0   |
|-----------------|-------|------|-------|---------------|-----|-------|---------|-----|
| Bit<br>Mnemonic | ADCEN | ADCS | LOWSP | EOC/AD<br>CIF |     | ADCIS | S[3: 0] |     |
| R/W             | R/W   | R/W  | R/W   | R/W           | R/W | R/W   | R/W     | R/W |
| POR             | 0     | 0    | 0     | 0             | 0   | 0     | 0       | n   |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                                                                          |
|------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | ADCEN        | ADC Power Control Bit<br>0: Disable ADC module power<br>1: Enable ADC module power                                                                                                                                                                                                                                   |
| 6          | ADCS         | ADC Start Trigger Control Bit (ADC Start)<br>Write "1" for this bit, an ADC conversion started, this bit is the trigger<br>signal only for ADC switch. This bit is valid only for writing "1".<br>Note: After writing "1" to ADCS, do not write to the ADCCON<br>register until the interrupt flag EOC/ADCIF is set. |
| 5          | LOWSP        | ADC Sampling Clocks Selector<br>0: Select clock frequency of ADC as 2MHz<br>1: Select clock frequency of ADC as 333kHz<br>Explanations:<br>The total time conversion time of ADC is T <sub>ADC</sub> , consists of the sampling                                                                                      |



|       |             | time and the conversion time. The conversion time is fixed at 950ns.                                                                                                                                                              |
|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |             | The total time for the ADC from sampling to completing the conversion is calculated as follows:                                                                                                                                   |
|       |             | • When LOWSP is 0 (LOWSP=0): T <sub>ADC1</sub> = 6 * (1/2MHz) + 950ns $\approx$ 4us                                                                                                                                               |
|       |             | ● When LOWSP is 1 (LOWSP=1): T <sub>ADC2</sub> = 6 * (1/333kHz) + 950ns ≈ 19us                                                                                                                                                    |
|       |             | End Of Conversion / ADC Interrupt Flag                                                                                                                                                                                            |
|       |             | 0: Conversion not completed                                                                                                                                                                                                       |
|       |             | 1: ADC conversion completed and need the user cleared up by software.                                                                                                                                                             |
| 4     | EOC /ADCIF  | ADC conversion completion flag EOC: when the user sets up ADCS for conversions, this bit will be cleared to 0 by hardware automatically; after completing conversion, this bit will be configured to 1 automatically by hardware; |
|       |             | ADC interrupt request flag ADCIF: this bit is also used as interrupt request flag of ADC interrupt. If ADC interrupt is enabled, this bit must be cleared by the user with software after ADC interrupt generated.                |
|       |             | ADC Input Selection Bits                                                                                                                                                                                                          |
|       |             | 0000: Select AIN0 as ADC input                                                                                                                                                                                                    |
|       |             | 0001: Select AIN1 as ADC input                                                                                                                                                                                                    |
|       |             | 0100: Select AIN4 as ADC input                                                                                                                                                                                                    |
|       |             | 0101: Select AIN5 as ADC input                                                                                                                                                                                                    |
| 3 ~ 0 | ADCIS[3: 0] | 0110: Select AIN6 as ADC input                                                                                                                                                                                                    |
|       |             | 0111: Select AIN7 as ADC input                                                                                                                                                                                                    |
|       |             | 1000: Select AIN8 as ADC input                                                                                                                                                                                                    |
|       |             | 1001: Select AIN9 as ADC input                                                                                                                                                                                                    |
|       |             | 1111: ADC input is $1/4 V_{DD}$ , used for measuring power voltage                                                                                                                                                                |
|       |             | Others: Reserved                                                                                                                                                                                                                  |

#### ADCCFG0 (ABH) ADC Configuration Register 0 (Read/Write)

| Bit Number      | 7     | 6     | 5     | 4     | 3 | 2 | 1     | 0     |
|-----------------|-------|-------|-------|-------|---|---|-------|-------|
| Bit<br>Mnemonic | EAIN7 | EAIN6 | EAIN5 | EAIN4 | - | - | EAIN1 | EAINO |
| R/W             | R/W   | R/W   | R/W   | R/W   | - | - | R/W   | R/W   |
| POR             | 0     | 0     | 0     | 0     | х | х | 0     | 0     |

#### ADCCFG1 (ACH) ADC Configuration Register 1 (Read/Write)

| Bit Number         7         6         5         4         3         2         1         0 |
|--------------------------------------------------------------------------------------------|
|--------------------------------------------------------------------------------------------|



| Bit<br>Mnemonic | - | - | - | - | - | - | EAIN9 | EAIN8 |
|-----------------|---|---|---|---|---|---|-------|-------|
| R/W             | - | - | - | - | - | - | R/W   | R/W   |
| POR             | х | х | х | х | х | х | 0     | 0     |

| Bit Number | Bit Mnemonic              | Description                                                                                                                                       |
|------------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | EAINx<br>(x=0 ~ 1, 4 ~ 9) | ADC Port Configuration Register<br>0: Configure AINx as IO PORT<br>1: Configure ANIx as ADC input and remove pull-up resistance<br>automatically. |

#### OP\_CTM1 (C2H@FFH) Customer Option Register 1 (Read/Write)

| Bit Number      | 7     | 6 | 5 | 4 | 3    | 2      | 1 | 0 |
|-----------------|-------|---|---|---|------|--------|---|---|
| Bit<br>Mnemonic | VREFS | - | - | - | IAPS | [1: 0] | - | - |
| R/W             | R/W   | - | - | - | R/W  | R/W    | - | - |
| POR             | n     | х | x | x | n    | n      | х | х |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                            |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | VREFS        | Reference Voltage Selection Bit (Default values are configured by the user and loaded from Code Option)<br>0: Configure ADC VREF as V <sub>DD</sub><br>1: Configure ADC VREF as internal correct 2.4 V |

#### ADCVL (AEH) ADC Conversion Value Register (Low Bit) (Read/Write)

| Bit Number      | 7   | 6          | 5   | 4   | 3 | 2 | 1 | 0 |
|-----------------|-----|------------|-----|-----|---|---|---|---|
| Bit<br>Mnemonic |     | ADCV[3: 0] |     |     |   | - | - | - |
| R/W             | R/W | R/W        | R/W | R/W | - | - | - | - |
| POR             | 0   | 0          | 0   | 0 0 |   | х | х | x |



#### ADCVH (AFH) ADC Conversion Value Register (High Bit) (Read/Write)

| Bit Number      | 7   | 6           | 5   | 4       | 3 | 2   | 1   | 0   |  |  |
|-----------------|-----|-------------|-----|---------|---|-----|-----|-----|--|--|
| Bit<br>Mnemonic |     | ADCV[11: 4] |     |         |   |     |     |     |  |  |
| R/W             | R/W | R/W         | R/W | R/W R/W |   | R/W | R/W | R/W |  |  |
| POR             | 0   | 0           | 0   | 0       | 0 | 0   | 0   | 0   |  |  |

| Bit Number | Bit Mnemonic                                      | Description                           |  |  |  |  |
|------------|---------------------------------------------------|---------------------------------------|--|--|--|--|
| 11 ~ 4     | ADCV[11: 4] ADC conversion value high byte values |                                       |  |  |  |  |
| 3 ~ 0      | ADCV[3: 0]                                        | ADC conversion value low 4-bit values |  |  |  |  |

#### IE (A8H) Interrupt Enable Register (Read/Write)

| Bit Number      | 7   | 6    | 5   | 4     | 3   | 2 | 1   | 0     |
|-----------------|-----|------|-----|-------|-----|---|-----|-------|
| Bit<br>Mnemonic | EA  | EADC | ET2 | EUART | ET1 | - | ETO | EINTO |
| R/W             | R/W | R/W  | R/W | R/W   | R/W | - | R/W | R/W   |
| POR             | 0   | 0    | 0   | 0     | 0   | х | 0   | 0     |

| Bit Number | Bit Mnemonic | Description                                                                                              |
|------------|--------------|----------------------------------------------------------------------------------------------------------|
| 6          | EADC         | ADC Interrupt Enable Control Bit<br>0: EOC/ADCIF interrupt not allowed<br>1: EOC/ADCIF interrupt allowed |

#### IP (B8H) Interrupt Priority Control Register (Read/Write)

| Bit Number      | 7 | 6     | 5         | 4      | 3    | 2 | 1    | 0      |
|-----------------|---|-------|-----------|--------|------|---|------|--------|
| Bit<br>Mnemonic | - | IPADC | IPT2      | IPUART | IPT1 | - | IPT0 | IPINT0 |
| R/W             | - | R/W   | R/W - R/W |        | R/W  | - | R/W  | R/W    |
| POR             | х | 0     | 0         | Х      | 0    | х | 0    | 0      |



| Bit Number | Bit Mnemonic | Description                                                                                                                                      |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | IPADC        | ADC Interruption Priority Selection Bit<br>0: Set the interrupt priority of ADC to be "low"<br>1: Set the interrupt priority of ADC to be "high" |

### **16.2 ADC Conversion Steps**

Operating steps for the user to practically conduct ADC conversion are shown below:

- Configure ADC input pin; (configure corresponding bit of AINx as ADC input, in general, ADC pin will be prefixed);
- (2) Configure ADC reference voltage Vref and ADC conversion frequency;
- 3 Enable ADC;
- ④ Select ADC input channel; (Configure ADCIS bit and select ADC input channel);
- (5) Enable ADCS, and start conversion;
- (6) Wait for EOC/ADCIF=1, if ADC interrupt is enabled, ADC interrupt will be generated and the user shall clear EOC/ADCIF flag to 0 by software;
- ⑦ Obtain 12-bit data from ADCVH, ADCVL from high bit to low bit, and complete a conversion
- (8) If no change in input channel, repeat Step 5 to Step 7 for next conversion.
- Note: Before setting up IE[6] (EADC), it is recommended for the user to use software to clear the EOC/ADCIF flag first. After completing ADC interrupt service process, user shall eliminate EOC/ADCIF to avoid generating ADC interrupt constantly.



# **17 EEPROM and IAP Operations**

There are two options for the SC92F730X IAP operating scope:

EEPROM and IAP operating modes are shown below:

- 1. 128 bytes EEPROM can be used as data storage;
- 2. The Code area of IC ROM and 128 bytes of EEPROM can be used for IAP operations, which is mainly used for remote program updating.
- Note: The number of erasure of EEPROM is 100,000 times. The user should not exceed the rated burn number of EEPROM, otherwise there will be an exception!

As Code Option, the user shall select IAP operating space before it is written to IC by programmer:

| Bit number      | 7     | 6 | 5 | 4 | 3    | 2     | 1 | 0 |
|-----------------|-------|---|---|---|------|-------|---|---|
| Bit<br>Mnemonic | VREFS | - | - | - | IAPS | [1:0] | - | - |
| R/W             | R/W   | - | - | - | R/W  | R/W   | - | - |
| POR             | n     | Х | x | x | n n  |       | х | х |

#### OP\_CTM1 (C2H@FFH) Customer Option Register 1 (Read/Write)

| Bits | Name       | Description                                                                                |
|------|------------|--------------------------------------------------------------------------------------------|
|      |            | EEPROM and IAP Area Selection Bits                                                         |
|      |            | 00: Code memory prohibits IAP operations, only EEPROM data memory is used for data storage |
| 3~2  | IAPS[1: 0] | 01: last 0.5k code memory allows IAP operation (1E00H ~ 1FFFH)                             |
|      |            | 10: Last 1k code memory allows IAP operation (1C00H ~ 1FFFH)                               |
|      |            | 11: All code memory allows IAP operation (0000H ~ 1FFFH)                                   |

### 17.1 EEPROM / IAP Operating-related Registers

#### Description for EEPROM / IAP operating-related registers:

| Mnemonic | Add | Description                    | 7 6 5 4 3 |              |  |  |  | 2 | 1        | 0        | POR |
|----------|-----|--------------------------------|-----------|--------------|--|--|--|---|----------|----------|-----|
| IAPKEY   | F1H | IAP Protection Register        |           | IAPKEY[7: 0] |  |  |  |   |          | 0000000b |     |
| IAPADL   | F2H | IAP Write Address Low Register |           | IAPADR[7: 0] |  |  |  |   | 0000000b |          |     |



| Mnemonic | Add | Description                            | 7 | 6             | 5            | 4 | 3 | 2          | 1             | 0              | POR       |
|----------|-----|----------------------------------------|---|---------------|--------------|---|---|------------|---------------|----------------|-----------|
| IAPADH   | F3H | IAP Write Address High Register        | - | -             |              | - | - |            | IAPADR[12: 8] |                | xxx00000b |
| IAPADE   |     | IAP Write Extended Address<br>Register |   | IAPADER[7: 0] |              |   |   |            | 0000000b      |                |           |
| IAPDAT   | F5H | AP Data Register                       |   |               | IAPDAT[7: 0] |   |   |            |               |                | 0000000b  |
| IAPCTL   | F6H | IAP Control Register                   | - | -             | -            | - |   | IMES<br>0] | CMD           | <b>[</b> 1: 0] | xxxx0000b |

#### IAPKEY (F1H) IAP Protection Register (Read/Write)

| Bit Number      | 7   | 6           | 5   | 4   | 3   | 2   | 1   | 0   |
|-----------------|-----|-------------|-----|-----|-----|-----|-----|-----|
| Bit<br>Mnemonic |     | IAPKEY[7:0] |     |     |     |     |     |     |
| R/W             | R/W | R/W         | R/W | R/W | R/W | R/W | R/W | R/W |
| POR             | 0   | 0           | 0   | 0   | 0   | 0   | 0   | 0   |
|                 |     |             |     |     |     |     |     |     |

| Bit Number | Bit Mnemonic | Description                                                                                                                                                                                                                                                                  |
|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 ~ 0      | IAPKEY[7: 0] | <ul> <li>Enable EEPROM/IAP function and operation time limit configuration, Written values must be non-zero:</li> <li>① Enable EEPROM / IAP function;</li> <li>② If no writing command is received after n system clocks, EEPROM / IAP function will be reclosed.</li> </ul> |

#### IAPADL (F2H) IAP Write Address Low Register (Read/Write)

| Bit Number      | 7   | 6            | 5   | 4   | 3   | 2   | 1   | 0   |
|-----------------|-----|--------------|-----|-----|-----|-----|-----|-----|
| Bit<br>Mnemonic |     | IAPADR[7: 0] |     |     |     |     |     |     |
| R/W             | R/W | R/W          | R/W | R/W | R/W | R/W | R/W | R/W |
| POR             | 0   | 0            | 0   | 0   | 0   | 0   | 0   | 0   |

| Bit Number | Bit Mnemonic | Description                         |
|------------|--------------|-------------------------------------|
| 7 ~ 0      | IAPADR[7: 0] | EEPROM/IAP writing address low byte |



#### IAPADH (F3H) IAP Write Address High Register (Read/Write)

| Bit Number      | 7 | 6 | 5 | 4   | 3   | 2            | 1   | 0   |
|-----------------|---|---|---|-----|-----|--------------|-----|-----|
| Bit<br>Mnemonic | - | - | - |     |     | IAPADR[12: 8 | 3]  |     |
| R/W             | - | - | - | R/W | R/W | R/W          | R/W | R/W |
| POR             | х | х | х | 0   | 0   | 0            | 0   | 0   |

| Bit Number | Bit Mnemonic  | Description                           |
|------------|---------------|---------------------------------------|
| 4 ~ 0      | IAPADR[12: 8] | EEPROM/IAP writing address high 5-bit |
| 7 ~ 5      | -             | Reserved                              |

#### IAPADE (F4H) IAP Write Extended Address Register (Read/Write)

| Bit Number      | 7   | 6            | 5   | 4   | 3   | 2   | 1   | 0   |
|-----------------|-----|--------------|-----|-----|-----|-----|-----|-----|
| Bit<br>Mnemonic |     | IAPADER[7:0] |     |     |     |     |     |     |
| R/W             | R/W | R/W          | R/W | R/W | R/W | R/W | R/W | R/W |
| POR             | 0   | 0            | 0   | 0   | 0   | 0   | 0   | 0   |

| Bit Number | Bit Mnemonic  | Description                                                                                                                                                                            |
|------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7~0        | IAPADER[7: 0] | IAP Extended Address:<br>0x00: MOVC and IAP programming for Code<br>0x01: Perform reading operation on user's ID area, but can't perform<br>writing operation<br>0x02: MOVC for EEPROM |
|            |               | Note: The number of erasure of EEPROM is 100,000 times. The<br>user should not exceed the rated burn number of EEPROM,<br>otherwise there will be an exception!<br>Other: Reserved     |

#### IAPDAT (F5H) IAP Data Register (Read/Write)

| Bit Number      | 7 | 6 | 5 | 4     | 3       | 2 | 1 | 0 |
|-----------------|---|---|---|-------|---------|---|---|---|
| Bit<br>Mnemonic |   |   |   | IAPDA | T[7: 0] |   |   |   |



| Bit Number | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|-----|-----|-----|-----|-----|-----|-----|-----|
| R/W        | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| POR        | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

| Bit Number | Bit Mnemonic | Description                |
|------------|--------------|----------------------------|
| 7 ~ 0      | IAPDAT       | Data written by EEPROM/IAP |

#### IAPCTL (F6H) IAP Control Register (Read/Write)

| Bit Number      | 7 | 6 | 5 | 4 | 3      | 2        | 1         | 0   |
|-----------------|---|---|---|---|--------|----------|-----------|-----|
| Bit<br>Mnemonic | - | - | - | - | PAYTIM | ES[1: 0] | CMD[1: 0] |     |
| R/W             | - | - | - | - | R/W    | R/W      | R/W       | R/W |
| POR             | х | х | х | x | 0      | 0        | 0         | 0   |
|                 |   |   |   |   |        |          |           |     |

| Bit Number | Bit Mnemonic   | Description                                                                                                                                                                                                                             |  |  |
|------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|            |                | Upon EEPROM/IAP writing operation, CPU Hold Time length configuration                                                                                                                                                                   |  |  |
|            |                | 00: Configure CPU HOLD TIME 4mS@24/12/6/2 MHz                                                                                                                                                                                           |  |  |
|            |                | 01: Configure CPU HOLD TIME 2mS@24/12/6/2 MHz                                                                                                                                                                                           |  |  |
|            |                | 10: Configure CPU HOLD TIME 1mS@24/12/6/2 MHz                                                                                                                                                                                           |  |  |
|            |                | 11: Reserved                                                                                                                                                                                                                            |  |  |
| 3 ~ 2      | PAYTIMES[1: 0] | Note: The CPU Hold is for PC pointer, other functional module<br>continues to work; interrupt flag is saved, and interrupt is<br>generated after completing Hold, but only the last interrupt<br>can be saved among several interrupts. |  |  |
|            |                | 1. Select 10 for the Flash ROM IAP operation. Note: Users should<br>set the LVR to 3.7V or higher and ensure that the VDD voltage<br>range is between 3.7V and 5.5V when performing IAP operations<br>on Flash ROM                      |  |  |
|            |                | 2. Select 00 or 01 for the EEPROM IAP operation. Note: Users should ensure that the VDD voltage range is between 2.4V and 5.5V when performing IAP operations on EEPROM applications                                                    |  |  |
|            |                | EEPROM / IAP writing operating command                                                                                                                                                                                                  |  |  |
|            |                | 10: Write                                                                                                                                                                                                                               |  |  |
| 1~0        | CMD[1: 0]      | Other: Reserved                                                                                                                                                                                                                         |  |  |
| 1~0        | Смр[1: 0]      | Note: The statement of EEPROM/IAP write operation shall be<br>followed by at least 8 NOP instructions to guarantee<br>subsequent instruction can be implemented normally<br>after finishing EEPROM/IAP operation!                       |  |  |



### 17.2 EEPROM / IAP Operating Procedures:

Writing procedure of the SC92F730X EEPROM/IAP are shown below:

- Write 0x00 into IAPADE[7: 0]: select Code memory and conduct IAP operation; write 0x02 into IAPADE[7: 0]: select EEPROM and conduct EEPROM reading and writing operations;
- (2) Write data into IAPDAT[7: 0] (data for EEPROM / IAP writing ready);
- ③ Write address into {IAPADR[12: 8], IAPADR[7: 0]} (target address of EEPROM/IAP operation ready);
- (4) Write a nonzero value n into IAPKEY[7: 0] (switch on protection of EEPROM / IAP, and EEPROM / IAP function will be switched off when there is no writing command within n system clocks);
- (5) Write CPU Hold time into IAPCTL[3: 0] (configue CPU Hold time by setting CMD[1: 0] to 1 or 0, CPU is Hold up and start up EEPROM/IAP writing);
- 6 EEPROM/IAP writing ends, CPU proceeds to subsequent operations.
- Note: When programming IC, if "Code memory Prohibits IAP Operations" is selected by Code Option, IAP is unavailable upon IAPADE[7: 0]=0x00 (Select Code memory), meaning it is unable to write data, and such data can only be read by MOVC command.

#### 17.2.1 128 bytes Independent EEPROM Operating Demo program

#include "intrins.h"
unsigned char EE\_Add;

unsigned char EE\_Data;

unsigned char code \* POINT =0x0000;

#### C Demo Program of EEPROM Write Operation:

| EA = 0;           | // Disable global Interrupt                                       |
|-------------------|-------------------------------------------------------------------|
| IAPADE = 0x02;    | //Select EEPROM data memory                                       |
| IAPDAT = EE_Data; | //Transmit data to EEPROM data register                           |
| IAPADH = 0x00;    | //High-bit address default write 0x00                             |
| IAPADL = EE_Add;  | //Write EEPROM target address low bit                             |
| IAPKEY = 0xF0;    | //This value can be adjusted as required: it shall guarantee that |
|                   | // <u>_</u>                                                       |

// The time interval between this instruction implemented and writing IAPCTL value shall be less than 240 (0xf0) system clocks, or else, IAP function is closed;

//Pay special attention to enabling interrupt;



| IAPCTL = 0x0A; | //Implement EEPROM write operation, 1ms@24/12/6/2 MHz; |
|----------------|--------------------------------------------------------|
| _nop_ ();      | //Wait (at least 8 _nop_ ())                           |
| _nop_ ();      |                                                        |
| IAPADE = 0x00; | //Return to ROM data memory                            |
| EA = 1;        | //Enable master interrupt                              |
|                |                                                        |

C Demo Program of EEPROM Read Operation

| EA = 0;                     | //Disable master interrupt                                   |
|-----------------------------|--------------------------------------------------------------|
| IAPADE = 0x02;              | //Select EEPROM data memory                                  |
| EE_Data = * ( POINT +EE_Add | d); //Read value in IAP_Add to IAP_Data                      |
| IAPADE = 0x00;              | //Return to ROM data memory, prevent MOVC operates to EEPROM |
| EA = 1;                     | // Enable global interrupt                                   |

### 17.2.2 16K bytes Code memory IAP Operating Demo program

#include "intrins.h"
unsigned int IAP\_Add;
unsigned char IAP\_Data;
unsigned char code \* POINT =0x0000;

C Demo Program of IAP Write Operation:

IAPADE = 0x00; //Select Code memory

IAPDAT = IAP\_Data; //Transmit data to IAP data register

IAPADH = (unsigned char) ( (IAP\_Add >> 8)); //Write IAP target address high bit



| IAPADL = (unsigned char)IAP_         | Add; //Write IAP target address low bit                                                                                            |
|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| IAPKEY = 0xF0;                       | <pre>//This value can be adjusted as required; it shall guarantee this //instruction is implemented to assigned IAPTL value;</pre> |
|                                      | // Time interval shall be less than 240 (0xf0) system clocks, or else, IAP function is closed;                                     |
|                                      | //Pay special attention upon starting interrupt                                                                                    |
| IAPCTL = 0x0A;                       | //Implement EEPROM write operation, 1ms@24/12/6/2MHz;                                                                              |
| _nop_ ();                            | //Wait (at least 8 _nop_ ())                                                                                                       |
| _nop_ ();                            |                                                                                                                                    |
| C Demo Program of IAP Read Operation | 1:                                                                                                                                 |
| IAPADE = 0x00;                       | //Select Code memory                                                                                                               |
| IAP_Data = * ( POINT+IAP_Add         | ); //Read value in IAP_Add to IAP_Data                                                                                             |

Note: IAP operation in 8K bytes Code memory has certain risks, the user shall implement corresponding safety measures in software. Incorrect operation may result in the user program to be rewritten! Unless such function is required by the user (such as used for remote program update, etc.), it is not recommended to used by the user.



# **18 Electrical Characteristics**

### **18.1 Absolute Maximum Ratings**

| Symbol                | Parameter                         | Min Value | Max Value            | Unit |
|-----------------------|-----------------------------------|-----------|----------------------|------|
| VDD/VSS               | DC supply voltage                 | -0.3      | 5.5                  | V    |
| Voltage ON any<br>Pin | Input/output voltage of any pin   | -0.3      | V <sub>DD</sub> +0.3 | V    |
| T <sub>A</sub>        | Ambient temperature               | -40       | 85                   | °C   |
| T <sub>STG</sub>      | Storage temperature               | -55       | 125                  | °C   |
| Ivdd                  | Current value flowing through VDD |           | 200                  | mA   |
| Ivss                  | Current value flowing through VSS | -         | 200                  | mA   |

## **18.2 Recommended Operating Conditions**

| Symbol          | Parameter                                        | Min Value | Max Value | Unit | System Clock<br>Frequency |
|-----------------|--------------------------------------------------|-----------|-----------|------|---------------------------|
|                 | Operating voltage 1                              | 3.7       | 5.5       | V    | 24MHz                     |
| V <sub>DD</sub> | Operating voltage 2                              | 2.4       | 5.5       | V    | 12/6/2MHz                 |
| VDD(Flash)      | Flash ROM operating voltage during IAP operation | 3.7       | 5.5       | V    | -                         |
| VDD(EEPROM)     | EEPROM operating voltage<br>during IAP operation | 2.4       | 5.5       | V    | -                         |
| T <sub>A</sub>  | Ambient temperature                              | -40       | 85        | °C   | -                         |

### **18.3 DC Characteristics**

(V\_DD = 5V,  $T_A$  = +25°C, unless otherwise specified)

| Symbol           | Parameter         | Min<br>Value | Typical<br>Value | Max<br>Value | Unit | Testing Conditions      |
|------------------|-------------------|--------------|------------------|--------------|------|-------------------------|
| Current          | Current           |              |                  |              |      |                         |
| I <sub>op1</sub> | Operating current | -            | 4                | -            | mA   | f <sub>SYS</sub> =24MHz |



| Symbol            | Parameter                         | Min<br>Value       | Typical<br>Value | Max<br>Value         | Unit | Testing Conditions                                                       |
|-------------------|-----------------------------------|--------------------|------------------|----------------------|------|--------------------------------------------------------------------------|
| I <sub>op2</sub>  | Operating current                 | -                  | 3.2              | -                    | mA   | fsys =12MHz                                                              |
| I <sub>op3</sub>  | Operating current                 | -                  | 2.7              | -                    | mA   | fsys =6MHz                                                               |
| I <sub>op4</sub>  | Operating current                 | -                  | 2.4              | -                    | mA   | fsys =2MHz                                                               |
| I <sub>pd1</sub>  | Standby Current (Power Down Mode) | -                  | 3                | 6                    | μA   |                                                                          |
| I <sub>IDL1</sub> | Standby Current (IDLE Mode)       | -                  | 2.2              | -                    | mA   |                                                                          |
| Івтм              | Base Timer Operating Current      | -                  | 1                | 2                    | μΑ   | BTMFS[3: 0]=<br>1000<br>One interrupt<br>occurs for every 4.0<br>seconds |
| Iwdt              | WDT Current                       | -                  | 1                | 2                    | μΑ   | WDTCKS[2: 0]=<br>000<br>WDT overflows<br>every 500ms                     |
| I/O Port          | Features                          |                    |                  |                      |      |                                                                          |
| VIH1              | Input high voltage                | 0.7V <sub>DD</sub> | -                | V <sub>DD</sub> +0.3 | V    |                                                                          |
| VIL1              | Input low voltage                 | -0.3               | -                | 0.3V <sub>DD</sub>   | V    |                                                                          |
| V <sub>IH2</sub>  | Input high voltage                | 0.8Vdd             | -                | Vdd                  | V    | Schmidt trigger<br>input:                                                |
| VIL2              | Input low voltage                 | -0.2               | -                | 0.2V <sub>DD</sub>   | V    | RST<br>tCK/tDIO<br>UART Enter RX<br>INT0, INT2<br>Timer clock input      |
| Iol1              | Output low current                | -                  | 37               | -                    | mA   | V <sub>Pin</sub> =0.4V                                                   |
| IOL2              | Output low current                | -                  | 70               | -                    | mA   | V <sub>Pin</sub> =0.8V                                                   |
| Іон1              | Output high current P1            | -                  | 22               | -                    | mA   | V <sub>Pin</sub> =4.3V                                                   |
| Іон2              | Output high current P1            | -                  | 11               | -                    | mA   | V <sub>Pin</sub> =4.7V                                                   |
| Іонз              | Output high current P0/P2         | -                  | 22               | -                    | mA   | V <sub>Pin</sub> =4.3V<br>Pxyz = 0, I <sub>OH</sub> level 0              |
|                   | Output high current P0/P2         | -                  | 11               | -                    | mA   | V <sub>Pin</sub> =4.3V                                                   |



| Symbol                                            | Parameter                              | Min<br>Value | Typical<br>Value | Max<br>Value | Unit | Testing Conditions                                          |
|---------------------------------------------------|----------------------------------------|--------------|------------------|--------------|------|-------------------------------------------------------------|
|                                                   |                                        |              |                  |              |      | Pxyz = 1, Іон level 1                                       |
|                                                   | Output high current P0/P2              | -            | 5                | -            | mA   | V <sub>Pin</sub> =4.3V<br>Pxyz = 2, I <sub>OH</sub> level 2 |
|                                                   | Output high current P0/P2              | -            | 2.2              | -            | mA   | V <sub>Pin</sub> =4.3V<br>Pxyz = 3, I <sub>OH</sub> level 3 |
|                                                   | Output high current P0/P2              | -            | 11               | -            | mA   | V <sub>Pin</sub> =4.7V<br>Pxyz = 0, I <sub>OH</sub> level 0 |
| Leve .                                            | Output high current P0/P2              | -            | 5.5              | -            | mA   | V <sub>Pin</sub> =4.7V<br>Pxyz = 1, I <sub>OH</sub> level 1 |
| Іон4                                              | Output high current P0/P2              | -            | 2.2              | -            | mA   | V <sub>Pin</sub> =4.7V<br>Pxyz = 2, I <sub>OH</sub> level 2 |
|                                                   | Output high current P0/P2              | _            | 1                | -            | mA   | V <sub>Pin</sub> =4.7V<br>Pxyz = 3, I <sub>OH</sub> level 3 |
| R <sub>PH1</sub>                                  | Pull-up resistance                     |              | 30               | -            | kΩ   |                                                             |
| Internal calibrated 2.4V as ADC reference voltage |                                        |              |                  |              |      |                                                             |
| V <sub>DD24</sub>                                 | Internal reference 2.4V voltage output | 2.38         | 2.40             | 2.42         | V    | T <sub>A</sub> =-40 ~ 85℃                                   |

(V\_DD = 3.3V,  $T_A$  = +25 °C, unless otherwise specified)

| Symbol            | Parameter                         | Min<br>Value | Typical<br>Value | Max<br>Value | Unit | Conditions  |
|-------------------|-----------------------------------|--------------|------------------|--------------|------|-------------|
| Current           |                                   |              |                  |              |      |             |
| l <sub>op5</sub>  | Operating current                 | -            | 3.2              | -            | mA   | fsys =24MHz |
| I <sub>op6</sub>  | Operating current                 | -            | 2.6              | -            | mA   | fsys =12MHz |
| I <sub>op7</sub>  | Operating current                 | -            | 2.3              | -            | mA   | fsys =6MHz  |
| I <sub>op8</sub>  | Operating current                 | -            | 2                | -            | mA   | fsys =2MHz  |
| I <sub>pd2</sub>  | Standby Current (Power Down Mode) | -            | 3                | 6            | uA   |             |
| I <sub>IDL2</sub> | Standby Current (IDLE Mode)       | -            | 1.9              | -            | mA   |             |
| I/O Port          | I/O Port Features                 |              |                  |              |      |             |



| Symbol           | Parameter                                | Min<br>Value | Typical<br>Value | Max<br>Value         | Unit | Conditions                                                          |
|------------------|------------------------------------------|--------------|------------------|----------------------|------|---------------------------------------------------------------------|
| VIH3             | Input high voltage                       | $0.7V_{DD}$  | -                | V <sub>DD</sub> +0.3 | V    |                                                                     |
| VIL3             | Input low voltage                        | -0.3         | -                | 0.3V <sub>DD</sub>   | V    |                                                                     |
| VIH4             | Input high voltage                       | 0.8Vdd       | -                | Vdd                  | V    | Schmidt trigger<br>input:                                           |
| VIL4             | Input low voltage                        | -0.2         | -                | 0.2V <sub>DD</sub>   | V    | RST<br>tCK/tDIO<br>UART Enter RX<br>INT0, INT2<br>Timer clock input |
| I <sub>OL3</sub> | Output low current                       | -            | 30               | -                    | mA   | V <sub>Pin</sub> =0.4V                                              |
| I <sub>OL4</sub> | Output low current                       | -            | 50               | -                    | mA   | V <sub>Pin</sub> =0.8V                                              |
| Іон5             | Output high current P1                   | -            | 7                | -                    | mA   | V <sub>Pin</sub> =3.0V                                              |
|                  | Output high current P0/P2                | -            | 7                | -                    | mA   | V <sub>Pin</sub> =3.0V<br>Pxyz = 0, I <sub>OH</sub> level 0         |
|                  | Output high current P0/P2                |              | 3.5              | -                    | mA   | V <sub>Pin</sub> =3.0V<br>Pxyz = 1, I <sub>OH</sub> level 1         |
| I <sub>OH6</sub> | Output high current P0/P2                | -            | 1.4              | -                    | mA   | V <sub>Pin</sub> =3.0V<br>Pxyz = 2, I <sub>OH</sub> level 2         |
|                  | Output high current P0/P2                | -            | 0.7              | -                    | mA   | V <sub>Pin</sub> =3.0V<br>Pxyz = 3, I <sub>OH</sub> level 3         |
| R <sub>PH2</sub> | Pull-up resistance                       | -            | 52               | -                    | kΩ   |                                                                     |
| Internal of      | calibrated 2.4V as ADC reference voltage | !            |                  |                      |      |                                                                     |
| Vdd24            | Internal reference 2.4V voltage output   | 2.38         | 2.40             | 2.42                 | V    | TA=-40 ~ 85℃                                                        |

### **18.4 AC Characteristics**

(V\_DD = 2.4V ~ 5.5V, TA = 25  $^\circ \!\! \mathbb{C}$  , unless otherwise specified)

| Symbol             | Parameter                      | Min | Typical | Max | Unit | Conditions          |
|--------------------|--------------------------------|-----|---------|-----|------|---------------------|
| TPOR               | Power On Reset time            | -   | 15      | -   | ms   |                     |
| TPDW               | Power Down Mode waking-up time | -   | 65      | 130 | μs   |                     |
| T <sub>Reset</sub> | Reset Pulse Width              | 18  | -       | -   | μs   | Valid for Low level |



| Symbol           | Parameter                | Min   | Typical | Max   | Unit | Conditions                                                 |
|------------------|--------------------------|-------|---------|-------|------|------------------------------------------------------------|
| T <sub>LVR</sub> | LVR anti-shake time      | -     | 30      | -     | μs   |                                                            |
| f <sub>HRC</sub> | RC oscillation stability | 23.76 | 24      | 24.24 | MHz  | V <sub>DD</sub> =2.4 ~ 5.5V<br>T <sub>A</sub> =-40 ~ 85 °C |

### **18.5 ADC Characteristics**

(T\_A= 25  $^\circ\!\mathrm{C}$  , unless otherwise specified)

| Symbol           | Parameter                    | Min | Typical | Max | Unit | Conditions                             |
|------------------|------------------------------|-----|---------|-----|------|----------------------------------------|
| V <sub>AD1</sub> | Supply Voltage 1             | 2.7 | 5.0     | 5.5 | V    | V <sub>ref</sub> =2.4V                 |
| V <sub>AD2</sub> | Supply Voltage 2             | 2.4 | 5.0     | 5.5 | V    | V <sub>ref</sub> =V <sub>DD</sub>      |
| NR               | Precision                    | -   | 12      | -   | bit  | GND≤V <sub>AIN</sub> ≤V <sub>DD</sub>  |
| Vain             | ADC Input Voltage            | GND | -       | Vdd | V    |                                        |
| R <sub>AIN</sub> | ADC input resistance         | 1   | -       |     | MΩ   | V <sub>IN</sub> =5V                    |
| IADC1            | ADC conversion current 1     |     | -       | 2   | mA   | ADC Module on<br>V <sub>DD</sub> =5V   |
| IADC2            | ADC conversion current 2     | -   | -       | 1.8 | mA   | ADC module on<br>V <sub>DD</sub> =3.3V |
| DNL              | Differential nonlinear error | _   | ±4      | -   | LSB  |                                        |
| INL              | Integral nonlinear error     | -   | ±4      | -   | LSB  |                                        |
| Ez               | Offset error                 | -   | ±1      | -   | LSB  | V <sub>DD</sub> =5V                    |
| EF               | Full scale error             | -   | 4       | -   | LSB  | $V_{REF}=5V$                           |
| Ead              | Total absolute error         | -   | ±4      | -   | LSB  |                                        |
| TADC1            | ADC conversion time 1        | -   | 4       | -   | μs   | ADC Clock = 2MHz                       |
| TADC2            | ADC conversion time 2        | -   | 19      | -   | μs   | ADC Clock =<br>333kHz                  |



# **19 Ordering Information**

| PRODUCT NO    | PKG     | PACKING |
|---------------|---------|---------|
| SC92F7300M08U | SOP8    | TUBE    |
| SC92F7301M16U | SOP16   | TUBE    |
| SC92F7302M20U | SOP20   | TUBE    |
| SC92F7302X20U | TSSOP20 | TUBE    |
| SC92F7302Q20R | QFN20   | TRAY    |



# **20 Packaging Information**

#### SC92F7302Q20R





| Symbol |       | mm     |       |
|--------|-------|--------|-------|
| Symbol | Min   | Normal | Max   |
| А      | 0.700 | 0.750  | 0.800 |
| A1     | 0     | -      | 0.050 |
| A2     | 0.153 | 0.203  | 0.253 |
| b      | 0.180 | 0.250  | 0.300 |
| D      | 3.900 | 4.000  | 4.100 |
| D1     | 1.900 | 2.000  | 2.100 |
| E      | 3.900 | 4.000  | 4.100 |
| E1     | 1.900 | 2.000  | 2.100 |
| е      | 0.450 | 0.500  | 0.550 |
| L      | 0.390 | 0.400  | 0.410 |



#### SC92F7302X20U

TSSOP20L Overall Dimension Unit:mm









| Cumbal     |       | mm        |       |  |  |
|------------|-------|-----------|-------|--|--|
| Symbol     | Min   | Normal    | Max   |  |  |
| А          | -     | -         | 1.200 |  |  |
| A1         | 0.050 |           | 0.150 |  |  |
| A <b>2</b> | 0.800 | -         | 1.050 |  |  |
| b          | 0.190 | -         | 0.300 |  |  |
| С          | 0.090 | -         | 0.200 |  |  |
| D          | 6.400 | -         | 6.600 |  |  |
| Е          | 6.20  | -         | 6.60  |  |  |
| e1         | 4.300 | -         | 4.500 |  |  |
| е          |       | 0.65(BSC) |       |  |  |
| L          | -     | -         | 1.00  |  |  |
| θ          | 0°    | -         | 8°    |  |  |
| Н          | 0.05  |           | 0.15  |  |  |



#### SC92F7302M20U

SOP20L(300mil) Overall Dimension

Unit:mm







| Cumb al    |        | mm        |            |
|------------|--------|-----------|------------|
| Symbol     | Min    | Normal    | Max        |
| А          | 2.40   | 2.56      | 2.65       |
| A1         | 0.100  | 0.200     | 0.300      |
| A <b>2</b> | 2.240  | 2.340     | 2.440      |
| b          | 0.35   |           | 0.47       |
| С          | 0.25   |           | 0.31       |
| D          | 12.60  | 12.80     | 13.00      |
| Е          | 7.30   | 7.50      | 7.70       |
| HE         | 10.100 | 10.300    | 10.500     |
| е          |        | 1.27(BSC) |            |
| L          | 0.700  | 0.850     | 1.000      |
| LE         | 1.30   | 1.40      | 1.50       |
| θ          | 0°     | -         | <b>8</b> ° |



#### SC92F7301M16U

SOP16L(150mil) Overall Dimension





| Symbol     |       | mm        |       |
|------------|-------|-----------|-------|
| Symbol     | Min   | Normal    | Мах   |
| A          | 1.500 | 1.625     | 1.750 |
| A1         | 0.050 | 0.1375    | 0.225 |
| A <b>2</b> | 1.30  | 1.45      | 1.55  |
| b          | 0.38  | 0.43      | 0.48  |
| С          | 0.20  | 0.23      | 0.26  |
| D          | 9.70  | 9.90      | 10.10 |
| E          | 3.70  | 3.90      | 4.10  |
| HE         | 5.80  | 6.00      | 6.20  |
| е          |       | 1.27(BSC) |       |
| L          | 0.50  | 0.65      | 0.80  |
| LE         | 0.95  | 1.05      | 1.15  |
| θ          | 0°    | -         | 8°    |



#### SC92F7300M08U

#### SOP8L(150mil) Overall Dimension Unit:mm









| Currench and |       | mm         |       |
|--------------|-------|------------|-------|
| Symbol       | Min   | Normal     | Max   |
| А            | 1.500 | 1.625      | 1.750 |
| A <b>1</b>   | 0.100 | 0.1625     | 0.225 |
| A <b>2</b>   | 1.30  | 1.425      | 1.55  |
| b            | 0.39  | 0.435      | 0.48  |
| С            | 0.20  | 0.23       | 0.26  |
| D            | 4.70  | 4.90       | 5.10  |
| E            | 3.70  | 3.90       | 4.10  |
| HE           | 5.80  | 6.00       | 6.20  |
| е            |       | 1.270(BSC) |       |
| L            | 0.50  | 0.65       | 0.80  |
| L1           | 0.95  | 1.05       | 1.15  |
| θ            | 0°    | -          | 8°    |



# **21 Revision History**

| Version | Notes            | Date       |
|---------|------------------|------------|
| V0.1    | Initial Release. | 2024.02.01 |



## **Important Notice**

Shenzhen SinOne Microelectronics Co., Ltd. (hereinafter referred to as SinOne) reserves the right to change, correct, enhance, modify and improve SinOne products, documents or services at any time without prior notice. SinOne considers the information provided to be accurate and reliable. The information in this document will be used in February 2024. In the actual production design, please refer to the latest data manual of each product and other relevant materials.