Super High-speed 1T 8051 Core Flash MCU, 8 Kbytes SRAM, 128 Kbytes Flash, 0~4 Kbytes LDROM, 6 Kbytes Independent EEPROM,12-bit ADC, 14-channel 16-bit PWM, 5 Timers, MDU, UART, 6-channel USCI, CRC Check Module, 1 Analog Comparator # 1 General Description SC95F7767/7766/7765/7763 (hereinafter referred to as the SC95F776X) is a series of enhanced 1T 8051 core industry-standard Flash Microcontroller unit (MCU), the instruction set is compatible with the standard 8051 series. The SC95F776X has a Super-high-speed 1T 8051 CPU core with an operating frequency of up to 32 MHz. The SC95F776X integrates a hardware multiplier and divider hardware CRC and dual DPTR data pointers to accelerate data operations and movement speed. The hardware multiplier and divider and hardware CRC does not occupy CPU cycles, and the operation is implemented by hardware, and the speed is faster than the multiplication and division speed realized by software; dual DPTR data pointers can be used to accelerate data storage and movement. The SC95F776X has high performance and reliability, with a wide operating voltage of 2.0V~5.5V, a super-wide operating temperature of -40°C to 105°C, and has good ESD performance and EFT anti-interference ability. Using the industry-leading eFlash process, the Flash can be written more than 100,000 times, and can be stored for 100 years at room temperature. The SC95F776X has a built-in low power consumption WDT Watchdog Timer. It has a 4-level selectable voltage LVR low voltage reset function and a system clock monitoring function. It has low power consumption capability in operation and power-down modes. Under normal operating mode: about 6mA@32M at 5V. The SC95F776X series is also integrated with super rich hardware resources: 128 Kbytes Flash ROM, SRAM: internal 256 bytes+ external 8 Kbytes+ PWM&LCD 80 bytes、6 Kbytes EEPROM, up to 46 GP I/O (partially gradable control), 16 IO can be externally interrupted, 5 16-bit timers, 14-channel 16-bit PWM: 8-channel multifunction dead zone complementary PWM, 6 channel PWM output of timer, 1 UART, 6 USCI(UART/SPI/IIC), Builtin LCD/LED hardware driver, internal ±2% high-precision high-frequency 32/16/8/4 MHz oscillator and ±4% precision low-frequency 32 kHz oscillator, external 32.768 kHz resources such as crystal oscillators. 1 analog comparator, 17 channels 12-bit high precision ADC. The SC95F776X is very convenient for development and debugging, with ISP (In-System Programming), ICP (In-Circuit Programming) and IAP (In-Application Programming). Allow the chip to debug and upgrade the program memory directly on the circuit board when the chip is online or powered. The SC95F776X has very excellent anti-jamming performance. It is very suitable for various applications about main control system, such as Intelligent home appliances and Intelligent House System, Internet of things, wireless communication, game consoles and other industrial controls, and consumer application areas. Page 1 of 252 V0.1 ## 2 Features #### **Operating Conditions** Voltage Range: 2.0V~5.5V Temperature Range: -40°C ~ +105°C #### **EMS** ESD ■ HBM: MIL-STD-883J Class 3A ■ MM: JEDEC EIA/JESD22-A115 Class C ■ CDM: ANSI/ESDA/JEDEC JS-002-2018 Class C3 • EFT ■ EN61000-4-4 Level 4 #### **Package** • 28 PIN: SOP28 / TSSOP28 32 PIN: LQFP32 (7X7) / QFN32 (5X5) 44 PIN: LQFP44 (10X10) 48 PIN: LQFP48 (7X7) / QFN48 (7X7) #### **CPU** - Super-high-speed 1T 8051 core - The instruction set compatible with 8051 - The execution speed is about twice that of other 1T 8051 - Double data pointers (DPTRs) ### Flash ROM - 128 Kbytes Flash ROM - Can be rewritten 100,000 times - APROM area allowed IAP operation in Flash can be set to 0K/1K/2K/All APROM by Code Option. #### **LDROM** - BootLoader code memory - LDROM area can be set to 0K/1K/2K/4K by Code Option Page 2 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU #### **EEPROM** - Independent 6 Kbytes EEPROM - Can be rewritten 100,000 times, has more than 100-year preservation life in the ambient temperature of 25°C #### **SRAM** - 256 bytes on-chip direct access RAM - 8 Kbytes on-chip Indirect access RAM - 80 bytes PWM&LCD RAM #### Flash Programming and Emulation 2-wire JTAG programming and emulation interface #### System clock (fsys) - Built-in high frequency 32 MHz oscillator (f<sub>HRC</sub>) - can be selected and set by the programmer as: 32/16/8/4 MHz@2.0~5.5V - Frequency Error: Within ±1% @ -40 ~ 85°C @ 2.0 ~ 5.5V - Frequency Error: Within ±2% @ -40 ~ 105°C @ 2.0 ~ 5.5V - The system clock can be automatically calibrated by 32.768 kHz external crystal oscillator, after calibration HRC accuracy can be infinitely close to the accuracy of external 32.768 kHz crystal oscillator. #### Built-in low-frequency crystal oscillator circuit: • 32.768k oscillator can be connected externally as a Base Timer clock source. #### Built-in low-frequency 32 kHz oscillator (LRC): - used as the clock source for Base Timer and WDT and wake up STOP - Frequency Error: After the register correction, within ±4% @ -20 ~ 85°C @ 4.0 ~ 5.5V #### Low-voltage Reset (LVR) - 4 options of reset voltage: 4.3/3.7/ 2.9/1.9V, - the default value can be selected by the Code Option #### Interrupts (INT) - Timer 0~Timer 4, INT0~2, ADC, PWM, UART, USCI0~5, Base Timer, CMP 19 interrupt sources in total - External interrupt contains 3 interrupt vectors, 16 interrupt ports. All can set up rising edge, falling edge, dual edge interrupt. Page 3 of 252 V0.1 http://www.socmcu.com ### Super High-speed 1T 8051 Core Flash MCU Two-level interrupt priority capability #### **Digital Peripheral** - GPIO: Up to 46 bidirectional independently controllable I/O ports - Independent setting of pull-up resistors - P0~P3L(P3.0/1/2/3) port source drive capacity is controlled by four levels - All IO ports have large sink current drive capability (50mA) - Built-in WDT, optional clock frequency division ratio - 5 Timers: Timer0~4、Timer1、Time2、Timer3 and Timer4 - Time2、Timer3 and Timer4 have Capture function - Time2、Timer3 and Timer4 each can provide two conventional PWM - 6-channel 16-bit conventional PWM - Time2、Timer3 and Timer4 each can provide two conventional PWM - 8-channel 16-bit multi-function PWM - Public cycle and the duty cycle can be set separately - Complementary PWM waveforms with dead zones can be output - One independent UART communication port UART0 - Six UART/SPI/TWI communication interfaces (USCI) - When USCI0 is set to SPI0, the driving capability of the pins corresponding to its signal port will be enhanced - Built-in CRC check module - Integrated with 16 \* 16-bit hardware Multiplier-Divide Unit (MDU) #### LCD/LED driver - Choose one of two LCD/LED, share registers and IO ports - 8 X 24, 6 X 26, 5 X 27, or 4X 28 segments LED driver - LED segment port source drive capability is selectable in four levels - 8 X 24, 6 X 26, 5 X 27, or 4 X 28 segments LCD driver #### **Analog Peripheral** ● 17-channel 12-bit±2LSB ADC Page 4 of 252 V0.1 - Build-in reference voltage of 2.048V, 1.024V and 2.4V - The ADC reference voltages is optional: VDD, internal 2.048V, internal 1.024V and 2.4V - 1 internal channel can measure the voltage of the power supply - ADC conversion complete interruption can be set - 1 Analog Comparator - 4-channel input and 1-channel reference voltage input - 16-level optional comparison voltage ### **Power Saving Mode** - IDLE Mode: can be woken up by any interrupt - STOP Mode: can be woken up by INT0~2, Base Timer and CMP. Page 5 of 252 V0.1 # Naming Rules for 95 Series Products | Name | SC | 95 | F | 7 | 7 | 6 | 7 | Х | Р | 48 | R | |------|----|----|---|---|-----|---|---|---|---|-----|-----| | S/R | 1 | 2 | 3 | 4 | (5) | 6 | Ī | 8 | 9 | 100 | 11) | | 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, 5 for 32K and 6 for 64K | | 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:(default, B, C, D) | | 9 | Package Type: (D: DIP; M: SOP; X: TSSOP; F: QFP; P: LQFP; Q: QFN; K: SKDIP) | | 100 | Number of Pins. | | (11) | Packaging Mode: (U: Tube; R: Tray; T: Reel) | Page 6 of 252 V0.1 # **Ordering Information** | PRODUCT ID | PACKAGE | PACK | |---------------|---------------|------| | SC95F7763M28U | SOP28 | TUBE | | SC95F7763X28U | TSSOP28 | TUBE | | SC95F7765P32R | LQFP32(7X7) | TRAY | | SC95F7765Q32R | QFN32(5X5) | TRAY | | SC95F7766P44R | LQFP44(10X10) | TRAY | | SC95F7767P48R | LQFP48(7X7) | TRAY | | SC95F7767Q48R | QFN48(7X7) | TRAY | Page 7 of 252 V0.1 # **Contents** | 1 GENERAL DESCRIPTION | 1 | |---------------------------------------------------------------------------|----| | 2 FEATURES | 2 | | NAMING RULES FOR 95 SERIES PRODUCTS | 6 | | ORDERING INFORMATION | 7 | | CONTENTS | 8 | | 3 PIN DESCRIPTION | 12 | | 3.1 Pin Configuration | | | 3.1.1 48/44 Pin Definition | 15 | | 4 INNER BLOCK DIAGRAM | 22 | | 5 FLASH ROM AND SRAM | 24 | | 5.1 APROM and LDROM | 24 | | 5.1.1 Flash ROM Sectors | 27 | | 5.2 6K bytes independent EEPROM | 27 | | 5.3 96 bits Unique ID Area | 28 | | 5.3.1 Unique ID Read Operating Demo Program In C Language | 29 | | 5.4 User ID Area | | | 5.5 Programming | 30 | | 5.6 In Application Programming (IAP) | 31 | | 5.6.1 IAP Operation Related Register | | | 5.6.2 IAP Operation process5.6.3 IAP Operating Demo Program In C Language | | | 5.6.4 IAP Operation notes | 37 | | 5.7 BootLoader | | | 5.7.1 BootLoader Mode operation related registers | | | 5.8 Encryption | | | 5.9 Code Option Area (User Programming Settings) | 45 | | 5.9.1 Customer-Option-related Registers Operation Instructions | 49 | | 5.10 SRAM | 50 | | 5.10.1 Internal 256 Bytes SRAM | | | 5.10.2 External 8 Kbytes SRAM5.10.3 External 80 bytes PWM&LCD/LED SRAM | | | 6 SPECIAL FUNCTION REGISTER (SFR) | 53 | | 6.1 SFR Mapping | | | 6.2 SFR Instructions | 54 | | 6.2.1 SFR | | | 6.2.2 PWM0 Duty Cycle Adjustment Register(R/W) | | | 6.2.4 LCD/LED display RAM configuration (R/W) | 62 | | 6.2.5 Introduction of Common Special Function Registers of 8051 Core | | # Super High-speed 1T 8051 Core Flash MCU | Program Counter PC | 63 | |-----------------------------------------------------------------------------------------------------|-----| | Accumulator ACC (E0H) | | | B Register (F0H) | | | Stack Pointer SP (81H)Data Pointers DPTR0 (82H, 83H), DPTR1 (84H, 85H) And Its Selection Register I | | | 7 POWER, RESET AND SYSTEM CLOCK | , , | | 7.1 Power Circuit | | | 7.2 Power-on Reset | | | 7.2.1 Reset Stage | | | 7.2.2 Loading Information Stage | | | 7.2.3 Normal Operation Stage | | | 7.3 Reset Modes | 68 | | 7.3.1 External Reset | | | 7.3.2 Low-voltage Reset LVR | | | 7.3.3 Power-on Reset (POR) | | | 7.3.5 Software Reset | | | 7.3.6 Register Reset Value | | | 7.4 High- frequency System Clock Circuit | 73 | | 7.5 Low- frequency RC Oscillator and Low- frequency Clock Timer | | | 7.6 Power Saving Modes | | | 8 CPU AND INSTRUCTION SET | 81 | | 8.1 CPU | | | 8.2 Addressing Mode | 81 | | 8.2.1 Immediate Addressing | | | 8.2.2 Direct Addressing | | | 8.2.4 Register Addressing | | | 8.2.5 Relative Addressing | | | 8.2.6 Indexed Addressing | | | 8.2.7 Bits Addressing | | | 9 INTERRUPTS | | | 9.1 Interrupt Source and Vector | | | 9.2 Interrupt Structure Diagram | | | 9.3 Interrupt Priority | | | 9.4 Interrupt Processing Flow | | | 9.5 Interrupt-related SFR Registers | | | 10 TIMER/COUNTER TO AND T1 | | | 10.1 T0 and T1-related Registers | | | 10.2 T0 Operating Modes | | | 10.3 T1 Operating Mode | | | 11 TIMER/COUNTER T2/T3/T4 | 110 | | 11.1 T2/3/4-related Registers | 110 | # Super High-speed 1T 8051 Core Flash MCU | 11.2 Timer 2 | 111 | |-------------------------------------------------|------------| | 11.3 Timer 3 | 115 | | 11.4 Timer 4 | 119 | | 11.5 Timer 2/3/4 Operating Modes | 122 | | 11.5.1 Timer 2/3/4 Operating Modes | 123 | | 12 PWM2/3/4 | 128 | | 12.1 PWM2/3/4 related Registers | 128 | | 12.2 PWM2/3/4 Duty Variation Characteristics | | | 12.3 PWM2/3/4 Cycle Variation Characteristics | 132 | | 13 PWM0 | 133 | | 13.1 PWM Structure Diagram | | | 13.2 PWM0 General Configuration Register | | | 13.2.1 PWM0 General Configuration Register | 135<br>141 | | 13.3 PWM0 Independent Mode | 144 | | 13.3.1 PWM0 Independent Mode Block Diagram | | | 13.4 PWM0 Complementary Model | | | 13.4.1 PWM0 Block Diagram of Complementary Mode | 146<br>147 | | 13.5 PWM0 Waveforms and Directions | | | 14 GENERAL-PURPOSE I/O (GPIO) | 151 | | 14.1 GPIO Structure Diagram | | | 14.2 I/O Port-related Registers | | | 15 LCD/LED DISPLAY DRIVER | | | 15.1 LCD/LED Display Drive-related Registers | | | 15.2 LCD/LED Display RAM Configuration | | | 15.3 LCD Waveform | | | 15.3.1 1/3Bias LCD Waveform | | | 15.4 LED Waveform | 172 | | 15.5 LCD/LED Example | 173 | | 15.5.1 LCD Configuration Demo Program | | | 16 SERIAL INTERFACE (UART0) | 175 | | 16.1 Baud Rate of Serial Communication | 177 | | 17 SPI/TWI/UART SERIAL INTERFACE (USCI) | 179 | | 17.1 SPI | 183 | # Super High-speed 1T 8051 Core Flash MCU | 17.1.1 SPI Operation Related Registers | 184 | |-------------------------------------------------|-----| | 17.1.2 Signal Description | | | 17.1.3 Operating Modes | | | 17.1.4 Transfer Form | | | 17.2 TWI | | | 17.2.1 Signal Description | | | 17.2.1 Signal Description | | | 17.2.3 Slave Mode Operation Steps | | | 17.2.4 Master operating Mode | | | 17.2.5 Master Mode Operation Steps | | | 17.3 Serial Interface (UART) | | | 18 HIGH-SPEED ANALOG-TO-DIGITAL CONVERTER (ADC) | | | 18.1 ADC-related Registers | | | 18.2 ADC Conversion Steps | | | 19 ANALOG COMPARATOR | | | 19.1 Block Diagram of Analog Comparator | | | 20 CRC MODULE | 220 | | 20.1 CRC Check Operation Related Registers | 221 | | 21 MULTIPLIER-DIVIDER UNIT (MDU) | 227 | | 22 ELECTRICAL CHARACTERISTICS | 230 | | 22.1 Absolute Maximum Ratings | 230 | | 22.2 Recommended Operating Conditions | 230 | | 22.3 Flash ROM Characteristics | 231 | | 22.4 DC Characteristics | 231 | | 22.5 AC Characteristics | 236 | | 22.6 ADC Characteristics | 237 | | 22.7 Analog Comparator Characteristics | 239 | | 23 PACKAGE INFORMATION | 240 | | 24 REVISION HISTORY | 251 | | IMPORTANT NOTICE | 252 | # 3 Pin Description # 3.1 Pin Configuration SC95F7767 Pin Diagram Suitable for LQFP48 & QFN48 package Page 12 of 252 V0.1 SC95F7766 Pin Diagram Suitable for LQFP44 package Page 13 of 252 V0.1 SC95F7765 Pin Diagram Suitable for LQFP32 & QFN32 package Page 14 of 252 V0.1 SC95F7763 Pin Diagram Suitable for SOP28 & TSSOP28 package ### 3.1.1 48/44 Pin Definition | | Pin number | | | Die News | | | |----|------------|----|----|-------------------|------|------------------------------------------------------------------------------------------------| | 48 | 44 | 32 | 28 | Pin Name | Туре | Description | | 1 | 1 | - | | P0.2/T0/S22/USTX5 | I/O | P0.2: GPIO P0.2 T0: Timer/Counter 0 External Input S22: LCD/LED SEG22 USTX5: USCI5 MOSI/SDA/TX | | 2 | 2 | - | • | P0.3/T1/S23/USRX5 | I/O | P0.3: GPIO P0.3 T1: Timer/Counter 1 External Input S23: LCD/LED SEG23 | Page 15 of 252 V0.1 | | | | | | | USRX5: USCI5 MISO/RX | |----|----|---|----|----------------------|-------|-----------------------------------------------------------------------------------------------------| | 3 | 3 | 1 | 27 | P0.4/INT04/USCK0/S24 | I/O | P0.4: GPIO P0.4 INT04: Input 4 of external interrupt 0USCK0: USCI0 SCK S24: LCD/LED SEG24 | | 4 | 4 | 2 | 28 | P0.5/INT05/USTX0/S25 | I/O | P0.5: GPIO P0.5 INT05: Input 5 of external interrupt 0USTX0: USCI0 MOSI/SDA/TX S25: LCD/LED SEG25 | | 5 | 5 | 3 | 1 | P0.6/INT06/USRX0/S26 | I/O | P0.6: GPIO P0.6 INT06: Input 6 of external interrupt 0 USRX0: USCI0 MISO/RX S26: LCD/LED SEG26 | | 6 | 6 | 4 | 2 | P0.7/INT07/S27 | I/O | P0.7: GPIO P0.7 INT07: Input 7 of external interrupt 0 S27: LCD/LED SEG27 | | 7 | 7 | 5 | 3 | VSS | Power | Ground | | 8 | 8 | 6 | | P5.0/PWM00/OSCI | I/O | P5.0: GPIO P5.0 PWM00: PWM00 Output OSCI: 32K oscillator output | | 9 | 9 | 7 | - | P5.1/PWM01/OSCO | I/O | P5.1: GPIO P5.1 PWM01: PWM01 Output OSCO: 32K oscillator output | | 10 | 10 | 8 | - | P5.2/PWM02/RST | I/O | P5.2: GPIO P5.2<br>PWM02: PWM02 Output | Page 16 of 252 V0.1 | | | | | | | RST: Reset pin | |----|----|----|---|---------------------------------------|-------|------------------------------------------------------------------------------------------------| | 11 | 11 | 9 | - | P5.3/PWM03 | I/O | P5.3: GPIO P5.3<br>PWM03: PWM03 Output | | 12 | - | - | - | P5.4/T4EX/PWM41 | I/O | P5.4: GPIO P5.4 T4EX: External capture for Timer4 PWM41: PWM41 Output | | 13 | - | - | - | P5.5/USCK4/T4/PWM40 | I/O | P5.5: GPIO P5.5 USCK4: USCI4 SCK T4: Timer/Counter4 external input PWM40: PWM40 Output | | 14 | - | - | - | P4.7/USTX4 | I/O | P4.7: GPIO P4.7<br>USTX4: USCI4 MOSI/SDA/TX | | 15 | - | - | - | P4.6/USRX4 | I/O | P4.6: GPIO P4.6<br>USRX4: USCI4 MISO/RX | | 16 | 12 | 10 | 4 | VDD | Power | Power | | 17 | 13 | 11 | 5 | P4.5/USRX2/FLT | I/O | P4.5: GPIO P4.5 USRX2: MISO/RX of USCI2 FLT: PWM1 fault detection input pin | | 18 | 14 | 12 | 6 | P4.4/USTX2/CMPR | I/O | P4.4: GPIO P4.4 USTX2: MOSI/SDA/TX of USCI2 CMPR: The reference voltage of comparator input. | | 19 | 15 | 13 | 7 | P4.3/INT13/USCK2/PWM0<br>4/CMP3/AIN15 | I/O | P4.3: GPIO P4.3 INT13: Input 3 of external interrupt 1 | Page 17 of 252 V0.1 | | | | | | | USCK2: SCK of USCI2 PWM04: PWM04 Output CMP3: Analog comparator input channel 3 AIN15: ADC input channel 15 | |----|----|----|----|---------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------| | 20 | 16 | 14 | 8 | P4.2/INT12/PWM05/CMP2/<br>AIN14 | I/O | P4.2: GPIO P4.2 INT12: Input 2 of external interrupt 1 PWM05: PWM05 Output CMP2: Analog comparator input channel 2 AIN14: ADC input channel 14 | | 21 | 17 | 15 | 9 | P4.1/INT11/PWM06/CMP1/<br>AIN13 | I/O | P4.1: GPIO P4.1 INT11: Input 1 of external interrupt 1 PWM06: PWM06 Output CMP1: Analog comparator input channel 1 AIN13: ADC input channel 13 | | 22 | 18 | 16 | 10 | P4.0/INT10/PWM07/CMP0/<br>AIN12 | I/O | P4.0: GPIO P4.0 INT10: Input 0 of external interrupt 1 PWM07: PWM07 Output CMP0: Analog comparator input channel 0 AIN12: ADC input channel 12 | | 23 | 19 | - | - | P3.7/AIN11/C7 | I/O | P3.7: GPIO P3.7 AIN11: ADC Input Channel 11 C7: LCD/LED common output 7 | | 24 | 20 | - | - | P3.6/AIN10/C6 | I/O | P3.6: GPIO P3.6 AIN10: ADC input channel 10 | Page 18 of 252 V0.1 | | | | | | | C6: LCD/LED common output 6 | |----|----|----|----|--------------------|-----|--------------------------------------------------------------------------------------------| | 25 | 21 | - | - | P3.5/AIN9/C5 | I/O | P3.5: GPIO P3.5 AIN9: ADC input channel 9 C5: LCD/LED common output 5 | | 26 | 22 | - | - | P3.4/AIN8/C4 | I/O | P3.4: GPIO P3.4 AIN9: ADC input channel 8 C4: LCD/LED common output 4 | | 27 | 23 | 17 | 11 | P3.3/S0/C3 | I/O | P3.3: GPIO P3.3 S0: LCD/LED SEG 0 C3: LCD/LED common output 3 | | 28 | 24 | 18 | 12 | P3.2/S1/C2 | I/O | P3.2: GPIO P3.2 S1: LCD/LED SEG 1 C2: LCD/LED common output 2 | | 29 | 25 | 19 | 13 | P3.1/S2/C1 | I/O | P3.1: GPIO P3.1 S2: LCD/LED SEG 2 C1: LCD/LED common output 1 | | 30 | 26 | 20 | 14 | P3.0/S3/C0 | I/O | P3.0: GPIO P3.0 S3: LCD/LED SEG 3 C0: LCD/LED common output 0 | | 31 | 27 | 21 | 15 | P1.0/S4/T3EX/PWM31 | I/O | P1.0: GPIO P1.0 S4: LCD/LED SEG 4 T3EX: External capture for Timer3 PWM31: PWM31 Output | | 32 | 28 | 22 | 16 | P1.1/USRX1/S5 /tCK | I/O | P1.1: GPIO P1.1 | Page 19 of 252 V0.1 | | | | | T | | | |----|----|----------------------|-----|----------------------------------------|------|---------------------------------------------| | | | | | | | USRX1: MISO/RX of USCI1 | | | | | | | | S5: LCD/LED SEG 5 | | | | | | | | tCK: Programming and Emulation<br>Clock Pin | | | | | | | | P1.2: GPIO P1.2 | | 33 | 29 | 23 | 17 | P1.2/USCK1/S6 | I/O | USCK1: SCK of USCI1 | | | | | | | | S6: LCD/LED SEG 6 | | | | | | | | P1.3: GPIO P1.3 | | | | | | | | USTX1: MOSI/SDA/TX of USCI1 | | 34 | 30 | 24 | 18 | P1.3/USTX1/S7/tDIO | I/O | S7: LCD/LED SEG 7 | | | | | | | | tDIO: Programming and Emulation | | | | | | | | Data Pin | | | | | | | | P1.4: GPIO P1.4 | | | | D4 4/INIT44/AINI0/00 | 1/0 | INT14: Input 4 of external interrupt 1 | | | | 35 | 31 | - | - | P1.4/INT14/AIN0/S8 | I/O | AIN0: ADC input channel 0 | | | | | | | | S8: LCD/LED SEG 8 | | | | | | | | P1.5: GPIO P1.5 | | | | | | | | INT15: Input 5 of external interrupt 1 | | 36 | 32 | - | - | P1.5/INT15/AIN1/S9 | I/O | AIN1: ADC input channel 1 | | | | | | | | S9: LCD/LED SEG 9 | | | | | | | | | | | | | | | | P1.6: GPIO P1.6 | | 37 | 33 | - | _ | P1.6/INT16/AIN2/S10 | I/O | INT16: Input 6 of external interrupt 1 | | | | | | | | AIN2: ADC Input Channel 2 | | | | | | | | S10: LCD/LED SEG10 | | | | | | | | P1.7: GPIO P1.7 | | 38 | 34 | - | - | P1.7/INT17/AIN3/S11 | I/O | INT17: Input 7 of external interrupt 1 | | | | | | | | AIN3: ADC Input Channel 3 | | | | | | | | S11: LCD/LED SEG11 | | 39 | 35 | 25 | 19 | P2.0/INT20/RX0/AIN4/S12 | I/O | P2.0: GPIO P2.0 | | | | | - | | ., 5 | INT20: Input 0 of external interrupt 2 | Page 20 of 252 V0.1 | | | | | | | RX0: UART0 Receiver AIN4: ADC Input Channel 4 S12: LCD/LED SEG12 P2.1: GPIO P2.1 INT21: Input 1 of external interrupt 2 | |----|----|----|----|------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 40 | 36 | 26 | 20 | P2.1/INT21/TX0/AIN5/S13 | I/O | TX0: UART0 Transmitter AIN5: ADC Input Channel 5 S13: LCD/LED SEG13 | | 41 | 37 | 27 | 21 | P2.2/INT22/AIN6/S14/T2E<br>X/PWM21 | I/O | P2.2: GPIO P2.2 INT22: Input 2 of external interrupt 2 AIN6: ADC Input Channel 6 S14: LCD/LED SEG14 T2EX: External capture for Timer2 PWM21: PWM21 Output | | 42 | 38 | 28 | 22 | P2.3/INT23/AIN7/S15/T2/P<br>WM20 | I/O | P2.3: GPIO P2.3 INT23: Input 3 of external interrupt 2 AIN7: ADC Input Channel 7 S15: LCD/LED SEG15 T2: Timer/Counter2 external input PWM20: PWM20 Output | | 43 | 39 | 29 | 23 | P2.4/S16/T3/PWM30 | I/O | P2.4: GPIO P2.4 S16: LCD/LED SEG 16 T3: Timer/Counter3 external input PWM30: PWM30 Output | | 44 | 40 | 30 | 24 | P2.5/S17/USCK3 | I/O | P2.5: GPIO P2.5<br>S17: LCD/LED SEG 17<br>USCK3:USCI3 SCK | | 45 | 41 | 31 | 25 | P2.6/S18/USTX3 | I/O | P2.6: GPIO P2.6<br>S18: LCD/LED SEG 18<br>USTX3: USCI3 MOSI/SDA/TX | Page 21 of 252 V0.1 | 46 | 42 | 32 | 26 | P2.7/S19/USRX3 | I/O | P2.7: GPIO P2.7<br>S19: LCD/LED SEG 19<br>USRX3: USCI3 MISO/RX | |----|----|----|----|----------------|-----|----------------------------------------------------------------| | 47 | 43 | - | - | P0.0/S20 | I/O | P0.0: GPIO P0.0<br>S20: LCD/LED SEG 20 | | 48 | 44 | - | - | P0.1/S21/USCK5 | I/O | P0.1: GPIO P0.1<br>S21: LCD/LED SEG 21<br>USCK5: USCI5 SCK | # 4 Inner Block Diagram Page 22 of 252 V0.1 #### LVR reset LVD Internal Controller 256 bytes RAM WDT External 32kHz LRC 8K bytes RAM WAKECNT Controller PWM&LCD 32kHz X'OSC 80 bytes RAM Regulator clock 32MHz 6 Kbytes Clock **EEPROM** Controller Voltage Reference 2.048V 1.024V ADC LDROM ADC 2.4V REG Controller 0/1/2/4K 1T 8051 CORE CMP **CMP** Controller **UART** 128 Kbytes SPI BandGap TWI Program ROM Voltage x6 Reference (Flash) **UART** TIMER0 LDO IAP Option: TIMER1 Power Manager 0/1/2K/ALL TIMER2 TIMER3 LCD/LED Driver TIMER4 **PWM** I/O INT Interrupt **IO PADS** Interrupt Controller SC95F776X BLOCK DIAGRAM Page 23 of 252 V0.1 ### 5 Flash ROM and SRAM The Flash ROM of SC95F776X is divided into five regions: APROM/LDROM/EEPROM/User ID/Unique ID, as shown in the following figure: #### 5.1 APROM and LDROM APROM and LDROM are two independent pieces of hardware that divide ROM by LDSIZE[1:0]. They are distinguished by the extended address "00" and "03" set by IAPADE register. They can be programmed and erased by SC LINK PRO. - The extended address of the APROM area is "00". The maximum size of the area is 128 Kbytes. It supports IAP (In Application Programming) and APROM area allowed IAP operation in Flash can be set to 0K/1K/2K/All APROM by Code Option. - The extended address of LDROM area is "03", area size 0~4 Kbytes optional. IAP on LDROM is not allowed. The SC95F776X has 128 Kbytes of Flash ROM, the address is (00)00000H~(00)1FFFFH, "00" in brackets is the extended address, which is set by the IAPADE register. Flash ROM can be programmed and erased by SC LINK PRO provided by SinOne. The characteristics of this 128 Kbytes Flash ROM are as follows: Divided into 256 sectors,512 bytes per sector Can be rewritten 100,000 times Page 24 of 252 V0.1 # Super High-speed 1T 8051 Core Flash MCU - The data written-in has more than 100-year preservation life in the ambient temperature of 25°C - In ICP mode, BLANK, PROGRAM, VERIFY, ERASE and READ functions are supported. The READ function is only valid for ICs with no security encryption function enabled - Secure Encryption: Optionally enable APROM (128 Kbytes Flash ROM) and LDROM secure encryption - Support IAP (In Application Programming). The 128 Kbytes Flash ROM of the SC95F776X is divided into four banks. The structure is as follows: The LDROM and IAP operating areas are defined as follows: Page 25 of 252 V0.1 # **Super High-speed 1T 8051 Core Flash MCU** The switch between the four banks of SC95F776X Flash ROM can be implemented through ROMBNK registers: ### ROMBNK (DFH) Program Bank switch register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|--------------|--------------|---|---|-------------|-------------| | Bit<br>Mnemonic | - | - | DATABN<br>K1 | DATABN<br>K0 | - | - | ROMBN<br>K1 | ROMBN<br>K0 | | R/W | - | | R/W | R/W | - | - | R/W | R/W | | POR | х | x | 0 | 1 | Х | х | 0 | 1 | | Bit<br>number | Bit Mnemonic | Description | |---------------|---------------|------------------------------------------------------------------------------------------------------------| | 5~4 | DATABNK [1:0] | Target data address Bank switch bit, controls ROM high 32K address target MOVC and IAP point to the region | | | | 00: Both MOVC and IAP programing are directed at Bank0, where the IAP address range is only 32K | | | | 01: Both MOVC and IAP programing are directed at Bank0 and Bank1 | | | | 10: Both MOVC and IAP programing are directed at Bank0 and Bank2 | | | | 11: Both MOVC and IAP programing are directed at Bank0 and Bank3 | | | | Note: This control bit is only valid when IAPADE=0x00 | | 1~0 | ROMBANK[1:0] | Operation Bank switch bit: | Page 26 of 252 V0.1 ### Super High-speed 1T 8051 Core Flash MCU | | | 00: Instruction for Bank0; | |---------|---|--------------------------------------| | | | 01: Instruction for Bank0 and Bank1; | | | | 10: Instruction for Bank0 and Bank2; | | | | 11: Instruction for Bank0 and Bank3; | | 7~6,3~2 | - | reserved | SC95F776X has a maximum addressing interval of 64 Kbytes, i.e., two banks, where Bank0 is fixed (interrupt vector etc in Bank0 to prevent disruption after jump) and bank1-3 can be switched. The jump mode of Bank1~3 is as follows: close the interrupt in the user program → jump to Bank0 (the code of switching Bank is stored in Bank0) → modify ROMBNK #### 5.1.1 Flash ROM Sectors The SC95F776X has 128 Kbytes of Flash ROM divided into 256 sectors, each sector is 512 bytes, the sector to which the target address belongs will be forcibly erased by the programmer during writing, and then write data; When the user writes, must erasing it before writing. SC95F776X 128 Kbytes Flash ROM Sectors # 5.2 6K bytes independent EEPROM The SC95F776X has 6 Kbytes of independent EEPROM, the address is (02)000H ~ 17FFH, "02" in brackets is the extended address, which is set by the IAPADE register. Independent EEPROM can be rewritten 100,000 times and the data written-in has more than 100-year preservation life in the ambient temperature of 25°C. EEPROM supports blank checking, programming, verification, erasing and reading functions. EEPROM divided into 12 sectors,512 bytes per sector Page 27 of 252 V0.1 #### SC95F776X EEPROM Sectors Notes: EEPROM can be rewritten 100,000 times. User should not exceed the rated burn times of EEPROM, otherwise there will be exceptions! ## 5.3 96 bits Unique ID Area The SC95F776X provides an independent Unique ID area. A 96-bit unique code can be pre-programmed before leaving the factory to ensure the uniqueness of the chip. The only way for the user to obtain the serial number is to read the relative address $(01)0260H\sim(01)026BH$ through the IAP instruction. The Unique ID range is $(01)0260H\sim(01)026BH$ , the "01" in brackets indicates the extended address which is set by the IAPADE register. The specific operation method is as follows: #### IAPADE (F4H) IAP Write to extended address register (Read/Write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----------------|-----|---------------|-----|-----|-----|-----|-----|-----|--| | Bit<br>Mnemonic | | IAPADER[7: 0] | | | | | | | | | R/W | | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Page 28 of 252 V0.1 # **Super High-speed 1T 8051 Core Flash MCU** | Bit number | Bit Mnemonic | Description | |------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7~0 | IAPADER[7: 0] | IAP Extended address: 0x00: Both MOVC and IAP are for APROM 0x01: For the unique ID area, read and write operations are not allowed, otherwise it may cause an exception! 0x02: Both MOVC and IAP are for EEPROM 0x03: This parameter takes effect only when the LDROM program is operating. Programs running in the LDROM region are allowed to perform MOVC operations on the LDROM program region. Note: LDROM operation permission is only for MOVC operation, prohibit IAP operation on LDROM, otherwise it will cause unpredictable exceptions! | # 5.3.1 Unique ID Read Operating Demo Program In C Language ``` #include "intrins.h" unsigned char UniqueID [12];//store UniqueID unsigned char code * POINT =0x0260; unsigned char i; EA = 0; // Disable the global interrupt IAPADE = 0X01; // Expand address 0x01, select Unique ID area for(i=0;i<12;i++) UniqueID [i]= *( POINT+i); // Read the value of UniqueID } IAPADE = 0X00; // Expand address 0x00, return to Code area // Enable global interrupt EA = 1; ``` ### 5.4 User ID Area Page 29 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU User ID area, whose extended address is (01), is written for user in the factory. Users can read the User ID area, but cannot write the User ID area. ## 5.5 Programming The SC95F776X's Flash ROM can be programmed through tDIO, tCK, VDD, VSS, the specific connection relationship is as follows: ICP mode Flash Writer programming connection diagram tDIO,tCK is a 2-wire JTAG programming and emulation signal line. Users can configure the mode of these two ports through the Code Option when programming: JTAG Specific Mode and Normal Mode (JTAG specific port is invalid). #### 5.5.1 JTAG Specific Mode tDIO,tCK are specific port for programming and emulation, and other functions multiplexed with it are not available. This mode is generally used in the online debugging stage, which is convenient for users to simulate and debug. After the JTAG special mode takes effect, the chip can directly enter the programming or emulation mode without powering on and off again. #### 5.5.2 Normal Mode (JTAG specific port is invalid) The JTAG function is not available, and other functions multiplexed with it can be used normally. This mode can prevent the programming port from occupying the MCU pins, which is convenient for users to maximize the use of MCU resources. Note: When the invalid configuration setting of the JTAG dedicated port is successful, the chip must be completely powered off and then on again to enter the programming or emulation mode, which will affect the programming and emulation in the live mode. SinOne recommends that users select the invalid configuration of the JTAG dedicated port during mass production and programming, and select the JTAG mode during the development and debugging phase. #### **Code Option register:** #### OP\_CTM1 (C2H@FFH) Code Option register1 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |------------|---|---|---|---|---|---|---|---|--| |------------|---|---|---|---|---|---|---|---|--| Page 30 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU | Bit<br>Mnemonic | VREF | S[1: 0] | OP_BL | DISJTG | IAPS[1: 0] | | LDSIZE[1:0] | | |-----------------|------|---------|-------|--------|------------|-----|-------------|--| | R/W R | | | POR | n | n | n | n | n | n | n | | | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------------------------------------------------------------------------------------------------------------------| | 4 | DISJTG | IO/JTAG port switching control | | | | 0 : JTAG mode is enabled, P1.1 and P1.3 can only be used as tCK/tDIO. Recommended settings during R&D and commissioning | | | | 1 : Normal mode (Normal), JTAG function is invalid. The recommended setting for the mass production burning stage. | # 5.6 In Application Programming (IAP) Application Programming (IAP) operations can be carried out in the APROM of SC95F776X (0K, 1K, 2K, or all APROM ranges are optional) and 6K bytes EEPROM. Users can implement remote program updates through IAP operations. You can also obtain Unique ID field or User ID field information via IAP reads. Before IAPS write data, you must erase the Sector to which the target address belongs. The length of a Sector is 512 bytes. Flash ROM is divided into 256 sectors from (00)0000H~(00)1FFFFH. The "00" in brackets is the expanded address set by the IAPADE register: SC95F776X 128 Kbytes Flash ROM Sectors Page 31 of 252 V0.1 #### NOTE: - 1. During the IAP erase/write process, the CPU holds the program counter, and after the IAP erase/write is complete, the program counter continues to execute subsequent instructions. - 2. IAP operation in APROM area has certain risks, users need to take corresponding security measures in the software, if improper operation may cause user program rewriting! This feature is not recommended unless it is required by the user (for example, for remote application updates). - 3. The EEPROM erasure count is 100,000. Do not exceed the rated EEPROM erasure count; otherwise, an exception may occur. The user can select the IAP region range of APROM through Customer Option during programming, or set the IAP region of APROM through IAPS control bit in the program. The relevant registers are as follows: #### OP\_CTM1 (C2H@FFH) Code Option Register 1(Read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------------|-----|-------|--------|------------|-----|-------------------|---| | Bit<br>Mnemonic | VREFS[1: 0] | | OP_BL | DISJTG | IAPS[1: 0] | | LDSIZE[1:0]-<br>- | | | R/W -R<br>- | | | POR | n | n | n | n | n | n | n | n | | Bit Number | Bit Mnemonic | Description | |------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------| | 3~2 | IAPS[1: 0] | IAP spatial range selection | | | | 00: Full Flash ROM not allows IAP operation | | | | 01: Last 1K Flash ROM allows IAP operation | | | | 10: Last 2K Flash ROM allows IAP operation | | | | 11: Full Flash ROM allows IAP operation | | | | Note: | | | | 1. The above setting items are invalid in BootLoader mode. The BootLoader program can perform IAP operation on the entire Flash ROM area. | Page 32 of 252 V0.1 | | 2. LDROM does not allow IAP operation under any circumstances. | |--|----------------------------------------------------------------| | | | # 5.6.1 IAP Operation Related Register | Symbol | Address | Description | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | POR | |--------|---------|----------------------------------------|--------------|---------------|------------|-----------|---|-----------|-----------|--------|-----------| | IAPKEY | F1H | Data protection register | | IAPKEY[7: 0] | | | | 00000000b | | | | | IAPADL | F2H | IAP write address<br>low register | | IAPADR[7: 0] | | | | 0000000b | | | | | IAPADH | F3H | IAP write address<br>high register | | IAPADR[15: 8] | | | | | 00000000b | | | | IAPADE | F4H | IAP write to extended address register | | IAPADER[7: 0] | | | | | 00000000b | | | | IAPDAT | F5H | IAP data register | IAPDAT[7: 0] | | | 00000000b | | | | | | | IAPCTL | F6H | IAP control register | BTL<br>D | | SERAS<br>E | PRG | - | - | CMD | [1: 0] | 0x00xx00b | ## IAPKEY (F1H) Data Protection Register (Read/Write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|--------------|-----|-----|-----|-----|-----|-----|-----| | Bit<br>Mnemonic | IAPKEY[7: 0] | | | | | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit Number | Bit Mnemonic | Description | |------------|--------------|-------------| |------------|--------------|-------------| Page 33 of 252 V0.1 | 7~0 | IAPKEY[7: 0] | Open IAP function and operation time limit setting | |-----|--------------|----------------------------------------------------------------------------------------------------| | | | Write a value n greater than or equal to 0x40, which represents: | | | | 1.Enable the IAP function; | | | | 2.If no IAP write command is received after n system clocks, the IAP function is turned off again. | ### 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 | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit Number | Bit Mnemonic | Description | |------------|--------------|------------------------------------------| | 7~0 | IAPADR[7: 0] | IAP writes the low 8 bits of the address | # IAPADH (F3H) IAP Write Address High Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|---------------|-----|-----|-----|-----|-----|-----| | Bit<br>Mnemonic | | IAPADR[15: 8] | | | | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Page 34 of 252 V0.1 | Bit Number | Bit Mnemonic | Description | |------------|---------------|-------------------------------------------| | 7~0 | IAPADR[15: 8] | IAP writes the high 8 bits of the address | # IAPADE (F4H) IAP Write to Extended Address Register (Read/Write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|---------------|-----|-----|-----|-----|-----|-----| | Bit<br>Mnemonic | | IAPADER[7: 0] | | | | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit Number | Bit Mnemonic | Description | |------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7~0 | IAPADER[7: 0] | IAP extended address: | | | | 0x00: Both MOVC and IAP are for code | | | | 0x01: The Unique ID area is read but cannot be written 0x02: Both MOVC and IAP are for independent EEPROM | | | | 0x03: MOVC is performed in the LDROM region (Note: only MOVC can be used, not IAP, this item is only valid for LDROM operation, APROM operation this item is not valid!) | | | | Other: reserved | # IAPDAT (F5H) IAP Data Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|--------------|---|---|---|---|---|---| | Bit<br>Mnemonic | | IAPDAT[7: 0] | | | | | | | Page 35 of 252 V0.1 # **Super High-speed 1T 8051 Core Flash MCU** | R/W |-----|-----|-----|-----|-----|-----|-----|-----|-----| | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit<br>Mnemonic | R/W | | Description | | |------------|-----------------|-----|---------------------|-------------|--| | 7~0 | IAPDAT[7:0] | R/W | Data written by IAP | | | #### IAPCTL (F6H) IAP Control register (Read/Write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------|------|---|--------|-----|---|---|------|-------| | Bit Mnemonic | BTLD | = | SERASE | PRG | - | - | CMD[ | 1: 0] | | R/W | R/W | - | RW | R/W | - | - | R/W | R/W | | POR | 0 | Х | 0 | 0 | х | х | 0 | 0 | ## **5.6.2 IAP Operation process** Please refer to the "SC95FXX6X\_SC95FXX1XB IAP Operation Library Documentation Pack" for the IAP operation process of SC95F776X. ## 5.6.3 IAP Operating Demo Program In C Language The header files shared by the following routines are as follows: #include "intrins.h" unsigned int IAP\_Add; unsigned char IAP\_Data; unsigned char code \* POINT =0x0000; IAP operation: read data: Page 36 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU EA = 0; // Close global interrupt IAPADE = 0X00; //The extended address is 0x00, selectFlash ROM IAP\_Data = \*( POINT+IAP\_Add); //Read the value of IAP\_Add toIAP\_Data EA = 1; // Open global interrupt #### IAP operation: erase and write data: Please refer to "SC95FXX6X\_SC95FXX1XB IAP Operation Library Kit" if you want to implement IAP erasable operation. #### 5.6.4 IAP Operation notes - 1. The user must erase the target sector before writing. - 2. IAP operation in APROM area has certain risks, users need to take corresponding security measures in the software, if improper operation may cause user program rewriting! This feature is not recommended unless required (for remote application updates, for example); - 3. When programming IC, if "APROM zone prevents IAP operation" is selected through Code Option, then IAPADE [7:0]=0x00 (APROM zone is selected), IAP cannot be operated, that is, data cannot be written, data can only be read by MOVC instruction; - 4. When IAPADE is not 0x00, the MOVC and write target is non-APROM region. At this time, if there is an interrupt and MOVC operation occurs in the interrupt, the result of MOVC will be wrong and the program will run abnormally. To avoid this situation, if IAPADE is not 0x00 during IAP operation, it is important to turn off total interrupt (EA=0) before operation, and set IAPADE = 0x00 after operation before turning on total interrupt (EA=1); - 5. During the IAP wipe/write process, the CPU holds the program counter, and the program counter only continues to execute subsequent instructions after the IAP wipe/write is complete; - 6. The EEPROM erasure count is 100,000. Do not exceed the rated EEPROM erasure count; otherwise, an exception may occur! Page 37 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU #### 5.7 BootLoader The LDROM is used to store the bootLoader code. LDROM supports blank checking (BLANK), programming (PROGRAM), verifying (VERIFY), erasing (ERASE) and reading (READ) functions in ICP mode. Users can realize ISP (In System Programing) function through LDROM: when ISP is executed, IC runs the boot code In LDROM area. When the boot code is executed, IC receives new program code through serial port, and then programs the received code into user code area through IAP command. The LDROM has four address ranges: - (03)0000H~(03)0000H (without LDROM) - (03)0000H~(03)03FFH (1K) - (03)0000H~(03)07FFH (2K) - (03)0000H~(03)0FFFH (4K) Where: "03" in the brackets above indicates the extended address, which is set by LDSIZE [1:0]. ## 5.7.1 BootLoader Mode operation related registers #### OP\_CTM1 (C2H@FFH) Code Option Register1 (Read/Write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|---------|-------|--------|------|--------|-------|---------| | Bit<br>Mnemonic | VREF | S[1: 0] | OP_BL | DISJTG | IAPS | [1: 0] | LDSIZ | E [1:0] | | R/W Only | read | | POR | n | n | n | n | n | n | n | n | | Bit Number | Bit Mnemonic | Description | |------------|--------------|---------------------------------------------------------------------------| | 5 | OP_BL | Program run area control bit 0: After the chip is reset, it enters APROM | Page 38 of 252 V0.1 | | | 1: After the chip is reset, | it enters LDROM | | | | |-----|--------------|----------------------------------------------------------------------------------------------|------------------------------------------|----------------|--|--| | | | ① The MOVC and IAP | restrictions for APROM are | as follows: | | | | | | Operation | Is it operable? | | | | | | | LDROM MOVC | x | | | | | | | APROM MOVC | <b>V</b> | | | | | | | LDROM IAP | × | | | | | | | APROM IAP | V | | | | | | | ② The MOVC and IAP restrictions for LDROM are as follows: | | | | | | | | Operation Is it operable? | | | | | | | | LDROM MOVC | | $\sqrt{}$ | | | | | | APROM MOVC | | $\checkmark$ | | | | | | LDROM IAP | | × | | | | | | ALL APROM IAP, not | restricted by IAPRANGE | √ | | | | 1~0 | LDSIZE [1:0] | LDROM space range se | lection | | | | | | | 00: None LDROM, the A | PROM address is 00000H- | -1FFFFH | | | | | | 01: The last 1K APROM area of the Flash ROM is LDROM, and the APROM address is 00000H~1FBFFH | | | | | | | | 10: The last 2K APROM APROM address is 0000 | area of the Flash ROM is L<br>00H~1F7FFH | .DROM, and the | | | | | | 11: The last 4K APROM APROM address is 0000 | area of the Flash ROM is L<br>00H~1EFFFH | .DROM, and the | | | | | | NOTE: LDROM not allo | w IAP operation in anywa | ıys | | | ## IAPKEY (F1H) Data Protection Register (Read/Write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|---|---|---|---|---|---|---|---| | | | | | | | | | | Page 39 of 252 V0.1 | 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] | Open IAP and operation time limit setting | | | | | Write a value n greater than or equal to 0x40, which represents: | | | | | 1. Enable the IAP; | | | | | 2. If no IAP write command is received after n system clocks, the IAP is turned off again. | | ## IAPADL (F2H) IAP Write Low Address Register (Read/Write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|-----|-----|-------|----------|-----|-----|-----| | Bit<br>Mnemonic | | | | IAPAD | PR[7: 0] | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|------------------------------------------| | 7~0 | IAPADR[7: 0] | IAP writes the low 8 bits of the address | Page 40 of 252 V0.1 ### IAPADH (F3H) IAP Write High Address Register (Read/Write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|---------------|-----|-----|-----|-----|-----|-----| | Bit<br>Mnemonic | | IAPADR[15: 8] | | | | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|---------------|--------------------------------------------| | 7~0 | IAPADR[15: 8] | IAP writes the upper 8 bits of the address | ## IAPADE (F4H) IAP Write to Extended Address Register (Read/Write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|-----|-----|--------|----------|-----|-----|-----| | Bit<br>Mnemonic | | | | IAPADI | ER[7: 0] | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7~0 | IAPADER[7: 0] | IAP extended address: 0x00: Both MOVC and IAP are for Flash ROM 0x01: The Unique ID area is read but cannot be written 0x02: Both MOVC and IAP are for independent EEPROM | Page 41 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU | | 0x03: MOVC is performed in the LDROM region ( <b>Note: only MOVC</b> can be used, not IAP, this item is only valid for LDROM operation, APROM operation this item is not valid!) | |--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Other: reserved | #### IAPDAT (F5H) IAP Data Register (Read/Write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|--------------|-----|-----|-----|-----|-----|-----|-----| | Bit<br>Mnemonic | IAPDAT[7: 0] | | | | | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|---------------------| | 7~0 | IAPDAT[7:0] | Data written by IAP | ## IAPCTL (F6H) IAP Control Register (Read/Write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------|------|---|--------|-----|---|---|-----------|-----| | Bit Mnemonic | BTLD | - | SERASE | PRG | - | - | CMD[1: 0] | | | R/W | R/W | 1 | R/W | R/W | - | - | R/W | R/W | | POR | 0 | х | 0 | 0 | х | х | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------| |------------|--------------|-------------| Page 42 of 252 V0.1 | 7 | BTLD | BootLoader control bit | |---|------|-------------------------------------------------------------------------------------| | | | 0: The program starts to run from the main program area (main program) after Reset; | | | | 1: The program starts to run from the BootLoader area after Reset | #### PCON (87h) Power Management Control Register (write only, \*not readable\*) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---------------|---|---|---|---------------|---|---------------|---------------| | Bit<br>Mnemonic | SMOD | | - | - | RST | | STOP | IDL | | R/W | write<br>only | - | - | • | write<br>only | - | write<br>only | write<br>only | | POR | 0 | х | х | х | n | х | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|----------------------------------------------------------------| | 3 | RST | Software reset control bit: | | | | Write status: | | | | 0: The program runs normally; | | | | 1: The CPU resets immediately after this bit is written to "1" | #### **Bootloader Notes:** - 1. The user must erase the target sector before writing LDROM; - For the specific operation method, please refer to the description document "SinOne hardware BootLoader Function Implementation Application Guide" provided by SinOne. ## 5.8 Encryption Users can choose whether to encrypt the SC95F776X's ROM through the settings on the computer program: Page 43 of 252 V0.1 - 1. If the encryption function is disabled, users can read the last data written in APROM and LDROM by SC LINK; - 2. If the encryption function is enabled, the data written in APROM (128 Kbytes Flash ROM) and LDROM will never be read from outsid. It is recommended to enable the encryption function during mass production; - 3. The only way to release security encryption is to re-programming - 4. The encryption has no effect on iap read and write operation For the specific operation method, please refer to the chapter of Secure Encryption and Reading in the "SOC LINK Series Programmer & Simulator User Manual". Page 44 of 252 V0.1 ## **5.9 Code Option Area (User Programming Settings)** | Symbol | OPINX<br>Address | Instructions | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | |-------------|------------------|------------------------------|---------------|-----------|-----------|------------|------------|------------|-------|---------| | OP_CTM<br>0 | C1H@FF<br>H | Code Option register 0 | ENW<br>DT | ENX<br>TL | SCLK | S[1: 0] | DISR<br>ST | DISL<br>VR | LVRS | S[1: 0] | | OP_CTM<br>1 | C2H@FF<br>H | Code Option register 1 | | | OP_<br>BL | DISJ<br>TG | IAPS | [1: 0] | LDSIZ | E[1:0] | | OP_HRC<br>R | 83H@FF<br>H | System clock change register | OP_HRCR[7: 0] | | | | | | | | | IFB Address | Symbol | Write<br>read | Instructions | |--------------|-------------|---------------|-----------------------------------------------------------------| | OP_CTM0[7] | ENWDT | R/W | WDT Switch | | | | | 0: WDT invalid | | | | | WDT valid (WDT stops counting during IAP execution) | | OP_CTM0[6] | ENXTL | R/W | External 32K crystal selector switch | | | | | 0: External 32K crystal Interface disable, P5.0 and P5.1 valid | | | | | 1: External 32K crystal Interface enable, P5.0 and P5.1 invalid | | OP_CTM0[5~4] | SCLKS [1:0] | R/W | System clock frequency selection bits | | | | | 00: System clock frequency is HRC frequency divided by 1; | | | | | 01: System clock frequency is HRC frequency divided by 2; | | | | | 10: System clock frequency is HRC frequency divided by 4; | | | | | 11: System clock frequency is HRC frequency divided by 8; | Page 45 of 252 V0.1 | | only | IO/RST Selection bit 0: configure P5.2 as Externa | al Reset input pin | | | | | |--------------------------|------|---------------------------------------------------------|--------------------|--|--|--|--| | | | 1: configure P5.2 as GPIO | | | | | | | OP_CTM0[2] DISLVR | R/W | LVR control bit | | | | | | | | | 0: LVR valid | | | | | | | | | 1: LVR invalid | | | | | | | OP_CTM0[1~0] LVRS [1:0] | R/W | LVR voltage selection cor | ntrol | | | | | | | | 11: 4.3V reset | | | | | | | | | 10: 3.7V reset | | | | | | | | | 01: 2.9V reset | | | | | | | | | 00: 1.9V reset | | | | | | | OP_CTM1[7~6] VREFS [1:0] | R/W | Reference voltage selection | on | | | | | | | | 00: Configure ADC VREF a | s VDD; | | | | | | | | 01: Configure ADC VREF a | s internal 2.048V | | | | | | | | 10: Configure ADC VREF a | s internal 1.024V | | | | | | | | 11: Configure ADC VREF a | s internal 2.4V | | | | | | OP_CTM1[5] OP_BL | R/W | Program run area control | bit | | | | | | | | 0: After the chip is reset, it e | enters APROM | | | | | | | | 1: After the chip is reset, it e | enters LDROM | | | | | | | | The MOVC and IAP restrictions for APROM are as follows: | | | | | | | | | Operation | Is it operable? | | | | | | | | LDROM MOVC | х | | | | | | | | APROM MOVC | √ | | | | | Page 46 of 252 V0.1 | | | | LDROM IAP | × | | | | | |--------------|-------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-------------------|--|--|--| | | | | APROM IAP | | | | | | | | | | 2. The MOVC and IAP restrictions for LDROM are as follows: | | | | | | | | | | Operation | | Is it operable? | | | | | | | | LDROM MOVC | LDROM MOVC √ | | | | | | | | | APROM MOVC | | 1 | | | | | | | | LDROM IAP | LDROM IAP | | | | | | | | | ALL APROM IAP, not res | tricted by IAPRANGE | √ | | | | | OP_CTM1[4] | DISJTG | | IO/JTAG Port switching control or JTAG mode is enabled, For the second of the second of the switching control or s | P1.1 and P1.3 can only be | used as tCK/tDIO. | | | | | OP_CTM1[3~2] | IAPS[1:0] | | IAP spatial range selection 00: All Flash ROM not allows IAP operation 01: Last 1K Flash ROM allows IAP operation 10: Last 2K Flash ROM allows IAP operation 11: All Flash ROM allows IAP operation | | | | | | | | | | <ol> <li>Note:</li> <li>The preceding Settings are invalid in BootLoader mode, and the BootLoader program can perform IAP operations on the entire APROM region</li> <li>LDROM does not allows IAP operation</li> </ol> | | | | | | | OP_CTM1[1:0] | LDSIZE[1:0] | | LDROM space range selection | | | | | | | | | only | 00: None LDROM, the APROM address is 00000H~1FFFFH | | | | | | Page 47 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU | | | | 01: The last 1K APROM APROM address is 0000 | area of the Flash ROM is LDROM, and the 0H~1FBFFH | |---------|--------------|-----|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------| | | | | 10: The last 2K APROM APROM address is 0000 | area of the Flash ROM is LDROM, and the 0H~1F7FFH | | | | | 11: The last 4K APROM APROM address is 0000 | area of the Flash ROM is LDROM, and the 0H~1EFFFH | | | | | NOTE: LDROM not allow | w IAP operation in anyways | | OP_HRCR | OP_HRCR[7:0] | R/W | HRC frequency change | register | | | | | | h-frequency oscillator frequency f <sub>HRC</sub> by is register, and then change the system clock | | | | | | PP_HRCR[7: 0] after power-on OP_HRCR[s] is a re that fHRC is 32MHz, OP_HRCR[s] of each IC | | | | | fsys of the IC can b | ue is OP_HRCR[s], the system clock frequency se set to an accurate 32/16/8/4MHz through the OP_HRCR [7: 0] changes by 1, the fsys frequency 18% | | | | | The relationship between as follows: | OP_HRCR [7: 0] and fsys output frequency is | | | | | OP_HRCR [7: 0]<br>Value | fsys actual output frequency (32M as an example) | | | | | OP_HRCR [s]-n | 32000*(1-0.18%*n)kHz | | | | | | | | | | | OP_HRCR [s]-2 | 32000*(1-0.18%*2) = 31 884.8kHz | | | | | OP_HRCR [s]-1 | 32000*(1-0.18%*1) = 31 942.4kHz | | | | | OP_HRCR [s] | 32000kHz | | | | | OP_HRCR [s]+1 | 32000*(1+0.18%*1) = 32 057.6kHz | | | | | OP_HRCR [s]+2 | 32000*(1+0.18%*2) = 32 115.2kHz | Page 48 of 252 V0.1 | OP_HRCR [s]+n | 32000*(1+0.18%*n)kHz | |--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | of the high-frequency of the user corrects the H | value of IC after each power-on is the value scillator frequency fHRC closest to 32MHz; RC value after each power-on so that the ency fSYS works at the user's desired | | | e reliable operation of IC, the highest IC should not exceed 10% of 32MHz, i.e. | | 3. Confirm that the char functions. | nge of HRC frequency will not affect other | ### **5.9.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 | Instructions | | POR | |--------|---------|-----------------|-------------|-----------| | OPINX | FEH | Option pointer | OPINX[7: 0] | 00000000b | | OPREG | FFH | Option register | OPREG[7: 0] | nnnnnnnb | The OPINX register stores the address of the related OPTION register when operating the Option related SFR, and the OPREG register stores the corresponding value. For example: To set ENWDT (OP\_CTM0.7) to 1, the specific operation method is as follows: C language example: OPINX = 0xC1; // Write the address of OP\_CTM0 to the OPINX register OPREG |= 0x80; // Set 1 for OP\_CTM0.7 Assembly language example: Page 49 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU MOV OPINX,#C1H ; Write the address of OP\_CTM0 to the OPINX register ORL OPREG,#80H ; Set 1 for OP\_CTM0.7 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.10 SRAM** The SRAM structure of the SC95F776X is as follows: The SRAM of the SC95F776X MCU is divided into internal 256 bytes RAM, external 8192 bytes RAM and 80 bytes PWM&LCD RAM. The address range of the internal RAM is 00H~FFH, where the high 128 bytes (address 80H~FFH) can only be indirectly addressed, and the low 128 bytes (address 00H~7FH) can be directly or indirectly addressed. The address of the special function register SFR is also 80H~FFH. But the difference between SFR and internal high 128 bytes SRAM is: SFR register is directly addressed, while internal high 128 bytes SRAM can only be indirectly addressed. The address of the external RAM is 0000H~1FFFH, but it needs to be addressed by the MOVX instruction. #### 5.10.1 Internal 256 Bytes SRAM The internal low 128 bytes SRAM area can be divided into three parts: ① Operating register group 0~3, address 00H~1FH, the combination of RS0 and RS1 in the program status word register PSW determines the operating register currently used, using operating register group 0~ 3 can speed up the operation; Page 50 of 252 V0.1 ### Super High-speed 1T 8051 Core Flash MCU - ② Bit addressing area 20H~2FH, this area can be used as ordinary RAM or bit-wise addressing RAM; when addressing by bit, the bit address is 00H~7FH, (The address is programmed bit by bit, which is different from the general SRAM coded by byte), which can be distinguished by instructions in the program; - 3 User RAM and stack area, after the SC95F776X is reset, the 8-bit stack pointer points to the stack area. Users generally set the initial value during initialization. It is recommended to set the initial value between E0H ~ FFH.. | FFh | SFR | RAM | |------------|------------------------------------------------|-----------------------| | 80h | (direct addressing) | (indirect addressing) | | 7Fh<br>00h | RAM (direct addressing or indirect addressing) | | Internal 256 bytes RAM structure diagram The internal low 128 bytes RAM structure is as follows: SRAM structure diagram Page 51 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU ## 5.10.2 External 8 Kbytes SRAM External 8192 bytes RAM can be accessed through MOVX @DPTR, A; you can also use MOVX A, @Ri or MOVX @Ri, A with EXADH register to access external 8192 bytes RAM: EXADH register stores the high address of external SRAM, Ri register stores the low 8 bits of the external SRAM. #### **EXADH (F7H) External SRAM Operation Address High Bit (read/write)** | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-----------------|---|---|---|--------------|---|---|---|---|--|--| | Bit<br>Mnemonic | - | - | - | EXADH [4: 0] | | | | | | | | POR | х | х | х | 0 | 0 | 0 | 0 | 0 | | | | Bit number | Bit Mnemonic | Description | |------------|--------------|---------------------------------------------| | 4~0 | EXADH [4: 0] | High-bit of external SRAM operation address | | 7~5 | - | reserved | #### 5.10.3 External 80 bytes PWM&LCD/LED SRAM The 2000H~204FH of the RAM address are used as PWM&LCD/LED SRAM of 80 bytes, among them: - 1. The PWM duty cycle adjustment register occupies 2034H~204FH and can be read and written.; - 2. LCD/LED display RAM occupies 2000H~201BH and can be read and written. Page 52 of 252 V0.1 ## 6 Special Function Register (SFR) ## 6.1 SFR Mapping The SC95F776X provides some registers equipped with special functions, called SFR. The addresses of these registers are located at 80H~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 SC95F776X SFR Map is as follows: | | 0/8 | 1/9 | 2/A | 3/B | 4/C | 5/D | 6/E | 7/F | |-----|-------|--------|---------|---------|---------------|---------|---------|---------| | F8h | - | - | - | BTMCON | CRCINX | CRCREG | OPINX | OPREG | | F0h | В | IAPKEY | IAPADL | IAPADH | IAPADE | IAPDAT | IAPCTL | EXADH | | E8h | - | EXA0 | EXA1 | EXA2 | EXA3 | EXBL | EXBH | OPERCON | | E0h | ACC | - | - | - | - | - | - | - | | D8h | P5 | P5CON | P5PH | - | USXINX | - | - | ROMBNK | | D0h | PSW | PWMCFG | PWMCON0 | PWMCON1 | WMCON1 PWMPDL | | PWMDFR | PWMFLT | | C8h | TXCON | TXMOD | RCAPXL | RCAPXH | TLX | THX | TXINX | WDTCON | | C0h | P4 | P4CON | P4PH | 1 | USXCON0 | USXCON1 | USXCON2 | USXCON3 | | B8h | IP | IP1 | IP2 | INT0R | INT1F | INT1R | INT2F | INT2R | | B0h | Р3 | P3CON | P3PH | P3VO | INTOF | ADCCFG2 | CMPCFG | CMPCON | | A8h | IE | IE1 | IE2 | ADCCFG0 | ADCCFG1 | ADCCON | ADCVL | ADCVH | | A0h | P2 | P2CON | P2PH | P2VO | US1CON0 | US1CON1 | US1CON2 | US1CON3 | | 98h | SCON | SBUF | POCON | P0PH | P0VO | US0CON1 | US0CON2 | US0CON3 | Page 53 of 252 V0.1 | 90h | P1 | P1CON | P1PH | DDRCON | P1VO | US0CON0 | IOHCON0 | IOHCON1 | | | | | |-----|------------------------|-------|---------------------|--------|------|---------|---------|---------|--|--|--|--| | 88h | TCON | TMOD | TL0 | TL1 | TH0 | TH1 | TMCON | OTCON | | | | | | 80h | P0 | SP | DPL | DPH | DPL1 | DPH1 | DPS | PCON | | | | | | | Bit<br>addressabl<br>e | | Non-bit addressable | | | | | | | | | | Note: The empty part of the SFR register are not recommended for users. ### **6.2 SFR Instructions** #### 6.2.1 SFR SFR specific explanations are as follows: | Mnemonic | Add | Description | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | POR | | |----------|-----|-----------------------------------|------|-----------|-----|-----|-----------|-----|------|-----|------------|--| | P0 | 80H | P0 port data register | P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 | 00000000b | | | SP | 81H | Stack pointer | | SP[7: 0] | | | | | | | | | | DPL | 82H | DPTR data pointer low | | DPL[7: 0] | | | | | | | | | | DPH | 83H | DPTR data pointer high | | DPH[7: 0] | | | | | | | | | | DPL1 | 84H | DPTR1 data pointer low | | | | DI | PL1[7: 0] | | | | 00000000Ь | | | DPH1 | 85H | DPTR1 data pointer high | | | | DF | PH1[7: 0] | | | | 00000000Ь | | | DPS | 86H | DPTR selection register | ID1 | ID0 | TSL | AU1 | AU0 | - | - | SEL | 00000xx0b | | | PCON | 87H | Power management control register | SMOD | - | - | - | RST | - | STOP | IDL | 0xxx0x000b | | | TCON | 88H | Timer control register | TF1 | TR1 | TF0 | TR0 | IE1 | - | IE0 | - | 00000x0xb | | Page 54 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU | TMOD | 89H | Timer operating mode register | - | C/T1 | M11 | M01 | - | C/T0 | M10 | M00 | x000x000b | | |---------|-----|-------------------------------------------------|-------------------------------|-----------------------|-------|---------|------------|----------|-----------|---------|-----------|--| | TLO | 8AH | Low 8 bits of timer 0 | | | | Т | L0[7: 0] | | | | 00000000ь | | | TL1 | 8BH | Low 8 bits of timer 1 | | TL1[7: 0] | | | | | | | | | | TH0 | 8CH | Timer 0 high 8 bits | | | | Т | H0[7: 0] | | | | 00000000Ь | | | TH1 | 8DH | Timer 1 high 8 bits | | | | Т | H1[7: 0] | | | | 00000000Ь | | | TMCON | 8EH | Timer frequency control register | USMI | USMDX[1: 0] T1FD T0FD | | | | | | TOFD | 00xxxx00b | | | OTCON | 8FH | Output control register | USMI | D1[1: 0] | USMD | 0[1: 0] | VOIF | RS[1: 0] | scs | BIAS | 00000000Ь | | | P1 | 90H | P1 port data register | P17 | P16 | P15 | P14 | P13 | P12 | P11 | P10 | 00000000Ь | | | P1CON | 91H | P1 port input/output<br>control register | P1C7 | P1C6 | P1C5 | P1C4 | P1C3 | P1C2 | P1C1 | P1C0 | 00000000Ь | | | P1PH | 92H | P1 port pull-up<br>resistor control<br>register | P1H7 | P1H6 | P1H5 | P1H4 | P1H3 | P1H2 | P1H1 | P1H0 | 00000000Ь | | | DDRCON | 93H | Display drive control register | DDRON | DMOD | DUTY | /[1: 0] | | VLCD | )[3: 0] | | 00000000Ь | | | P1VO | 94H | P1 port display<br>driver output register | P17VO | P16VO | P15VO | P14VO | P13VO | P12VO | P11VO | P10VO | 00000000Ь | | | US0CON0 | 95H | USCI0 control register 0 | | | | US0 | CON0[7: 0] | | | | 00000000Ь | | | IOHCON0 | 96H | IOH setting register<br>0 | P1F | H[1: 0] | P1L | 1: 0] | POH | H[1: 0] | POL | L[1: 0] | 00000000Ь | | | IOHCON1 | 97H | IOH setting register | P3L[1: 0] | | | | P2ł | H[1: 0] | P2l | L[1: 0] | xx000000b | | | SCON | 98H | Serial control register | SM0 SM1 SM2 REN TB8 RB8 TI RI | | | | | | 00000000Ь | | | | | SBUF | 99H | Serial data buffer register | | | | SE | BUF[7: 0] | | | | 00000000Ь | | Page 55 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU | | | | | | | | | | | | _ | | |---------|-----|-------------------------------------------------|---------------|---------------|-------|-------|------------|-------|-------|--------|-----------|--| | P0CON | 9AH | P0 port input/output<br>control register | P0C7 | P0C6 | P0C5 | P0C4 | P0C3 | P0C2 | P0C1 | P0C0 | 00000000b | | | POPH | 9BH | P0 port pull-up<br>resistor control<br>register | P0H7 | P0H6 | P0H5 | P0H4 | P0H3 | P0H2 | P0H1 | РОНО | 00000000Ь | | | P0VO | 9CH | P0 port display<br>driver output register | P07VO | P06VO | P05VO | P04VO | P03VO | P02VO | P01VO | P00VO | 00000000ь | | | US0CON1 | 9DH | USCI0 control register 1 | | US0CON1[7: 0] | | | | | | | | | | US0CON2 | 9EH | USCI0 control register 2 | | US0CON2[7: 0] | | | | | | | | | | US0CON3 | 9FH | USCI0 control register 3 | | US0CON3[7: 0] | | | | | | | | | | P2 | АОН | P2 port data register | P27 | P26 | P25 | P24 | P23 | P22 | P21 | P20 | 00000000Ь | | | P2CON | A1H | P2 port input/output<br>control register | P2C7 | P2C6 | P2C5 | P2C4 | P2C3 | P2C2 | P2C1 | P2C0 | 00000000b | | | P2PH | A2H | P2 port pull-up<br>resistor control<br>register | P2H7 | P2H6 | P2H5 | P2H4 | P2H3 | P2H2 | P2H1 | P2H0 | 00000000Ь | | | P2VO | АЗН | P2 port display<br>driver output register | P27VO | P26VO | P25VO | P24VO | P23VO | P22VO | P21VO | P20VO | 00000000b | | | US1CON0 | A4H | USCI1 control register 0 | | | | US1 | CON0[7: 0] | | | | 00000000b | | | US1CON1 | A5H | USCI1 control register 1 | | | | US1 | CON1[7: 0] | | | | 00000000b | | | US1CON2 | А6Н | USCI1 control register 2 | | | | US1 | CON2[7: 0] | | | | 00000000Ь | | | US1CON3 | А7Н | USCI1 control register 3 | US1CON3[7: 0] | | | | | | | | 00000000Ь | | | IE | A8H | Interrupt enable register | EA | EADC | ET2 | EUART | ET1 | EINT1 | ET0 | EINT0 | 00000000b | | | IE1 | А9Н | Interrupt enable register 1 | ET4 | ET3 | ECMP | | EINT2 | EBTM | EPWM | EUSCI0 | 000x0000b | | Page 56 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU | IE2 | ААН | Interrupt enable register 2 | - | - | - | EUSCI5 | EUSCI4 | EUSCI3 | EUSCI2 | EUSCI1 | xxx00000b | |---------|-----|-------------------------------------------------|-------------|--------|---------------|---------------|------------------|-------------|--------|-----------|-----------| | ADCCFG0 | АВН | ADC setting register 0 | EAIN7 | EAIN6 | EAIN5 | EAIN4 | EAIN3 | EAIN2 | EAIN1 | EAIN0 | 00000000b | | ADCCFG1 | ACH | ADC setting register | EAIN15 | EAIN14 | EAIN13 | EAIN12 | EAIN11 | EAIN10 | EAIN9 | EAIN8 | 00000000Ь | | ADCCON | ADH | ADC control register | ADCEN | ADCS | EOC/<br>ADCIF | | | ADCIS[4: 0] | | | 00000000Ь | | ADCVL | AEH | ADC Conversion<br>Value Register | | ADC | CV[3: 0] | | - | | | | 1111xxxxb | | ADCVH | AFH | ADC Conversion<br>Value Register | ADCV[11: 4] | | | | | | | 11111111b | | | P3 | ВОН | P3 port data register | P37 | P36 | P35 | P34 | P33 | P32 | P31 | P30 | 00000000Ь | | P3CON | B1H | P3 port input/output<br>control register | P3C7 | P3C6 | P3C5 | P3C4 | P3C3 | P3C2 | P3C1 | P3C0 | 00000000b | | РЗРН | B2H | P3 port pull-up<br>resistor control<br>register | РЗН7 | P3H6 | P3H5 | P3H4 | P3H3 | P3H2 | P3H1 | P3H0 | 00000000Ь | | P3VO | взн | P3 port display<br>driver output register | P37VO | P36VO | P35VO | P34VO | P33VO | P32VO | P31VO | P30VO | 00000000ь | | INTOF | В4Н | INTO falling edge interrupt control register | INT0F7 | INT0F6 | INT0F5 | INT0F4 | - | - | - | - | 0000xxxxb | | ADCCFG2 | B5H | ADC setting register 2 | - | - | - | | LOWSP[2: | 0] | - | - | xxx000xxb | | CMPCFG | В6Н | Analog comparator setting register | - | - | - | CMPP | CMPP CMPIM[1: 0] | | | IS[1: 0] | xxx00000b | | CMPCON | в7Н | Analog Comparator<br>Control Register | CMPEN | CMPIF | CMPSTA | - CMPRF[3: 0] | | | | 000x0000b | | | IP | В8Н | Interrupt priority control register | 1 | IPADC | IPT2 | IPUART | IPT1 | IPINT1 | IPT0 | IPINT0 | x0000000b | | IP1 | вэн | Interrupt priority control register 1 | IPT4 | IPT3 | IPCMP | | IPINT2 | IPBTM | IPPWM | IPSSI0 | 000x0000b | Page 57 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU | IP2 | ВАН | Interrupt priority control register 2 | - | - | - | IPUSCI5 | IPUSCI4 | IPUSCI3 | IPUSCI2 | IPUSCI1 | xxx00000b | |---------|-----|-------------------------------------------------|--------|--------|--------|---------|------------|---------|---------|---------|-----------| | INTOR | ВВН | INTO rising edge interrupt control register | INTOR7 | INTOR6 | INT0R5 | INT0R4 | - | - | - | - | 0000xxxxb | | INT1F | ВСН | INT1 falling edge interrupt control register | INT1F7 | INT1F6 | INT1F5 | INT1F4 | INT1F3 | INT1F2 | INT1F1 | INT1F0 | 00000000Ь | | INT1R | BDH | INT1 rising edge interrupt control register | INT1R7 | INT1R6 | INT1R5 | INT1R4 | INT1R3 | INT1R2 | INT1R1 | INT1R0 | 00000000ь | | INT2F | BEH | INT2 falling edge interrupt control register | - | - | - | - | INT2F3 | INT2F2 | INT2F1 | INT2F0 | xxxx0000b | | INT2R | BFH | INT2 rising edge interrupt control register | - | - | - | - | INT2R3 | INT2R2 | INT2R1 | INT2R0 | xxxx0000b | | P4 | СОН | P4 port data register | P47 | P46 | P45 | P44 | P43 | P42 | P41 | P40 | 0000000b | | P4CON | C1H | P4 port input/output<br>control register | P4C7 | P4C6 | P4C5 | P4C4 | P4C3 | P4C2 | P4C1 | P4C0 | 00000000b | | P4PH | C2H | P4 port pull-up<br>resistor control<br>register | P4H7 | P4H6 | P4H5 | P4H4 | P4H3 | P4H2 | P4H1 | P4H0 | 00000000Ь | | USXCON0 | C4H | USCI2/3/4/5 control register 0 | | | | USX | CON0[7: 0] | | | | 00000000b | | USXCON1 | C5H | USCI2/3/4/5 control register 1 | | | | USX | CON1[7: 0] | | | | 00000000b | | USXCON2 | С6Н | USCI2/3/4/5 control register 2 | | | | USX | CON2[7: 0] | | | | 00000000b | | USXCON3 | С7Н | USCI2/3/4/5 control register 3 | | | | USX | CON3[7: 0] | | | | 00000000b | | TXCON | C8H | Timer 2/3/4 control register | TFX | EXFX | RCLKX | TCLKX | EXENX | TRX | С/ТХ | CP/RLX | 00000000b | | TXMOD | С9Н | Timer 2/3/4<br>operating mode<br>register | TXFD | - | EPWMN1 | EPWMN0 | INVN1 | INVN0 | TXOE | DCXEN | 0x000000b | Page 58 of 252 V0.1 | RCAPXL | САН | Timer 2/3/4 reload low 8 bits | | | | RC. | APXL[7: 0] | | | | 00000000b | |---------|-----|-------------------------------------------------|------------|-------------------------|----------|----------|-----------------------|--------|-------------|-----------|------------| | RCAPXH | СВН | Timer 2/3/4 reload<br>high 8 bits | | RCAPXH[7: 0] | | | | | | 00000000Ь | | | TLX | ссн | Timer 2/3/4 low 8 bits | | | | Т | <sup>-</sup> LX[7: 0] | | | | 0000000b | | ТНХ | CDH | Timer 2/3/4 high 8 bits | | | | Т | 'HX[7: 0] | | | | 0000000b | | TXINX | СЕН | Timer control register pointer | - | - | - | - | - | | TXINX[2: 0] | | xxxxx010b | | WDTCON | CFH | WDT control register | - | - | - | CLRWDT | - | v | VDTCKS[2: 0 | )Ţ | xxx0x0000b | | PSW | D0H | Program status word register | CY | AC | F0 | RS1 | RS0 | ov | F1 | Р | 00000000b | | PWMCFG | D1H | PWM0 setting register | INV7 | INV6 | INV5 | INV4 | INV3 | INV2 | INV1 | INV0 | 00000000b | | PWMCON0 | D2H | PWM0 control register0 | ENPWM | PWMIF | PWMC | CK[1: 0] | | - | PWM | MD[1:0] | 0000xx00b | | PWMCON1 | D3H | PWM0 control register 1 | ENPWM<br>7 | ENPWM6 | ENPWM5 | ENPWM4 | ENPWM3 | ENPWM2 | ENPWM1 | ENPWM0 | x0000000b | | PWMPDL | D4H | PWM0 period register low 8 bits | | | > | PW | MPDL[7:0] | | | | 00000000b | | PWMPDH | D5H | PWM0 period register high 8 bits | | | | PW | MPDH[7:0] | | | | 00000000b | | PWMDFR | D6H | PWM0 dead time setting register | | PDF | F1[3: 0] | | | PDR1 | [3: 0] | | 00000000Ь | | PWMFLT | D7H | PWM0 fault<br>detection setting<br>register | FLTEN1 | FLTSTA1 | FLTMD1 | FLTLV1 | - | - | FLTD | T1[1: 0] | 0000xx00b | | P5 | D8H | P5 port data register | - | P55 P54 P53 P52 P51 P50 | | | | P50 | xx000000b | | | | P5CON | D9H | P5 port input/output<br>control register | - | - | P5C5 | P5C4 | P5C3 | P5C2 | P5C1 | P5C0 | xx000000b | | P5PH | DAH | P5 port pull-up<br>resistor control<br>register | - | - | P5H5 | P5H4 | P5H3 | P5H2 | P5H1 | P5H0 | xx000000b | | | • | | • | | | | • | | | | | Page 59 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU | USXINX | DCH | USCI2/3/4/5 Control register pointer | - | - | - | - | - | | USCIX[2:0] | | xxxxx000b | |---------|-----|----------------------------------------|---------------|-----------|--------------|--------------|------------|---|------------|---------|-----------| | ROMBNK | DFH | Program Bank<br>switches registers | - | - | DATABNK<br>1 | DATABNK<br>0 | - | - | ROMBNK1 | ROMBNK0 | xx01xx01 | | ACC | E0H | accumulator | | ACC[7: 0] | | | | | | | 00000000ь | | EXA0 | E9H | Extended<br>Accumulator 0 | | | | E | XA[7: 0] | | | | 00000000b | | EXA1 | EAH | Extended<br>Accumulator 1 | | | | EX | KA[15: 8] | | | | 0000000b | | EXA2 | EBH | Extended<br>Accumulator 2 | | | | EX | [A[23: 16] | | 7)- | | 00000000b | | EXA3 | ECH | Extended<br>Accumulator 3 | | | | EX | A[31: 24] | | | | 00000000b | | EXBL | EDH | Extended B register<br>L | | | | E: | XB [7: 0] | | | | 00000000b | | EXBH | EEH | Extended B register<br>H | | | | E> | (B [15: 8] | | | | 00000000b | | OPERCON | EFH | Arithmetic control register | OPERS | MD | | - | - | - | CRCRST | CRCSTA | 00xxxx00b | | В | F0H | B register | | | > | | B[7: 0] | | | | 00000000ь | | IAPKEY | F1H | IAP protection register | | | | IAF | PKEY[7: 0] | | | | 00000000b | | IAPADL | F2H | IAP write address<br>low register | | | | IAP | ADR[7: 0] | | | | 00000000b | | IAPADH | F3H | IAP write address<br>high register | | | | IAP | ADR[15: 8] | | | | 00000000b | | IAPADE | F4H | IAP write to extended address register | IAPADER[7: 0] | | | | | | 00000000Ь | | | | IAPDAT | F5H | IAP data register | IAPDAT[7: 0] | | | | | | 0000000b | | | | IAPCTL | F6H | IAP control register | BTLD | - | SERASE | PRG | - | - | СМЕ | D[1: 0] | 0x00xx00b | Page 60 of 252 V0.1 | EXADH | | High-bit address of external SRAM operation address | - | - | - | | EXADH [4: 0] | xxx00000b | |--------|-----|-----------------------------------------------------|-------|-------------|---|-----|--------------|-----------| | BTMCON | FBH | Low frequency timer control register | ENBTM | BTMIF | - | - | BTMFS[3: 0] | 00xx0000b | | CRCINX | FCH | CRC pointer | | | | CR | CINX[7: 0] | 00000000ь | | CRCREG | FDH | CRC register | | | | CRO | CREG[7: 0] | nnnnnnnb | | OPINX | FEH | Option pointer | | | | OF | PINX[7: 0] | 00000000ь | | OPREG | FFH | Option register | | OPREG[7: 0] | | | | nnnnnnnb | ## 6.2.2 PWM0 Duty Cycle Adjustment Register(R/W) | ADD | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | POR | |-------|---|------------|---|------|----------------------|---|---|---|-----------| | 2040H | | | | PDT | 00[15:8] | | | | 00000000Ь | | 2041H | | | | PDT | 700[7:0] | | | | 0000000b | | 2042H | | | | PDTO | 01[15:8] | | | | 00000000b | | 2043H | | | | PDT | <sup>-</sup> 01[7:0] | | | | 00000000b | | 2044H | | | | PDTO | 02[15:8] | | | | 00000000b | | 2045H | | | | PDT | 02[7:0] | | | | 00000000b | | 2046H | | | | PDTO | 03[15:8] | | | | 00000000b | | 2047H | | | | PDT | <sup>-</sup> 03[7:0] | | | | 0000000b | | 2048H | | | | PDTO | 04[15:8] | | | | 00000000Ь | | 2049H | | | | PDT | <sup>-</sup> 04[7:0] | | | | 00000000Ь | | 204AH | | | | PDT | 05[15:8] | | | | 00000000Ь | | 204BH | | | | PDT | <sup>-</sup> 05[7:0] | | | | 00000000Ь | | 204CH | | | | PDTO | 06[15:8] | | | | 00000000Ь | | 204DH | | PDT06[7:0] | | | | | | | 00000000Ь | | 204EH | | | | PDT | 07[15:8] | | | | 00000000Ь | Page 61 of 252 V0.1 ## 6.2.3 PWM2~4 Duty Cycle Adjustment Register(R/W) | ADD | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | POR | | |-------|---|-------------|---|------|-----------|---|----|---|-----------|--| | 2034H | | PDT20[15:8] | | | | | | | | | | 2035H | | | | PDT2 | 20[7:0] | | | | 00000000ь | | | 2036H | | | | PDT2 | 1[15:8] | | | | 00000000ь | | | 2037H | | | | PDT2 | 21[7:0] | | | | 00000000ь | | | 2038H | | | | PDT3 | 0[15:8] | | 17 | | 00000000ь | | | 2039H | | | | PDT3 | 30[7:0] | | | | 00000000ь | | | 203AH | | | | PDT3 | 1[15:8] | | | | 00000000ь | | | 203BH | | | | PDT3 | 31[7:0] | | | | 00000000ь | | | 203CH | | PDT40[15:8] | | | 00000000ь | | | | | | | 203DH | | PDT40[7:0] | | | | | | | | | | 203EH | | PDT41[15:8] | | | | | | | | | | 203FH | | | | PDT4 | 11[7:0] | | | | 00000000ь | | ## 6.2.4 LCD/LED display RAM configuration (R/W) | ADD | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|------|------|------|------|------|------|------|------| | | СОМ7 | СОМ6 | COM5 | COM4 | СОМЗ | COM2 | COM1 | СОМО | | 2000H | SEG0 | 2001H | SEG1 | 2002H | SEG2 | 2003H | SEG3 | 2004H | SEG4 | 2005H | SEG5 | 2006H | SEG6 Page 62 of 252 V0.1 ## **Super High-speed 1T 8051 Core Flash MCU** | ADD | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|-------|-------|-------|-------|-------|-------| | | COM7 | COM6 | COM5 | COM4 | COM3 | COM2 | COM1 | СОМО | | 2007H | SEG7 | 2008H | SEG8 | 2009H | SEG9 | 200AH | SEG10 | 200BH | SEG11 | 200CH | SEG12 | 200DH | SEG13 | 200EH | SEG14 | 200FH | SEG15 | 2010H | SEG16 | 2011H | SEG17 | 2012H | SEG18 | 2013H | SEG19 | 2014H | SEG20 | 2015H | SEG21 | 2016H | SEG22 | 2017H | SEG23 | 2018H | SEG24 | 2019H | SEG25 | 201AH | SEG26 | 201BH | SEG27 ### 6.2.5 Introduction of Common Special Function Registers of 8051 Core ## **Program Counter PC** The program counter PC does not belong to the SFR register. The PC has 16 bits and is a register used to control the order of execution of instructions. After the MCU is powered on or reset, the PC value is 0000H, which means that the MCU program starts executing the program from the 0000H address. Page 63 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU #### Accumulator ACC (E0H) The accumulator ACC is one of the most commonly used registers of the 8051 core single-chip microcomputer, and A is used as a mnemonic in the instruction set. Commonly used to store operands and results that participate in calculations or logical operations. #### B Register (F0H) The B register must be used with the accumulator A in multiplication and division operations. The multiplication instruction MUL A, B multiplies the 8-bit unsigned number in accumulator A and register B. The low-bit byte of the resulting 16-bit product is placed in A, and the high-bit byte is placed in B. The division instruction DIV A, B divides A by B, the integer quotient is placed in A, and the remainder is placed in B. Register B can also be used as a general temporary storage register. #### Stack Pointer SP (81H) The stack pointer is an 8-bit special register that indicates the location of the top of the stack in general-purpose RAM. After the Microcontroller unit (MCU) is reset, the initial value of SP is 07H, that is, the stack will increase upward from 08H. 08H~1FH is operating register group 1~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 | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | CY | Flag 1: When there is a carry in the highest bit of addition, or a borrow in the highest bit of subtraction 0: When there is no carry in the highest bit of addition, or there is no borrow in the highest bit of subtraction | | 6 | AC | Carry auxiliary flag (can be easily adjusted during the addition and subtraction of BCD code) 1: When the addition operation has a carry in bit3, or the subtraction operation has a borrow in bit3 | Page 64 of 252 V0.1 | | | 0: No bo | rrowing, c | arry | | | | | |-----|---------|--------------------------------------------------------------------------------------------|------------------------------------------|---------------------------------------------|--|--|--|--| | 5 | F0 | User flag | | | | | | | | 4~3 | RS1,RS0 | Operatin | Operating register group selection bits: | | | | | | | | | RS1 | RS0 | Operating register set currently in use 0~3 | | | | | | | | 0 | 0 | TEAM 0 (00H~07H) | | | | | | | | 0 | 1 | TEAM 1 (08H~0FH) | | | | | | | | 1 | 0 | TEAM 2 (10H~17H) | | | | | | | | 1 | 1 | TEAM 3 (18H~1FH) | | | | | | 2 | ov | Overflow | flag | | | | | | | 1 | F1 • | F1 flag | | | | | | | | | | User-def | ined flag | · | | | | | | 0 | P | Parity flag. This flag bit is the parity value of the number of 1s in the accumulator ACC. | | | | | | | | | | 1: The n | umber of 1 | Is in ACC is odd | | | | | | | | 0: The n | umber of 1 | s in ACC is even (including 0) | | | | | ### Data Pointers DPTR0 (82H, 83H), DPTR1 (84H, 85H) And Its Selection Register DPS (86H) The SC95F776X has two data pointers DPTR0 and DPTR1. Data pointers DPTR0/DPTR1 are 16-bit special registers, which are composed of low 8-bit DPL/DPL1 and high 8-bit DPH/DPH1. DPTR0/DPTR1 is a register that can directly perform 16-bit operations, and can also operate on DPL and DPH in bytes respectively. The selection and operating status of the data pointer DPTR0/DPTR1 are set by the data pointer selection register DPS. #### DPS(86H)Data Pointer Selection Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|---|---|---|---|---|---|---|---| | | | | | | | | | | Page 65 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU | Bit<br>Mnemonic | ID1 | ID0 | TSL | AU1 | AU0 | - | - | SEL | |-----------------|-----|-----|-----|-----|-----|---|---|-----| | 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 | ID1 | DPTR1 plus or minus control bit | | | | 0: When AU1=1, whenever the MOVC/MOVX @DPTR is executed, the current DPTR1 will automatically increase by 1. | | | | 1: When AU1=1, whenever MOVC/MOVX @DPTR is executed, the current DPTR1 will automatically decrease by 1. | | 6 | ID0 | DPTR plus or minus control bit | | | | 0: When AU0=1, whenever MOVC/MOVX @DPTR is executed, the current DPTR0 will automatically increase by 1. | | | | 1: When AU0=1, whenever MOVC/MOVX @DPTR is executed, the current DPTR0 will automatically decrease by 1. | | 5 | TSL | SEL flip control bit | | | | 0: Whenever MOVC/MOVX @DPTR is executed, DPS.0 (SEL) does not flip | | | | 1: Whenever MOVC/MOVX @DPTR is executed, DPS.0 (SEL) flips once | | 4 | AU1 | DPTR1 automatic plus and minus control bit | | | | 0: None | | | | 1: Whenever MOVC/MOVX @DPTR is executed, the current DPTR1 will increase or decrease by 1 (depending on ID1) | | 3 | AU0 | DPTR automatic plus and minus control bit | | | | 0: None | Page 66 of 252 V0.1 | | | Whenever MOVC/MOVX @DPTR is executed, the current DPTR0 will increase or decrease by 1 (depending on ID0) | | | | | | |-----|-----|-----------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 0 | SEL | DPTR0, DPTR1 selection bits 0: MOVC/MOVX @DPTR object is DPTR0 1: MOVC/MOVX @DPTR object is DPTR1 | | | | | | | 2~1 | - | reserved | | | | | | Page 67 of 252 V0.1 ## 7 Power, Reset And System Clock #### 7.1 Power Circuit The SC95F776X power supply system includes BG, LDO, POR, LVR and other circuits, which can achieve reliable operation in the range of 2.0~5.5V. In addition, the IC has a built-in, accurate 2.048V, 1.024V and 2.4V voltage that can be used as an internal reference voltage for the ADC. Users can find the specific settings in the <a href="mailto:18">18</a> analog-to-digital converter (ADC). #### 7.2 Power-on Reset After the SC95F776X 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 SC95F776X will always be reset until the voltage supplied to SC95F776X is higher than a certain voltage, and the internal Clock starts to be effective. 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 warm-up counter inside The SC95F776X. During the reset stage, the warm-up counter is cleared to 0 until the voltage exceeds the POR voltage, the internal RC oscillator starts to oscillate, and the warm-up counter starts counting. When the internal warm-up counter counts to a certain number, every certain number of HRC clocks will read a byte of data from the IFB (including Code Option) in the Flash ROM and store it in the internal system register. This reset signal will not end until the warm-up is completed. ### 7.2.3 Normal Operation Stage After finishing the Loading Information stage, The SC95F776X starts to read the instruction code from Flash and enters the normal operation stage. The LVR voltage is the set value of Code Option written by the user. #### 7.3 Reset Modes The SC95F776X has 5 reset methods, the first four are hardware reset: - 1. External reset - 2. Low-voltage reset LVR - 3. Power-on reset POR - 4. Watchdog WDT reset - Software reset. The circuit diagram of the reset part of the SC95F776X is as follows: Page 68 of 252 V0.1 SC95F776X Reset circuit diagram #### After reset the boot area: After the external RST reset, low voltage reset LVR, power-on reset POR, watchdog WDT, the chip starts from the boot region (APROM/LDROM) set by the user OP\_BL. After the software is reset, the chip is started according to the boot region (APROM/LDROM) set by BTLD (IAPCTL.7). SC95F776X's boot area switch after reset #### 7.3.1 External Reset External reset is a reset pulse signal of a certain width given to SC95F776X from external RST pin to realize the reset of SC95F776X. The user can configure the P5.2/RST pin as RST (reset pin) by Code Option. Page 69 of 252 V0.1 ## 7.3.2 Low-voltage Reset LVR The SC95F776X provides a low-voltage reset circuit. There are 4-level LVR voltage options: 4.3V, 3.7V, 2.9V, 1.9V. The default value is the Option value written by the user. A reset occurs when the VDD voltage is less than the threshold voltage for low-voltage reset and the duration is greater than $T_{LVR}$ . Among them, $T_{LVR}$ is the buffeting time of LVR, about 30µs. #### OP\_CTM0(C1H@FFH) Code Option Register 0 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------|-------|-------------|---|-----------|--------|------------|---| | Bit<br>Mnemonic | ENWDT | ENXTL | SCLKS[1: 0] | | DISRST | DISLVR | LVRS[1: 0] | | | R/W | R/W | R/W | R/W | | read only | R/W | R/ | W | | POR | n | n | r | n | | С | n | 1 | | Bit number | Bit Mnemonic | Description | | | | | | |------------|--------------|-----------------------------------------|--|--|--|--|--| | 2 | DISLVR | LVR enable setting | | | | | | | | | 0: LVR valid | | | | | | | | | 1: LVR invalid | | | | | | | 1~0 | LVRS [1: 0] | LVR voltage threshold selection control | | | | | | | | | 11: 4.3V | | | | | | | | | 10: 3.7V | | | | | | | | | 01: 2.9V | | | | | | | | | 00: 1.9V | | | | | | #### 7.3.3 Power-on Reset (POR) The SC95F776X has a power-on reset circuit inside. When the power supply voltage VDD reaches the POR reset voltage, the system automatically resets. ### 7.3.4 Watchdog Reset (WDT) Page 70 of 252 V0.1 ## **Super High-speed 1T 8051 Core Flash MCU** The SC95F776X has a WDT, the clock source of which is the internal 32 kHz LRC. The user can choose whether to enable the watchdog reset function by Code Option. ### OP\_CTM0 (C1H@FFH) Code Option Register 0 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------|-------|-------------|---|-----------|--------|------------|---| | Bit<br>Mnemonic | ENWDT | ENXTL | SCLKS[1: 0] | | DISRST | DISLVR | LVRS[1: 0] | | | R/W | R/W | R/W | R/W | | read only | R/W | R/W | | | POR | n | n | r | n | | n | r | n | | Bit number | Bit Mnemonic | Description | |------------|--------------|--------------------------------------------------------------------------------------------------| | 7 | ENWDT | WDT control bit (This bit is transferred by the system to the value set by the user Code Option) | | | | 1: WDT valid | | | | 0: WDT invalid | ### WDTCON (CFH) WDT Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|---|--------|---|--------------|---|---| | Bit<br>Mnemonic | - | - | - | CLRWDT | 1 | WDTCKS[2: 0] | | | | R/W | - | - | ı | R/W | 1 | R/W | | | | POR | х | х | х | 0 | х | 0 | 0 | 0 | Page 71 of 252 V0.1 | 4 | CLRWDT | Clear WDT (Only valid when set to 1) 1: WDT counter restart, cleared by system hardware | | | | | | | | | |-------|---------------|------------------------------------------------------------------------------------------|-------------------|--|--|--|--|--|--|--| | 2~0 | WDTCKS [2: 0] | Watchdog clock selection | | | | | | | | | | | | WDTCKS[2: 0] | WDT overflow time | | | | | | | | | | | 000 | 500ms | | | | | | | | | | | 001 | 250ms | | | | | | | | | | | 010 | 125ms | | | | | | | | | | | 011 | 011 62.5ms | | | | | | | | | | | 100 | 31.5ms | | | | | | | | | | | 101 | 15.75ms | | | | | | | | | | | 110 | 7.88ms | | | | | | | | | | | 111 | 111 3.94ms | | | | | | | | | 7~5,3 | | Reserved | | | | | | | | | ## 7.3.5 Software Reset ## PCON (87h) Power Management Control Register (write only, \*unreadable\*) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------------|---|---|---|---------------|---|---------------|---------------| | Bit<br>Mnemonic | SMOD | - | - | - | RST | - | STOP | IDL | | R/W | write only | - | - | - | Write<br>only | - | Write<br>only | Write<br>only | Page 72 of 252 V0.1 ### Super High-speed 1T 8051 Core Flash MCU | POR | 0 | х | х | х | n | х | 0 | 0 | | |-----|---|---|---|---|---|---|---|---|--| |-----|---|---|---|---|---|---|---|---|--| | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------| | 3 | RST | Software reset control bit: Write status: 0: The program runs normally; 1: The CPU resets immediately after this bit is written to "1" | ### 7.3.6 Register Reset Value When The SC95F776X is in reset state, most registers will return to their initial state. The watchdog (WDT) is turned off. The initial value of the program counter PC is 0000h, and the initial value of the stack pointer SP is 07h. The "hot restart" Reset (such as WDT, LVR, software reset, etc.) will not affect the SRAM, and the SRAM value is always the value before the reset. The loss of SRAM content will occur when the power supply voltage is so low that the RAM cannot be saved. The initial values of the power-on reset of the SFR register see 6.2.1 SFR. # 7.4 High- frequency System Clock Circuit The SC95F776X has a built-in high-precision high-frequency oscillator (HRC) with adjustable oscillation frequency. The HRC is accurately adjusted to 32 MHz@5V/25°C at the factory. Users can set the system clock to 32/16/8/4 MHz through the Code Option when programming. This HRC will have a certain drift under the influence of the ambient temperature and operating voltage: - 2.0V ~ 5.5V,-40 ~ 85°C application environment, frequency error does not exceed ±1% - -40 ~ 105°C application environment, does not exceed ±2% The HRC can be automatically calibrated by connecting an external 32.768 kHz crystal oscillator. After calibration, HRC precision can be infinitely close to the precision of external 32.768kHz crystal oscillator. Users only need to connect an external 32.768 kHz crystal oscillator, and set the external 32.768 kHz crystal oscillator function through the Code Opiton when programming. The HRC self-calibration function is automatically turned on after the IC is powered on. #### Note: 1. The clock source of the PWM is fixed at $f_{HRC}$ = 32 MHz. Page 73 of 252 V0.1 ### **Super High-speed 1T 8051 Core Flash MCU** 2. After the external 32.768khz crystal oscillator function is enabled, the HRC self-calibration function will start synchronously. At this point, if the external 32.768khz crystal oscillator is not connected or abnormally connected, the HRC calibration value will have unexpected deviation, resulting in abnormal HRC frequency value. SC95F776X Internal clock relationship #### OP\_CTM0 (C1H@FFH) Code Option Register 0 (read/write) | Bit number | 7 | 6 | 5 4 | 3 | 2 | 1 | 0 | |-----------------|-------|-------|-------------|-----------|--------|------------|---| | Bit<br>Mnemonic | ENWDT | ENXTL | SCLKS[1: 0] | DISRST | DISLVR | LVRS[1: 0] | | | R/W | R/W | R/W | R/W | read only | R/W | R/W | | | POR | n | n | n | n | n | n | | | Bit number | Bit Mnemonic | Description | |------------|--------------|--------------------------------------------------------------------------------------------------| | 5~4 | SCLKS[1: 0] | System clock frequency selection bits 00: System clock frequency is HRC frequency divided by 1; | Page 74 of 252 V0.1 ### **Super High-speed 1T 8051 Core Flash MCU** | 01: System clock frequency is HRC frequency divided by 2; | |-----------------------------------------------------------| | 10: System clock frequency is HRC frequency divided by 4; | | 11: System clock frequency is HRC frequency divided by 8; | Note: The SC95F776X has a special function: the user can modify the value of SFR to adjust the HRC frequency within a certain range. The user can achieve this by configuring the OP\_HRCR register. Note: HRC can be automatically calibrated by connecting a 32.768 kHz crystal oscillator. Therefore, if the user uses the 32.768 kHz external crystal oscillator function, the HRC frequency will always be corrected to 32 MHz. At this time, adjusting OP\_HRCR cannot change the HRC frequency. #### 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] | HRC frequency change register The user can change the high-frequency oscillator frequency fhrc by modifying the value of this register, and then change the system clock frequency fsys of the IC: The initial value of OP_HRCR[7: 0] after power-on OP_HRCR[s] is a fixed value to ensure that fhrc is 32 MHz, OP_HRCR[s] of each IC may be different When the initial value is OP_HRCR[s], the system clock frequency fsys of the IC can be set to an accurate 32/16/8/4 MHz through the Option item. When OP_HRCR [7: 0] changes by 1, the fsys frequency changes by about 0.18% The relationship between OP_HRCR [7: 0] and HRC output frequency is as follows: | Page 75 of 252 V0.1 | OP_HRCR [7: 0] value | fsys actual output frequency (32M as an example) | |----------------------|--------------------------------------------------| | OP_HRCR [s]-n | 32000*(1-0.18%*n) kHz | | | | | OP_HRCR [s]-2 | 32000*(1-0.18%*2) = 31 884.8 kHz | | OP_HRCR [s]-1 | 32000*(1-0.18%*1) = 31 942.4 kHz | | OP_HRCR [s] | 32000 kHz | | OP_HRCR [s]+1 | 32000*(1+0.18%*1) = 32 057.6 kHz | | OP_HRCR [s]+2 | 32000*(1+0.18%*2) = 32 115.2 kHz | | | | | OP_HRCR [s]+n | 32000*(1+0.18%*n) kHz | | | | #### Note: - After each power-on of the IC, the value of OP\_HRCR[7: 0] is the value of the HRC closest to 32/16/8/4 MHz; With the help of EEPROM, the user can correct the value of HRC after each poweron to allow HRC of the IC to work at Frequency required by users; - In order to ensure the reliable operation of the IC, the maximum operating frequency of the IC should not exceed 10% of 32 MHz, that is 35.2 MHz; - 3. Please confirm that the change of HRC frequency will not affect other functions. # 7.5 Low- frequency RC Oscillator and Low- frequency Clock Timer The SC95F776X with built-in 32 kHz RC and 32.768 kHz crystal oscillator circuit, can be used as the Base Timer clock source. The oscillator is directly connected to a Base Timer, which can wake the CPU from STOP mode and generate an interrupt. Page 76 of 252 V0.1 # BTMCON (FBH) Low-frequency Timer Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------|-------|---|---|-------------|---|---|---| | Bit<br>Mnemonic | ENBTM | BTMIF | - | - | BTMFS[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 | | | | | | | | | | 0: Base Timer and its clock source do not start | | | | | | | | | | 1: Base Timer and its clock source start | | | | | | | | 6 | BTMIF | Base Timer interrupt application flag | | | | | | | | | | When the CPU accepts the Base Timer interrupt, this flag will be automatically cleared by hardware. | | | | | | | | 3~0 | BTMFS [3: 0] | Low frequency clock interrupt frequency selection | | | | | | | | | | 0000: An interrupt is generated every 15.625ms | | | | | | | | | | 0001: An interrupt is generated every 31.25ms | | | | | | | | | | 0010: An interrupt is generated every 62.5ms | | | | | | | | | | 0011: An interrupt is generated every 125ms | | | | | | | | | | 0100: An interrupt is generated every 0.25 seconds | | | | | | | | | | 0101: An interrupt is generated every 0.5 seconds | | | | | | | | | | 0110: An interrupt is generated every 1.0 seconds | | | | | | | | | | 0111: An interrupt is generated every 2.0 seconds | | | | | | | | | | 1000: An interrupt is generated every 4.0ms | | | | | | | Page 77 of 252 V0.1 | | | 1001: An interrupt is generated every 8.0 seconds 1010: An interrupt is generated every 16.0 seconds 1011: An interrupt is generated every 32.0 seconds 1100~1111: reserved | |-----|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5~4 | - | reserved | #### OP\_CTM0 (C1H@FFH) Code Option Register 0 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------|-------|-------------|---|--------|-----------|------------|---| | Bit<br>Mnemonic | ENWDT | ENXTL | SCLKS[1: 0] | | DISRST | DISLVR | LVRS[1: 0] | | | R/W | R/W | R/W | R/W | | R/W | read only | R/W | | | POR | n | n | n | | n | n | ľ | 1 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------------------------------------------------------------------------------------------------------| | 6 | ENXTL | External 32.768kHz crystal selector switch | | | | 0: The external 32.768kHz crystal is off, P5.0 and P5.1 are valid, and the internal LRC is valid; | | | | 1: The external 32.768kHz crystal is turned on, P5.0 and P5.1 are invalid, and the internal LRC is invalid. | Note: HRC can be automatically calibrated by connecting a 32.768 kHz crystal oscillator. Therefore, if the user uses the 32.768 kHz external crystal oscillator function, the HRC frequency will always be corrected to 32 MHz. At this time, adjusting OP\_HRCR cannot change the HRC frequency. The connection circuit used by P5.0/P5.1 external 32.768kHz oscillator as BaseTimer is as follows: Page 78 of 252 V0.1 C2 (10~12P) # OSCI/P5.1 C1 (10~12P) 32.768K Crystal OSCO/P5.0 32.768kHz external crystal connection diagram The internal and external oscillation selection relationship of Base Timer is as follows: Base Timer Structure diagram # 7.6 Power Saving Modes The SC95F776X supports two different software selectable power-reducing modes: IDLE and STOP. These modes are accessed through the PCON register. Setting the PCON.1 bit enters STOP mode. STOP mode stops the internal high-frequency oscillator in order to minimize power consumption. In STOP mode, users can wake up the SC95F776X through external interrupts INT0~2, Base Timer and CMP interrupt. STOP mode can also be awakened by an external reset. Setting the PCON.0 bit enters IDLE mode. In IDLE mode the program stops running and all CPU states are saved before entering IDLE mode. IDLE mode can be woken up by any interrupt. #### PCON (87H) Power Management Control Register (read/write) (write only, \*not readable\*) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|---|---|---|-----|---|------|-----| | Bit<br>Mnemonic | SMOD | - | - | - | RST | - | STOP | IDL | Page 79 of 252 V0.1 # **Super High-speed 1T 8051 Core Flash MCU** | R/W | Write<br>only | - | - | - | Write<br>only | - | Write<br>only | Write<br>only | |-----|---------------|---|---|---|---------------|---|---------------|---------------| | POR | 0 | х | х | х | n | х | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | STOP | STOP mode bit. 0: normal operating mode 1: stop mode, high-frequency oscillator stops operating, low-frequency oscillator and WDT can select to work based on configuration | | 0 | IDL | IDLE mode bit. 0: normal operating mode 1: IDLE mode, the program stops operating, but external equipment and clock continue to operate and all CPU states are saved before entering IDLE mode | Notes: When Configuring 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: set MCU to enter STOP mode: Example in C Language #include"intrins.h" PCON |= 0x02; // PCON bit1 STOP bit write 1, configure the MCU to enter STOP mode \_nop\_(); // At least 8 \_nop\_() are required \_nop\_(); \_nop\_(); \_nop\_(); \_nop\_(); \_nop\_(); Page 80 of 252 V0.1 | _nop_(); | | |--------------------|--------------------------------------------------------------------| | _nop_(); | | | | | | | | | Assembly Language: | | | ORL PCON,#02H | ; PCON bit1 STOP bit write 1, configure the MCU to enter STOP mode | | NOP | ; At least 8 NOPs are requiredNOP | | NOP | | | NOP | | | NOP | | | NOP | | | NOP | | | NOP | | | | | # 8 CPU and Instruction Set #### 8.1 CPU The SC95F776X is built around an enhanced super-high-speed 1T 8051 core, and its instructions are fully compatible with classic 8051 core. # 8.2 Addressing Mode The addressing modes of 1T 8051 CPU instructions of the SC95F776X are: ①Immediate Addressing ② Direct Addressing ③ Indirect Addressing ④ Register Addressing ⑤ Relative Addressing ⑥ Indexed Addressing ⑦ Bit Addressing. #### 8.2.1 Immediate Addressing Immediate addressing is also called immediate data addressing. It directly gives the operands participating in the operation in the instruction operand. Examples of instructions are as follows: MOV A, #50H (This instruction moves the immediate value 50H to accumulator A) #### 8.2.2 Direct Addressing In direct addressing mode, the instruction operand field gives the address of the operand to participate in the operation. The direct addressing mode can only be used to represent special function registers, internal data Page 81 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU registers, and bit address spaces. The special function registers and bit address spaces can only be accessed by direct addressing. Examples are as follows: ANL 50H, #91H (indicating that the number in the 50H unit is ANDed with the immediate 91H, and the result is stored in the 50H unit. 50H is direct address, representing a unit in the internal data register RAM.) #### 8.2.3 Indirect Addressing Indirect addressing is indicated by adding the "@" symbol before R0 or R1. Assuming that the data in R1 is 40H, and the data in the internal data memory 40H unit is 55H, the instruction is MOV A, @R1 (Move data 55H to accumulator A). #### 8.2.4 Register Addressing When register addressing, operate on the selected operating registers R7~R0, accumulator A, general register B, address register and carry C. Registers R7~R0 are represented by the low three bits of the instruction code, and ACC, B, DPTR and carry bit C are implicitly contained in the instruction code. Therefore, register addressing also includes an implicit addressing method. The selection of the register operating area is determined by RS1 and RS0 in the program status word register PSW. The register specified by the instruction operand refers to the register in the current operating area. INC R0 Refers to(R0)+1→R0 #### 8.2.5 Relative Addressing Relative addressing is to add the current value in the program counter PC to the number given by the second byte of the instruction, and the result is used as the branch address of the branch instruction. The branch address also becomes the branch destination address, the current value in the PC becomes the base address, and the number given by the second byte of the instruction becomes the offset. Since the destination address is relative to the base address in the PC, this addressing method becomes relative addressing. The offset is a signed number, and the range that can be expressed is -128~+127. This addressing method is mainly used for branch instructions. JC \$+50H It means that if the carry bit C is 0, the content in the program counter PC does not change, that is, it does not transfer. If the carry bit C is 1, the current value as base address in the PC plus the offset 50H will be used as the destination address of the branch instruction. #### 8.2.6 Indexed Addressing In the indexed addressing mode, the instruction operand specifies an index register that stores the index base address. In indexed addressing, the offset is added to the index base value, and the result is used as the address of the operand. The index registers are the program counter PC and the address register DPTR. MOVC A, @A+DPTR It indicates that the accumulator A is an offset register, and its content is added to the content of the address register DPTR. The result is used as the address of the operand, and the number in this unit is taken out and sent to the accumulator A. #### 8.2.7 Bits Addressing Page 82 of 252 V0.1 ### Super High-speed 1T 8051 Core Flash MCU Bit addressing refers to the addressing mode when performing bit operations on some internal data memory RAMs and special function registers that can perform bit operations. When performing bit operations, with the help of carry bit C as a bit operation accumulator, the instruction operand directly gives the address of the bit, and then performs bit operation on the bit according to the nature of the opcode. The bit address is exactly the same as the byte address encoding method in direct byte addressing, which is mainly distinguished by the nature of the operation instruction, and special attention should be paid when using it. MOV C, 20H (The value of the bit manipulation register with address 20H is sent to carry bit C) Page 83 of 252 V0.1 # 9 Interrupts SC95F776X provides 20 interrupt sources: TIMER 0~4, INT0~2, ADC, PWM, UART, USCI0~5, BASE TIMER, CMP. These 19 interrupt sources are divided into two interrupt priorities and can be set to either high or low priority separately..Three external interrupts can be set as up, down or both trigger conditions for each interrupt source respectively. Each interrupt has its own priority setting bit, interrupt flag, interrupt vector and enable bit respectively. The total enable bit EA can open or close all interrupts. # 9.1 Interrupt Source and Vector The list of the SC95F776X interrupt sources, interrupt vectors, and related control bits are as follows: | Interrupt<br>Source | Interrupt<br>condition | Interrupt Flag | Interrupt<br>Enable Control | Interrupt<br>Priority<br>Control | Interrupt<br>Vector | Query Priority | Interrupt<br>Number (C51) | Flag Clear<br>Mode | Capability of<br>Waking up<br>STOP | |---------------------|--------------------------------------------------|----------------|-----------------------------|----------------------------------|---------------------|----------------|---------------------------|--------------------|------------------------------------| | INTO | External interrupt 0 conditions are met | IE0 | EINTO | IPINT0 | 0003H | 1 (HIGH) | 0 | H/W Auto | YES | | Timer 0 | Timer 0<br>overflow | TF0 | ET0 | IPT0 | 000BH | 2 | 1 | H/W Auto | NO | | INT1 | External<br>interrupt 1<br>conditions<br>are met | IE1 | EINT1 | IPINT1 | 0013H | 3 | 2 | H/W Auto | YES | | Timer 1 | Timer 1 overflow | TF1 | ET1 | IPT1 | 001BH | 4 | 3 | H/W Auto | NO | | UART | Receive<br>or send<br>completed | RI/TI | EUART | IPUART | 0023H | 5 | 4 | Must user<br>Clear | NO | | Timer 2 | Timer 2 overflow | TFX | ET2 | IPT2 | 002BH | 6 | 5 | Must user<br>Clear | NO | | ADC | ADC<br>conversio<br>n<br>completed | ADCIF | EADC | IPADC | 0033H | 7 | 6 | Must user<br>Clear | NO | Page 84 of 252 V0.1 # Super High-speed 1T 8051 Core Flash MCU | USCI0 | Receive<br>or send<br>completed | SPIF0/TWI<br>F0 | EUSCI0 | IPSPI | 003BH | 8 | 7 | Must user<br>Clear | NO | |---------|--------------------------------------------------|-----------------|--------|--------|-------|----|----|--------------------|-----| | PWM | PWM<br>overflow | PWMIF | EPWM | IPPWM | 0043H | 9 | 8 | Must user<br>Clear | NO | | ВТМ | Base<br>timer<br>overflow | BTMIF | EBTM | IPBTM | 004BH | 10 | 9 | H/W Auto | YES | | INT2 | External<br>interrupt 2<br>conditions<br>are met | - | EINT2 | IPINT2 | 0053H | 11 | 10 | - | YES | | СМР | Comparat<br>o-r<br>interrupt<br>condition<br>met | CMPIF | ECMP | IPCMP | 0063H | 13 | 12 | Must user<br>Clear | YES | | Timer 3 | Timer 3 overflow | TFX | ЕТ3 | IPT3 | 006BH | 14 | 13 | Must user<br>Clear | NO | | Timer 4 | Timer 4<br>overflow | TFX | ET4 | IPT4 | 0073H | 15 | 14 | Must user<br>Clear | NO | | USCI1 | Receive<br>or send<br>completed | SPIF1/TWI<br>F1 | EUSCI1 | IPSPI1 | 007BH | 16 | 15 | Must user<br>Clear | NO | | USCI2 | Receive<br>or send<br>completed | SPIF2/TWI<br>F2 | EUSCI2 | IPSPI2 | 0083H | 17 | 16 | Must user<br>Clear | NO | | USCI3 | Receive<br>or send<br>completed | SPIF3/TWI<br>F3 | EUSCI3 | IPSPI3 | 008BH | 18 | 17 | Must user<br>Clear | NO | | USCI4 | Receive<br>or send<br>completed | SPIF4/TWI<br>F4 | EUSCI4 | IPSPI4 | 0093H | 19 | 18 | Must user<br>Clear | NO | Page 85 of 252 V0.1 ### Super High-speed 1T 8051 Core Flash MCU | USCI5 | Receive<br>or send<br>completed | SPIF5/TWI<br>F5 | EUSCI5 | IPSPI5 | 009BH | 20 | 19 | Must user<br>Clear | NO | | |-------|---------------------------------|-----------------|--------|--------|-------|----|----|--------------------|----|--| |-------|---------------------------------|-----------------|--------|--------|-------|----|----|--------------------|----|--| Under the circumstance where the master interrupt control bit EA=1 and the respective interrupt control bit have been enable, the interrupt occurrence is shown below: **Timer Interrupt:** Interrupt generates when Timer 0 or Timer 1 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 Timer 2~4 overflows and the interrupt flag TF2 is set to "1". Once Timer 2~4 interrupt generates, the hardware would not automatically clear TF2~4 bit, which must be cleared by the user's software. **UART Interrupt:** When UART0 completes receiving or transmitting a frame of data, bit RI or TI will be set to "1" automatically by hardware, and UART interrupt occurs. Once UART interrupt occurs, the hardware would not automatically clear up RI/TI bit, which shall be cleared by user's software. **ADC Interrupt:** After ADC conversion is completed, ADC interrupt generates, whose interrupt flag is the ADC conversion completion flag EOC/ADCIF (ADCCON.5). 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. **SSI Interrupt:** When SSI completes receiving or transmitting a frame of data, SPIF/TWIF bit will be set to "1" automatically by hardware, and SSI interrupt generates. When the microcontroller unit serves SSI interrupt, the interrupt flag SPIF/TWIF must be cleared by software. **PWM Interrupt:** When PWM counter overflows (beyond PWMPD), the flag will be set as 1 automatically by hardware. Meanwhile, if the PWM interrupt control bit IE1[1] (EPWM) is set as 1, PWM interrupt will occurs. Once PWM interrupt occurs, the hardware would not clear the interrupt flag automatically, which shall be cleared by user's software. **External Interrupt INT0 ~ 2:** When any external interrupt pin meets the interrupt conditions, external interrupt generates. The external interrupt INT0 and INT1 would set up interrupt flag IE0 and IE1 respectively, which will be automatically cleared by hardware rather than user. INT0 have 4 external interrupt sources, INT1 have 8 external interrupt sources and INT2 have 4 external interrupt sources, 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 ~ 2 can also wake up STOP mode of microcontroller unit. Page 86 of 252 V0.1 # 9.2 Interrupt Structure Diagram The interrupt structure of SC95F776X is shown below: Page 87 of 252 V0.1 ### Super High-speed 1T 8051 Core Flash MCU SC95F776X Interrupt structure and vector # 9.3 Interrupt Priority The SC95F776X micro controller 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: - ① A lower priority interrupt can be interrupted by a higher priority interrupt request, but not vice verse; - ② 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 SC95F776X 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 an interrupt is generated and responded by the CPU, the main program execution is interrupted and the following operations will be performed: - The currently executing instruction is finished; - 2 The PC value is pushed into the stack to protect the scene: - The interrupt vector address is loaded into the program counter PC; - 4 Execute the corresponding interrupt service program; - (5) The interrupt service routine ends and RETI; - (6) Unstack the PC value and return to the program before the interruption. In this process, the system will not immediately execute other interrupts of the same priority, but will retain the interrupt request that has occurred, and after the current interrupt processing is completed, go to execute a new interrupt request. # 9.5 Interrupt-related SFR Registers IE (A8H) Interrupt Enable Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|---|---|---|---|---|---|---|---| |------------|---|---|---|---|---|---|---|---| Page 88 of 252 V0.1 | Bit<br>Mnemonic | EA | EADC | ET2 | EUART | ET1 | EINT1 | ET0 | EINT0 | |-----------------|-----|------|-----|-------|-----|-------|-----|-------| | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|------------------------------------------------------------------------| | 7 | EA | Interrupt enable total control | | | | 0: Close all interrupts | | | | 1: Enable all interrupts | | 6 | EADC | ADC interrupt enable control | | | | 0: Disable ADC interrupt | | | | Allow the ADC to generate an interrupt when the conversion is complete | | 5 | ET2 | Timer 2 interrupt enable control | | | | 0: Disable Timer 2 interrupt | | | | 1: Enable Timer 2 interrupt | | 4 | EUART | UART interrupt enable control | | | | 0: Disable UART interrupt | | | | 1: Allow UART interrupt | | 3 | ET1 | Timer 1 interrupt enable control | | | | 0: Disable Timer | | | | 1 interrupt1: Enable Timer 1 interrupt | | 2 | EINT1 | External interrupt 1 enable control | Page 89 of 252 V0.1 | | | 0: close INT1 interrupt 1: Enable INT1 interrupt | |---|-------|-------------------------------------------------------------------------------------------| | 1 | ET0 | Timer 0 interrupt enable control 0: Disable TIMER0 interrupt 1: Enable TIMER0 interrupt | | 0 | EINT0 | External interrupt 0 enable control 0: close INT0 interrupt 1: Enable INT0 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 | IPINT1 | IPT0 | IPINT0 | | R/W | - | R/W | POR | х | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------------------------------------------------------------------------------------------------------------| | 6 | IPADC | ADC interrupt priority selection 0: ADC interrupt priority is low 1: ADC interrupt priority is high | | 5 | IPT2 | Timer 2 interrupt priority selection 0: Timer 2 interrupt priority is low 1: Timer 2 interrupt priority is high | Page 90 of 252 V0.1 | 4 | IPUART | UART interrupt priority selection 0: UART interrupt priority is low 1: UART interrupt priority is high | |---|--------|-------------------------------------------------------------------------------------------------------------------| | 3 | IPT1 | Timer 1 interrupt priority selection 0: Timer 1 interrupt priority is low 1: Timer 1 interrupt priority is high | | 2 | IPINT1 | INT1 counter interrupt priority selection 0: INT1 interrupt priority is low 1: INT1 interrupt priority is high | | 1 | IPT0 | Timer 0 interrupt priority selection 0: Timer 0 interrupt priority is low 1: Timer 0 interrupt priority is high | | 0 | IPINT0 | INT0 counter interrupt priority selection 0: INT0 interrupt priority is low 1: INT0 interrupt priority is high | | 7 | - | Reserved | # IE1 (A9H) Interrupt Enable Register 1 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|-----|------|---|-------|------|------|--------| | Bit<br>Mnemonic | ET4 | ET3 | ECMP | - | EINT2 | EBTM | EPWM | EUSCI0 | | R/W | R/W | R/W | R/W | - | R/W | R/W | R/W | R/W | | POR | 0 | 0 | 0 | х | 0 | 0 | 0 | 0 | Page 91 of 252 V0.1 | Bit number | Bit Mnemonic | Description | |------------|--------------|---------------------------------------------------------| | 7 | ET4 | Timer 4 interrupt enable control | | | | 0: Disable Timer 4 interrupt | | | | 1: Enable Timer 4 interrupt | | 6 | ЕТ3 | Timer 3 interrupt enable control | | | | 0: Disable Timer 3 interrupt | | | | 1: Enable Timer 3 interrupt | | 5 | ECMP | Analog comparator interrupt enable control | | | | 0: Disable the analog comparator interrupt | | | | 1: Open the analog comparator interrupt | | 3 | EINT2 | External interrupt 2 enable control | | | | 0: close INT2 interrupt | | | | 1: Open INT2 interrupt | | 2 | EBTM | Base Timer interrupt enable control | | | | 0: Disable Base Timer interrupt | | | | 1: Enable Base Timer interrupt | | 1 | EPWM | PWM interrupt enable control | | | | 0: Disable PWM interrupt | | | | 1: Enable interrupt when PWM count overflows | | 0 | EUSCI0 | Three-in-one serial port USCI0 interrupt enable control | | | | 0: Disable serial port interrupt | | | | 1: Allow serial port interrupt | Page 92 of 252 V0.1 | 4 | - | Reserved | |---|---|----------| |---|---|----------| #### IP1 (B9H) Interrupt Priority Control Register 1 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|-------|---|--------|-------|-------|---------| | Bit<br>Mnemonic | IPT4 | IPT3 | IPCMP | - | IPINT2 | IPBTM | IPPWM | IPUSCI0 | | 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 | IPT4 | Timer 4 interrupt priority selection 0: Timer 4 interrupt priority is low 1: Timer 4 interrupt priority is high | | 6 | IPT3 | Timer 3 interrupt priority selection 0: Timer 3 interrupt priority is low 1: Timer 3 interrupt priority is high | | 5 | IPCMP | Analog comparator interrupt priority selection 0: Analog comparator interrupt priority is low 1: Analog comparator interrupt priority is high | | 3 | IPINT2 | INT2 counter interrupt priority selection 0: INT2 interrupt priority is low 1: INT2 interrupt priority is high | Page 93 of 252 V0.1 | 2 | IPBTM | Base Timer interrupt priority selection 0: Base Timer interrupt priority is low 1: Base Timer interrupt priority is high | |---|---------|--------------------------------------------------------------------------------------------------------------------------------------| | 1 | IPPWM | PWM interrupt enable selection 0: PWM interrupt priority is low 1: PWM interrupt priority is high | | 0 | IPUSCI0 | Three-in-one serial port USCI0 interrupt priority selection 0: USCI0 interrupt priority is low 1: USCI0 interrupt priority is high | | 4 | - | Reserved | # IE2 (AAH) Interrupt Enable Register 2 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------------------|---|---|---|----------------|----------------|----------------|----------------|----------------| | Symbol | - | | | EUSCI5 | EUSCI4 | EUSCI3 | EUSCI2 | EUSCI1 | | Read/<br>Write | - | | - | Read/<br>Write | Read/<br>Write | Read/<br>Write | Read/<br>Write | Read/<br>Write | | Initial<br>power-on<br>value | х | x | х | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------------------------------------------------------------------------------------| | 4 | EUSCI5 | Three-in-one serial port USCI5 interrupt enable control 0: Disable serial port interrupt | Page 94 of 252 V0.1 | | | 1: Allow serial port interrupt | |-----|--------|---------------------------------------------------------------------------------------------------------------------------| | 3 | EUSCI4 | Three-in-one serial port USCI4 interrupt enable control 0: Disable serial port interrupt 1: Allow serial port interrupt | | 2 | EUSCI3 | Three-in-one serial port USCI3 interrupt enable control 0: Disable serial port interrupt 1: Allow serial port interrupt | | 1 | EUSCI2 | Three-in-one serial port USCI2 interrupt enable control 0: Disable serial port interrupt 1: Allow serial port interrupt | | 0 | EUSCI1 | Three-in-one serial port USCI1 interrupt enable control 0: Disable serial port interrupt 1: Allow serial port interrupt | | 7~2 | - | Reserved | # IP2 (BAH) Interrupt Priority Control Register 2 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|---|---------|---------|---------|----------|---------| | Bit<br>Mnemonic | - | - | - | IPUSCI5 | IPUSCI4 | IPUSCI3 | IPUSCI 2 | IPUSCI1 | | R/W | - | - | - | R/W | R/W | R/W | R/W | R/W | | POR | х | х | х | 0 | 0 | 0 | 0 | 0 | Page 95 of 252 V0.1 | Bit number | Bit Mnemonic | Description | |------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------| | | IPUSCI5 | Three-in-one serial port USCI5 interrupt priority selection 0: USCI5 interrupt priority is low 1: USCI5 interrupt priority is high | | | IPUSCI4 | Three-in-one serial port USCI4 interrupt priority selection 0: USCI4 interrupt priority is low 1: USCI4 interrupt priority is high | | | IPUSCI3 | Three-in-one serial port USCI3 interrupt priority selection 0: USCI3 interrupt priority is low 1: USCI3 interrupt priority is high | | 1 | IPUSCI2 | Three-in-one serial port USCI2 interrupt priority selection 0: USCI2 interrupt priority is low 1: USCI2 interrupt priority is high | | 0 | IPUSCI1 | Three-in-one serial port USCI1 interrupt priority selection 0: USCI1 interrupt priority is low 1: USCI1 interrupt priority is high | | 7~5 | | Reserved | ### TCON (88H) Timer Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|-----|-----|-----|-----|---|-----|---| | Bit<br>Mnemonic | TF1 | TR1 | TF0 | TR0 | IE1 | - | IE0 | - | | R/W | R/W | R/W | R/W | R/W | R/W | - | R/W | - | Page 96 of 252 V0.1 | Bit number | Bit Mnemonic | Description | |------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | IE1 | INT1 overflow interrupt request flag. INT1 generates an overflow. When an interrupt occurs, the hardware sets IE1 to "1" and applies for an interrupt. When the CPU responds, the hardware clears "0". | | 1 | IE0 | INTO overflow interrupt request flag. INTO generates an overflow. When an interrupt occurs, the hardware sets IEO to "1" and applies for an interrupt. When the CPU responds, the hardware clears "0". | | 2,0 | - | Reserved | # INT0F (B4H) INT0 Falling Edge Interrupt Control Register (read/write) | Bit number | 7 | 6 | .5 | 4 | 3 | 2 | 1 | 0 | |-----------------|--------|--------|--------|--------|---|---|---|---| | Bit<br>Mnemonic | INT0F7 | INT0F6 | INT0F5 | INT0F4 | - | - | - | - | | R/W | R/W | R/W | R/W | R/W | - | - | - | - | | POR | 0 | 0 | 0 | 0 | х | х | х | х | | Bit number | Bit Mnemonic | Description | |------------|-------------------|--------------------------------------------------------------------------------------------------------------------| | 7~4 | INT0Fn<br>(n=7~4) | INT0 falling edge interrupt control 0: INT0n falling edge interrupt close 1: INT0n falling edge interrupt enable | | 3~0 | - | Reserved | Page 97 of 252 V0.1 ### INTOR (BBH) INTO Rising Edge Interrupt Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|--------|--------|--------|--------|---|---|---|---| | Bit<br>Mnemonic | INT0R7 | INT0R6 | INT0R5 | INT0R4 | - | - | - | - | | R/W | R/W | R/W | R/W | R/W | - | - | - | | | POR | 0 | 0 | 0 | 0 | х | х | х | x | | Bit number | Bit Mnemonic | Description | |------------|-------------------|-----------------------------------------------------------------------------------------------------------------| | 7~4 | INT0Rn<br>(n=7~4) | INT0 rising edge interrupt control 0: INT0n rising edge interrupt close 1: INT0n rising edge interrupt enable | | 3~0 | - | Reserved | ### INT1F (BCH) INT1 Falling Edge Interrupt Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|--------|--------|--------|--------|--------|--------|--------|--------| | Bit<br>Mnemonic | INT1F7 | INT1F6 | INT1F5 | INT1F4 | INT1F3 | INT1F2 | INT1F1 | INT1F0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------| |------------|--------------|-------------| Page 98 of 252 V0.1 | 7~0 | INT1Fn | INT1 falling edge interrupt control | |-----|---------|----------------------------------------| | | (n=7~0) | 0: INT1n falling edge interrupt close | | | | 1: INT1n falling edge interrupt enable | ### INT1R (BDH) INT1 Rising Edge Interrupt Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|--------|--------|--------|--------|--------|--------|--------|--------| | Bit<br>Mnemonic | INT1R7 | INT1R6 | INT1R5 | INT1R4 | INT1R3 | INT1R2 | INT1R1 | INT1R0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | | | | | | |------------|-------------------------------------------|---------------------------------------|--|--|--|--|--| | 7~0 | INT1Rn INT1 rising edge interrupt control | | | | | | | | | (n=7~0) | 0: INT1n rising edge interrupt off | | | | | | | | | 1: INT1n rising edge interrupt enable | | | | | | # INT2F (BEH) INT2 Falling Edge Interrupt Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|---|---|--------|--------|--------|--------| | Bit<br>Mnemonic | - | - | - | - | INT2F3 | INT2F2 | INT2F1 | INT2F0 | | R/W | - | - | - | - | R/W | R/W | R/W | R/W | | POR | х | х | х | х | 0 | 0 | 0 | 0 | Page 99 of 252 V0.1 | Bit number | Bit Mnemonic | Description | |------------|-------------------|--------------------------------------------------------------------------------------------------------------------| | 3~0 | INT2Fn<br>(n=3~0) | INT2 falling edge interrupt control 0: INT2n falling edge interrupt close 1: INT2n falling edge interrupt enable | | 7~4 | - | Reserved | # INT2R (BFH) INT2 Rising Edge Interrupt Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|---|---|--------|--------|--------|--------| | Bit<br>Mnemonic | - | - | - | | INT2R3 | INT2R2 | INT2R1 | INT2R0 | | R/W | - | - | | - | R/W | R/W | R/W | R/W | | POR | х | x | х | x | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|-------------------|-----------------------------------------------------------------------------------------------------------------| | 3~0 | INT2Rn<br>(n=3~0) | INT2 rising edge interrupt control 0: INT2n rising edge interrupt close 1: INT2n rising edge interrupt enable | | 7~4 | - | Reserved | Page 100 of 252 V0.1 ### 10 Timer/Counter T0 and T1 Timer 0 and Timer 1 inside the SC95F776X MCU are two 16-bit timers/counters. They have two operating modes: counting mode and timing mode. There is a control bit C/Tx in the special function register TMOD to select whether T0 and T1 are timers or counters. They are essentially an addition counter, but the source of the count is different. The source of the timer is the system clock or its divided clock, but the source of the counter is the input pulse of the external pin. Only when TRx=1, T0 and T1 will be opened to count. In counter mode, for each pulse on the P0.2/T0 and P0.3/T1 pins, the count value of T0 and T1 increases by 1, respectively. In the timer mode, the count source of T0 and T1 can be selected as fsys/12 or fsys through the special function register TMCON (fsys is the divided system clock). There are 4 operating modes for timer/counter T0, and 3 operating modes for timer/counter T1 (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 auto-reload mode - 4 Mode 3: Two 8-bit timer/counter modes In the 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 | Symbol | Address | Description | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | POR | |--------|---------|-------------------------------|-------------------------------|-----------|-----------|-----|----------|----------|-----|---|-----------| | TCON | 88H | Timer control register | TF1 | TR1 | TF0 | TR0 | IE1 | ı | IE0 | ı | 00000x0xb | | TMOD | 89H | Timer operating mode register | - C/T1 M11 M01 - C/T0 M10 M00 | | x000x000b | | | | | | | | TL0 | 8AH | Low 8 bits of timer 0 | | TL0[7: 0] | | | | 0000000b | | | | | TL1 | 8BH | Low 8 bits of timer 1 | | TL1[7: 0] | | | 0000000b | | | | | | TH0 | 8CH | Timer 0 high 8 bits | | TH0[7: 0] | | | | 0000000b | | | | | TH1 | 8DH | Timer 1 high 8 bits | | | | TH | l1[7: 0] | | | | 00000000b | Page 101 of 252 V0.1 # Super High-speed 1T 8051 Core Flash MCU | TMCON | 8EH | Timer frequency control register | USMDX[1<br>: 0] | - | - | - | - | T1FD | T0FD | 00xxxx00b | |-------|-----|----------------------------------|-----------------|---|---|---|---|------|------|-----------| | | | | | | | | | | | | The explanation of each register is as follows: #### TCON (88H) Timer Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|-----|-----|-----|-----|---|-----|---| | Bit<br>Mnemonic | TF1 | TR1 | TF0 | TR0 | IE1 | | IEO | • | | 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 | TF1 | T1 overflow interrupt request flag. T1 generates an overflow. When an interrupt occurs, the hardware sets TF1 to "1" and applies for an interrupt. When the CPU responds, the hardware clears "0". | | 6 | TR1 | Operation control bit of timer T1. This bit is set and cleared by software. When TR1=1, T1 is allowed to start counting. When TR1=0, T1 counting is prohibited. | | 5 | TF0 | To overflow interrupt request flag. To overflows. When an interrupt occurs, the hardware sets TF0 to "1" and applies for an interrupt. When the CPU responds, the hardware clears "0". | | 4 | TR0 | Operation control bit of timer T0. This bit is set and cleared by software. When TR0=1, T0 is allowed to start counting. When TR0=0, T0 counting is prohibited. | | 2,0 | - | Reserved | Page 102 of 252 V0.1 # 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 | - | C/T0 | 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 | C/T1 | TMOD[6] control timer 1 0: Timer, T1 count comes from fsys frequency division 1: Counter, T1 count comes from external pin T1/P0.3 | | 5~4 | M11,M01 | Timer/Counter 1 mode selection 00: 13-bit timer/counter, the upper 3 bits of TL1 are invalid 01: 16-bit timer/counter, TL1 and TH1 all are valid 10: 8-bit auto-reload timer, automatically reload the value stored in TH1 into TL1 when overflow 11: Timer/Counter 1 is invalid (stop counting) | | 2 | С/Т0 | TMOD[2] control timer 0 0: Timer, T0 count comes from fsys frequency division 1: Counter, T0 count comes from external pin T0/P0.2 | | 1~0 | M10,M00 | Timer/Counter 0 mode selection 00: 13-bit timer/counter, the upper 3 bits of TL0 are invalid | Page 103 of 252 V0.1 | 7,3 | _ | 11: Timer 0 is now a dual 8-bit timer/counter. TL0 is an 8-bit timer/counter controlled by the control bits of standard timer 0; TH0 is only an 8-bit timer controlled by the control bits of timer 1. | |-----|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | <ul><li>01: 16-bit timer/counter, TL0 and TH0 all are valid</li><li>10: 8-bit auto-reload timer, automatically reload the value stored in TH0 into TL0 when overflow</li></ul> | TMOD[0]~TMOD[2] in TMOD register is to set the operating mode of T0; TMOD[4]~TMOD[6] is to set the operating mode of T1. The timer and counter Tx functions are selected by the control bits C/Tx of the special function register TMOD. M0x and M1x are used to select the Tx operating mode. TRx acts as the switch control of T0 and T1. Only when TRx=1, T0 and T1 are turned on. #### TMCON (8EH) Timer Frequency Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|----------|---|---|---|---|------|------| | Bit<br>Mnemonic | USMD | 0X[1: 0] | | | - | 1 | T1FD | T0FD | | R/W | R/W | R/W | - | _ | - | - | R/W | R/W | | POR | 0 | 0 | x | х | х | х | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|---------------------------------------------------------------------------------------------------------------------| | 1 | T1FD | T1 input frequency selection control 0: T1 frequency is derived from fsys/12 1: T1 frequency is derived from fsys | | 0 | T0FD | T0 input frequency selection control 0: T0 frequency is derived from fsys/12 | Page 104 of 252 V0.1 | | 1: T0 frequency is derived from 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 | EINT1 | ЕТО | EINTO | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|----------------------------------| | 3 | ET1 | Timer 1 interrupt enable control | | | | 0: Disable Timer 1 interrupt | | | | 1: Enable Timer 1 interrupt | | 1 | ET0 | Timer 0 interrupt enable control | | | | 0: Disable Timer 0 interrupt | | | | 1: Enable Timer 0 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 | IPINT1 | IPT0 | IPINT0 | | R/W | - | R/W | POR | х | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Page 105 of 252 V0.1 | Bit number | Bit Mnemonic | Description | |------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------| | 3 | IPT1 | Timer 1 interrupt priority 0: Set the interrupt priority of Timer 1 to "Low" 1: Set the interrupt priority of Timer 1 to "High" | | 1 | IPT0 | Timer 0 interrupt priority 0: Set the interrupt priority of Timer 0 to "Low" 1: Set the interrupt priority of Timer 0 to "High" | # 10.2 T0 Operating Modes By setting M10 and M00 (TMOD[1], TMOD[0]) in the register TMOD, timer/counter 0 can realize 4 different operating modes. #### Operating Mode 0: 13-bit Counter/Timer TH0 register stores the upper 8 bits (TH0.7~TH0.0) of the 13-bit counter/timer, and the TL0 stores the low 5 bits (TL0.4~TL0.0). The upper three bits of TL0 (TL0.7~TL0.5) are uncertain values and should be ignored when reading. When the 13-bit timer/counter overflows, the system will set the timer overflow flag TF0 to 1. If the timer 0 interrupt is enabled, an interrupt will be generated. C/T0 bit selects the clock input source of the counter/timer. If C/T0=1, the level change of the timer 0 input pin T0 (P0.2) from high to low will increase the timer 0 data register by 1. If C/T0=0, select the frequency division of the system clock as the clock source of timer 0. When TR0 is set to 1, the timer T0 is started. Setting TR0 does not forcibly reset the timer, meaning that if TR0 is set, the timer register will start counting from the value when TR0 was cleared last time. Therefore, before enabling the timer, the initial value of the timer register should be set. When applied as a timer, TOFD can be configured to select the frequency division ratio of the clock source. Page 106 of 252 V0.1 #### Timer/counter operating mode 0: 13-bit timer/counter #### **Operating Mode 1: 16-bit Counter/Timer** Except for using a 16-bit (all 8-bit data of TL0 is valid) counters/timers, Mode 1 and Mode 0 operate in the same way. The way to open and configure the counter/timer is the same. Timer/Counter Operating Mode 1: 16-bit Timer/Counter #### Operating Mode 2: 8-bit Automatic Reload Counter/Timer In operating mode 2, Timer 0 is an 8-bit auto-reload counter/timer. TL0 stores the count value, and TH0 stores the reload value. When the counter in TL0 overflows to 0x00, the timer overflow flag TF0 is set to 1, and the value of register TH0 is reloaded into register TL0. If the timer interrupt is enabled, an interrupt will be generated when TF0 is set to 1, but the reload value in TH0 will not change. Before allowing the timer to count correctly, TL0 must be initialized to the required value. Except for the auto-reload function, the counter/timer in operating mode 2 is enabled and configured in the same way as in modes 0 and 1. When used as a timer, the register TMCON.0 (T0FD) can be configured to select the ratio of the timer clock source divided by the system clock fsys. Timer/counter operating mode 2: 8-bit timer/counter with automatic reload Page 107 of 252 V0.1 #### Operating Mode 3: Two 8-bit Counters/Timers (Timer 0 Only) In operating mode 3, Timer 0 is used as two independent 8-bit counters/timers, which are controlled by TL0 and TH0, respectively. TL0 is controlled by timer 0 control bits (in TCON) and status bits (in TMOD): TR0, C/T0, TF0. Timer 0 can select the timer mode or counter mode through T0 TMOD.2 (C/T0). TH0 sets related control by timer 1 control TCON, but TH0 is only limited to timer mode and cannot be set to counter mode by TMOD.2 (C/T0). TH0 is enabled by the control of the timer control bit TR1, and TR1=1 needs to be set. When an overflow occurs and an interrupt is generated, TF1 will be set to 1, and the interrupt will be processed according to T1. When T0 is set to operating mode 3, the TH0 timer occupies the interrupt resources of T1 and the registers in TCON, and the 16-bit counter of T1 will stop counting, which is equivalent to "TR1=0". When using the TH0 timer to work, set TR1=1. ### 10.3 T1 Operating Mode By setting M11 and M01 (TMOD[5], TMOD[4]) in the register TMOD, timer/counter 1 can realize three different operating modes. #### Operating mode 0: 13-bit Timer/Counter The TH1 register stores the upper 8 bits (TH1.7~TH1.0) of the 13-bit counter/timer; the TL1 stores the low 5 bits (TL1.4~TL1.0). The upper three bits of TL1 (TL1.7~TL1.5) are uncertain values and should be ignored when reading. When the 13-bit timer counter increments and overflows, the system sets the timer overflow flag TF1 to 1. If Timer 1 interrupt is enabled, an interrupt will be generated. The C/T1 bit selects the clock source of the counter/timer. If C/T1=1, the level of timer 1 input pin T1 (P0.3) changes from high to low, which will increase the timer 1 data register by 1. If C/T1=0, select the frequency division of the system clock as the clock source of timer 1. Set TR1 to enable the timer. Setting TR1 does not forcibly reset the timer, meaning that if TR1 is set to 1, the timer register will start counting from the value when TR1 was cleared to 0 last time. Therefore, before enabling the timer, the initial value of the timer register should be set. When applied as a timer, T1FD can be configured to select the frequency division ratio of the clock source. Timer/counter operating mode 0: 13-bit timer/counter #### Operating mode 1: 16-bit Counter/Timer Page 108 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU Except for using a 16-bit (all 8-bit data of TL1 is valid) counter/timer, Mode 1 and Mode 0 operate in the same way. The way to open and configure the counter/timer is the same. Timer/counter operating mode 1: 16-bit timer/counter #### Operating mode 2: 8-bit Automatic Reload Counter/Timer In operating mode 2, Timer 1 is an 8-bit auto-reload counter/timer. TL1 stores the count value, and TH1 stores the reload value. When the counter in TL1 overflows to 0x00, the timer overflow flag TF1 is set to 1, and the value of register TH1 is reloaded into register TL1. If the timer interrupt is enabled, an interrupt will be generated when TF1 is set to 1, but the reload value in TH1 will not change. Before allowing the timer to count correctly, TL1 must be initialized to the required value. Except for the auto-reload function, the counter/timer in operating mode 2 is enabled and configured in the same way as modes 0 and 1. When used as a timer, the register TMCON.1 (T1FD) can be configured to select the ratio of the timer clock source divided by the system clock fsys. Timer/counter operating mode 2: 8-bit timer/counter with automatic reload Page 109 of 252 V0.1 ### 11 Timer/Counter T2/T3/T4 Timer 2/3/4 inside SC95F776X MCU are three independent Timers, among which Timer 2 has 4 operating modes, Timer 3 and Timer 4 have 3 operating mode. The control registers of Timer 2/3/4 share the same set of addresses (C8H-CDH), users can point the Timer X register set (TXCON / TXMOD / RCAPXL / RCAPXH / TLX / THX) to Timer 2/3/4 through TXINX[2: 0] In order to realize the function of three independent Timers configured by a group of registers. Note: Only after the TXINX[2: 0] configuration is successful, the Timer X register group will point to the Timer 2/3/4 specified by the user. At this time, operating the TimeX register group is an effective operation for the corresponding Timer. ### 11.1 T2/3/4-related Registers | Symbol | Address | Description | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | POR | |--------|---------|-------------------------------------------|-------------|-----------|------------|------------|-----------|-----------|----------|------------|-----------| | TXINX | CEH | Timer 2/3/4 control register pointer | TXINX[2: 0] | | | | xxxxx010b | | | | | | TXCON | C8H | Timer 2/3/4 control register | TFX | EXFX | RCLK<br>X | TCL<br>KX | EXEN<br>X | TRX | C/TX | CP/RL<br>X | 00000000b | | TXMOD | С9Н | Timer 2/3/4<br>operating mode<br>register | TXF<br>D | 1 | EPW<br>MN1 | EPW<br>MN0 | INVN1 | INVN<br>0 | TXO<br>E | DCXE<br>N | 0xxxxx00b | | RCAPXL | CAH | Timer 2/3/4 reload low 8 bits | | | | RCAP | XL[7: 0] | | | | 00000000b | | RCAPXH | СВН | Timer 2/3/4 reload high 8 bits | | | | RCAP | XH[7: 0] | | | | 00000000b | | TLX | ССН | Timer 2/3/4 low 8 bits | | | | TLX | ([7: 0] | | | | 00000000b | | ТНХ | CDH | Timer 2/3/4 high 8 bits | | THX[7: 0] | | | | | | 00000000b | | | TMCON | 8EH | Timer frequency control register | USME | X[1: 0] | - | - | - | - | T1FD | T0FD | 00xxxx00b | TXINX (CEH) Timer 2/3/4 Control Register Pointer (read/write) Page 110 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|---|---|---|-----|-------------|-----| | Bit<br>Mnemonic | - | - | - | - | - | | TXINX[2: 0] | | | R/W | - | - | - | - | - | R/W | R/W | R/W | | POR | х | х | х | х | x | 0 | 1 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2~0 | TXINX[2: 0] | Timer 2/3/4 control register pointer 010: Timer X register set: TXCON / TXMOD / RCAPXL / RCAPXH / TLX / THX points to T2 011: Timer X register set points to T3 100: Timer X register set points to T4 Other: reserved | | 7~3 | - | Reserved | # 11.2 Timer 2 Timer 2 inside the SC95F776X MCU has two operating modes: counting mode and timing mode. There is a control bit C/TX in the special function register TXCON to select whether T2 is a timer or a counter. They are essentially an addition counter, but the source of the count is different. The source of the timer is the system clock or its divided clock, but the source of the counter is the input pulse of the external pin. TRX is the switch control of T2/T3/T4 counting in the timer/counter mode. Only when TRX=1, T2 will be opened for counting. In counter mode, for every pulse on the T2 pin, the count value of T2 increases by 1 respectively. In timer mode, the count source of T2 can be selected as fsys/12 or fsys through the special function register TXMOD.7 (TXFD). Timer/counter T2 has 4 operating modes: ① Mode 0: 16-bit capture mode 2 Mode 1: 16-bit auto-reload timer mode Page 111 of 252 V0.1 - ③ Mode 2: Baud rate generator mode - 4 Mode 3: Programmable clock output mod TXINX[2: 0] = 010, the Timer X register group points to Timer 2, the explanation of each register is as follows: #### TXCON (C8H) Timer 2 Control Register (read/write) ( TXINX[2: 0] = 010) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|------|-------|-------|-------|-----|------|--------| | Bit<br>Mnemonic | TFX | EXFX | RCLKX | TCLKX | EXENX | TRX | C/TX | CP/RLX | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | TFX | Timer 2 overflow flag 0: No overflow (must be cleared by software) 1: Overflow (if RCLK = 0 and TCLK = 0, set by hardware 1) | | 6 | EXFX | Flag bit detected by external event input (falling edge) of T2EX pin 0: No external event input (must be cleared by software) 1: External input detected (if EXENX = 1, set by hardware) | | 5 | RCLKX | UART0 receive clock control bit 0: Timer 1 generates the receive baud rate 1: Timer 2 generates the receive baud rate | | 4 | TCLKX | UART0 transmit clock control bit 0: Timer 1 generates transmission baud rate | Page 112 of 252 V0.1 | | | 1: Timer 2 generates transmission baud rate | |---|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | EXENX | T2EX pin is used as a reload/capture trigger enable/disable control: 0: Ignore events on T2EX pin 1: When Timer 2 is not used as the UART0 clock, a falling edge on the T2EX pin is detected, and a capture or reload is generated | | 2 | TRX | Timer 2 start/stop control bit 0: stop timer 2/stop PWM2 counter 1: Start timer 2/start PWM2 counter | | 1 | С/ТХ | Timer 2 Timer/counter mode selection positioning 2 0: Timer mode, T2 pin is used as I/O port 1: Counter mode | | 0 | CP/RLX | Capture/reload mode selection positioning 0: 16-bit timer/counter with reload function 1: 16-bit timer/counter with capture function, TXEX is timer 2 external capture signal input port | # TXMOD (C9H) Timer 2 Operating Mode Register (read/write) ( TXINX[2: 0] = 010) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|---|--------|--------|-------|-------|------|-------| | Bit<br>Mnemonic | TXFD | - | EPWM21 | EPWM20 | INV21 | INV20 | TXOE | DCXEN | | 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 | |------------|--------------|-------------| |------------|--------------|-------------| Page 113 of 252 V0.1 | 7 | TXFD | T2 input frequency selection control 0: T2 frequency is derived from fsys/12 1: T2 frequency is derived from fsys | |---|-------|------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | TXOE | Timer 2 output enable bit 0: Set T2 as clock input or I/O port 1: Set T2 as the clock output | | 0 | DCXEN | Count down enable bit 0: Timer 2 is prohibited as an up/down counter, Timer 2 is only used as an up counter 1: Allow Timer 2 as an up/down counter | | 6 | - | Reserved | #### 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 | EINT1 | ET0 | EINTO | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|----------------------------------| | 5 | ET2 | Timer 2 interrupt enable control | | | | 0: Disable Timer 2 interrupt | | | | 1: Enable Timer 2 interrupt | Page 114 of 252 V0.1 ### **Super High-speed 1T 8051 Core Flash MCU** #### 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 | IPINT1 | IPT0 | IPINT0 | | R/W | - | R/W | POR | х | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------| | 5 | IPT2 | Timer 2 interrupt priority 0: Set the interrupt priority of Timer 2 to "Low" 1: Set the interrupt priority of Timer 2 to "High" | #### 11.3 Timer 3 Timer 3 inside the SC95F776X MCU as a timer is essentially an addition counter. The clock source of the timer is the system clock or its divided clock. TRX is the switch control of T3 counting. Only when TRX=1, T3 will be opened to count. In timer mode, the count source of T3 can be selected as fsys/12 or fsys through the special function register TXMOD.7 (TXFD). TXINX[2: 0] = 011, the Timer X register group points to Timer 3, the explanation of each register is as follows: ### TXCON (C8H) Timer 3 Control Register (read/write) ( TXINX[2: 0] = 011) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|------|---|---|-------|-----|------|--------| | Bit<br>Mnemonic | TFX | EXFX | - | - | EXENX | TRX | C/TX | CP/RLX | | R/W | R/W | R/W | - | - | R/W | R/W | R/W | R/W | Page 115 of 252 V0.1 | POR | 0 | 0 | х | х | 0 | 0 | 0 | 0 | | |-----|---|---|---|---|---|---|---|---|--| |-----|---|---|---|---|---|---|---|---|--| | Bit number | Bit Mnemonic | Description | |------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | TFX | Timer 3 control register (read/write) Timer 3 overflow flag 0: No overflow (must be cleared by software) 1: Overflow (set by hardware 1) | | 6 | EXFX | Flag bit detected by external event input (falling edge) of T3EX pin 0: No external event input (must be cleared by software) 1: External input detected (if EXENX = 1, set by hardware) | | 3 | EXENX | T3EX pin is used as a reload/capture trigger enable/disable control: 0: Ignore events on T3EX pin 1: A falling edge on the T3EX pin is detected, and a capture or reload is generated | | 2 | TRX | Timer 3 start/stop control bit 0: stop timer 3/stop PWM3 counter 1: Start timer 3/start PWM3 counter | | 1 | С/ТХ | Timer 3 Timer/counter mode selection positioning 2 0: Timer mode, T3 pin is used as I/O port 1: Counter mode | | 0 | CP/RLX | Capture/reload mode selection positioning 0: 16-bit timer/counter with reload function 1: 16-bit timer/counter with capture function, TXEX is timer 3 external capture signal input port | | 5~4 | <u>-</u> | Reserved | Page 116 of 252 V0.1 ### TXMOD (C9H) Timer 3 Operating Mode Register (read/write) ( TXINX[2: 0] = 011) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|---|--------|--------|-------|-------|------|-------| | Bit<br>Mnemonic | TXFD | - | EPWM31 | EPWM30 | INV31 | INV30 | TXOE | DCXEN | | 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 | TXFD | T3 input frequency selection control | | | | 0: T3 frequency is derived from fsys/12 | | | | 1: T3 frequency is derived from fsys | | 1 | TXOE | Timer 3 output enable bit | | | | 0: Set T3 as clock input or I/O port | | | | 1: Set T3 as the clock output | | 0 | DCXEN | Count down enable bit | | | | 0: Timer 3 is prohibited as an up/down counter, Timer 3 is only used as an up counter | | | | 1: Allow Timer 3 as an up/down counter, T3EX is used to select the counting direction | | 6 | - | Reserved | ### IE1 (A9H) Interrupt Enable Register 1 (read/write) Page 117 of 252 V0.1 | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|-----|------|---|-------|------|------|--------| | Bit<br>Mnemonic | ET4 | ET3 | ECMP | - | EINT2 | EBTM | EPWM | EUSCI0 | | 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 | ЕТ3 | Timer 3 interrupt enable control 0: Disable Timer 3 interrupt 1: Enable Timer 3 interrupt | | | | | | | 4 | - | Reserved | | | | | | # IP1 (B9H) Interrupt Priority Control Register 1 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|-------|---|--------|-------|-------|---------| | Bit<br>Mnemonic | IPT4 | IPT3 | IPCMP | - | IPINT2 | IPBTM | IPPWM | IPUSCI0 | | 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 | |--|------------|--------------|-------------| |--|------------|--------------|-------------| Page 118 of 252 V0.1 | 6 | IPT3 | Timer 3 interrupt priority selection | | | | |---|------|--------------------------------------------------------------------------|--|--|--| | | | Timer 3 interrupt priority is low Timer 3 interrupt priority is high | | | | | | | | | | | | 4 | - | Reserved | | | | #### 11.4 Timer 4 Timer 4 inside the SC95F776X MCU as a timer is essentially an addition counter. The clock source of the timer is the system clock or its divided clock. TRX is the switch control of T4 count. Only when TRX=1, T4 will be turned on and counted. In timer mode, the count source of T4 can be selected as fsys/12 or fsys through the special function register TXMOD.7 (TXFD). TXINX[2: 0] = 100, Timer X register group points to Timer 4, the explanation of each register is as follows: #### TXCON (C8H) Timer 4 Control Register (read/write) (TXINX[2: 0] = 100) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|------|---|---|-------|-----|------|--------| | Bit<br>Mnemonic | TFX | EXFX | | - | EXENX | TRX | C/TX | CP/RLX | | 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 | TFX | Timer 4 overflow flag 0: No overflow (must be cleared by software) 1: Overflow (set by hardware 1) | | 6 | EXFX | Flag bit detected by external event input (falling edge) of T4EX pin | Page 119 of 252 V0.1 | | | O: No external event input (must be cleared by software) 1: External input detected (if EXENX = 1, set by hardware) | |-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | EXENX | T4EX pin is used as a reload/capture trigger enable/disable control: 0: Ignore events on T4EX pin 1: A falling edge on the T4EX pin is detected, and a capture or reload is generated | | 2 | TRX | Timer 4 start/stop control bit 0: stop timer 4/stop PWM4 counter 1: Start timer 4/start PWM4 counter | | 1 | С/ТХ | Timer 4 Timer/counter mode selection positioning 2 0: Timer mode, T4 pin is used as I/O port 1: Counter mode | | 0 | CP/RLX | Capture/reload mode selection positioning 0: 16-bit timer/counter with reload function 1: 16-bit timer/counter with capture function, TXEX is timer 4 external capture signal input port | | 5~4 | - | Reserved | # TXMOD (C9H) Timer 4 Operating Mode Register (read/write) ( TXINX[2: 0] = 100) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|---|--------|--------|-------|-------|------|-------| | Bit<br>Mnemonic | TXFD | - | EPWM41 | EPWM40 | INV41 | INV40 | TXOE | DCXEN | | R/W | R/W | - | R/W | R/W | R/W | R/W | R/W | R/W | | POR | 0 | х | 0 | 0 | 0 | 0 | 0 | 0 | Page 120 of 252 V0.1 | Bit number | Bit Mnemonic | Description | |------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | TXFD | T4 input frequency selection control 0: T4 frequency is derived from fsys/12 1: T4 frequency is derived from fsys | | 1 | TXOE | Timer 4 output enable bit 0: Set T4 as clock input or I/O port 1: Set T4 as the clock output | | 0 | DCXEN | Count down enable bit 0: Timer 4 is prohibited as an up/down counter, Timer 4 is only used as an up counter 1: Allow Timer 4 as an up/down counter, T4EX is used to select the counting direction | | 6 | - | Reserved | #### IE1 (A9H) Interrupt Enable Register 1 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|-----|------|---|-------|------|------|--------| | Bit<br>Mnemonic | ET4 | ET3 | ECMP | - | EINT2 | EBTM | EPWM | EUSCI0 | | R/W | R/W | R/W | R/W | - | R/W | R/W | R/W | R/W | | POR | 0 | 0 | 0 | X | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------| |------------|--------------|-------------| Page 121 of 252 V0.1 | 7 | ET4 | Timer 4 interrupt enable control 0: Disable Timer 4 interrupt 1: Enable Timer 4 interrupt | | |---|-----|---------------------------------------------------------------------------------------------|--| | 4 | - | Reserved | | #### IP1 (B9H) Interrupt Priority Control Register 1 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|-------|---|--------|-------|-------|---------| | Bit<br>Mnemonic | IPT4 | IPT3 | IPCMP | - | IPINT2 | IPBTM | IPPWM | IPUSCI0 | | 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 | IPT4 | Timer 4 interrupt priority selection | | | | 0: Timer 4 interrupt priority is low 1: Timer 4 interrupt priority is high | | 4 | - | Reserved | # 11.5 Timer 2/3/4 Operating Modes Timer Timer2/3/4's operating modes as follows: ① Mode 0: 16-bit capture 2 Mode 1: 16-bit auto-reload timer Page 122 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU - Mode 2: Baud rate generator, only Timer 2 support this mode - 4 Mode 3: Programmable clock output - 5 Mode 4: PWM output mode The preceding working modes and configuration modes are listed as follows: | С/ТХ | TXOE | DCXE<br>N | TRX | CP/RL<br>X | EXEN<br>X | Mode | | | |------|------|-----------|-----|------------|-----------|-----------|---------------------------------------------------------------|--| | Х | 0 | Х | 1 | 1 | 1 | Mode<br>0 | 16-bit capture | | | Х | 0 | 0 | 1 | 0 | 0 | | 16-bit auto-reload timer/counter, normally auto-reload | | | Х | 0 | 0 | 1 | 0 | 1 | Mode<br>1 | 16-bit auto-reload timer/counter, with TnEX trigger reload | | | Х | 0 | 1 | 1 | 0 | Х | | 16-bit auto-reload timer/counter, increase or decrease reload | | | Х | 0 | Х | 1 | Х | х | Mode<br>2 | UART0 Baud rate generator, only for Timer 2 | | | 0 | 1 | Х | 1 | Х | х | Mode<br>3 | Programmable clock output | | | Х | Х | Х | 0 | Х | 1 | Х | Timer stops, TnEX(n=2~4) channel is still allowed | | #### 11.5.1 Timer 2/3/4 Operating Modes **Operating Mode 0: 16-bit Capture** CP/RLX = 1, set Timer $n(n=2\sim4)$ to 16-bit capture In the capture mode, the EXENX bit of TXCON has two options: If EXENX = 0, Timer n acts as a 16-bit timer or counter. If ETn is enabled, Timer n can set TFX overflow to generate an interrupt. If EXENX = 1, Timer n performs the same operation, but the falling edge on external input TnEX can also cause the current values in THX and TLX to be captured in RCAPXH and RCAPXL, respectively. In addition, the falling edge on TnEX also Can cause EXFX in TXCON to be set. If ETn is enabled, the EXFX bit also generates an interrupt like TFX. Page 123 of 252 V0.1 Mode 0: 16-bit capture #### **Operating Mode 1: 16-bit Auto-Reload Timer** In 16-bit auto-reload mode, Timer n(n=2~4) can be selected to count up or count down. This function is selected by the DCEN bit (down counting allowed) in TnMOD. After the system is reset, the reset value of the DCEN bit is 0, and the timer n counts up by default. When DCEN is set to 1, Timer n counts up or down depending on the level on the TnEX pin. When DCEN = 0, two options are selected through the EXENX bit in TXCON. If EXENX = 0, Timer n increments to 0xFFFFH, sets the TFX bit after overflow, and the timer automatically loads the 16-bit values of registers RCAPXH and RCAPXL written in user software into the THX and TLX registers. If EXENX = 1, an overflow or a falling edge on TnEX can trigger a 16-bit reload and set the EXFX bit. If ETn is enabled, both TFX and EXFX bits can generate an interrupt. Page 124 of 252 V0.1 http://www.socmcu.com #### Mode 1: 16-bit auto-reload DCEN = 0 Setting the DCEN bit allows Timer n to count up or down. When DCEN = 1, the TnEX pin controls the direction of the count, and EXENX control is invalid. Setting TnEX causes Timer n to count up. The timer overflows to 0xFFFFH, and then sets the TFX bit. Overflow can also cause the 16-bit values on RCAPXH and RCAPXL to be reloaded into the timer register, respectively. Setting TnEX to 0 causes Timer n to count down. When the values of THX and TLX are equal to the values of RCAPXH and RCAPXL, the timer overflows. The TFX bit is set and 0xFFFFH is reloaded into the timer register. Regardless of whether Timer n overflows or not, the EXFX bit is used as the 17th bit of the result. In this operating mode, EXFX is not used as an interrupt flag. Mode 1: 16-bit auto-reload DCEN = 1 #### Operating Mode 2: Baud Rate Generator, only for Timer 2 Set TCLK and/or RCLK in the TXCON register to select Timer 2 as the baud rate generator. The baud rate of the receiver and transmitter can be different. If Timer 2 acts as a receiver or transmitter, then Timer 1 acts as another baud rate generator Set TCLK and/or RCLK in the TXCON register to make Timer 2 enter the baud rate generator mode, which is similar to the automatic reload mode The overflow of Timer 2 will reload the values in the RCAPXH and RCAPXL registers to the Timer 2 count, but no interrupt will be generated If EXENX is set to 1, the falling edge on the T2EX pin will set up EXFX, but it will not cause a heavy load. So when Timer 2 is used as a baud rate transmitter, T2EX can be used as an additional external interrupt The baud rate in UART0 mode 1 and 3 is determined by the overflow rate of timer 2 according to the following equation: $$BaudRate = \frac{fsys}{[RCAPXH,RCAPXL]}; (Note: [RCAPXH, RCAPXL] \ must \ be \ bigger \ than \ 0x0010)$$ Page 125 of 252 V0.1 #### The schematic diagram of Timer 2 as a baud rate generator is as follows: Mode 2: Baud rate generator #### **Operating Mode 3: Programmable Clock Output** In this way, Timer $n(n=2\sim4)$ can be programmed to output a 50% duty cycle clock cycle: when $C/\overline{Tn}=0$ ; TnOE = 1, timer n is enabled as a clock generator In this way, Tn outputs a clock with a 50% duty cycle Colck Out Frequency = $$\frac{\text{fn}}{(65536-[\text{RCAPXH,RCAPXL}])\times 4}$$ ; Among them, fn is the timer n clock frequency: $$fn = \frac{fsys}{12}$$ ; TXFD = 0 $$fn = fsys;$$ TXFD = 1 Timer n overflow does not generate an interrupt, and the Tn port is used as a clock output. Page 126 of 252 V0.1 # Fsys TXFD = 0 /2 TLX THX /1 TXFD = 1 RCAPXL **RCAPXH** C/TX TX ⊠-TXOE TimerX Interrupt TXEX ⋈ **EXFX** Mode 3: Programmable clock output **EXĖNX** #### Note: - 1. Both TFX and EXFX can cause the interrupt request of Timer $n(n=2\sim4)$ , both have the same vector address; - 2. When the event occurs or at any other time, TFX and EXFX can be set to 1 by software, and only software and hardware reset can clear it to 0; - 3. When EA = 1 and ETn = 1, setting TFX or EXFX to 1 can cause Timer n to interrupt; - 4. When Timer n is used as a baud rate generator, writing THX/TLX or RCAPXH/RCAPXL will affect the accuracy of the baud rate and cause communication errors. Page 127 of 252 V0.1 ### 12 PWM2/3/4 The SC95F776X provides up to 14 PWM, which divided into two categories: - 1. Multi-function PWM: 8 channels for only one group PWM0, output signal port: PWM00~07 - 2. Conventional PWM: 6 channels divided into 3 groups: PWM2, PWM3, PWM4. Note: These three sets of PWM period registers are shared with the TLX and THX of Timer2, Timer3, and Timer4 respectively. Therefore, once users use the PWM2, PWM3, and PWM4 resources, they cannot change the timing/count value of Timer2, Timer3, and Timer4. Otherwise it will lead to abnormal OUTPUT of PWM cycle! ## 12.1 PWM2/3/4 related Registers TXINX (CEH) Timer 2/3/4 Control Register Pointer (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|---|---|---|-----|-------------|-----| | Bit<br>Mnemonic | - | - | - | - | | | TXINX[2: 0] | | | R/W | - | - | - | · | - | R/W | R/W | R/W | | POR | х | х | х | х | х | 0 | 1 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2~0 | TXINX[2: 0] | Timer 2/3/4 control register pointer | | | | 010: Timer X register set: TXCON / TXMOD / RCAPXL / RCAPXH / TLX / THX points to PWM2 011: Timer X register set points to PWM3 100: Timer X register set points to PWM4 | | | | Other: reserved | | 7~3 | - | Reserved | TXCON (C8H) Timer n Control Register (read/write) Page 128 of 252 V0.1 | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|------|-------|-------|-------|-----|------|--------| | Bit<br>Mnemonic | TFX | EXFX | RCLKX | TCLKX | EXENX | TRX | C/TX | CP/RLX | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------------------------------------------------------------| | 2 | TRX | Timer n start/stop control bit 0: stop timer n/stop PWMn counter | | | | 1: Start timer n/start PWMn counter | When EPWMn0 or EPWMn1 is set to 1, the Timer can start PWM mode, Tn and TnEX ( $n=2\sim4$ ) are invalid, and PWMxy ( $x=2\sim4$ , $y=0\sim1$ ) can output PWM waveform. #### TXMOD (C9H) Timer 2 Operating Mode Register (read/write) ( TXINX[2: 0] = 010) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|---|--------|--------|-------|-------|------|-------| | Bit<br>Mnemonic | TXFD | | EPWM21 | EPWM20 | INV21 | INV20 | TXOE | DCXEN | | 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 | ENPWMn1 | PWMn1 Waveform output select 0: PWMn1 output is disabled | Page 129 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU | | | 1: I/O where PWMn1 resides serves as the output port of the PWM waveform | |---|---------|--------------------------------------------------------------------------| | 4 | ENPWMn0 | PWMn0 Waveform output select | | | | 0: PWMn0 output is disabled | | | | 1: I/O where PWMn0 resides serves as the output port of the PWM waveform | | 3 | INVn1 | PWMn1 waveform output reverse control | | | | 1: PWMn1 waveform output is reversed | | | | 0: PWMn1 waveform output is not reversed | | 2 | INVn0 | PWMn0 waveform output reverse control | | | | 1: PWMn0 waveform output is reversed | | | | 0: PWMn0 waveform output is not reversed | The THX and TLX counter starts counting from 0, and when the count value matches the value of the duty cycle setting item PDTxy [15: 0], the PWM output waveform switches between high and low levels, The THX and TLX counter then continues counting upward reload value PWMPDX, then THX and TLX counter is cleared and generate count overflow events and a PWM cycle ends. If the timer interrupt is enabled, a timer interrupt will be generated at this time. The calculation formula of PWM period **T**<sub>PWM</sub> output by Timer is as follows: $$Tpwm = \frac{PWMPDX[15:0] + 1}{fsys}$$ Duty calculation formula: $$duty = \frac{PDTxy [15:0]}{PWMPDX[15:0] + 1}$$ The PWM cycle is set through the following registers: #### RCAPXH (CBH) PWMn period register high 8 bits(R/W) Note: The PWM2/3/4 cycle register is multiplexed with Timer2, Timer3, and Timer4. Therefore, once users use the PWM2, PWM3, and PWM4 resources, they cannot change the timer/counter value of Timer2, Timer3, and Timer4. Otherwise, the PWM cycle output will be abnormal! | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|---|---|---|---|---|---|---|---| |------------|---|---|---|---|---|---|---|---| Page 130 of 252 V0.1 ### **Super High-speed 1T 8051 Core Flash MCU** | Bit<br>Mnemonic | PWMPDHX[7:0] | | | | | | | | |-----------------|--------------|-----|-----|-----|-----|-----|-----|-----| | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### **RCAPXL (CAH)** PWMn period register low 8 bits (R/W) ( TXINX[2:0] = 010) Note: The PWM2/3/4 cycle register is multiplexed with Timer2, Timer3, and Timer4. Therefore, once users use the PWM2, PWM3, and PWM4 resources, they cannot change the timer/counter value of Timer2, Timer3, and Timer4. Otherwise, the PWM cycle output will be abnormal! | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|--------------|-----|-----|-----|-----|-----|-----| | Bit<br>Mnemonic | | PWMPDLX[7:0] | | | | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------| | 7~0 | PWMPDX[15:0] | PWMn cycle set This value represents the output waveform of PWMn (cycle-1); that is to say PWMn cycle of output is(PWMPDX[15:0] + 1)* PW clock | The PWM duty is set through the following registers: #### PWM2~4 Duty cycle adjustment register (R/W) | ADD | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | POR | |-------|---|-------------|---|------|---------|---|---|-----------|-----------| | 2034H | | PDT20[15:8] | | | | | | | 0000000b | | 2035H | | PDT20[7:0] | | | | | | | 0000000b | | 2036H | | PDT21[15:8] | | | | | | 0000000b | | | 2037H | | PDT21[7:0] | | | | | | 00000000Ь | | | 2038H | | | | PDT3 | 0[15:8] | | | | 0000000b | | 2039H | | | | PDT3 | 60[7:0] | | | | 00000000Ь | | 203AH | | PDT31[15:8] | | | | | | | 0000000b | | 203BH | | PDT31[7:0] | | | | | | | 0000000b | | 203CH | | PDT40[15:8] | | | | | | 0000000b | | Page 131 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU | 203DH | PDT40[7:0] | 0000000b | |-------|-------------|----------| | 203EH | PDT41[15:8] | 0000000b | | 203FH | PDT41[7:0] | 0000000b | | Bit number | Bit Mnemonic | Description | |------------|------------------------------------------------------|------------------------------------------------| | 7~0 | PDTxy[15:0] PWMxy waveform duty cycle length setting | | | | (x=2~4, y=0~1) | The high level width of the PWMxy waveform is: | | | | (PDTxy[15:0] + 1 ) PWM clock | ## 12.2 PWM2/3/4 Duty Variation Characteristics The duty can be changed by changing the high level setting register PDTxy ( $x=2\sim4$ , $y=0\sim1$ ) when PWM2/3/4 output waveform. However, it should be noted that if you change the PDTxy value, the duty will not change immediately, but wait until the end of this cycle and change in the next cycle. # 12.3 PWM2/3/4 Cycle Variation Characteristics If you need to change the period when the PWM2/3/4 outputs the waveform, you can set the TLX and THX values of the register groups by changing the period. Change the value of the cycle register, the PWM output cycle changes as follows: Define the current period meter value as Tn, when writing the period register, the value recorded by the timer is Tm, and the period meter value to be updated is Tx, then: Tm ≤ Tx: the period changes in real time according to Tx; Tm > Tx: At this point, the cycle change will be divided into two stages. In the first stage, after writing to the cycle register, the cycle counter accumulates from the current count until overflow is cleared. In the second phase, the period changes with respect to Tx. Page 132 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU #### **13 PWM0** The SC95F776X provides up to 14 PWM, which divided into two categories: - 3. Multi-function PWM: 8 channels for only one group PWM0, output signal port: PWM00~07 - 4. Conventional PWM: 6 channels divided into 3 groups: PWM2, PWM3, PWM4. Note: These three sets of PWM period registers are shared with the TLX and THX of Timer2, Timer3, and Timer4 respectively. Therefore, once users use the PWM2, PWM3, and PWM4 resources, they cannot change the timing/count value of Timer2, Timer3, and Timer4. Otherwise it will lead to abnormal OUTPUT of PWM cycle! The functions of the PWM0 of the SC95F776X are as follows: - 1. 16-bit PWM accuracy; - 2. The output waveform can be reversed; - 3. Type: Can be set to center-aligned or edge-aligned; - 4. Mode: can be set to independent mode or complementary mode: - a) In independent mode, the 8 PWM cycles are the same, but the duty cycle of each PWM output waveform can be set separately; - b) In complementary mode, four sets of complementary PWM waveforms with dead zones can be output simultaneously; - 5. Provide one PWM overflow interrupt; - 6. Support fault detection mechanism. The PWM of the SC95F776X can support the adjustment of period and duty cycle. The registers PWMCFG, PWMCON0 and PWMCON1 control the state and period of PWM. The opening of each PWM and the output waveform duty cycle can be adjusted separately. ### 13.1 PWM Structure Diagram Page 133 of 252 V0.1 SC95F776X PWM Structure diagram Page 134 of 252 V0.1 ## 13.2 PWM0 General Configuration Register #### 13.2.1 PWM0 General Configuration Register The user can set the PWM output mode of SC95F776X to independent mode or complementary mode by configuring PWMMD[1: 0]. In independent mode, the 8 PWM cycles are the same, but the duty cycle of each PWM output waveform can be set separately. In complementary mode, four complementary PWM waveforms with dead zones can be output simultaneously. The PWM type of SC95F776X is divided into edge-aligned type and center-aligned type: #### **Edge-aligned:** The PWM counter starts counting from 0, and when the count value matches the value of the duty cycle setting item PDTxy [15: 0], the PWM output waveform switches between high and low levels, The PWM counter then continues counting upward until it matches the value of the period setting PWMPD[15:0] +1 (the end of a PWM period), the PWM counter is cleared, if the PWM interrupt is enabled, a PWM interrupt will be generated at this time. The output PWM waveform is aligned on the left edge. Calculation formula of edge-aligned period T<sub>PWM</sub>: $$\mathbf{Tpwm} = \frac{\text{PWMPD}[15:0] + 1}{\text{PWM Clock frequency}}$$ Edge-aligned duty calculation formula: $$\mathbf{duty} = \frac{\text{PDTxy } [15:0]}{\text{PWMPD}[15:0] + 1}$$ The edge-aligned waveform is as follows: Page 135 of 252 V0.1 **Edge-aligned PWM** #### Center-aligned type: The PWM counter starts counting from 0. When the count value matches the value of the duty cycle setting item PDTxy [15: 0], the PWM output waveform switches between high and low levels. Then the PWM counter continues to count up. When the count matches the value of PWMPD[15:0] +1 (that is, the midpoint of the PWM cycle), it automatically starts to count down. When the count value matches the value of PDTxy [15: 0] again, the PWM output waveform switches high and low again, and then The PWM counter continues to count down until it overflows (the end of a PWM period). If the PWM interrupt is enabled, a PWM interrupt will be generated at this time. Calculation formula of center-aligned period T<sub>PWM</sub>: $$\textbf{Tpwm} = 2 * \frac{\text{PWMPD[15: 0]} + 1}{\text{PWM Clock frequency}}$$ Center-aligned duty calculation formula: **duty** = $$\frac{\text{PDTxy } [15:0]}{\text{PWMPD}[15:0] + 1}$$ The center aligned waveform is as follows: Page 136 of 252 V0.1 Center-aligned PWM The above modes and types can be set through the PWMMOD register: #### PWMCON0 (D2H) PWM Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------|-------|------------|-----|---|---|------------|-----| | Bit<br>Mnemonic | ENPWM | PWMIF | PWMCK[1:0] | | - | - | PWMMD[1:0] | | | 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 | ENPWM | PWM module switch control (Enable PWM) | Page 137 of 252 V0.1 | | | 1: Allow Clock to enter the PWM unit, the PWM is in the operating state, and the state of the PWM output port is controlled by the register ENPWMx (x=0~7) 0: The PWM unit stops operating, the PWM counter is cleared, and all PWM output ports are set to the GPIO state | |-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | PWMIF | PWM interrupt request flag | | | | When the PWM counter overflows (that is, when the count exceeds PWMPD), this bit is automatically set to 1 by the hardware. If IE1[1] (EPWM) is also set to 1, the PWM interrupt is generated at this time. After the PWM interrupt occurs, the hardware will not automatically clear this bit. This bit must be cleared by the user's software. | | 5~4 | PWMCK[1: 0] | PWM Clock Source Selector (PWM Clock Source Selector) | | | | 00: fhrc | | | | 01: f <sub>HRC</sub> /2 | | | | 10: f <sub>HRC</sub> /4 | | | | 11: f <sub>HRC</sub> /8 | | | | The frequency of the PWM clock source is fixed at f <sub>HRC</sub> = 32 MHz | | 1~0 | PWMMD[1: 0] | PWM operating mode setting | | | | 0x: Independent mode | | | | 1x: complementary mode | | | | x0: edge alignment mode | | | | x1: center alignment mode | | 3~2 | | Reserved | # PWMCFG (D1H) PWM Set Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | INV7 | INV6 | INV5 | INV4 | INV3 | INV2 | INV1 | INV0 | Page 138 of 252 V0.1 # Super High-speed 1T 8051 Core Flash MCU | R/W |-----|-----|-----|-----|-----|-----|-----|-----|-----| | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|--------------------------------------------------------------------------------------------------------------------| | 7~0 | INVx(x=0~7) | PWMx waveform output reverse control 1: PWMx waveform output is reversed 0: PWMx waveform output is not reversed | # PWMCON1 (D3H) PWM Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------------|------------|------------|------------|------------|------------|------------|------------| | Bit<br>Mnemonic | ENPWM<br>7 | ENPWM<br>6 | ENPWM<br>5 | ENPWM<br>4 | ENPWM<br>3 | ENPWM<br>2 | ENPWM<br>1 | ENPWM<br>0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------| | 7~0 | ENPWMx<br>(x=0~7) | PWMx Waveform output select 0: PWMx output is disabled 1: I/O where PWMx resides serves as the output port of the PWM waveform | Note: Page 139 of 252 V0.1 ### **Super High-speed 1T 8051 Core Flash MCU** 1. If ENPWM is set to 1, the PWM module is turned on, but ENPWMx=0, and the PWM output is turned off as a GPIO port. In this case, the PWM module can be used as a 16-bit Timer. When EPWM(IE1.1) is set to 1, the PWM will still interrupt. #### PWMPDL (D4H) period register low 8 bits(R/W) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|-------------|-----|-----|-----|-----|-----|-----| | Bit<br>Mnemonic | | PWMPDL[7:0] | | | | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### PWMPDH (D5H)PWMn period register high 8 bits (R/W) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|-------------|-----|-----|-----|-----|-----|-----| | Bit<br>Mnemonic | | PWMPDH[7:0] | | | | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------| | 7~0 | PWMPD[15:0] | PWM cycle set This value represents the output waveform of PWMn (cycle-1); that is to say PWMn cycle of output is(PWMPDX[15:0] + 1)* PW clock | #### IE1 (A9H) Interrupt Enable Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|-----|------|---|-------|------|------|--------| | Bit<br>Mnemonic | ET4 | ET3 | ECMP | - | EINT2 | EBTM | EPWM | EUSCI0 | | R/W | R/W | R/W | R/W | 1 | R/W | R/W | R/W | R/W | | POR | 0 | 0 | 0 | X | 0 | 0 | 0 | 0 | Page 140 of 252 V0.1 | Bit number | Bit Mnemonic | Description | |------------|--------------|--------------------------------------------------------------------------------------------------------| | 1 | EPWM | PWM interrupt enable control 0: Disable PWM interrupt 1: Enable interrupt when PWM counter overflows | | 4 | - | Reserved | #### IP1 (B9H) Interrupt Priority Register 1 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|-------|---|--------|-------|-------|---------| | Bit<br>Mnemonic | IPT4 | IPT3 | IPCMP | - | IPINT2 | IPBTM | IPPWM | IPUSCI0 | | R/W | R/W | R/W | R/W | | R/W | R/W | R/W | R/W | | POR | 0 | 0 | 0 | X | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|---------------------------------------------------------------------------------------------------------------------------| | 1 | IPPWM | PWM interrupt priority selection 0: Set the PWM interrupt priority to "low" 1: Set the PWM interrupt priority to "High" | | 4 | - | Reserved | #### 13.2.2 PWM0 Fault Detection Function Setting The fault detection function is often applied to the protection of motor systems. When the fault detection function is enabled, FLTEN1 (PWMFLT.7) is set to 1, and the fault detection signal input pin (FLT) becomes effective. When the signal of the FLT pin meets the fault condition, the flag bit FLTSTA1 is set by hardware, and the PWM Page 141 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU output stops. The PWM counter still keeps counting and THE PWM interrupt is not affected. The fault detection mode is divided into latch mode and immediate mode; in immediate mode, when the fault signal on the FLT pin meets the disabling condition, the flag FLTSTA1 is cleared by hardware, and until the PWM counter returns to zero. Output; In the latch mode, when the fault signal on the FLT pin meets the disabling condition, the status of the FLTSTA1 flag remains unchanged, and the user can clear it through software. Once the FLTSTA1 status is cleared, the PWM counter resumes counting until the PWM counter returns The PWM resumes output after zero. The fault detection mode is divided into latch mode and immediate mode. The specific configuration methods are as follows: #### PWMFLT (D7H) PWM Fault Detection Setting Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|--------|---------|--------|--------|---|---|-------|----------| | Bit<br>Mnemonic | FLTEN1 | FLTSTA1 | FLTMD1 | FLTLV1 | - | | FLTDT | 71[1: 0] | | 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 | FLTEN1 | PWM fault detection function control bit | | | | | 0: The fault detection function is turned off | | | | | 1: The fault detection function is turned on | | | 6 | FLTSTA1 | PWM fault detection status flag | | | | | 0: PWM is in normal output state; | | | | | 1: Fault detection is valid, the PWM output is in a high-impedance state, if in latch mode, this bit can be cleared by software | | | 5 | FLTMD1 | PWM fault detection mode setting bit | | | | | 0: Latch mode: when the fault input is valid, FLTSTA1 is set to "1", the PWM stops outputting, and the FLTSTA1 state remains unchanged when the fault input is invalid | | | | | 1: Immediate mode: When the fault input is valid, FLTSTA1 is set to "1" and the PWM stops outputting. When the fault input is invalid, the state | | Page 142 of 252 V0.1 | | | of FLTSTA1 is cleared immediately, and the PWM waveform will resume output when the PWM time base counter count to zero | |-----|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | FLTLV1 | PWM fault detection level selection bit 0: Low level of fault detection is effective 1: High level of fault detection is effective | | 1~0 | FLTDT1[1: 0] | PWM fault detection input signal filtering time setting 00: filtering time is 0 01: filtering time is 1us 10: filter time is 4us 11: The filtering time is 16us | | 3~2 | - | Reserved | Page 143 of 252 V0.1 # Super High-speed 1T 8051 Core Flash MCU # 13.3 PWM0 Independent Mode In independent mode (PWMMD.1 = 0), the duty cycle of 8 PWM channels can be set independently. The user configures the PWM output status and period, and then configures the duty cycle register of the corresponding PWM channel to output the PWM waveform at a fixed duty cycle. #### 13.3.1 PWM0 Independent Mode Block Diagram SC95F776X PWM Independent mode block diagram Page 144 of 252 V0.1 ## 13.3.2 PWM0 Independent Mode Duty Cycle Configuration ## PWM0 Duty Cycle Adjustment Register PDT0x (Read/Write) | 2040H | PDT00[15:8] | |-------|-------------| | 2041H | PDT00[7:0] | | 2042H | PDT01[15:8] | | 2043H | PDT01[7:0] | | 2044H | PDT02[15:8] | | 2045H | PDT02[7:0] | | 2046H | PDT03[15:8] | | 2047H | PDT03[7:0] | | 2048H | PDT04[15:8] | | 2049H | PDT04[7:0] | | 204AH | PDT05[15:8] | | 204BH | PDT05[7:0] | | 204CH | PDT06[15:8] | | 204DH | PDT06[7:0] | | 204EH | PDT07[15:8] | | 204FH | PDT07[7:0] | | | | | Bit number | Bit Mnemonic | Description | |------------|--------------------------|--------------------------------------------------------------------------------------------------------------------| | 7~0 | PDT0x [15: 0]<br>(x=0~7) | PWM0x waveform duty cycle length setting The high-level width of the PWM0x waveform is (PDT0x [15: 0]) PWM clocks | Page 145 of 252 V0.1 ## 13.4 PWM0 Complementary Model ### 13.4.1 PWM0 Block Diagram of Complementary Mode SC95F776X PWM block diagram of complementary mode ## 13.4.2 PWM Complementary Mode Duty Cycle Configuration In complementary mode (PWMMD[1:0] = 1x), PWM00/PWM01, PWM02/PWM03, PWM04/PWM05 and PWM06/PWM07 are divided into four groups, respectively through PDT00[15:0], PDT02[15:0], PDT04[15:0] and PDT06[15:0] adjust the duty ratio; The registers PDT01[15:0], PDT03[15:0], PDT05 [15:0] and PDT07[15:0] are invalid in the complementary mode. ### PWM0 Duty Cycle Adjustment Register PDT0x (Read/Write) | 2040H | PDT00[15:8] | |-------|-------------| | 2041H | PDT00[7:0] | Page 146 of 252 V0.1 | 2042H | PDT01[15:8] | |-------|-------------| | 2043H | PDT01[7:0] | | 2044H | PDT02[15:8] | | 2045H | PDT02[7:0] | | 2046H | PDT03[15:8] | | 2047H | PDT03[7:0] | | 2048H | PDT04[15:8] | | 2049H | PDT04[7:0] | | 204AH | PDT05[15:8] | | 204BH | PDT05[7:0] | | 204CH | PDT06[15:8] | | 204DH | PDT06[7:0] | | 204EH | PDT07[15:8] | | 204FH | PDT07[7:0] | | Bit number | Bit Mnemonic | Description | |------------|---------------|----------------------------------------------------------------------------------------------| | 7~0 | PDT0x [15: 0] | PWM0x and PWM0y, y=x+1 port PWM waveform duty cycle length setting | | | (x=0~7) | The high-level width of the PWM waveform on the Px and Py pins is (PDT0x [15: 0]) PWM clocks | #### Note: 1. If ENPWM is set to 1, the PWM module is turned on, but EMPWMx=0, the PWM output is turned off and used as a GPIO port. At this time, PWM module can be used as a 16-bit Timer. At this time, EPWM (IE1.1) is set to 1, and PWM will still generate an interrupt. ### 13.4.3 PWM Complementary Mode Dead Time Setting When the PWM0 of the SC95F776X works in complementary mode, the dead zone control module can prevent the effective time zones of the two PWM signals of complementary outputs from overlapping each other, so as to ensure that a pair of complementary power switch tubes driven by PWM signals will not be turned on at the same time. Page 147 of 252 V0.1 ### PWMDFR (D6H) PWM0 Dead Time Setting Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----------|-----|-----|-----|-----------|-----|-----|-----| | Bit<br>Mnemonic | PDF[3: 0] | | | | PDR[3: 0] | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|---------------------------------------------------------------------------------| | 7~4 | PDF[3: 0] | Complementary mode: PWM falling edge dead time= 4*PDF[3: 0] / f <sub>HRC</sub> | | 3~0 | PDR[3: 0] | Complementary mode: PWM rising edge dead time= 4*PDR[3: 0] / fhrc | ## 13.4.4 PWM0 Dead Zone Output Waveform The following figure is based on the PWM00 and PWM01 in the complementary mode of the dead time adjustment waveform, in order to facilitate the distinction, PWM01 has reversed (INV1=1). Page 148 of 252 V0.1 PWM0 dead zone output waveform ### 13.5 PWM0 Waveforms and Directions The effect of changing SFR parameters on the PWM0 waveform is as follows: 1 Duty cycle change characteristics When the PWM0n outputs a waveform, if the duty cycle needs to be changed, it can be achieved by changing the value of the high-level setting register (PDT0x). But need to pay attention: change the value of PDT0x, the duty ratio will not change immediately, but wait for the PWM counter changing when it counts to 0 or up until it matches the value of the period setting item PWMPD[15:0] +1. 2 Periodic change characteristics Page 149 of 252 V0.1 ### SC95F7767/7766/7765/7763 ### Super High-speed 1T 8051 Core Flash MCU Periodic change characteristic diagram When the PWM outputs a waveform, if the period needs to be changed, it can be achieved by changing the value of the period setting register PWMPD. Change the value of PWMPD, the cycle will not change immediately, but wait for the PWM counter changing when it counts to 0 or up until it matches the value of the period setting item PWMPD[15:0] +1, refer to the figure above. #### Relationship between period and duty cycle Relationship between cycle and duty cycle The relationship between period and duty cycle is shown in the figure above. The premise of this result is that the PWM output inverse control (INVx, x-0~7) is initially 0. If you want to get the opposite result, you can set INVx to 1. Page 150 of 252 V0.1 ## 14 General-purpose I/O (GPIO) The SC95F776X provides up to 46 bidirectional GPIO ports that can be controlled. The input and output control registers are used to control the input and output status of each port. When the port is used as an input, each I/O port has an internal pull-up resistor controlled by PxPHy. The 46 IOs are multiplexed with other functions. Among them, P3 can be set to output 1/4VDD or 1/3VDD voltage, which can be used as a COM driver for LCD display. When the I/O port is in the input or output state, the actual state value of the port is read from the port data register. Note: The unused and unleaded IO ports should be set to strong push-pull output mode. ## 14.1 GPIO Structure Diagram #### Strong Push-pull Output Mode In the strong push-pull output mode, it can provide continuous high-current drive: - Other than P04, P05, and P06, the I/O driver capability is an output greater than 10mA is high, and an output greater than 50mA is low. - P04/P05/P06 drive can be achieved an output greater than 20mA is high, and an output greater than 50mA is low. The schematic diagram of the port structure of the strong push-pull output mode is as follows: Strong push-pull output mode ### **Pull-up Input Mode** In the pull-up input mode, a pull-up resistor is constantly connected to the input port. Only when the input port is pulled low, the low-level signal is detected. The schematic diagram of the port structure with pull-up input mode is as follows: Page 151 of 252 V0.1 Input mode with pull-up resistor ### **High Impedance Input Mode (Input only)** The schematic diagram of the port structure of the high impedance input mode is as follows: High impedance input mode Page 152 of 252 V0.1 ## 14.2 I/O Port-related Registers ### P0CON (9AH) P0 Port Input/Output Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P0C7 | P0C6 | P0C5 | P0C4 | P0C3 | P0C2 | P0C1 | P0C0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### P0PH (9BH) P0 Port pull-up Resistor Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P0H7 | P0H6 | P0H5 | P0H4 | P0H3 | P0H2 | P0H1 | Р0Н0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## P1CON (91H) P1 Port Input/Output Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P1C7 | P1C6 | P1C5 | P1C4 | P1C3 | P1C2 | P1C1 | P1C0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Page 153 of 252 V0.1 ### P1PH (92H) P1 Port Pull-up Resistor Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P1H7 | P1H6 | P1H5 | P1H4 | P1H3 | P1H2 | P1H1 | P1H0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### P2CON (A1H) P2 Port Input/output Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P2C7 | P2C6 | P2C5 | P2C4 | P2C3 | P2C2 | P2C1 | P2C0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### P2PH (A2H) P2 Port Pull-up Resistor Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P2H7 | P2H6 | P2H5 | P2H4 | P2H3 | P2H2 | P2H1 | P2H0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | P3CON (B1H) P3 Port Input/output Control Register (read/write) Page 154 of 252 V0.1 | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P3C7 | P3C6 | P3C5 | P3C4 | P3C3 | P3C2 | P3C1 | P3C0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### P3PH (B2H) P3 Port Pull-up Resistor Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P3H7 | P3H6 | P3H5 | P3H4 | РЗН3 | P3H2 | P3H1 | P3H0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### P4CON (C1H) P4 Port Input/output Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P4C7 | P4C6 | P4C5 | P4C4 | P4C3 | P4C2 | P4C1 | P4C0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | P4PH (C2H) P4 Port Pull-up Resistor Control Register (read/write) Page 155 of 252 V0.1 | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P4H7 | P4H6 | P4H5 | P4H4 | P4H3 | P4H2 | P4H1 | P4H0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## P5CON (D9H) P5 Port Input/output Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|------|------|------|------|------|------| | Bit<br>Mnemonic | - | - | P5C5 | P5C4 | P5C3 | P5C2 | P5C1 | P5C0 | | R/W | - | - | R/W | R/W | R/W | R/W | R/W | R/W | | POR | х | x | 0 | 0 | 0 | 0 | 0 | 0 | ## P5PH (DAH) P5 Port Pull-up Resistor Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|------|------|------|------|------|------| | Bit<br>Mnemonic | - | - | P5H5 | P5H4 | P5H3 | P5H2 | P5H1 | P5H0 | | R/W | - | 1 | R/W | R/W | R/W | R/W | R/W | R/W | | POR | х | х | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------| |------------|--------------|-------------| Page 156 of 252 V0.1 | 7~0 | PxCy<br>(x=0~5, y=0~7) | Px port input and output control: 0: Pxy is the input mode (initial value at power-on) 1: Pxy is a strong push-pull output mode | |-----|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7~0 | PxHy<br>(x=0~5, y=0~7) | The Px port pull-up resistor setting is only valid when PxCy=0: 0: Pxy is the high-impedance input mode (initial value at power-up), and the pull-up resistor is turned off; 1: Pxy pull-up resistor is on | ## P0 (80H) P0 Port Data Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P0.7 | P0.6 | P0.5 | P0.4 | P0.3 | P0.2 | P0.1 | P0.0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### P1 (90H) P1 Port Data Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P1.7 | P1.6 | P1.5 | P1.4 | P1.3 | P1.2 | P1.1 | P1.0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Page 157 of 252 V0.1 ### P2 (A0H) P2 Port 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.3 | P2.2 | P2.1 | P2.0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### P3 (B0H) P3 Port Data Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P3.7 | P3.6 | P3.5 | P3.4 | P3.3 | P3.2 | P3.1 | P3.0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## P4 (C0H) P4 Port Data Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|------|------|------|------| | Bit<br>Mnemonic | P4.7 | P4.6 | P4.5 | P4.4 | P4.3 | P4.2 | P4.1 | P4.0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## P5 (D8H) P5 Port Data Register (read/write) Page 158 of 252 V0.1 | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|------|------|------|------|------|------| | Bit<br>Mnemonic | - | - | P5.5 | P5.4 | P5.3 | P5.2 | P5.1 | P5.0 | | 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 | P0.x | P0 port latch register data | | | (x=0~7) | | | 7~0 | P1.x | P1 port latch register data | | | (x=0~7) | | | 7~0 | P2.x | P2 port latch register data | | | (x=0~7) | | | 7~0 | P3.x | P3 port latch register data | | | (x=0~7) | | | 7~0 | P4.x | P4 port latch register data | | | (x=0~7) | | | 5~0 | P5.x | P5 port latch register data | | | (x=0~5) | | IOHCON0 (96H) IOH Setting Register 0 (read/write) Page 159 of 252 V0.1 | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|--------|------|-------|-----|--------|------|-------| | Bit<br>Mnemonic | P1H | [1: 0] | P1L[ | 1: 0] | P0H | [1: 0] | P0L[ | 1: 0] | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|---------------------------------------------| | 7~6 | P1H[1: 0] | P1 high four IOH settings | | | | 00: Set P1 high four IOH level 0 (maximum); | | | | 01: Set P1 high four IOH level 1; | | | | 10: Set P1 high four IOH level 2; | | | | 11: Set P1 high four IOH level 3 (minimum); | | 5~4 | P1L[1: 0] | P1 low four IOH settings | | | | 00: Set P1 low four IOH level 0 (maximum); | | | | 01: Set P1 low four IOH level 1; | | | | 10: Set P1 low four IOH level 2; | | | | 11: Set P1 low four IOH level 3 (minimum); | | 3~2 | P0H[1: 0] | P0 high four IOH settings | | | | 00: Set P0 high four IOH level 0 (maximum); | | | | 01: Set P0 high four IOH level 1; | | | | 10: Set P0 high four IOH level 2; | | | | 11: Set P0 high four IOH level 3 (minimu | | 1~0 | P0L[1: 0] | P0 low four IOH settings | Page 160 of 252 V0.1 | | 00: Set P0 low four IOH level 0 (maximum); | |--|--------------------------------------------| | | 01: Set P0 low four IOH level 1; | | | 10: Set P0 low four IOH level 2; | | | 11: Set P0 low four IOH level 3 (minimum); | | | 11: Set PO low four IOH level 3 (minimum); | ## IOHCON1 (97H) IOH Setting Register 1 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|------|--------|-----|--------|------|--------| | Bit<br>Mnemonic | - | - | P3L[ | [1: 0] | P2H | [1: 0] | P2L[ | [1: 0] | | 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~4 | P3L[1: 0] | P3 low four IOH settings | | | | 00: set P3 low four IOH level 0 (maximum); | | | | 01: Set P3 low four IOH level 1; | | | | 10: Set P3 low four IOH level 2; | | | | 11: Set P3 low four IOH level 3 (minimum); | | 3~2 | P2H[1: 0] | P2 high four IOH settings | | | | 00: Set P2 high four IOH level 0 (maximum); | | | | 01: Set P2 high four IOH level 1; | | | | 10: Set P2 high four IOH level 2; | | | | 11: Set P2 high four IOH level 3 (minimum); | Page 161 of 252 V0.1 | 1~0 | P2L[1: 0] | P2 low four IOH settings | |-----|-----------|--------------------------------------------| | | | 00: Set P2 low four IOH level 0 (maximum); | | | | 01: Set P2 low four IOH level 1; | | | | 10: Set P2 low four IOH level 2; | | | | 11: Set P2 low four IOH level 3 (minimum); | | 7~6 | - | Reserved | Page 162 of 252 V0.1 ## 15 LCD/LED Display Driver The SC95F776X integrates hardware LCD/LED display drive circuit inside, which can facilitate users to realize LCD and LED display drive. Its main features are as follows: - 1. Choose one of LCD and LED display driver; - 2. LCD and LED display drivers share related IO ports and registers. #### The LCD display driver functions are as follows: - 1. 4 display drive modes are available: 8 X 24, 6 X 26, 5 X 27, or 4X 28 segments; - 2. 2 kinds of offset methods are available: 1/4 Bias and 1/3 Bias; - 3. 4 levels of COM port drive capability are optional; - The display drive circuit can choose the built-in 32 kHz LRC or external 32.768 kHz oscillator as the clock source, the frame frequency is about 64Hz. Note: If the LCD driver frame frequency is not 64Hz, you are advised to contact sinone technical support for solutions. #### The LED display driver functions are as follows: - 1. 4 display drive modes are available: 8 X 24, 6 X 26, 5 X 27, or 4X 28 segments; - SEG port drive capability is optional in 4 levels; - 3. The display drive circuit can select the built-in 32 kHz LRC or external 32.768kHz oscillator as the clock source, and the frame frequency is about 64Hz. ## 15.1 LCD/LED Display Drive-related Registers #### DDRCON (93H) Display Drive Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----------------|-------|------|------------|-----|------------|-----|-----|-----|--| | Bit<br>Mnemonic | DDRON | DMOD | DUTY[1: 0] | | VLCD[3: 0] | | | | | | R/W | | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Page 163 of 252 V0.1 | Bit number | Bit Mnemonic | Description | |------------|--------------|-----------------------------------------------------------------------------------------------| | 7 | DDRON | LCD/LED display drive enable control 0: The display driver scan is turned off | | | | 1: The display driver scan is turned on | | 6 | DMOD | LCD/LED display drive mode | | | | 0: LCD mode; | | | | 1: LED mode | | 5~4 | DUTY[1: 0] | LCD/LED display duty control | | | | 00: 1/8 duty cycle, S4~S27 are segments, C0~C7 are common; | | | | 01: 1/6 duty cycle, S2~S27 are segments, C2~C7 are common; | | | | 10: 1/5 duty cycle, S1~S27 are segments, C3~C7 are common; | | | | 11: 1/4 duty cycle, S0~S27 is segment, C4~C7 is common, or S4~S27 is segment, C0~C3 is common | | 3~0 | VLCD[3: 0] | LCD voltage regulation | | | | VLCD=V <sub>DD</sub> *(17+VLCD[3: 0])/32 | ## P0VO (9CH) P0 Port Display Driver Output Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------|-------|-------|-------|-------|-------|-------|-------| | Bit<br>Mnemonic | P07VO | P06VO | P05VO | P04VO | P03VO | P02VO | P01VO | P00VO | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Page 164 of 252 V0.1 | Bit number | Bit Mnemonic | Description | |------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | 7~0 | P0nVO | Open P0n port display driver output 0: Disable the display driver output function of P0n port 1: Enable the display driver output function of P0n port | ### P1VO (94H) P1 Port Display Driver Output Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------|-------|-------|-------|-------|-------|-------|-------| | Bit<br>Mnemonic | P17VO | P16VO | P15VO | P14VO | P13VO | P12VO | P11VO | P10VO | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-----------------------------------------------------------| | 7~0 | P1nVO | Open P1n port display driver output | | | | 0: Disable the display driver output function of P1n port | | | | 1: Enable the display driver output function of P1n port | ## P2VO (A3H) P2 Port Display Driver Output Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------|-------|-------|-------|-------|-------|-------|-------| | Bit<br>Mnemonic | P27VO | P26VO | P25VO | P24VO | P23VO | P22VO | P21VO | P20VO | | R/W Page 165 of 252 V0.1 | POR 0 0 0 0 0 | 0 0 0 | | |---------------|-------|--| |---------------|-------|--| | Bit number | Bit Mnemonic | Description | |------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | 7~0 | P2nVO | Open P2n port display driver output 0: Disable the display driver output function of P2n port 1: Enable the display driver output function of P2n port | ## P3VO (B3H) P3 Port Display Driver Output Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------|-------|-------|-------|-------|-------|-------|-------| | Bit<br>Mnemonic | P37VO | P36VO | P35VO | P34VO | P33VO | P32VO | P31VO | P30VO | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7~0 | P3nVO | Open P3n port display driver output 0: Disable the display driver output function of P3n port 1: Enable the display driver output function of the P3n port | ### OTCON (8FH) Output Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|---|---|---|---|---|---|---|---| |------------|---|---|---|---|---|---|---|---| Page 166 of 252 V0.1 | Bit<br>Mnemonic | USMD | 1[1: 0] | USMD0[1: 0] | | VOIRS[1: 0] | | scs | BIAS | |-----------------|------|---------|-------------|-----|-------------|-----|-----|------| | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3~2 | VOIRS[1: 0] | LCD voltage output port voltage divider resistance selection | | | | 00: Set the total resistance of the internal voltage divider to be $100k\Omega$ | | | | 01: Set the total resistance of the internal voltage divider resistor to $200 k\Omega$ | | | | 10: Set the total resistance of the internal voltage divider to $400k\Omega$ | | | | 11: Set the total resistance of the internal voltage divider to $800k\Omega$ | | | | Each time Common is switched, the first 1/16 time is fixed to select a 100k resistor, and the last 15/16 time is switched to the resistance value selected by VORIS | | 1 | scs | LCD/LED Segment/Common multiplex pin selection | | | | 0: When set to 1/4 duty cycle, S0~S27 are segments and C4~C7 are common | | | | 1: When set to 1/4 duty cycle, S4~S27 are segments and C0~C3 are common | | 0 | BIAS | LCD display drive bias voltage setting: | | | | 0: 1/4 bias voltage; | | | | 1: 1/3 bias voltage | ## 15.2 LCD/LED Display RAM Configuration | Address | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---|---| |---------|---|---|---|---|---|---|---|---| Page 167 of 252 V0.1 | | COM7 | COM6 | COM5 | COM4 | СОМЗ | COM2 | COM1 | СОМО | |-------|-------|-------|-------|-------|-------|-------------|-----------|---------------------| | 2000H | SEG0 | 2001H | SEG1 | | 2002H | SEG2 | 2003H | SEG3 | 2004H | SEG4 | 2005H | SEG5 SEG6 SEG7 SEG8 | | 2006H | SEG6 SEG6 | | | 2007H | SEG7 | | 2008H | SEG8 | | 2009H | SEG9 | 200AH | SEG10 | 200BH | SEG11 | 200CH | SEG12 | 200DH | SEG13 | 200EH | SEG14 | 200FH | SEG15 | 2010H | SEG16 | SEG16 | SEG16 | SEG16 | SEG16 | SEG16 SEG16 | | SEG16 | Page 168 of 252 V0.1 | 2011H SEG17 SEG18 SEG19 SEG19 SEG19 SEG19 SEG19 SEG19 SEG19 SEG19 SEG20 SEG20 SEG20 SEG20 SEG21 SEG21 SEG21 SEG21 SEG21 SEG21 SEG21 SEG22 SEG22 SEG22 SEG22 SEG22 SEG22 SEG22 SEG22 SEG22 SEG23 SEG23 SEG23 <th< th=""><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th></th<> | | | | | | | | | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|-------|--------------|-------------------|-------|-------|-------| | 2013H SEG19 SEG20 SEG20 SEG20 SEG20 SEG20 SEG20 SEG20 SEG21 SEG22 SEG23 SEG23 SEG23 SEG23 SEG23 SEG23 SEG23 SEG24 SEG24 SEG24 SEG24 SEG24 SEG24 SEG24 SEG24 SEG24 SEG25 SEG25 SEG25 SEG25 SEG26 SEG26 SEG26 SEG26 SEG26 <th< td=""><td>2011H</td><td>SEG17</td><td>SEG17</td><td>SEG17</td><td>SEG17</td><td>SEG17</td><td>SEG17</td><td>SEG17</td><td>SEG17</td></th<> | 2011H | SEG17 | 2014H SEG20 SEG21 SEG22 SEG23 SEG23 SEG23 SEG23 SEG23 SEG23 SEG23 SEG23 SEG24 SEG24 SEG24 SEG24 SEG24 SEG24 SEG24 SEG24 SEG24 SEG25 SEG25 SEG25 SEG25 SEG25 SEG25 SEG26 SEG26 SEG26 <td< td=""><td>2012H</td><td>SEG18</td><td>SEG18</td><td>SEG18</td><td>SEG18</td><td>SEG18</td><td>SEG18</td><td>SEG18</td><td>SEG18</td></td<> | 2012H | SEG18 | 2015H SEG21 SEG22 SEG23 SEG23 SEG23 SEG23 SEG23 SEG23 SEG23 SEG24 SEG25 SEG25 SEG25 SEG25 SEG25 SEG26 SEG26 SEG26 SEG26 SEG26 SEG26 SEG26 SEG26 SEG26 <td< td=""><td>2013H</td><td>SEG19</td><td>SEG19</td><td>SEG19</td><td>SEG19</td><td>SEG19</td><td>SEG19</td><td>SEG19</td><td>SEG19</td></td<> | 2013H | SEG19 | 2016H SEG22 SEG23 SEG24 SEG25 SEG25 SEG25 SEG25 SEG25 SEG25 SEG25 SEG25 SEG26 <td< td=""><td>2014H</td><td>SEG20</td><td>SEG20</td><td>SEG20</td><td>SEG20</td><td>SEG20</td><td>SEG20</td><td>SEG20</td><td>SEG20</td></td<> | 2014H | SEG20 | 2017H SEG23 SEG24 SEG25 SEG25 SEG25 SEG25 SEG25 SEG25 SEG25 SEG25 SEG26 <td< td=""><td>2015H</td><td>SEG21</td><td>SEG21</td><td>SEG21</td><td colspan="2">EG21 SEG21 S</td><td>SEG21</td><td>SEG21</td><td>SEG21</td></td<> | 2015H | SEG21 | SEG21 | SEG21 | EG21 SEG21 S | | SEG21 | SEG21 | SEG21 | | 2018H SEG24 SEG25 SEG26 <td< td=""><td>2016H</td><td>SEG22</td><td>SEG22</td><td>SEG22</td><td>SEG22</td><td>SEG22</td><td>SEG22</td><td>SEG22</td><td>SEG22</td></td<> | 2016H | SEG22 | 2019H SEG25 SEG26 | 2017H | SEG23 | 201AH SEG26 SEG26 SEG26 SEG26 SEG26 SEG26 SEG26 | 2018H | SEG24 | | 2019H | SEG25 | SEG25 | SEG25 | SEG25 | SEG25 SEG25 SEG25 | | SEG25 | SEG25 | | 201BH SEG27 SEG27 SEG27 SEG27 SEG27 SEG27 SEG27 SEG27 | 201AH | SEG26 | | 201BH | SEG27 ## 15.3 LCD Waveform ### 15.3.1 1/3Bias LCD Waveform Page 169 of 252 V0.1 1/3 Bias LCD Gated and non-gated voltages 1/3 Bias Waveforms of COM and SEG in LCD applications Page 170 of 252 V0.1 http://www.socmcu.com ### 15.3.2 1/4Bias LCD Waveform 1/4 Bias LCD Gated and non-gated voltages Page 171 of 252 V0.1 1/4 Bias Waveforms of COM and SEG in LCD applications ### 15.4 LED Waveform Page 172 of 252 V0.1 Waveforms of COM and SEG in LED applications ## 15.5 LCD/LED Example ### 15.5.1 LCD Configuration Demo Program unsigned char xdata LCDRAM[30] \_at\_ 0x2000; unsigned char lcd\_addr; unsigned char lcd\_data; DDRCON = 0x00; //0: LCD mode 1: LED mode DDRCON |= 0x30; //1/4 Duty cycle DDRCON $\mid = 0x07$ ; // VLCD= $V_{DD}*3/4$ DDRCON |= 0x80; // Display driver scan on POVO = 0xFF; // Open the display driver output function of P0 port P1VO = 0xFF; // Open the display driver output function of P1 port P2VO = 0xFF; // Open the display driver output function of P2 port P3VO = 0xFF; // Open the display driver output function of P3 port Page 173 of 252 V0.1 ## SC95F7767/7766/7765/7763 ### Super High-speed 1T 8051 Core Flash MCU OTCON = 0x06; // Set the total resistance of the internal voltage divider resistor to $200K\Omega$ //1/4 Bias voltage; S4~S27 is segment, C0~C3 is common LCDRAM[lcd\_addr] = lcd\_data; /Write the value to be displayed to the LCD RAM #### 15.5.2 LED Configuration Demo Program unsigned char xdata LEDRAM[30] \_at\_ 0x2000; unsigned char led\_addr; unsigned char led\_data; DDRCON |= 0x4F; //0: LCD mode1 : LED mode //LED mode; 1/8 Duty cycle //S4~S27 is segment,C0~C7 is common; DDRCON |= 0x80; // Display driver scan on IOHCON0 = 0xC0; // Set P1 high four IOH level 3 (minimum), other pins IOH level 0 (maximum) IOHCON1 = 0x00; P0VO = 0xFF; // Open the display driver output function of P0 port P1VO = 0xFF; // Open the display driver output function of P1 port P2VO = 0xFF; // Open the display driver output function of P2 port P3VO = 0xFF; // Open the display driver output function of P3 port OTCON = 0x00; LCDRAM[led\_addr] = led\_data; //Write the value to be displayed to the LED RAM Page 174 of 252 V0.1 ## **16 SERIAL INTERFACE (UART0)** The SC95F776X supports a full-duplex serial port, which can be conveniently used for connection with other devices or equipment, such as Wifi module circuit or other UART communication interface driver chip. The functions and features of UART0 are as follows: - 1. Three communication modes are available: Mode 0, Mode 1 and Mode 3; - 2. Can choose Timer 1 or Timer 2 as the baud rate generator; - Interrupt RI/TI can be generated after transmission and reception are completed, and the interrupt flag needs to be cleared by software. #### SCON (98H) Serial 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 | | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bit number | Bit Mnemonic | Description | |------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7~6 | SM0~1 | <ul> <li>Serial communication mode control bit</li> <li>00: Mode 0, 8-bit half-duplex synchronous communication mode, serial data is sent and received on the RX pin. The TX pin is used as the transmit shift clock. 8 bits are sent and received per frame, the low bit is received or sent first;</li> <li>01: Mode 1, 10-bit full-duplex asynchronous communication, consisting of 1 start bit, 8 data bits and 1 stop bit, the communication baud rate is variable;</li> <li>10: reserved;</li> <li>11: Mode 3, 11-bit full-duplex asynchronous communication, consisting of 1 start bit, 8 data bits, a programmable 9th bit, and 1 stop bit. The communication baud rate is variable.</li> </ul> | | 5 | SM2 | Serial communication mode control bit 2, this control bit is only valid for mode 3 | Page 175 of 252 V0.1 | | | <ul> <li>0: set RI to generate an interrupt request every time a complete data frame is received;</li> <li>1: When a complete data frame is received, RI will be set to generate an interrupt request only when RB8=1.</li> <li>The baud rate override setting bit is only valid in mode 0 (SM0~1 = 00):</li> <li>0: The serial port runs at 1/12 of the system clock</li> <li>1: The serial port runs at 1/4 of the system clock</li> </ul> | |---|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | REN | Receive enable control bit 0: data reception is not allowed; 1: Allow receiving data. | | 3 | TB8 | Only valid for mode 3, which is the 9th bit of the transmitted data | | 2 | RB8 | Only valid for mode 3, the 9th bit of the received data | | 1 | TI | Transmit interrupt flag | | 0 | RI | Receive interrupt flag | ## SBUF (99H) Serial Data Buffer 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 | |------------|--------------|-------------| |------------|--------------|-------------| Page 176 of 252 V0.1 #### SC95F7767/7766/7765/7763 ### Super High-speed 1T 8051 Core Flash MCU | 7~0 | SBUF[7: 0] | Serial data buffer register | |-----|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | SBUF contains two registers: a transmit shift register and a receive latch. The data written to SBUF will be sent to the transmit shift register and start the transmission process. Reading SBUF will return the contents of the receive latch. | #### PCON (87h) Power Management Control Register (write only, \*unreadable\*) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----------------|---|---|---|------------|---|-------|---------------| | Bit<br>Mnemonic | SMOD | - | - | - | RST | | STOP | IDL | | R/W | -\write<br>only | - | - | - | Write only | | Write | Write<br>only | | POR | 0 | х | х | х | n | х | 0 | 0 | | Bit number | Bit Mnemonic | Description | | | | | | |------------|--------------|-------------------------------------------------------------------------------------------|--|--|--|--|--| | 7 | SMOD | When SM0~1 = 01 (UART0 mode 1) or SM0~1 = 11 (UART0 mode 3), the baud rate is set to bit: | | | | | | | | | 0: the serial port runs at fsys/1 | | | | | | | | | 1: indicates that the serial port runs at sys/16 | | | | | | ### 16.1 Baud Rate of Serial Communication In mode 0, the baud rate can be programmed to 1/12 or 1/4 of the system clock: - 1. SM2=0, the serial port runs at 1/12 of the system clock; - 2. SM2=1, the serial port runs at 1/4 of the system clock. - In modes 1 and 3, the serial port clock source can be programmed as either 1 or 16 of the system clock, determined by SMOD(pcon.7) bits. When SMOD is 0, the serial port runs at 1/fsys. When SMOD is 1, the serial port runs at 16/fsys. After the serial port clock source is determined, set the baud rate overflow rate by Timer 1 or Timer 2:When TCLK(TXCON. 4) and RCLK(TXCON. 5) bits are both 0, then timer 1 is baud rate generator mode, and the baud rate overflow rate of UART0 is set by [TH1,TL1]. The formula is as follows, note: When timer 1 acts as a baud rate generator, timer 1 must stop counting, i.e. TR1=0: ■ SMOD = 0: BaudRate = $\frac{\text{fsys}}{\text{[TH1,TL1]}}$ ; (Note: [TH1, TL1] must be bigger than 0x0010) Page 177 of 252 V0.1 ## SC95F7767/7766/7765/7763 ## **Super High-speed 1T 8051 Core Flash MCU** SMOD = 1: BaudRate = $$\frac{1}{16} * \frac{\text{fsys}}{\text{[TH1,TL1]}}$$ ; - When TCLK(TXCON. 4) or RCLK(TXCON. 5) is 1, then timer 2 is in baud rate generator mode, and the baud rate overflow rate of UART0 is set by [RCAP2H, RCAP2L], the formula is as follows: - SMOD = 0: BaudRate = $\frac{\text{fsys}}{[\text{RCAP2H}, \text{RCAP2L}]}$ ; Note: [RCAP2H, RCAP2L] must be bigger than 0x0010) - SMOD = 1: BaudRate = $\frac{1}{16} * \frac{\text{fsys}}{[\text{RCAP2H,RCAP2L}]}$ ; Page 178 of 252 V0.1 ## 17 SPI/TWI/UART Serial Interface (USCI) | Symbol | Address | Description | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | POR | |-------------|---------|-----------------------------|---|---------------|---|-------|----------|---|---|---|---------------| | US0CO<br>N0 | 95H | USCI0 control register 0 | | US0CON0[7: 0] | | | | | | | | | US0CO<br>N1 | 9DH | USCI0 control register 1 | | US0CON1[7: 0] | | | | | | | | | US0CO<br>N2 | 9EH | USCI0 control<br>register 2 | | US0CON2[7: 0] | | | | | | | 0000000<br>0b | | US0CO<br>N3 | 9FH | USCI0 control register 3 | | US0CON3[7: 0] | | | | | | | | | US1CO<br>N0 | A4H | USCI1 control register 0 | | US1CON0[7: 0] | | | | | | | | | US1CO<br>N1 | A5H | USCI1 control register 1 | | US1CON1[7: 0] | | | | | | | 0000000<br>0b | | US1CO<br>N2 | A6H | USCI1 control register 2 | | | | US1CO | N2[7: 0] | | | | 0000000<br>0b | | US1CO<br>N3 | A7H | USCI1 control register 3 | | | | US1CO | N3[7: 0] | | | | 0000000<br>0b | | USXCO<br>N0 | C4H | USCI2 control<br>register 0 | | | | US2CO | N0[7: 0] | | | | 0000000<br>0b | | USXCO<br>N1 | С5Н | USCI2 control register 1 | | US2CON1[7: 0] | | | | | | | 0000000<br>0b | | USXCO<br>N2 | С6Н | USCI2 control<br>register 2 | | US2CON2[7: 0] | | | | | | | 0000000<br>0b | | USXCO<br>N3 | С7Н | USCI2 control register 3 | | | | US2CO | N3[7: 0] | | | | 0000000<br>0b | Page 179 of 252 V0.1 #### SC95F7767/7766/7765/7763 ### Super High-speed 1T 8051 Core Flash MCU | USXINX | DCH | USCI2/3/4/5<br>Control<br>register pointer | - | - | - | - | - | USCIX[2:0] | | xxxxx000<br>b | | |--------|-----|--------------------------------------------|------|---------|------------|---|------------|------------|------|---------------|---------------| | TMCON | 8EH | Timer<br>frequency<br>control register | USMD | X[1:0] | - | - | - | - | T1FD | T0FD | 00xxxx00<br>b | | OTCON | 8FH | Output control register | USME | 01[1:0] | USMD0[1:0] | | VOIRS[1:0] | | scs | BIAS | 0000000<br>0b | The SC95F776X internally integrates 6 three-select one universal serial circuits interface (referred to as USCI), which can facilitate the connection between MCU and devices or equipment with different interfaces. The user can configure the USCI0~5 interface to any one of SPI, TWI and UART through the USMD1[1: 0], USMD0[1: 0] bits of the configuration register OTCON, or the USMDX[1: 0] bits of TMCON. Its characteristics are as follows: - 1. When USCI0 is set to SPI0, the output drive capability is enhanced, which is consistent with common I/O features in other modes - 2. SPI mode can be configured as one of master mode or slave mode, with 8-bit or 16-bit transmission mode - 3. TWI mode communication can be configured as master mode or slave mode - 4. UART modes can work in: Mode 0: 8-bit half-duplex synchronous communication, Mode 1: 10-bit full-duplex asynchronous communication and Mode 3: 11-bit full-duplex asynchronous communication - 5. USCI0/1/2/3/4 are independent USCI interfaces. Note the following: The USCI2/3/4/5 control registers share the same set of addresses (C4H-C7H). Users can point the USCIX register group (USXCON0~3) to USCI2/3/4/5 through USXINX[2:0], thus realizing the function of configuring three independent USCI interfaces for one set of registers Note: Only after USXINX[2:0] has been successfully configured will the USCIX register group point to USCI2/3/4/5 specified by the user, in which case set the USCIX register group is valid for the corresponding USCI interface. The specific configuration method is as follows: #### USXINX (DCH) USCI2/3/4/5 Control register pointer (R/W) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|---|---|---|------------|-----|-----| | Bit<br>Mnemonic | - | - | - | - | - | USCIX[2:0] | | | | R/W | - | - | - | - | - | R/W | R/W | R/W | | POR | х | х | х | х | х | 0 | 1 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------| |------------|--------------|-------------| Page 180 of 252 V0.1 | 2~0 | USCIX[2:0] | USCI2/3/4/5 Control register pointer | |-----|------------|------------------------------------------------------| | | | 010: USCIX register(USXCON0~3 及 USMDX)point to USCI2 | | | | 011: USCIX register point to USCI3 | | | | 100: USCIX register point to USCI4 | | | | 101: USCIX register point to USCI5 | | | | Other: Reserved | | 5~3 | - | Reserved | ## OTCON (8FH) Output Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|---------|-------------|-----|-------------|-----|-----|------| | Bit<br>Mnemonic | USMD | 1[1: 0] | USMD0[1: 0] | | VOIRS[1: 0] | | SCS | BIAS | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|-------------------------------------------| | 7~6 | USMD1[1: 0] | USCI1 Communication mode control bit | | | | 00: USCI1 close | | | | 01: USCI1 Set to SPI communication mode; | | | | 10: USCI1 Set to TWI communication mode; | | | | 11: USCI1 Set to UART communication mode; | | 5~4 | USMD0[1: 0] | USCI0 Communication mode control bit | | | | 00: Reserved; | | | | 01: USCI0 Set to SPI communication mode; | | | | 10: USCI0 Set to TWI communication mode; | Page 181 of 252 V0.1 | | 11: USCI0 Set to UART communication mode; | |--|-------------------------------------------| | | | ## TMCON (8EH) Timer Frequency Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|---------|---|---|---|---|------|------| | Bit<br>Mnemonic | USMD | X[1: 0] | - | - | - | - | T1FD | T0FD | | R/W | R/W | R/W | - | - | - | | R/W | R/W | | POR | 0 | 0 | х | х | х | x | 0 | 0 | | Bit number | Bit<br>Mnemoni<br>c | Condition | Description | |------------|---------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7~6 | USMDX[<br>1: 0] | USCIX = 010 USCIX = 011 | USCI2 Communication mode control bit 00: USCI2 close 01: USCI2 set to SPI communication mode; 10: USCI2 set to TWI communication mode; 11: USCI2 set to UART communication mode; USCI3 Communication mode control bit 00: USCI3 close 01: USCI3 set to SPI communication mode; 10: USCI3 set to TWI communication mode; 11: USCI3 set to TWI communication mode; | | | | USCIX =<br>100 | USCI4 Communication mode control bit 00: USCI4 close 01: USCI4 set to SPI communication mode; | Page 182 of 252 V0.1 | | | | 10: USCI4 set to TWI communication mode; | |--|--|-----------------|-------------------------------------------| | | | | 11: USCI4 set to UART communication mode; | | | | | USCI5 Communication mode control bit | | | | 00: USCI5 close | | | | | USCIX = 101 | 01: USCI5 set to SPI communication mode; | | | | | 10: USCI5 set to TWI communication mode; | | | | | 11: USCI5 set to UART communication mode; | #### Note: A USCI interface can be set to different communication modes by USMD, each of which has a corresponding operation register group. The control register groups in different communication modes share the same mapped address, but the operations among the groups are independent. Setting the control register in one communication mode does not affect the values in the register groups in other communication modes. #### For example: - Set USMD1 = 01, USCI0 is SPI communication interface, in this mode set US0CON0 (95H) = 0x80H; - Then set USMD1 =11, USCI0 is the UART communication interface, set US0CON0 (95H) = 0x0FH; - Then set USMD1 = 01, USCI0 is set back to SPI communication interface, read US0CON0 (95H) in this mode, should be 0x80H; - Then set USMD1 =11, USCI0 is set back to the UART communication interface, and US0CON0 (95H) is read in this mode, which should be 0x0FH. #### 17.1 SPI USMDn[1: 0] = 01, n=0~5, select one of three serial interface USCI is configured as SPI interface: - USTXn as MOSI signal - USRXn as MISO signal - USCKn as CLK signal Serial Peripheral Device Interface (SPI for short) is a high-speed serial communication interface that allows the MCU to perform full-duplex, synchronous serial communication with peripheral devices (includi5g other MCUs). The SPI interface of USCI0 has 16-bit 8-level FIFO cache and is independent of sending and receiving, that is, users can achieve: • Write up to 8 bits or less 16-bit data sequentially to SPI send caches (US0CON2, US0CON3) When the SPI sends data, the first data written is also sent first. When the data written into the FIFO by the user is sent, the null flag TXE of the sending buffer is set to 1. If the DATA in THE FIFO is full, the write conflict flag bit WCOL is set, and the user cannot write data to the FIFO until the data in the FIFO is sent out and the FIFO is not satisfied. The interrupt flag SPIF is raised when all data in the FIFO is sent. Page 183 of 252 V0.1 - The SPI receive cache (US0CON2, US0CON3) continuously reads 8 or less 16-bit received data, and the first received data is also read first. - In addition, when USCI0 is set as SPI0, the driving ability of the pins corresponding to its signal port will be enhanced. | Contrast | USCI1~5 SPI | USCI0 SPI | |----------|--------------------------------------------------------------------|---------------------------------------------------------------------| | TXE | The send buffer is empty, set 1 | Set to 1 when data written to the FIFO is sent | | WCOL | When a frame is being sent, rewrites are set to 1 and cannot write | If the FIFO is filled, set it to 1, and can't write the FIFO | | SPIF | Send complete, interrupt flag set up | The interrupt flag is not raised until all data in the FIFO is sent | ## 17.1.1 SPI Operation Related Registers US0CON0 (95H) SPI0 control register (read/write) US1CON0 (A4H) SPI1 control register (read/write) USXCON0 (C4H) SPI2~5 control register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|---|------|------|------|------|------|------| | Bit<br>Mnemonic | SPEN | | MSTR | CPOL | СРНА | SPR2 | SPR1 | SPR0 | | 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 | SPEN | SPI Enable control 0: close SPI | Page 184 of 252 V0.1 | | | 4 ODI | |-----|-----------|-----------------------------------------------------| | | | 1: open SPI | | 5 | MSTR | SPI master-slave selection | | | | 0: SPI is slave device | | | | 1: SPI is master device | | 4 | CPOL | Clock polarity control bit | | | | 0: SCK is low in idle state | | | | 1: SCK is high in idle state | | 3 | СРНА | Clock phase control bit | | | | 0: Collect data on the first edge of the SCK cycle | | | | 1: Collect data on the second edge of the SCK cycle | | 2~0 | SPR[2: 0] | SPI Clock rate selection bit | | | | 000: fsys | | | | 001: fsys/2 | | | | 010: fsys/4 | | | | | | | | 011: fsys/8 | | | | 011: fsys/8<br>100: fsys/16 | | | | | | | | 100: fsys/16 | | | | 100: fsys/16<br>101: fsys/32 | Page 185 of 252 V0.1 # Super High-speed 1T 8051 Core Flash MCU US0CON1 (9DH) SPI0 Status Register (read/write) US1CON1 (A5H) SPI1 Status Register (read/write) USXCON1 (C5H) SPI2~5 Status Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|---|---|-----|------|------|------| | Bit<br>Mnemonic | SPIF | WCOL | - | - | TXE | DORD | SPMD | TBIE | | R/W | R/W | R/W | - | - | R/W | R/W | R/W | R/W | | POR | 0 | 0 | х | x | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | SPIF | SPI data transmission flag 0: Cleared by software 1: Indicates that data transmission has been completed, set by hardware | | 6 | WCOL | Write conflict flag 0: Cleared by software, indicating that the write conflict has been processed 1: Set by hardware to indicate that a conflict is detected Transmission direction selection bit | | 3 | TXE | Send cache null flag 0: The send cache is not empty 1: The send cache is empty and must be cleared by the software. At this time, the user can write data to FIFO. | | 2 | DORD | Transmission direction selection bit 0: MSB first sent | Page 186 of 252 V0.1 | | | 1: LSB first sent | |---|------|-------------------------------------------------------------------------------------| | 1 | SPMD | SPI transmission mode selection: | | | | 0: 8-bit mode | | | | 1: 16-bit mode | | | TBIE | Interrupt enable bit when the send cache is empty: | | | | | | | | 0: When TXE=1, interrupts are not allowed | | | | 0: When TXE=1, interrupts are not allowed 1: When TXE=1, SPI interrupt is generated | US0CON2 (9EH) SPI0 Data register low byte (read/write) US1CON2 (A6H) SPI1 Data register low byte (read/write) USXCON2 (C6H) SPI2~5 Data register low byte (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|------------|-----|-----|-----|-----|-----|-----| | Bit<br>Mnemonic | | SPDL[7: 0] | | | | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|---------------------------------------------------| | 7~0 | SPDL[7: 0] | SPI data buffer register low byte (8/16 bit mode) | | | | Low byte of data written to data register SPD | | | | Read data low byte of data register SPD | Page 187 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU US0CON3 (9FH) SPI0 Data register high byte (read/write) US1CON3 (A7H) SPI1 Data register high byte (read/write) USXCON3 (C7H) SPI2~5 Data register high byte (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------------|-----|-----|-----|-----|-----|-----|-----| | Bit<br>Mnemonic | SPDH[7: 0] | | | | | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7~0 | SPDH[7: 0] | SPI data buffer register high byte (only for 16-bit mode) | | | | High byte of data written to data register SPD | | | | Read data high byte of data register SPD | | | | Note: When SPI is set to 16-bit mode, you must write the high byte first, then write the low byte, and start sending immediately after the low byte is written | ### 17.1.2 Signal Description #### Master-Out/Slave-In (MOSI): This signal connects the master device and a slave device. Data is serially transmitted from the master device to the slave device through MOSI, the master device outputs, and the slave device inputs. #### Master-In and Slave-Out (MISO): This signal connects the slave device and the master device. Data is serially transmitted from the slave device to the master device through MISO, the slave device is output, and the master device is input. When the SPI is configured as a slave device and not selected, the MISO pin of the slave device is in a high impedance state. #### SPI Serial Clock (SCK): Page 188 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU The SCK signal is used to control the synchronous movement of input and output data on the MOSI and MISO lines. A byte is transmitted on the wire every 8 clock cycles. If the slave is not selected, the SCK signal is ignored by the slave. ### 17.1.3 Operating Modes SPI can be configured as one of master mode or slave mode. The configuration and initialization of the SPI module are completed by setting the SPI control register USnCON0 (n=0~2) and the SPI status register USnCON1. After the configuration is completed, the data transfer is completed by setting the SPI data registers USnCON2, USnCON3 (hereinafter referred to as SPD). During SPI communication, data is shifted in and out serially synchronously. The serial clock line (SCK) keeps the movement and sampling of data on the two serial data lines (MOSI and MISO) synchronized. If the slave is not selected, it cannot participate in activities on the SPI bus. When the SPI master device transmits data to the slave device through the MOSI line, the slave device sends the data to the master device as a response via the MISO line, which realizes the synchronous full-duplex transmission of data sending and receiving under the same clock. The sending shift register and the receiving shift register use the same special function address. Writing to the SPI data register SPD will write to the sending shift register, and reading the SPD will get the data of the receiving shift register. The SPI interface of some devices will lead to the SS pin (slave device selection pin, active low). When communicating with the SPI of the SC95F776X, the connection mode of the SS pin of other devices on the SPI bus needs to be connected according to different communication modes. The following table lists the connection modes of the SS pin of other devices on the SPI bus in different SPI communication modes of the SC95F776X: | SC95F776X SPI | Other devices on the SPI bus | Mode | Slave SS (Slave selection pin) | |---------------|------------------------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | Master mode | Slave mode | One master and one slave | Pull down | | | | One master and multiple slaves | The SC95F776X leads to multiple I/Os, which are connected to the SS pin of the slave. Before data transmission, the SS pin of the slave device must be set low | | Slave mode | Master mode | One master and one slave | Pull up | #### **Master Mode** #### Mode Startup: The SPI master device controls the start of all data transfers on the SPI bus. When the MSTR bit in the SPI control register USnCON0 is set to 1, the SPI runs in the master mode and only one master device can start the transfer. #### • Transmitting: Page 189 of 252 V0.1 #### Super High-speed 1T 8051 Core Flash MCU In SPI master mode, perform the following operations on SPD: write a byte of data to SPDL in 8-bit mode or write the high byte to SPDH first, and then write the low byte to SPDL in 16-bit mode, the data will be written to the transmit shift buffer. If there is already a data in the transmit shift register, the main SPI generates a WCOL signal to indicate that the write is too fast. But the data in the transmission shift register will not be affected, and the transmission will not be interrupted. In addition, if the transmission shift register is empty, the master device immediately shifts the data in the transmission shift register to the MOSI line in accordance with the SPI clock frequency on SCK. When the transfer is complete, the SPIF bit in the SPI status register USnCON1 is set to 1. If the SPI interrupt is enabled, an interrupt will also be generated when the SPIF bit is set. #### Receiving: When the master device transmits data to the slave device through the MOSI line, the corresponding slave device also transmits the contents of its transmitting shift register to the receiving shift register of the master device through the MISO line, realizing full-duplex operation. Therefore, the SPIF flag set 1 means that the transmission is complete and the data is received. The data received by the slave device is stored in the receive shift register of the master device according to the MSB or LSB first transmission direction. When a byte of data is completely moved into the receive register, the processor can obtain the data by reading the SPD. #### Slave mode #### • Mode Startup: When the MSTR bit in the SPI control register USnCON0 register is cleared to 0, SPI runs in slave mode. ### Transmitting and Receiving: In slave mode, according to the SCK signal controlled by the master device, data is shifted in through the MOSI pin, and the MISO pin is shifted out. A bit counter records the number of edges of SCK. When the receiving shift register shifts in 8-bit data (one byte) and the sending shift register shifts out 8-bit data (one byte), the SPIF flag bit is set to 1. The data can be obtained by reading the SPD register. If the SPI interrupt is enabled, an interrupt will also be generated when SPIF is set. At this time, the receiving shift register keeps the original data and the SPIF bit is 1, so that the SPI slave device will not receive any data until SPIF is cleared. The SPI slave device must write the data to be transmitted into the transmit shift register before the master device starts a new data transmission. If no data is written before starting to send, the slave device will transmit the "0x00" byte to the master device. If the SPD write operation occurs during the transfer, the WCOL flag of the SPI slave device is set to 1, that is, if the transfer shift register already contains data, the WCOL bit of the SPI slave device is set to 1, indicating that the write SPD conflicts. But the data of the shift register is not affected, and the transmission will not be interrupted. #### 17.1.4 Transfer Form By software setting the CPOL bit and CPHA bit of the SPI control register USnCON0, the user can select four combinations of SPI clock polarity and phase. The CPOL bit defines the polarity of the clock, that is, the level state when idle, and it has little effect on the SPI transmission format. The CPHA bit defines the phase of the clock, that is, defines the clock edge that allows data sampling and shifting. In the two devices of master-slave communication, the setting of the clock polarity phase should be the same. When CPHA = 0, the first edge of SCK captures data, and the slave must prepare the data before the first edge of SCK. Page 190 of 252 V0.1 CPHA = 0 Data transfer diagram When CPHA = 1, the master device outputs data to the MOSI line on the first edge of SCK, the slave device uses the first edge of SCK as the sending signal, and the second edge of SCK starts to capture data, So the user must write SPD inside two edges of the first SCK. This form of data transmission is the preferred form of communication between a master device and a slave device. CPHA = 1 Data transfer diagram ### 17.1.5 Error Detection Writing to SPD during the data transmission sequence will cause a write conflict, and the WCOL bit in the SPI status register USnCON1 is set to 1. WCOL bit 1 will not cause interruption, and transmission will not be aborted. The WCOL bit needs to be cleared by software. #### 17.2 TWI USMDn[1: 0] = 10,n=0~5 One of three serial interface USCI is configured as TWI interface: - USTXn as SDA signal - USCKn as CLK signal Page 191 of 252 V0.1 The SC95F776X can be set as master or slave mode according to application requirements during TWI communication. ## US0CON0 (95H) TWI0 Control Register 0 (read/write) ### US1CON0 (A4H) TWI1 Control Register 0 (read/write) ### USXCON0 (C4H) TWI2~5 Control Register 0 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|------|------|------|------|-----|------|-------------|------| | Bit<br>Mnemonic | TWEN | TWIF | MSTR | GCA | AA | | STATE[2: 0] | | | R/W | R/W | R/W | Read | Read | R/W | Read | Read | Read | | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | | | | |------------|--------------|-------------------------------------------------------------------------------|--|--|--| | 7 | TWEN | TWI enable control | | | | | | | 0: Disable TWI | | | | | | | 1: Enable TWI | | | | | 6 | TWIF | TWI interrupt flag | | | | | | | Cleared by software | | | | | | | 2. Under the following conditions, the interrupt flag bit is set by hardware: | | | | | | | 1) Master mode: | | | | | | | ① Send start signal | | | | | | | ② After sending the address frame | | | | | | | ③ Receive or send the data frame | | | | | | | 2) Slave mode: | | | | Page 192 of 252 V0.1 | | | ① The first frame address matches successfully | |-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | ② Successfully receive or send 8-bit data | | | | ③ Receive repeated start condition | | | | ④ The slave receives a stop signal | | 5 | MSTR | Master-slave flag | | | | 0: Slave mode | | | | 1: Master mode | | | | Description: | | | | 1. When the TWI interface sends a start condition to the bus, it will automatically switch to the master mode, and the hardware will set this bit at the same time; | | | | 2. When a stop condition is detected on the bus, the hardware clears this bit. | | 4 | GCA | General address response flag | | | | 0: Non-response general address | | | | 1: When GC is set to 1 and the general address matches at the same time, this bit is set to 1 by hardware and automatically cleare | | 3 | AA | Answer enable bit | | | | 0: No response, return UACK (the response bit is high) | | | | 1: After receiving a matching address or data, a response ACK is returned | | 2~0 | STATE[2: 0] | State machine status flag | | | | Slave mode: | | | | 000: The slave is in the idle state, waiting for TWEN to be set to 1, and detecting the TWI start signal. When the slave receives the stop condition, the jump will go to this state | | | | 001: The slave is receiving the first frame address and read/write bit (the 8th bit is the read/write bit, 1 is read, and 0 is write). The slave will jump to this state after receiving the start condition | | | | 010: Slave receiving data status | Page 193 of 252 V0.1 ### **Super High-speed 1T 8051 Core Flash MCU** 011: slave sending data status 100: In the state of sending data from the slave, when the master returns to UACK, it jumps to this state and waits for a restart signal or a stop signal. 101: When the slave is in the sending state, writing 0 to AA will enter this state, waiting for a restart signal or a stop signal. 110: If the address of the slave does not match the address sent by the master, it will jump to this state and wait for a new start condition or stop condition. #### Master mode: 000: The state machine is idle 001: The Master sends the start condition or the Master is sending the slave device address 010: Master sends data 011: Master receives data 100: The master sends a stop condition or receives a UACK signal from the slave ## US0CON1 (9DH) TWI0 Control Register 1 (read/write) US1CON1 (A5H) TWI1 Control Register 1 (read/write) #### USXCON1 (C5H) TWI2~5 Control Register 1 (read/write) | Bit<br>number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---------------|---------|-----|-----|-----|-----|----------|-----| | Bit<br>Mnemonic | TXnE/<br>RXnE | STRETCH | STA | STO | | TWC | CK[3: 0] | | | R/W | Read Only | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Page 194 of 252 V0.1 | Bit number | Bit Mnemonic | Description | |------------|--------------|-----------------------------------------------------------------------------------------------------------| | 7 | TXnE/RXnE | Send/receive complete flag | | | | In the following situations, TXnE/RXnE is set to 1 | | | | Master mode: | | | | ① The Master sends an address frame (write) and receives an ACK from the slave | | | | ② The master sends the data and receives the slave ACK | | | | ③ The Master receives the data, and the Master returns an ACK to the slave | | | | Slave mode: | | | | ① The slave receives the address frame (read), and it matches the slave address (TWA) | | | | ② The slave receives the data, and the slave returns an ACK to the master | | | | ③ The slave sends the data and receives the master ACK (AA=1) | | | | Reading and writing to TWIDAT will clear this flag. | | 6 | STRETCH | Allow clock extension (slave mode) | | | | 0: disable clock extension | | | | 1: Allow clock extension, the Master needs to support the clock extension function | | | | Description: After the data transmission is completed, and ACK is 0, clock stretching occurs at this time | | 5 | STA | Start bit | | | | Set "1" to generate start condition, TWI will switch to Master mode | | | | Software can set or clear this bit, or it can be cleared by hardware when the start condition is issued. | | 4 | sто | Master mode stop bit | Page 195 of 252 V0.1 | | | Set to "1" in the Master mode, a stop condition will be generated after the current byte is transmitted or the start condition is sent Software can set or clear this bit, or it can be cleared by hardware when a stop condition is detected. | |-----|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3~0 | TWCK[3: 0] | TWI communication rate setting in Master mode: | | | | 0000: f <sub>sys</sub> /1024 | | | | 0001: f <sub>sys</sub> /512 | | | | 0010: <b>f</b> <sub>SYS</sub> /256 | | | | 0011: <b>f</b> <sub>SYS</sub> /128 | | | | 0100: <b>f</b> sys/64 | | | | 0101: <b>f</b> sys/32 | | | | 0110: <b>f</b> <sub>SYS</sub> /16 | | | | Others: Reserved | | | | Note: | | | | 1. The setting is invalid in slave mode. The maximum clock frequency is 400 kHz; | | | | 2. The clock source of TWI follow the System clock f <sub>SYS</sub> | | 7 | - | Reserved | # US0CON2 (9EH) TWI0 Address Register (read/write) ## US1CON2 (A6H) TWI1 Address Register (read/write) ## USXCON2 (C6H) TWI2~5 Address Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----------|-----|-----|-----|-----|-----|-----|-----| | Bit<br>Mnemonic | TWA[6: 0] | | | | | | GC | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Page 196 of 252 V0.1 | Bit number | Bit Mnemonic | Description | |------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------| | 7~1 | TWA[6: 0] | TWI address register TWA[6: 0] cannot be written as all 0s, 00H is dedicated to general address addressing. Invalid setting in Master mode | | 0 | GC | TWI general address enable 0: Forbid to respond to general address 00H 1: Allow response to general address 00H | US0CON3 (9FH) TWI0 Data Buffer Register (read/write) **US1CON3 (A7H) TWI1 Data Buffer Register (read/write)** USXCON3 (C7H) TWI2~5 Data Buffer Register (read/write) | Bit number | 7 | 6 | .5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------------|-----|-----|-----|-----|-----|-----|-----| | Bit<br>Mnemonic | TWDAT[7: 0] | | | | | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|--------------------------| | 7~0 | TWDAT[7: 0] | TWI Data buffer register | ## 17.2.1 Signal Description TWI Clock Signal Line(SCL) Page 197 of 252 V0.1 The clock signal is sent by the master and connected to all slaves. One byte of data is transmitted every 9 clock cycles. The first 8 cycles are used for data transmission, and the last clock is used as the receiver's response clock. It should be high when it is idle, pulled up by the pull-up resistor on the SCL line. #### TWI Data Signal Line(SDA) SDA is a bidirectional signal line, which should be high when it is idle, and is pulled high by the pull-up resistor on the SDA line. #### 17.2.2 Slave Operating Mode #### Mode Start: When the TWI enable flag is turned on (TWEN = 1) and the start signal sent by the Master is received at the same time, the mode is started. The slave enters the state of receiving the first frame address (STATE[2: 0] = 001) from the idle mode (STATE[2: 0] = 000), and waits for the first frame of data from the master. The first frame of data is sent by the Master, including 7-bit address bits and 1 bit for reading and writing. All slaves on the TWI bus will receive the first frame of data from the Master. The Master releases the SDA signal line after sending the first frame of data. If the address sent by the Master is the same as the value in a slave's own address register, it means that the slave is selected. The selected slave will judge the 8th bit on the bus, that is, the data read and write bit (=1, read command) ;=0, write command), then occupy the SDA signal line, give the Master a low-level response signal in the 9th clock cycle of SCL, and then release the bus. After the slave is selected, it will enter different states according to the different read and write bits: #### Non-general Address Response, Slave Device Receiving Mode: If the read/write bit received in the first frame is write (0), the slave enters the slave receiving state (STATE[2: 0] = 010) and waits for the data sent by the Master. The master must release the bus every time it sends 8 bits and wait for the response signal from the slave in the 9th cycle. - If the response signal of the slave is low, the communication of the master can be in the following three ways: - Continue to send data; - 2) Resend the start signal (start), at this time the slave re-enters the state of receiving the first frame address (STATE[2: 0] = 001); - 3) Send a stop signal to indicate the end of this transmission, and the slave returns to the idle state, waiting for the next start signal from the Master. Page 198 of 252 V0.1 2. If the slave responds to a high level (during the receiving process, the AA value in the slave register is rewritten to 0), it means that after the current byte is transmitted, the slave will actively end the transmission and return to the idle state (STATE[2: 0] = 000), no longer receive data from the Master. #### Non-general Address Response, Slave Device Transmitting Mode: If the read/write bit received in the first frame is read (1), the slave will occupy the bus and send data to the Master. Every time 8 bits of data are sent, the slave releases the bus and waits for the response from the master: 1. If the master responds with a low level, the slave continues to send data. In the process of sending, if the AA value in the slave register is rewritten to 0, the slave will actively end the transmission and release the bus after the current byte is transmitted, and wait for the stop signal or restart signal of the master (STATE[2: 0] = 101). 2. If the master responds to a high level, the slave STATE[2: 0] = 100, waiting for the master's stop signal or restart signal. Page 199 of 252 V0.1 #### General Address Response: When GC=1, the general address is allowed to be used at this time. The slave enters the state of receiving the first frame address (STATE[2: 0] = 001), the address bit data in the first frame of data received is 0x00, and all slaves respond to the master at this time. The read and write bits sent by the master must be write (0), and all slaves enter the state of receiving data (STATE[2: 0] = 010) after receiving. The Master releases the SDA line every time 8 data is sent, and reads the status on the SDA line: - 1. If there is a response from the slave, the communication of the master can be in the following three ways: - 1) Continue to send data; - 2) Restart; - 3) Send a stop signal to end this communication. 2. If no slave responds, SDA is idle. Note: When using the universal address in the one-master multiple-slave mode, the read and write bits sent by the Master cannot be in the read (1) state, otherwise, all devices on the bus will respond except for the device sending the data. ### 17.2.3 Slave Mode Operation Steps Page 200 of 252 V0.1 - Configure USMDn[1: 0] and select TWI mode; - 2. Configure the TWIn control registers USnCON0 and USnCON1; - Configure the TWI address register USnCON2; - 4. If the slave receives data, it waits for the interrupt flag bit TWIF in USnCON0 to be set. Every time the slave receives 8 bits of data, TWIF will be set to 1. The interrupt flag bit TWIF needs to be manually cleared: - 5. If the slave sends data, write the data to be sent into TWDAT, and TWI will automatically send the data. Every 8 bits are sent, the interrupt flag bit TWIF will be set. #### 17.2.4 Master operating Mode #### • Mode startup: When the TWI interface sends an initial condition to the bus, it will automatically switch to the main mode, and the hardware will set the MSTR bit to 1. The Master state bit STATE[2: 0] switches from 000 to 001, and the interrupt condition TWIF is set to 1. #### TWI Master sending mode: In the master sending mode, the first frame of data sent by the master includes 7 address bits (selected slave address) and 1 read/write bit (=0, write command). All slaves on the TWI bus will receive the master The first frame of data. The Master releases the SDA signal line after sending the first frame of data. The selected slave sends a response signal to the master in the 9th clock cycle of SCL, and then releases the bus and enters the slave receiving state to wait for the data sent by the master. The master must release the bus every time it sends 8 bits and wait for the response signal from the slave in the 9th cycle. 1. If the slave responds low, the master can continue to send data. You can also resend the start signal: 2. If the slave responds to a high level, it means that after the current byte has been transmitted, the slave will actively end this transmission and will no longer receive the data sent by the master. The master STATE[2: 0] will switch from the sending data state 010 to 100: Page 201 of 252 V0.1 #### TWI Master Receiving Mode: In the master sending mode, the first frame of data sent by the master includes a 7-bit address bit (selected slave address) and a 1-bit read and write bit (=1, read command). All slaves on the TWI bus will receive The first frame of data to the Master. The Master releases the SDA signal line after sending the first frame of data. The selected slave sends an acknowledge signal to the master in the 9th clock cycle of SCL, and then will occupy the bus and send data to the master. Every time 8 bits of data are sent, the slave releases the bus and waits for the response from the master. The Master receives the response signal ACK after the slave address is successfully matched, and starts to receive the slave data (STATE=011): - 1. If the Master response bit is enabled (AA=1), every time a BYTE data is received, the Master responds with the response signal ACK, and TWIF is set; - 2. Before receiving the last byte of data, if the response enable bit is turned off (AA=0), the Master will reply UACK after receiving the last byte of data, and then the Master can send a stop signal. In the Master receiving mode, the way to actively release the bus is as follows: #### 17.2.5 Master Mode Operation Steps 1. Configure USMDn[1: 0] and select TWI mode; Page 202 of 252 V0.1 ### Super High-speed 1T 8051 Core Flash MCU - 2. Configure the TWIn control register USnCON0: TWEN = 1, enable TWI - 3. Configure the TWIn control register USnCON1: configure the TWI communication rate (TWCK[3: 0]), set the start bit STA to "1" - 4. Configure TWIn address register USnCON3: write "slave address plus read and write bits" into TWDAT, and send out an address frame on the bus - If the Master receives data, it waits for the interrupt flag bit TWIF in USnCON0 to be set 1. When the Master receives 8 bits of data, the interrupt flag bit will be set. The interrupt flag bit needs to be manually cleared; - 6. If the Master sends data, write the data to be sent into TWDAT, and TWI will automatically send the data. Every 8 bits are sent, the interrupt flag bit TWIF will be set 1. - 7. After the data is sent and received, the Master can send a stop condition (STO=1), and the Master state switches to 000. Or send a repeated start signal to start a new round of data transmission. The TWIF of the Master will not be set after the Master generates a stop! Page 203 of 252 V0.1 ### Super High-speed 1T 8051 Core Flash MCU # 17.3 Serial Interface (UART) USMDn[1: 0] = 11, n=0~2 one of three serial interface USCI is configured as UART interface. It can be easily used to connect with other devices or equipment, such as Wifi module circuit or other UART communication interface driver chip. Its functions and characteristics are as follows: - 1. Three communication modes are available: mode 0, mode 1 and mode 3; - 2. Independent baud rate generator; - 3. The interrupt RI/TI can be generated after sending and receiving, and the interrupt flag needs to be cleared by software, the clearing mode is "Write 1 clear". - 4. Can realize full duplex communication When USCI is configured as UART interface: : - USTXn as TX signal - USRXn as RX signal US0CON0 (95H) Serial Port 1 Control Register (read/write) US1CON0 (A4H) Serial Port 2 Control Register (read/write) USXCON0 (C4H) Serial Port 3~6 Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|-----|-----|-----|-----|-----|---------------------|---------------------| | Bit<br>Mnemonic | SM0 | SM1 | SM2 | REN | TB8 | RB8 | ТІ | RI | | R/W R/ Write<br>1 clear | R/ Write<br>1 clear | | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | | | | | |------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 7~6 | SM0~1 | Serial communication mode control bit | | | | | | | | 00: Mode 0, 8-bit half-duplex synchronous communication mode, serial data is sent and received on the RX pin. The TX pin is used as the | | | | | Page 204 of 252 V0.1 | | | transmit shift clock. 8 bits are sent and received per frame, and the lower bits are received or sent first; | |---|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | 01: Mode 1, 10-bit full-duplex asynchronous communication, composed of 1 start bit, 8 data bits and 1 stop bit, and the communication baud rate is variable; | | | | 10: Reserved; | | | | 11: Mode 3, 11-bit full-duplex asynchronous communication, composed of 1 start bit, 8 data bits, a programmable 9th bit and 1 stop bit, and the communication baud rate is variable. | | 5 | SM2 | Serial communication mode control bit 2, this control bit is only valid for mode 3 | | | | 0: Set RI every time a complete data frame is received to generate an interrupt request; | | | | 1: When a complete data frame is received, RI will be set to generate an interrupt request only when RB8=1. | | | | Baud rate multiplier setting bit, only valid in mode 0 (SM0~1 = 00): | | | | 0: The serial port runs at 1/12 of the system clock | | | | 1: The serial port runs at 1/4 of the system clock | | 4 | REN | Receive permission control bit | | | | 0: It is not allowed to receive data; | | | | 1: Allow to receive data. | | 3 | TB8 | Only valid for mode 3, which is the 9th bit of the transmitted data | | 2 | RB8 | Only valid for mode 3, which is the 9th bit of the received data | | 1 | ті | Send interrupt flag | | 0 | RI | Receive interrupt flag | **US0CON1 (9DH) Serial Port 1 Baud Rate Control Register Low Bit (read/write)** **US1CON1 (A5H) Serial Port 2 Baud Rate Control Register Low Bit (read/write)** USXCON1 (C5H) Serial Port 3~6 Baud Rate Control Register Low Bit (read/write) Page 205 of 252 V0.1 # Super High-speed 1T 8051 Core Flash MCU | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | Symbol | BAUD1L [7: 0] | | | | | | | | | Read/<br>Write | Initial<br>power-on<br>value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | US0CON2 (9EH) Serial Port 1 Baud Rate Control Register High Bit (read/write) US1CON2 (A6H) Serial Port 2 Baud Rate Control Register High Bit (read/write) USXCON2 (C6H) Serial Port 3~6 Baud Rate Control Register High Bit (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | Symbol | | BAUD1H [7: 0] | | | | | | | | Read/<br>Write | Initial<br>power-on<br>value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|---------------|--------------------------------------------| | 7~0 | BAUD1 [15: 0] | USCI Serial port baud rate control | | | | $BaudRate = \frac{fsys}{[BAUD1H, BAUD1L]}$ | Page 206 of 252 V0.1 **US0CON3 (9FH) Serial 1 Data Buffer Register (read/write)** **US1CON3 (A7H) Serial 2 Data Buffer Register (read/write)** USXCON3 (C7H) Serial 3~6 Data Buffer Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-----|-------------|-----|-----|-----|-----|-----|-----| | Bit<br>Mnemonic | | SBUF1[7: 0] | | | | | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7~0 | SBUF1[7: 0] | Serial Data Buffer Register | | | | SBUF1 contains two registers: a sending shift register and a receiving latch. The data written in SBUF1 will be sent to the sending shift register and the sending process will be started. Reading SBUF1 will return the contents of the receiving latch. | Page 207 of 252 V0.1 # 18 High-speed Analog-to-Digital Converter (ADC) The SC95F776X integrates 17 channels of 12-bit high-precision 1M high-speed ADC, and the external 16 channels of ADC and other functions of the IO port are multiplexed. The internal channel can be connected to 1/4 VDD, and the internal 2.048V, 1.024V or 2.4V reference voltage is used for Measure the VDD voltage. 1 MHz super-high-speed sampling clock, the total time from sampling to completion of conversion is as low as 2µs There are 4 choices for the ADC reference voltage of SC95F776X: - (1) VDD pin (that is directly the internal VDD); - ② The reference voltage output by the internal Regulator is accurately 2.048V. - The reference voltage output by the internal Regulator is exactly 1.024V. - 4 The reference voltage output by the internal Regulator is exactly 2.4V. ## 18.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 | EOC/ADCIF | | P | ADCIS[4: 0] | | | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | n | | Bit number | Bit Mnemonic | Description | |------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | ADCEN | Power on ADC 0: Disable the ADC module power 1: Enable the ADC module power | | 6 | ADCS | ADC start trigger control (ADC Start) Write "1" to this bit to start ADC conversion, that is, this bit is only the trigger signal of ADC conversion. This bit can only be written with 1 to be valid. | Page 208 of 252 V0.1 | | | Note: After writing "1" to the ADCS, do not write to the ADCCON register until the interrupt flag EOC/ADCIF is set. | |-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | EOC /ADCIF | Conversion complete/ADC Interrupt Flag (End Of Conversion / ADC Interrupt Flag) | | | | 0: Conversion has not been completed | | | | 1: ADC conversion is complete. Need user software to clear | | | | ADC conversion complete flag EOC: when the user sets ADCS to start conversion, this bit will be automatically cleared to 0 by the hardware; when the conversion is completed, this bit will be automatically set to 1 by the hardware; | | | | ADC interrupt request flag ADCIF: | | | | This bit is also used as an interrupt request flag for ADC interrupt. If the user enables the ADC interrupt, the user must clear this bit by software after the ADC interrupt occurs. | | 4~0 | ADCIS[4: 0] | ADC Input Selector (ADC Input Selector) | | | | 00000: select AIN0 as ADC input | | | | 00001: select AIN1 as ADC input | | | | 00010: select AIN2 as ADC input | | | | 00011: select AIN3 as ADC input | | | | 00100: select AIN4 as ADC input | | | | 00101: select AIN5 as ADC input | | | | 00110: select AIN6 as ADC input | | | | 00111: select AIN7 as ADC input | | | | 01000: select AIN8 as ADC input | | | | 01001: select AIN9 as ADC input | | | | 01010: select AIN10 as ADC input | | | | 01011: select AIN11 as ADC input | | | | 01100: select AIN12 as ADC input | | | | 01101: select AIN13 as ADC input | | | | 01110: Select AIN14 as ADC input | | | | 01111: select AIN15 as ADC input | Page 209 of 252 V0.1 | 10000~11110: reserved | |---------------------------------------------------------------------------------------| | 11111: ADC input is $1/4\ V_{DD}$ , which can be used to measure power supply voltage | ## ADCCFG2 (B5H) ADC Set Register 2 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------------------|---|---|---|----------------|----------------|----------------|---|---| | Symbol | 1 | 1 | - | I | LOWSP[2: 0 | | - | - | | Read/<br>Write | - | - | - | Read/<br>Write | Read/<br>Write | Read/<br>Write | - | - | | Initial<br>power-on<br>value | Х | Х | Х | 0 | 0 | 0 | Х | х | | Bit number | Bit Mnemonic | Description | | | | | | |------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 4~2 | LOWSP[2: 0] | ADC sampling period selection: | | | | | | | | | 100: The sampling time is 3 system clocks, (about 100ns @fsys = 32 MHz) | | | | | | | | | 101: The sampling time is about 6 system clocks, (about 200ns @fsys = 32 MHz) | | | | | | | | | 110: The sampling time is about 16 system clocks, (about 500ns @ fsys = 32 MHz) | | | | | | | | | 111: The sampling time is about 32 system clocks, (about 1000ns @ fsys = 32 MHz) | | | | | | | | | Other: Reserved | | | | | | | | | Description: The total time from ADC sampling to completion of conversion TADC = sampling time + conversion time The ADC conversion time is fixed at 950ns. | | | | | | Page 210 of 252 V0.1 | 7~5, 1~0 | - | Reserved | |----------|---|----------| |----------|---|----------| ## ADCCFG0 (ABH) ADC Set Register 0 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------|-------|-------|-------|-------|-------|-------|-------| | Bit<br>Mnemonic | EAIN7 | EAIN6 | EAIN5 | EAIN4 | EAIN3 | EAIN2 | EAIN1 | EAIN0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## ADCCFG1 (ACH) ADC Set Register 1 (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|--------|--------|--------|--------|--------|--------|-------|-------| | Bit<br>Mnemonic | EAIN15 | EAIN14 | EAIN13 | EAIN12 | EAIN11 | EAIN10 | EAIN9 | EAIN8 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | | | | |------------|--------------|----------------------------------------------------------------------|--|--|--| | 0 | EAINx | ADC port setting register | | | | | | (x=0~15) | 0: Set AINx as IO port | | | | | | | Set AINx as ADC input and automatically remove the pull-up resistor. | | | | Page 211 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU ### OP\_CTM1 (C2H@FFH) Code Option Register 1(read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------------|-----|-------|--------|------------|-----|-------------|-----| | Bit<br>Mnemonic | VREFS[1: 0] | | OP_BL | DISJTG | IAPS[1: 0] | | LDSIZE[1:0] | | | R/W Read only | | | POR | n | n | n | n | n | n | n | n n | | Bit number | Bit Mnemonic | Description | |------------|--------------|----------------------------------------------------------------------------------------------------------------------| | 7~6 | VREFS[1: 0] | Reference voltage selection (the initial value is transferred from Customer Option, the user can modify the setting) | | | | 00: Set VREF of ADC to VDD; | | | A | 01: Set the VREF of ADC to the internal accurate 2.048V; | | | | 10: Set the VREF of ADC to the internal accurate 1.024V; | | | | 11: Set the VREF of ADC to the internal accurate 2.4V; | ## 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 | 1 | 1 | 1 | 1 | х | х | х | х | ADCVH (AFH) ADC Conversion Value Register (high bit) (read/write) Page 212 of 252 V0.1 | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----------------|-------------|-----|-----|-----|-----|-----|-----|-----|--| | Bit<br>Mnemonic | ADCV[11: 4] | | | | | | | | | | R/W | | POR | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | Bit number | Bit Mnemonic | Description | |------------|--------------|----------------------------------------------| | 11~4 | ADCV[11: 4] | The high 8-bit value of ADC conversion value | | 3~0 | ADCV[3: 0] | Low 4 bits of ADC conversion value | ## 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 | EINT1 | ET0 | EINT0 | | R/W | POR | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|----------------------------------------------------------------------------------------------------------------------| | 6 | EADC | ADC interrupt enable control 0: Disable EOC/ADCIF to generate interrupts 1: Enable EOC/ADCIF to generate interrupt | Page 213 of 252 V0.1 #### 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 | IPINT1 | IPT0 | IPINT0 | | R/W | - | R/W | POR | х | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|------------------------------------------------| | 6 | IPADC | ADC interrupt priority selection | | | | 0: Set the interrupt priority of ADC to "low" | | | | 1: Set the interrupt priority of ADC to "High" | # **18.2 ADC Conversion Steps** The actual operation steps required for the user to perform ADC conversion are as follows: - Set the ADC input pin; (set the bit corresponding to AINx as ADC input, usually the ADC pin will be fixed in advance); - ② Set ADC reference voltage Vref, set the frequency used for ADC conversion; - 3 Enable the ADC module power supply; - 4 Select ADC input channel; (set ADCIS bit, select ADC input channel); - 5 Start ADCS and start conversion; - Wait for EOC/ADCIF=1. If the ADC interrupt is enabled, the ADC interrupt will be generated. The user needs to clear the EOC/ADCIF flag by software; - Get 12-bit data from ADCVH and ADCVL, first high bit and then low bit, one conversion is completed; If you do not change the input channel, repeat steps 5~7 for the next conversion. Page 214 of 252 V0.1 # Super High-speed 1T 8051 Core Flash MCU Note: Before setting IE[6] (EADC), the user is better to clear EOC/ADCIF with software, and also clear the EOC/ADCIF when the ADC interrupt service routine is executed to avoid continuous ADC interrupts. . Page 215 of 252 V0.1 # 19 Analog Comparator The SC95F776X has a built-in analog comparator(CMP), CMP interrupt can wake up STOP mode. It can be used for alarm circuit, power supply voltage monitoring circuit, zero-crossing detection circuit, etc. This comparator has four analog signal positive input terminals: CMP0~3, which can be switched through CMPIS [1: 0]. The negative input voltage can be switched to one of the external voltage on the CMPR pin or the internal 16-level comparison voltage through CMPRF[3: 0]. CMPIM[1: 0] can conveniently set the interrupt mode of the comparator. When the interrupt condition set by CMPIM[1: 0] occurs, the comparator interrupt flag CMPIF will be set to 1, and the interrupt flag needs to be cleared by software. ## 19.1 Block Diagram of Analog Comparator Block Diagram of Analog Comparator #### CMPCON (B7H) Analog Comparator Control Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------|-------|--------|---|-------------|-----|-----|-----| | Bit<br>Mnemonic | CMPEN | CMPIF | CMPSTA | - | CMPRF[3: 0] | | | | | R/W | R/W | R/W | R/W | - | R/W | R/W | R/W | R/W | | POR | 0 | 0 | 0 | х | 0 | 0 | 0 | 0 | Page 216 of 252 V0.1 | Bit number | Bit Mnemonic | Description | | | | | | | | |------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | 7 | CMPEN | Analog comparator enable control bit | | | | | | | | | | | 0: Disable the analog comparator; | | | | | | | | | | | 1: Enable analog comparator | | | | | | | | | 6 | CMPIF | Analog comparator interrupt flag | | | | | | | | | | | 0: Comparator interrupt is not triggered; | | | | | | | | | | | 1: When the comparator meets the interrupt trigger condition, this bit will be automatically set to 1 by the hardware. If IE1[5] (ECMP) is also set to 1 at this time, the comparator interrupt is generated. After the comparator interrupt occurs, the hardware will not automatically clear this bit, the user's software must be responsible for clearing this bit. | | | | | | | | | 5 | CMPSTA | Analog comparator output status | | | | | | | | | | | 0: The voltage at the positive terminal of the comparator is less than the voltage at the negative terminal | | | | | | | | | | | 1: The voltage at the positive terminal of the comparator is greater than the voltage at the negative terminal | | | | | | | | | 3~0 | CMPRF[3: 0] | Analog comparator negative terminal comparison voltage selection: | | | | | | | | | | | 0000: Choose CMPR as the comparison voltage of the analog comparator; | | | | | | | | | | | 0001: Select 1/16V <sub>DD</sub> as the comparison voltage of the analog comparator; | | | | | | | | | | | 0010: Select $2/16V_{\text{DD}}$ as the comparison voltage of the analog comparator; | | | | | | | | | | | 0011: Choose 3/16V <sub>DD</sub> as the comparison voltage of the analog comparator; | | | | | | | | | | | 0100: Choose 4/16V <sub>DD</sub> as the comparison voltage of the analog comparator; | | | | | | | | | | | 0101: Choose 5/16V <sub>DD</sub> as the comparison voltage of the analog comparator; | | | | | | | | | | | 0110: Choose $6/16V_{DD}$ as the comparison voltage of the analog comparator; | | | | | | | | Page 217 of 252 V0.1 | | | 0111: Select 7/16V <sub>DD</sub> as the comparison voltage of the comparator; | analog | |---|---|---------------------------------------------------------------------------------|--------| | | | 1000: Select $8/16V_{DD}$ as the comparison voltage of the comparator; | analog | | | | 1001: Select $9/16V_{DD}$ as the comparison voltage of the comparator; | analog | | | | 1010: Select $10/16V_{DD}$ as the comparison voltage of the comparator; | analog | | | | 1011: Choose 11/16 $V_{\text{DD}}$ as the comparison voltage of the comparator; | analog | | | | 1100: Select 12/16 $V_{\text{DD}}$ as the comparison voltage of the comparator; | analog | | | | 1101: Select 13/16 $V_{DD}$ as the comparison voltage of the comparator; | analog | | | | 1110: Select $14/16V_{DD}$ as the comparison voltage of the comparator; | analog | | | | 1111: Select $15/16V_{\text{DD}}$ as the comparison voltage of the comparator; | analog | | 4 | - | Reserved | | # CMPCFG (B6H) Analog Comparator Setting Register (read/write) | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|---|------|-------------|-----|-------------|-----| | Bit<br>Mnemonic | ' | | - | CMPP | CMPIM[1: 0] | | CMPIS[1: 0] | | | R/W | - | - | - | R/W | R/W | R/W | R/W | R/W | | POR | х | х | х | 0 | 0 | 0 | 0 | 0 | Page 218 of 252 V0.1 | 4 | СМРР | Analog comparator positive input options: | |-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------| | | | 0: The positive input of the analog comparator is CMP0~3, which is set by CMPIS[1:0] | | | | 1: The positive input of the analog comparator is the internal 1.5V reference voltage | | 3~2 | CMPIM[1: 0] | Analog comparator interrupt mode selection: | | | | 00: no interrupt | | | | 01: Rising edge interrupt: An interrupt will be generated after IN+ is less than IN- to greater than IN-; | | | | 10: Falling edge interrupt: An interrupt will be generated after IN+ is greater than IN- to less than IN-; | | | | 11: Double-edge interrupt: IN+ from less than IN- to greater than IN-, or IN+ from greater than IN- to less than IN- will generate an interrupt; | | 1~0 | CMPIS[1: 0] | Analog comparator positive terminal input channel selection: When CMPP is 1, this bit is invalid | | | | 00: Select CMP0 as the input of the positive terminal of the analog comparator; | | | | 01: Select CMP1 as the input of the positive terminal of the analog comparator; | | | | 10: Select CMP2 as the input of the positive terminal of the analog comparator; | | | | 11: Select CMP3 as the input of the positive terminal of the analog comparator; | | 7~5 | | Reserved | Page 219 of 252 V0.1 ## Super High-speed 1T 8051 Core Flash MCU ### 20 CRC Module The SC95F776X has a built-in hardware CRC module. During the CRC execution calculation, the CPU keeps the program counter. After the CRC calculation is completed, the program counter continues to execute the following instructions. The module has two calculation modes: #### Hardware CRC mode 1: CRC operation processing on specified data: Write the data needed for CRC calculation to the CRC data register CRCREG. When the CRC calculation result needs to be read, read it out from CRCDRn ( $n = 0 \sim 3$ ). CRC calculation for a single byte requires 8 system clocks, namely 0.25µs@32 MHz. #### Hardware CRC mode 2: CRC calculation processing for APROM: It can be used to generate the 32-bit CRC value of APROM (ie 128 Kbytes Flash ROM) in real time. This value is compared with the theoretical value to monitor whether the content of the program area is correct. The theoretical value of CRC does not need to be calculated by the user. The burning software will automatically complete the calculation according to the loaded code and Code area setting items and write the 4 bytes CRC32 calculation result into the CRC result storage area through the programmer during burning. The specific operation For the method, please refer to "User Manual of SinOne Development Mass Production Tool". It takes about 32.6ms@32 MHz to calculate CRC for 64 Kbytes APROM. #### The hardware CRC parameter model of SC95F776X: | CRC algorithm name | CRC-32/MPEG-2 | |------------------------|---------------------------------------------------------------------------------------------| | Polynomial formula | $x^{32}+x^{26}+x^{23}+x^{22}+x^{16}+x^{12}+x^{11}+x^{10}+x^{8}+x^{7}+x^{5}+x^{4}+x^{2}+x+1$ | | Data width | 32bit | | Initial value | 0xFFFFFFF | | XOR value | 0x0000000 | | Input value inversion | false | | Output value inversion | false | | LSB/MSB | MSB | #### **CRC Precautions for use:** Page 220 of 252 V0.1 ### Super High-speed 1T 8051 Core Flash MCU - CRCDRn write data and read data are not the same; - 2. The CRC value calculated by the hardware is the 32-bit CRC check value of the data in the entire program area (note that the IAP area is not included here!). If there is a residual value after the user's last operation in the address unit, it will cause the CRC value to be inconsistent with the theoretical value. Therefore, it is recommended that the user erase the entire Flash ROM before programming the code to ensure that the CRC value is consistent with the theoretical value; - 3. The hardware CRC calculation range does not include the IAP area; - 4. Be sure to add at least 8 NOP instructions after the CRC start operation statement to ensure that the CRC calculation is completed; - 5. When performing CRC calculation, it is necessary to disable the global interrupt EA, and then reopen the global interrupt after 8 NOPs. # 20.1 CRC Check Operation Related Registers ### **OPERCON (EFH) Operation Control Register (read/write)** | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|-------|-----|---|---|---|---|--------|--------| | Bit<br>Mnemonic | OPERS | MD | - | | | - | CRCRST | CRCSTA | | R/W | R/W | R/W | - | - | - | - | R/W | R/W | | POR | 0 | 0 | х | х | х | х | 0 | 0 | | Bit number | Bit Mnemonic | Description | |------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------| | 1 | CRCRST | CRCDR register reset (Q31~Q0) Write "1" to this bit to reset CRCDR to all 1s | | 0 | CRCSTA | CRC hardware calculation start bit Write "1" to this bit to start a check sum calculation. This bit can only be written with 1 to be valid. | Page 221 of 252 V0.1 ## **Super High-speed 1T 8051 Core Flash MCU** The read and write operations of the CRC data register CRCDRn (n = $0\sim3$ ) are controlled by the two registers CRCINX and CRCREG. The specific position of each CRCRN is determined by CRCINX, as shown in the following table: | Symbol | Address | Description | | POR | |--------|---------|--------------|--------------|----------| | CRCINX | FCH | CRC pointer | CRCINX[7: 0] | 0000000b | | CRCREG | FDH | CRC register | CRCREG[7: 0] | nnnnnnnb | | Symbol | Address | Description | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|------------------------|-----|-----|-----|-----|-----|-----|-----|-----| | CRCDR3 | 03H@FDH | CRC Data<br>register 3 | Q31 | Q30 | Q29 | Q28 | Q27 | Q26 | Q25 | Q24 | | CRCDR2 | 02H@FDH | CRC Data register 2 | Q23 | Q22 | Q21 | Q20 | Q19 | Q18 | Q17 | Q16 | | CRCDR1 | 01H@FDH | CRC Data register 1 | Q15 | Q14 | Q13 | Q12 | Q11 | Q10 | Q9 | Q8 | | CRCDR0 | 00H@FDH | CRC Data register 0 | Q7 | Q6 | Q5 | Q4 | Q3 | Q2 | Q1 | Q0 | The related description of CRCDRn (n = 0~3) bits is as follows: | Bit number | Bit<br>Mnemonic | Description | |------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit31~0 | Qx<br>(x = 0~31) | <ol> <li>Hardware CRC mode 1: CRC operation processing on specified data:</li> <li>You must write CRCRST first, reset CRCDR to all 1s</li> <li>When CRCREG is written, the hardware automatically calculates the CRC result and continues to store it in CRCDR</li> <li>When needed, read the CRC calculation result instantly</li> </ol> | Page 222 of 252 V0.1 ### Super High-speed 1T 8051 Core Flash MCU Hardware CRC mode 2: CRC calculation processing on APROM: - 1. Started by CRCSTA, at this time the CPU automatically enters IDLE - 2. Automatically reset CRCDR to all 1: The hardware CRC calculation range does not include the IAP area. The calculation range of CRC is divided into four types according to the value of IAPS[1: 0]: - ① IAPS[1:0]=00(Flash ROM last 0K available for IAP): 0000H ~ before last 0K - ② IAPS[1:0]=01(Flash ROM last 1K available for IAP): 0000H ~ before last 1K - ③ IAPS[1:0]=10(Flash ROM last 1K available for IAP): 0000H ~ before last 2K - ④ IAPS[1:0]=11(Flash ROM all available for IAP): 0000H ~ All Flash ROM - 3. After the end, the CPU automatically exits IDLE, you can read the CRC calculation result Note: Write data and read data are not the same data. When operating CRC-related SFR, the CRCINX register stores the address of the relevant CRCREG register, and the CRCREG register stores the corresponding value. Before reading CRCREG, you need to set CRCINX and then read it. After each reading, CRCINX automatically adds 1 (0~3 cycles). #### Hardware CRC mode 1 example: calculate CRC according to the data provided by the user #include "intrins.h" xdata unsigned int i; xdata unsigned long int CRC\_Result = 0x00; // Verification result unsigned char $a[16] = \{0x00,0x01,0x02,0x03,0x04,0x05,$ 0x06,0x07,0x08,0x09,0x0A, 0x0B,0x0C,0x0D,0x0E,0x0F}; // The value to be verified Page 223 of 252 V0.1 ``` typedef struct char a3; // Highest address char a2; // Second highest address char a1; // Second lowest address char a0; // Lowest address }Value_Typedef; typedef union Value_Typedef reg; unsigned long int result; // Final Results }Result_Typedef; Result_Typedef CRC_Result; // Disable the global interrupt EA = 0; OPERCON |= 0x02; // Start software inspection // At least 8 NOP instructions _nop_(); for(i=0; i<16; i++) { ``` Page 224 of 252 V0.1 ``` CRCREG = a[i]; // Calculated value // At least 8 NOP instructions _nop_(); } CRCINX = 0x00; CRC_Result.reg.a0 = CRCREG; CRC_Result.reg.a1 = CRCREG; CRC_Result.reg.a2 = CRCREG; CRC_Result.reg.a3 = CRCREG; temp = CRC_Result.result; // Get results // Enable global interrupt EA = 1; Hardware CRC mode 2 routines: generate APROM CRC in real time ``` ``` #include "intrins.h" typedef struct char a3; // Highest address char a2; // Second highest address char a1; // Second lowest address char a0; // Lowest address }Value_Typedef; ``` Page 225 of 252 V0.1 ``` typedef union Value_Typedef reg; unsigned long int result; //Final Results }Result_Typedef; unsigned long int temp = 0x00; Result_Typedef CRC_Result; // Disable global interrupts EA = 0: OPERCON |= 0x01; // Start hardware verification // At least 8 NOP instructions _nop_(); _nop_(); _nop_(); _nop_(); _nop_(); _nop_(); _nop_(); _nop_(); CRCINX = 0x00; CRC_Result.reg.a0 = CRCREG; CRC_Result.reg.a1 = CRCREG; CRC_Result.reg.a2 = CRCREG; CRC_Result.reg.a3 = CRCREG; temp = CRC_Result.result; // Get results EA = 1; // Enable global interrupt ``` Note: It is prohibited to write values other than the CRC register address to the CRCINX register! Otherwise it will cause abnormal system operation! Page 226 of 252 V0.1 # 21 Multiplier-Divider Unit (MDU) The SC95F776X provides a 16-bit hardware multiplier and divider, which consists of extended accumulators EXA0~EXA3, extended B register EXB and operation control register OPERCON. It can replace software for 16-bit $\times$ 16-bit multiplication and 32-bit/16-bit division. The SC95F776X hardware multiplier and divider does not occupy CPU cycles, and the operation is implemented by hardware. The speed is dozens of times faster than the software implementation of multiplication and division. It can replace software for 16-bit $\times$ 16-bit multiplication and 32-bit/16-bit division and increase program running efficiency. | Symbol | Address | Description | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | POR | |-------------|---------|------------------------------|-----------|--------------|---|---|---|---|------------|------------|-----------| | EXA0 | E9H | Extended<br>Accumulator<br>0 | | EXA [7: 0] | | | | | | 00000000Ь | | | EXA1 | EAH | Extended<br>Accumulator<br>1 | | EXA [15: 8] | | | | | | 0000000b | | | EXA2 | ЕВН | Extended<br>Accumulator<br>2 | | EXA [23: 16] | | | | | | 00000000Ь | | | EXA3 | ECH | Extended<br>Accumulator<br>3 | | EXA [31: 24] | | | | | | 00000000Ь | | | EXBL | EDH | Extended B register L | | EXB [7: 0] | | | | | | 00000000b | | | EXBH | EEH | Extended B register H | | EXB [15: 8] | | | | | | 00000000b | | | OPERC<br>ON | EFH | Operation control register | OPE<br>RS | MD | - | - | - | - | CRCR<br>ST | CRCS<br>TA | 00xxxx00b | #### **OPERCON (EFH) Operation control register (read/write)** | Bit number | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|---|---|---|---|---|---|---|---| |------------|---|---|---|---|---|---|---|---| Page 227 of 252 V0.1 # Super High-speed 1T 8051 Core Flash MCU | Bit<br>Mnemonic | OPERS | MD | - | - | - | - | CRCRST | CRCSTA | |-----------------|-------|-----|---|---|---|---|--------|--------| | R/W | R/W | R/W | - | - | - | - | R/W | R/W | | POR | 0 | 0 | х | х | х | х | 0 | 0 | | Bit number | Bit Mnemonic | | D | escription | | | | | | |------------|--------------|--------------------------------------------------------------------------------------------------------------|----------------------------------|-------------------------------|------------------------------------|----------------|--|--|--| | 7 | OPERS | Multiplier-divider op | peration start | trigger contro | ol (Operater S | Start) | | | | | | | Write "1" to this bit is, this bit is just th start calculation. W been completed. The | e trigger sigr<br>hen the bit is | nal for the must zero, it mea | ultiplication ar<br>ns that the ca | nd division to | | | | | 6 | MD | Multiplication and d | livision | | | | | | | | | | 0: Multiplication operation. The multiplicand and multiplier are written and the product is read as follows: | | | | | | | | | | | Byte<br>Operand | Byte 3 | Byte 2 | Byte 1 | Byte 0 | | | | | | | multiplicand<br>16bit | - | - | EXA1 | EXA0 | | | | | | | multiplier 16bit | - | - | EXBH | EXBL | | | | | | | multiplier 32bit | EXA3 | EXA2 | EXA1 | EXA0 | | | | | | | | | | | | | | | | | | 1: Divide operation and remainder as for | | vidend and di | visor, read the | e quotient | | | | | | | Byte<br>Operand | Byte 3 | Byte 2 | Byte 1 | Byte 0 | | | | Page 228 of 252 V0.1 | d | dividend 32bit | EXA3 | EXA2 | EXA1 | EXA0 | |---|----------------|------|------|------|------| | C | divisor 16bit | 1 | - | EXBH | EXBL | | q | quotient 32bit | EXA3 | EXA2 | EXA1 | EXA0 | | r | emainder 16bit | - | - | EXBH | EXBL | #### Note: - 1. It is forbidden to perform read or write operations on the EXA and EXB data registers during the calculation operation. - 2. The time required for the operation conversion of the multiplier-divider is 16/fsys. Page 229 of 252 V0.1 # **22 Electrical Characteristics** # 22.1 Absolute Maximum Ratings | Symbol | Parameter | Min Value | Max Value | UNIT | |--------------------|-----------------------------------|-----------|----------------------|------| | VDD/VSS | DC supply voltage | -0.3 | 5.5 | V | | Voltage ON any Pin | Input/output voltage of any pin | -0.3 | V <sub>DD</sub> +0.3 | V | | T <sub>A</sub> | Operating temperature | -40 | 105 | °C | | T <sub>STG</sub> | Storage temperature | -55 | 125 | °C | | I <sub>VDD</sub> | Current value flowing through VDD | | 200 | mA | | I <sub>VSS</sub> | Current value flowing through VSS | - | 200 | mA | # 22.2 Recommended Operating Conditions | Symbol | Parameter | Min Value | Max Value | UNIT | System<br>Clock<br>requency | |-----------------|-----------------------|-----------|-----------|------|-----------------------------| | V <sub>DD</sub> | Operating Voltage | 2.0 | 5.5 | V | 32 MHz | | TA | Operating temperature | -40 | 105 | °C | | Page 230 of 252 V0.1 ## 22.3 Flash ROM Characteristics | Symbol | Parameter | Min Value | Typical<br>Values | Max<br>Value | UNIT | Condition | |--------------------|---------------------|-----------|-------------------|--------------|------------|------------------------| | Nend | Wipe the number | 100,000 | - | - | Cycle<br>s | | | T <sub>DR</sub> | Data Retention Time | 100 | - | - | Years | T <sub>A</sub> = +25°C | | Ts-Erase | Sector Erase Time | - | 5 | | ms | T <sub>A</sub> = +25°C | | T <sub>Erase</sub> | All Chip Erase Time | 30 | | 40 | ms | T <sub>A</sub> = +25°C | | Twrite | Byte Program Time | - | 150 | _ | μs | T <sub>A</sub> = +25°C | # 22.4 DC Characteristics $(V_{DD} = 5V, T_A = +25^{\circ}C, Unless otherwise specified)$ | Symbol | Parameter | Minimum | Typical<br>value | Maximum | Unit | Test Conditions | |------------------|-------------------|---------|------------------|---------|------|-----------------| | Current | | | | | | | | I <sub>op1</sub> | Operating current | - | 6 | - | mA | fsys=32 MHz | | I <sub>op2</sub> | Operating current | - | 3.8 | - | mA | fsys=16 MHz | | I <sub>op3</sub> | Operating current | - | 2.4 | - | mA | fsys=8 MHz | | I <sub>op4</sub> | Operating current | - | 1.7 | - | mA | fsys=4 MHz | Page 231 of 252 V0.1 | | T | | 1 | | | | |-------------------|------------------------------------|--------------------|-----|----------------------|----|--------------------------------------------------------------------------------------| | I <sub>pd1</sub> | Stand-by current (Power Down Mode) | - | 2.2 | - | μА | | | l <sub>IDL1</sub> | Stand-by current (IDLE Mode) | - | 2.2 | - | mA | fsys=32 MHz | | Івтм | Base Timer Operating current | - | 1.3 | 3 | μΑ | BTMFS[3: 0]= 1000 Generate an interrupt every 4.0 seconds | | І <sub>ШТ</sub> | WDT current | - | 1.3 | 3 | μΑ | WDTCKS[2: 0]= 000 WDT overflow time 500ms | | IO port cha | racteristics | | | | | | | V <sub>IH1</sub> | Input high voltage | 0.7V <sub>DD</sub> | - | V <sub>DD</sub> +0.3 | V | GPIO | | VIL1 | Input low voltage | -0.3 | - | 0.3V <sub>DD</sub> | V | | | V <sub>IH2</sub> | Input high voltage | 0.8V <sub>DD</sub> | - | V <sub>DD</sub> | V | Schmitt trigger input: RST | | VIL2 | Input low voltage | -0.2 | - | 0.2V <sub>DD</sub> | V | tCK / tDIO UART0 input RX0 USCI signal input port INT0~2 PWM fault detection FLT | Page 232 of 252 V0.1 | | | | | | | Timer clock input port Timer capture port | |------------------|------------------------------------------------------------------------------|---|-----|---|----|--------------------------------------------------------------------------------------------------| | I <sub>OL1</sub> | Output low current | - | 27 | - | mA | V <sub>Pin</sub> =0.4V | | I <sub>OL2</sub> | Output low current | - | 50 | - | mA | V <sub>Pin</sub> =0.8V | | Iонsрюа | SPI0 Signal port: USCK0 (P04) USTX0 (P05) USRX0 (P06) | - | 21 | - | mA | Only applicable to<br>SPI0 data<br>transmission | | | Output high current@<br>V <sub>Pin</sub> =4.3V | | | | | | | Іон1 | Drive capability fixed I/O group: P3H¹ P4 P5 Output high current @ VPin=4.3V | | 10 | - | mA | Pxyz=0,IOH level<br>0<br>Pxyz=1,IOH level<br>1<br>Pxyz=2,IOH level<br>2<br>Pxyz=3,IOH level<br>3 | | I <sub>OH2</sub> | Drive capability can be graded IO group: | - | 10 | - | mA | Pxyz=0,l <sub>OH</sub> level 0 | | | P0<br>P1 | - | 7 | - | mA | Pxyz=1,I <sub>OH</sub> level 1 | | | P2<br>P3L <sup>1</sup> | - | 5 | - | mA | Pxyz=2,I <sub>OH</sub> level 2 | | | Output high current @ VPin=4.3V | - | 2.5 | - | mA | Pxyz=3,l <sub>OH</sub> level 3 | | Іонѕрюв | SPI0 Signal port: USCK0 (P04) USTX0 (P05) USRX0 (P06) | - | 8 | - | mA | Only applicable to<br>SPI0 data<br>transmission | Page 233 of 252 V0.1 | | Output high current @ V <sub>Pin</sub> =4.7V | | | | | | |------------------|-------------------------------------------------------------------------------------------|---|----|---|----|---------------------------------------------------------------------------| | Іонз | Drive capability fixed I/O group: P3H¹ P4 P5 Output high current @ V <sub>Pin</sub> =4.7V | - | 4 | - | mA | Pxyz=0,IOH level 0 Pxyz=1,IOH level 1 Pxyz=2,IOH level 2 Pxyz=3,IOH level | | | | | | | | 3 | | <b>І</b> он4 | Drive capability can be graded IO group: | - | 4 | | mA | Pxyz=0,loн level 0 | | | P0<br>P1 | - | 3 | | mA | Pxyz=1,I <sub>OH</sub> level 1 | | | P2<br>P3L <sup>1</sup> | - | 2 | - | mA | Pxyz=2,loн level 2 | | | Output high current @ V <sub>Pin</sub> =4.3V | | 1 | - | mA | Pxyz=3,loн level 3 | | R <sub>PH1</sub> | Pull-up resistor | | 30 | - | kΩ | | ### Note: ### 1. H and L: • H: the port is four bits higher. • L: The port is four bits lower. # $(V_{DD} = 3.3V, T_A = +25$ °C, Unless otherwise specified) | Symbol | Parameters | Min Value | Typical<br>value | Max Value | Unit | Test condition | |------------------|-------------------|-----------|------------------|-----------|------|----------------| | Current | | | | | | | | I <sub>op5</sub> | Operating current | - | 6 | - | mA | fsys=32 MHz | | I <sub>op6</sub> | Operating current | - | 3.8 | - | mA | fsys=16 MHz | Page 234 of 252 V0.1 # Super High-speed 1T 8051 Core Flash MCU | l <sub>op7</sub> | Operating current | - | 2.4 | - | mA | fsys=8 MHz | |-------------------|-----------------------------------|--------------------|-----|----------------------|----|----------------------------| | I <sub>op8</sub> | Operating current | - | 1.7 | - | mA | fsys=4 MHz | | I <sub>pd2</sub> | Stand-by current(Power Down Mode) | - | 2.2 | - | μА | | | l <sub>IDL2</sub> | Stand-by current (IDLE Mode) | - | 2.2 | - | mA | fsys=32 MHz | | IO port cha | racteristics | | | | | | | V <sub>IH3</sub> | Input high voltage | 0.7V <sub>DD</sub> | - | V <sub>DD</sub> +0.3 | V | | | VIL3 | Input low voltage | -0.3 | - | 0.3V <sub>DD</sub> | V | | | V <sub>IH4</sub> | Input high voltage | 0.8V <sub>DD</sub> | · | V <sub>DD</sub> | ٧ | Schmitt trigger input: RST | | V <sub>IL4</sub> | Input low voltage | -0.2 | - | 0.2V <sub>DD</sub> | V | tCK / tDIO | | | | | | | | UART0 input<br>RX0 | | | | | | | | USCI signal | | | | | | | | input port | | | | | | | | INT0~2 | | | | | | | | PWM fault<br>detection FLT | | | | | | | | Timer clock input port | | | | | | | | Timer capture port | | <b>І</b> ОL3 | Output low current | - | 22 | - | mA | V <sub>Pin</sub> =0.4V | | l <sub>OL4</sub> | Output low current | - | 35 | - | mA | V <sub>Pin</sub> =0.8V | Page 235 of 252 V0.1 # Super High-speed 1T 8051 Core Flash MCU | Іонѕрюс | SPI0 Signal port: USCK0 (P04) USTX0 (P05) USRX0 (P06) | - | 7 | - | mA | Only applicable<br>to SPI0 data<br>transmission | |------------------|-------------------------------------------------------|---|-----|---|----|-------------------------------------------------| | | Output high current@<br>V <sub>Pin</sub> =3.0V | | | | | | | І <sub>ОН5</sub> | Drive capability fixed I/O group: P3H <sup>1</sup> | | З | , | mA | Pxyz=0,IOH<br>level 0<br>Pxyz=1,IOH | | | P4<br>P5 | | | | | level 1 | | | Output high current @ VPin=3.0V | | | | | Pxyz=2,IOH<br>level 2 | | | | | | | | Pxyz=3,IOH<br>level 3 | | І <sub>ОН6</sub> | Drive capability can be graded IO group: | - | 3 | - | mA | Pxyz=0,l <sub>OH</sub><br>level 0 | | | P1 | - | 2 | - | mA | Pxyz=1,I <sub>OH</sub> | | | P2<br>P3L <sup>1</sup> | | | | | level 1 | | | Output high current @ V <sub>Pin</sub> =3.0V | - | 1.5 | - | mA | Pxyz=2,lo <sub>H</sub><br>level 2 | | | | - | 0.8 | - | mA | Pxyz=3,I <sub>OH</sub><br>level 3 | | R <sub>PH2</sub> | Pull-up resistor | - | 55 | - | kΩ | | #### Note: ### 1. H and L: H: the port is four bits higher. • L: The port is four bits lower. ## 22.5 AC Characteristics Page 236 of 252 V0.1 ### $(V_{DD} = 2.0V \sim 5.5V, T_A = 25$ °C, Unless otherwise indicated) | Symbol | Parameters | Min<br>Value | Typical<br>Value | Max<br>Value | Unit | Test condition | |--------------------|---------------------------------------|--------------|------------------|--------------|------|------------------------------------| | Tosc | External 32k oscillator start-up time | • | - | 1 | S | External 32k<br>crystal oscillator | | T <sub>POR</sub> | Power On Reset time | ı | 15 | - | ms | | | T <sub>PDW</sub> | Power Down mode wake-up time | - | 65 | 130 | μs | | | T <sub>Reset</sub> | Reset pulse width | 18 | - | | μs | Low level valid | | T <sub>LVR</sub> | LVR buffeting time | - | 30 | | μs | | | f <sub>HRC1</sub> | RC oscillation stability | 31.68 | 32 | 32.32 | | V <sub>DD</sub> =2.0~5.5V | | | | | | N | MHz | T <sub>A</sub> =-40~85 ℃ | | f <sub>HRC2</sub> | RC oscillation stability | 31.36 | 32 | 32.64 | | V <sub>DD</sub> =2.0~5.5V | | | | | | | MHz | T <sub>A</sub> =-40~105 ℃ | # 22.6 ADC Characteristics ### (T<sub>A</sub> = 25°C,Unless otherwise indicated) | Symbol | Parameters | Min Value | Typical<br>Value | Max Value | Unit | Condition | |------------------|------------------------|-----------|------------------|-----------|------|-------------------------------------------| | V <sub>AD1</sub> | Supply voltage 1 | 2.7 | 5.0 | 5.5 | ٧ | Vref = 2.048V | | V <sub>AD2</sub> | Supply voltage 2 | 2.0 | 5.0 | 5.5 | V | Vref = 1.024V or Vref = V <sub>DD</sub> | | V <sub>AD3</sub> | Power supply voltage 3 | 2.7 | 5.0 | 5.5 | V | Vref = 2.4V | Page 237 of 252 V0.1 # Super High-speed 1T 8051 Core Flash MCU | V <sub>REF1</sub> | Internal reference 2.048V | 2.033 | 2.048 | 2.063 | V | V <sub>DD</sub> = 2.7~5.5V | |-------------------|----------------------------|-------|-------|----------|-----|---------------------------------------------| | V <sub>REF2</sub> | Internal reference 1.024V | 1.004 | 1.024 | 1.044 | V | $V_{DD} = 2.0 \sim 5.5 V$ | | V <sub>REF3</sub> | Internal reference 2.4V | 2.37 | 2.40 | 2.45 | V | $V_{DD} = 2.7 \sim 5.5 V$ | | N <sub>R</sub> | Precision | - | 12 | - | bit | $GND \leqslant V_{AIN} \leqslant V_{DD}$ | | Vain | ADC input voltage | GND | - | $V_{DD}$ | V | | | Rain | ADC input resistance | 1 | - | | ΜΩ | V <sub>IN</sub> =5V | | I <sub>ADC1</sub> | ADC conversion current 1 | - | 4 | 2 | mA | ADC module open | | | | | | | | V <sub>DD</sub> =5V | | I <sub>ADC2</sub> | ADC conversion current 2 | | | 1.8 | mA | ADC module open | | | | | | | | V <sub>DD</sub> =3.3V | | DNL | Differential Non-Linearity | - | - | ±3 | LSB | | | INL | Integral Non-Linearity | - | - | ±3 | LSB | | | Ez | Offset error | - | ±3 | - | LSB | V <sub>DD</sub> =5V<br>V <sub>REF</sub> =5V | | EF | Full scale error | - | ±1 | - | LSB | | | Ead | Absolute Accuracy | - | ±3 | - | LSB | | | T <sub>ADC1</sub> | ADC conversion time 1 | - | 1.1 | 1.4 | μs | fsys=32 MHz<br>LOWSP[2: 0] =<br>100 | | T <sub>ADC2</sub> | ADC conversion time 2 | - | 1.2 | 1.5 | μs | fsys=32 MHz<br>LOWSP[2: 0] =<br>101 | | | | • | | | | • | Page 238 of 252 V0.1 | Тадсз | ADC conversion time 3 | - | 1.5 | 1.9 | μs | fsys=32 MHz<br>LOWSP[2: 0] =<br>110 | |-------------------|-----------------------|---|-----|-----|----|-------------------------------------| | T <sub>ADC4</sub> | ADC conversion time 4 | - | 2.0 | 2.6 | μs | fsys=32 MHz<br>LOWSP[2: 0] =<br>111 | # 22.7 Analog Comparator Characteristics ( $V_{DD} = 5V, T_A = 25$ °C, Unless otherwise indicated) | Symbol | Parameters | Min Value | Typical<br>Value | Max<br>Value | Unit | Test<br>condition | |------------------|------------------------------------|-----------|------------------|--------------|------|---------------------| | V <sub>СМ</sub> | Input voltage range | 0 | · | $V_{DD}$ | V | | | Vos | Comparator offset error | | 10 | 30 | mV | | | V <sub>HYS</sub> | Schmitt trigger voltage hysteresis | - | 40 | - | mV | | | Ісмр | Analog comparator consumption | - | - | 100 | μА | V <sub>DD</sub> =5V | | Тсмр | Response time | - | - | 2 | μs | | Page 239 of 252 V0.1 # 23 Package Information #### SC95F7763M28U ## SOP28L(300mil) Overall Dimensions Unit: mm | Cumbal | | mm | | |------------|-----------|---------------|-----------| | Symbol | Min Value | Typical Value | Max Value | | А | 2.40 | 2.56 | 2.65 | | A <b>1</b> | 0.100 | 0.200 | 0.300 | | A2 | 2.240 | 2.340 | 2.440 | | b | 0.39 | | 0.48 | | С | | 0.254(BSC) | | | D | 17.80 | 18.00 | 18.20 | | E | 7.30 | 7.50 | 7.70 | | HE | 10.100 | 10.300 | 10.500 | | e | | 1.270(BSC) | | | L | 0.7 | 0.85 | 1.0 | | LE | 1.3 | 1.4 | 1.5 | Page 240 of 252 V0.1 | θ 0° | - | 8° | |------|---|----| |------|---|----| Page 241 of 252 V0.1 #### SC95F7763X28U ### TSSOP28L Overall Dimensions Unit:mm | Cumab el | 44 | mm | | |------------|-----------|---------------|-----------| | Symbol | Min Value | Typical Value | Max Value | | А | - | - | 1.200 | | A <b>1</b> | 0.050 | - | 0.150 | | A <b>2</b> | 0.800 | - | 1.050 | | b | 0.190 | - | 0.300 | | С | 0.090 | - | 0.200 | | D | 9.600 | - | 9.800 | | Е | 6.250 | - | 6.550 | | e1 | 4.300 | - | 4.500 | | e | | 0.65(BSC) | | | L | - | - | 1.0 | | θ | 0° | - | 8° | | Н | 0.05 | - | 0.25 | Page 242 of 252 V0.1 http://www.socmcu.com #### SC95F7765Q32R ## QFN32 (5X5) Overall Dimensions Unit: mm | Symbol | | mm | | |--------|-----------|---------------|-----------| | Symbol | Min Value | Typical Value | Max Value | | Α | 0.70 | 0.75 | 0.80 | | A1 | - | 0.02 | 0.05 | | b | 0.18 | 0.25 | 0.30 | | D | 4.90 | 5.00 | 5.10 | | E | | 5 BSC | | | е | | 0.5 BSC | | | k | | 0.4 REF | | | D1 | 3.30 | 3.45 | 3.60 | | E1 | 3.30 | 3.45 | 3.60 | | L | 0.30 | 0.40 | 0.50 | Page 243 of 252 V0.1 ### SC95F7765P32R ## LQFP32 (7X7) Overall Dimensions Unit: mm | Symbol | mm | | | | | |--------|-------------------------|-------|-----------|--|--| | Symbol | Min Value Typical Value | | Max Value | | | | А | 1.45 | 1.55 | 1.65 | | | | A1 | 0.01 | | 0.21 | | | | A2 | 1.30 | 1.4 | 1.5 | | | | A3 | | 0.254 | | | | | b | 0.30 | 0.35 | 0.41 | | | | b1 | 0.31 | 0.37 | 0.43 | | | | С | 0.12 | 0.13 | 0.14 | | | Page 244 of 252 V0.1 | D1 | 6.85 | 6.95 | 7.05 | |----|------|---------|------| | D2 | 6.90 | 7.00 | 7.10 | | Е | 8.80 | 9.00 | 9.20 | | E1 | 6.85 | 6.95 | 7.05 | | E2 | 6.90 | 7.00 | 7.10 | | e | | 0.8 | - | | L | 0.43 | | 0.75 | | L1 | 0.90 | 1.0 | 1.10 | | R | 0.1 | | 0.25 | | R1 | 0.1 | | | | θ | 0° | <b></b> | 10° | | θ1 | 0° | | | | У | | | 0.1 | | Z | | 0.70 | | Page 245 of 252 V0.1 ### SC95F7766P44R ## LQFP44 (10X10) Overall Dimensions Unit: mm | Symbol | mm | | | |--------|-----------|---------------|-----------| | Symbol | Min Value | Typical Value | Max Value | | A | 1.45 | 1.55 | 1.65 | | A1 | 0.015 | | 0.21 | | A2 | 1.3 | 1.4 | 1.5 | | A3 | | 0.254 | | | b | 0.25 | 0.30 | 0.36 | | b1 | 0.26 | 0.32 | 0.38 | | С | 0.12 | 0.13 | 0.14 | | D1 | 9.85 | 9.95 | 10.05 | Page 246 of 252 V0.1 | 9.90 | 10.00 | 10.10 | | |-------|-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--| | 11.80 | 12.00 | 12.20 | | | 9.85 | 9.95 | 10.05 | | | 9.90 | 10.00 | 10.10 | | | | 0.8 | | | | 0.42 | | 0.75 | | | 0.95 | 1.0 | 1.15 | | | 0.08 | | 0.25 | | | 0.08 | | | | | 0° | | 10° | | | 0° | | | | | | | 0.1 | | | | 1.0 | | | | | 11.80<br>9.85<br>9.90<br><br>0.42<br>0.95<br>0.08<br>0.08 | 11.80 12.00 9.85 9.95 9.90 10.00 0.8 0.42 0.95 1.0 0.08 0.08 0° | | Page 247 of 252 V0.1 ## SC95F7767Q48R ## QFN48 (7X7) Overall Dimensions Unit: mm | Symbol | mm | | | |--------|-----------|---------------|-----------| | | Min Value | Typical Value | Max Value | | Α | 0.70 | 0.75 | 0.80 | | A1 | 0 | 0.02 | 0.05 | | b | 0.18 | 0.25 | 0.30 | | D | 7.00 BSC | | | | D2 | 5.10 | 5.30 | 5.50 | | е | | 0.50 BSC. | | | k | 0.50 | | | | E | 7.00 BSC | | | | E2 | 5.10 | 5.30 | 5.50 | | L | 0.35 | 0.40 | 0.45 | Page 248 of 252 V0.1 #### SC95F7767P48R ## LQFP48 (7X7) Overall Dimensions Unit: mm | Symbol | mm | | | |--------|-----------|---------------|-----------| | | Min Value | Typical Value | Max Value | | А | 1.45 | 1.55 | 1.65 | | A1 | 0.01 | | 0.21 | | A2 | 1.3 | 1.4 | 1.5 | | A3 | | 0.254 | | | b | 0.15 | 0.20 | 0.25 | | b1 | 0.16 | 0.22 | 0.28 | | С | 0.12 | | 0.17 | Page 249 of 252 V0.1 | D1 | 6.85 | 6.95 | 7.05 | |----|------|---------|------| | D2 | 6.90 | 7.00 | 7.10 | | E | 8.8 | 9.00 | 9.20 | | E1 | 6.85 | 6.95 | 7.05 | | E2 | 6.9 | 7.00 | 7.10 | | e | | 0.5 | | | L | 0.43 | | 0.75 | | L1 | 0.90 | 1.0 | 1.10 | | R | 0.1 | | 0.25 | | R1 | 0.1 | | | | θ | 0° | <b></b> | 10° | | θ1 | 0° | | | | У | | | 0.1 | | Z | | 0.75 | | Page 250 of 252 V0.1 # **24 Revision History** | Revision | Changes | Date | |----------|------------------|------------| | V0.1 | Initial Release. | March 2022 | Page 251 of 252 V0.1 # **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. Cytron considers the information provided to be accurate and reliable. The information in this document will be used in March 2022. In the actual production design, please refer to the latest data manual of each product and other relevant materials. Page 252 of 252 V0.1