

General-purpose MCU with EEPROM, 12bit-ADC, LIN Communication

# BS9000AM Series V1.0

General-purpose MCU With EEPROM, 12bit-ADC, LIN Communication

V1.0 2022-05-30



### BS9000AM Series V1.0

General-purpose MCU with EEPROM, 12bit-ADC, LIN Communication

### **Table of Contents**

| 1 | B   | BS9000AM SERIES MCU OVERVIEW                                        | 9  |
|---|-----|---------------------------------------------------------------------|----|
|   | 1.1 | Features                                                            | 9  |
|   | 1.2 | DESCRIPTION                                                         | 10 |
|   | 1.3 | System Block Diagram                                                | 10 |
|   | 1.4 | CLOCK DIAGRAM                                                       | 11 |
|   | 1.5 | SELECTION TABLE                                                     |    |
|   | 1.6 | PIN CONFIGURATION                                                   | 13 |
|   | 1.  | .6.1 QFN20                                                          |    |
|   | 1.  | .6.2 TSSOP28                                                        | 14 |
|   | 1.7 | PIN FUNCTIONS                                                       | 15 |
| 2 | E   | ELECTRICAL CHARACTERISTICS                                          | 20 |
|   | 2.1 | AC CHARACTERISTICS                                                  | 20 |
|   | 2.2 | DC CHARACTERISTICS                                                  | 21 |
|   | 2.3 | ADC CHARACTERISTICS                                                 | 25 |
|   | 2.4 | ABSOLUTE MAXIMUM RATINGS                                            | 26 |
| 3 | N   | MEMORIES                                                            | 27 |
|   | 3.1 | FLASH                                                               |    |
|   | 3.2 | FLASH READ AND WRITE PROTECTION                                     |    |
|   | 3.  | .2.1 FLASH Write Protection                                         |    |
|   | 3.  | .2.2 FLASH Read Protection                                          |    |
|   | 3.3 | SRAM                                                                |    |
|   | 3.4 | EEPROM                                                              |    |
|   | 3.4 | .4.1 Page Erase                                                     |    |
|   | 3.4 | .4.2 Byte Programming                                               |    |
|   | 3.5 | IAP OPERATION                                                       |    |
|   | 3.  | .5.1 Program Upgrade                                                |    |
|   | 3.  | .5.2 FLASH IAP Erase Operation                                      |    |
|   | 3.  | .5.3 FLASH IAP bit Write                                            |    |
|   | 3.  | .5.4 FLASH IAP Operation                                            |    |
|   | 3.6 | REGISTERS FOR MEMORY                                                |    |
|   | 3.  | .6.1 Interrupt Vector Table Offset Register (OFFSET_ADDR_L)         |    |
|   | 3.  | .6.2 Vector Table Offset Interrupt Address Register (OFFSET_ADDR_H) |    |
|   | 3.  | .6.3 Address Control Register (SPROG_ADDR_H)                        |    |
|   | 3.  | .6.4 Address Control Register (SPROG_ADDR_L)                        |    |
|   | 3.  | .6.5 Data Register (SPROG_DATA)                                     | 40 |
|   | 3.  | .6.6 Command register (SPROG_CMD)                                   | 41 |
|   | 3.  | .6.7 Erase and Write Time Control Register (SPROG_TIM)              | 41 |

BYD)

### BS9000AM Series V1.0

|   | 3.6. | .8  | BOOT Status Register (FLASH_BOOT_EN)                                  | 41 |
|---|------|-----|-----------------------------------------------------------------------|----|
|   | 3.6. | .9  | Write Protect Range Configuration Register (FLASH_WPROTECT_PAGE)      | 42 |
| 4 | SY   | /ST | EM                                                                    | 43 |
|   | 4.1  |     | DCK                                                                   | 13 |
|   |      |     | SET SYSTEM                                                            |    |
|   |      |     | DT                                                                    |    |
|   |      |     | ERATING MODES                                                         |    |
|   |      |     | TCHDOG TIMER (WDT)                                                    |    |
|   |      |     | STEM REGISTERS                                                        |    |
|   | 4.6. |     | Software Reset Register (SOFT_RST)                                    |    |
|   | 4.6. |     | Reset Flag Register (RST_STAT)                                        |    |
|   | 4.6. |     | Module Switching Control Register (PD_ANA)                            |    |
|   | 4.6. |     | BOR Threshold Selection Register (BOR_SEL)                            |    |
|   | 4.6. | .5  | LVDT Control Register (LVDT_SEL)                                      | 53 |
|   | 4.6. | .6  | Test Clock Register (SFR_TEST_SEL1)                                   | 53 |
|   | 4.6. | .7  | Sleep Control Register (PCON)                                         | 54 |
|   | 4.6. | .8  | Clock control register (SYS_CLK_CFG)                                  | 55 |
|   | 4.6. | .9  | LVDT Rising/Falling Voltage Interrupt Status Register (INT_POBO_STAT) | 55 |
|   | 4.6. | .10 | WDT Test Mode Register (WDT_TEST_EN)                                  | 56 |
|   | 4.6. | .11 | WDT Clock Selection Register (WDT_CLK_SEL)                            |    |
|   | 4.6. | .12 | WDT Overflow Configuration Register (WDT_CTRL)                        |    |
|   | 4.6. | .13 | WDT Enable Configuration Register (WDT_EN)                            | 57 |
|   | 4.6. | .14 | WDT/Timer2 Interrupt Status Register (INT_PE_STAT)                    | 57 |
| 5 | GF   | PIO |                                                                       | 59 |
|   | 5.1  | Des | SCRIPTION                                                             | 59 |
|   | 5.2  | GP  | IO REGISTERS                                                          | 61 |
|   | 5.2. | .1  | Data Registers                                                        | 61 |
|   | 5.2. | .2  | Output Control Hold Register When Reset (PD_HOLD_EN)                  | 64 |
|   | 5.2. | .3  | Direction Registers                                                   |    |
|   | 5.2. | .4  | Pull-up Resistor Enable Registers                                     | 66 |
|   | 5.2. | .5  | Pull-down Resistor Enable Registers                                   | 68 |
|   | 5.2. | .6  | Open Drain Output Enable Register(ODRAIN_EN)                          |    |
|   | 5.3  | I/O | MULTIPLEXING TABLES                                                   | 70 |
|   | 5.3. | .1  | SPI I/O Multiplexing (SPI_IO_SEL)                                     | 70 |
|   | 5.3. | .2  | UART I/O Multiplexing (UART_IO_SEL)                                   | 70 |
|   | 5.3. | .3  | SCI I/O Multiplexing (SCI_IO_SEL)                                     | 71 |
|   | 5.3. | .4  | PWM I/O Multiplexing                                                  | 71 |
|   | 5.3. | .5  | IIC I/O Multiplexing (IIC_IO_SEL)                                     | 72 |
|   | 5.4  | GΡ  | IO CONFIGURATION FLOW DIAGRAM                                         | 73 |
| 6 | IN   | TEF | RRUPT                                                                 | 74 |

### BS9000AM Series V1.0

| 6.1                                                                                                | Int                                                                                                                                                   | ERRUPT SOURCES AND ENTRIES                                 | 75     |
|----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|--------|
| 6.2                                                                                                | INT                                                                                                                                                   | ERRUPT FUNCTIONS                                           | 77     |
| e                                                                                                  | 5.2.1                                                                                                                                                 | Interrupt Response                                         | 77     |
| e                                                                                                  | 5.2.2                                                                                                                                                 | Interrupt Handling                                         | 77     |
| 6                                                                                                  | 6.2.3                                                                                                                                                 | Interrupt Sampling                                         | 78     |
| 6.3                                                                                                | INT                                                                                                                                                   | ERRUPT WAKEUP                                              | 78     |
| 6.4                                                                                                | INT                                                                                                                                                   | ERRUPT REGISTERS                                           | 79     |
| 6                                                                                                  | 6.4.1                                                                                                                                                 | Interrupt Enable Register 0(IEN0)                          | 79     |
| 6                                                                                                  | 6.4.2                                                                                                                                                 | Interrupt Priority Register 0 (IPL0)                       | 80     |
| 6                                                                                                  | 6.4.3                                                                                                                                                 | Interrupt Flag Register (TCON)                             | 80     |
| 6                                                                                                  | 6.4.4                                                                                                                                                 | Interrupt Enable Register 1 (IEN1)                         | 81     |
| e                                                                                                  | 6.4.5                                                                                                                                                 | Interrupt Priority Register 1 (IPL1)                       | 82     |
| 6                                                                                                  | 6.4.6                                                                                                                                                 | Interrupt Flag Register 1(IRCON1)                          | 83     |
| 6                                                                                                  | 6.4.7                                                                                                                                                 | Interrupt Enable Register 2(IEN2)                          | 83     |
| 6                                                                                                  | 6.4.8                                                                                                                                                 | Interrupt Priority Register 2 (IPL2)                       | 84     |
| 6                                                                                                  | 5.4.9                                                                                                                                                 | Interrupt Flag Register 2 (IRCON2)                         |        |
| 6                                                                                                  | 5.4.10                                                                                                                                                | <b>3</b> ( <b>1 1 /</b>                                    |        |
| 6                                                                                                  | 6.4.11                                                                                                                                                | INT3 Selection Enable Register 2 (EXT3_INT_SEL2)           | 87     |
|                                                                                                    | 5.4.12                                                                                                                                                | <b>3</b> ( <b>1 1 /</b>                                    |        |
|                                                                                                    | 5.4.13                                                                                                                                                | <b>3</b> ( <b>1 1</b> <i>i</i>                             |        |
|                                                                                                    | 2 1 1 1                                                                                                                                               | External Interrupt Palarity Control Pagister (EVT INT CON) | 00     |
| 6                                                                                                  |                                                                                                                                                       | External Interrupt Polarity Control Register (EXT_INT_CON) |        |
| 6.5                                                                                                |                                                                                                                                                       | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5                                                                                                | Ex                                                                                                                                                    |                                                            | 89     |
| 6.5<br>7                                                                                           | Ex<br>TIME                                                                                                                                            | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  | 89<br> |
| 6.5<br><b>7</b><br>7.1                                                                             | Б Ех<br><b>ТІМЕ</b><br>ТІМ                                                                                                                            | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7                                                                                           | Ex<br><b>TIME</b><br>TIN<br>TIN                                                                                                                       | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7<br>7.1<br>7.2<br>7.3                                                                      | Ex<br><b>TIME</b><br>TIN<br>TIN                                                                                                                       | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7<br>7.1<br>7.2<br>7.3<br>7                                                                 | Ex<br><b>TIME</b><br>TIM<br>TIM<br>TIM                                                                                                                | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7<br>7.1<br>7.2<br>7.3<br>7                                                                 | Ex<br>TIME<br>TIM<br>TIM<br>TIM<br>7.3.1<br>7.3.2                                                                                                     | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7<br>7.1<br>7.2<br>7.3<br>7<br>7.4                                                          | Ex<br>TIME<br>TIM<br>TIM<br>TIM<br>7.3.1<br>7.3.2                                                                                                     | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7<br>7.1<br>7.2<br>7.3<br>7<br>7<br>7.4<br>7                                                | EX<br>TIME<br>TIM<br>TIM<br>TIM<br>7.3.1<br>7.3.2<br>TIM                                                                                              | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7<br>7.1<br>7.2<br>7.3<br>7<br>7<br>7.4<br>7<br>7                                           | EX<br>TIME<br>TIN<br>TIN<br>7.3.1<br>7.3.2<br>TIN<br>7.4.1<br>7.4.2                                                                                   | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7<br>7.1<br>7.2<br>7.3<br>7<br>7<br>7.4<br>7<br>7                                           | EX<br>TIME<br>TIN<br>TIN<br>7.3.1<br>7.3.2<br>TIN<br>7.4.1<br>7.4.2<br>PVVM                                                                           | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7<br>7.1<br>7.2<br>7.3<br>7<br>7<br>7.4<br>7<br>8<br>8<br>8.1                               | EX<br>TIME<br>TIN<br>TIN<br>7.3.1<br>7.3.2<br>TIN<br>7.4.1<br>7.4.2<br>PVVM                                                                           | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7<br>7.1<br>7.2<br>7.3<br>7<br>7<br>7.4<br>7<br>8<br>8<br>8.1<br>8                          | EX<br>TIME<br>TIN<br>TIN<br>7.3.1<br>7.3.2<br>TIN<br>7.4.1<br>7.4.2<br>PWM<br>16-                                                                     | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7<br>7.1<br>7.2<br>7.3<br>7<br>7<br>7.4<br>7<br>8<br>8<br>8.1<br>8                          | EX<br>TIME<br>TIM<br>TIM<br>7.3.1<br>7.3.2<br>TIM<br>7.4.1<br>7.4.2<br>PVVM<br>16-<br>3.1.1                                                           | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7<br>7.1<br>7.2<br>7.3<br>7<br>7.4<br>7<br>8<br>8.1<br>8<br>8.1<br>8                        | EX<br>TIME<br>TIN<br>TIN<br>7.3.1<br>7.3.2<br>TIN<br>7.4.1<br>7.4.2<br>PVVM<br>16-<br>3.1.1<br>3.1.2                                                  | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7<br>7.1<br>7.2<br>7.3<br>7<br>7<br>7<br>7<br>7<br>8<br>8<br>8.1<br>8<br>8<br>8.1<br>8<br>8 | EX<br>TIME<br>TIN<br>TIN<br>7.3.1<br>7.3.2<br>TIN<br>7.4.1<br>7.4.2<br>PWM<br>16-<br>3.1.1<br>3.1.2<br>3.1.3                                          | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |
| 6.5<br>7<br>7.1<br>7.2<br>7.3<br>7<br>7<br>7<br>7<br>7<br>8<br>8<br>8.1<br>8<br>8<br>8.1<br>8<br>8 | EX<br>TIME<br>TIM<br>TIM<br>TIM<br>TIM<br>7.3.1<br>7.3.2<br>TIM<br>7.4.1<br>7.4.1<br>7.4.2<br>PWM<br>16-<br>3.1.1<br>3.1.2<br>3.1.3<br>3.1.4<br>3.1.5 | TERNAL INTERRUPT CONFIGURATION PROCEDURES                  |        |

BYD

### BS9000AM Series V1.0

|    | 8.2.2   | Time Base Unit                                                |     |
|----|---------|---------------------------------------------------------------|-----|
|    | 8.2.3   | Clock/Trigger Controller                                      | 163 |
|    | 8.2.4   | Capture/Compare Channels                                      |     |
|    | 8.2.5   | Interrupt                                                     |     |
| 8  | 8.3 PW  | /M Registers                                                  | 176 |
|    | 8.3.1   | PWM0 Registers                                                | 176 |
|    | 8.3.2   | PWM1 Registers                                                | 214 |
|    | 8.3.3   | PWM0/1 Registers                                              | 234 |
| 8  | 8.4 PW  | M Configuration Procedures                                    | 237 |
|    | 8.4.1   | PWM0 Register Configuration Procedures                        | 237 |
|    | 8.4.2   | PWM1 Register Configuration Procedures                        | 238 |
| 9  | ADC.    |                                                               | 240 |
| g  | ).1 Int | RODUCTION                                                     | 240 |
| g  | ).2 AD  | C REGISTERS                                                   | 243 |
|    | 9.2.1   | Module Switch Control Register (PD_ANA)                       | 243 |
|    | 9.2.2   | ADC Scan Control Register (ADC_CH_CFG)                        | 243 |
|    | 9.2.3   | ADC Scan Result Register Low 8 bits (ADC_RDATAL)              | 244 |
|    | 9.2.4   | ADC Scan Result Register High 4 bits (ADC_RDATAH)             | 245 |
|    | 9.2.5   | ADC Sampling Time Configuration Register (ADC_SPT)            | 245 |
|    | 9.2.6   | ADC Sampling Timing Control Register 2 (ADC_ANA_CFG2)         | 245 |
|    | 9.2.7   | ADC Sampling Timing Control Register 1 (ADC_ANA_CFG1)         | 246 |
|    | 9.2.8   | ADC Clock Control Register (ADCCKC)                           | 246 |
|    | 9.2.9   | ADC Pin Control register 1 (ADC_IO_SEL1)                      | 247 |
|    | 9.2.10  | ADC Pin Control register 2 (ADC_IO_SEL2)                      | 248 |
|    | 9.2.11  | ADC Pin Control register 3 (ADC_IO_SEL3)                      | 248 |
|    | 9.2.12  | ADC Pin Control Register 4 (ADC_IO_SEL4)                      | 249 |
| g  | 9.3 AD  | C CONFIGURATION PROCEDURES                                    | 249 |
| 10 | TOU     | CHKEY                                                         | 252 |
| 1  | 0.1 IN  | TRODUCTION                                                    | 252 |
| 1  | 0.2 To  | DUCHKEY REGISTER                                              | 253 |
|    | 10.2.1  | Module Switch Control Register (PD_ANA)                       |     |
|    | 10.2.2  | CSD Start Scanning Register (CSD_START)                       |     |
|    | 10.2.3  | Touch Channel Control Register (SNS_CH_CFG)                   |     |
|    | 10.2.4  | CSD Pull-up Current Source Selection Register (PULL_I_SELA_L) |     |
|    | 10.2.5  | CSD Count Value Low 8 bits (CSD_RAWDATAL)                     |     |
|    | 10.2.6  | CSD Count Value High 8 bits (CSD_RAWDATAH)                    |     |
|    | 10.2.7  | SNS Channel Selection Register 1 (SNS_IO_SEL1)                |     |
|    | 10.2.8  | SNS Channel Selection Register 2 (SNS_IO_SEL2)                |     |
|    | 10.2.9  | SNS Channel Selection Register 3 (SNS_IO_SEL3)                | 257 |
|    | 10.2.1  | 0 SNS Channel Selection Register 4 (SNS_IO_SEL4)              |     |

### BS9000AM Series V1.0

|    |         | General-purpose MCU with EEPROM, 12bit-ADC, L                  | IN Communication |
|----|---------|----------------------------------------------------------------|------------------|
|    | 10.2.11 | TouchKey Scan Configuration Register 1 (SNS_SCAN_CFG1)         |                  |
|    | 10.2.12 | TouchKey Scan Configuration Register 2 (SNS_SCAN_CFG2)         |                  |
|    | 10.2.13 | TouchKey Scan Configuration Register (SNS_ANA_CFG)             |                  |
| 10 | 0.3 To  | UCHKEY CONFIGURATION PROCESS                                   |                  |
| 11 | IIC     |                                                                |                  |
| 1  | 1.1 Cc  | MMUNICATION SEQUENCE                                           |                  |
|    | 11.1.1  | IIC Host Write Sequence                                        |                  |
|    | 11.1.2  | IIC Host Write Pull-down Sequence                              |                  |
|    | 11.1.3  | IIC Host Read Sequence                                         |                  |
|    | 11.1.4  | IIC Host Read Pull-down Sequence                               |                  |
|    | 11.1.5  | IIC Host Write Data                                            |                  |
|    | 11.1.6  | IIC Host Read Data                                             |                  |
| 1' | 1.2 IIC | REGISTERS                                                      |                  |
|    | 11.2.1  | IIC Address Register (IICADD)                                  |                  |
|    | 11.2.2  | IIC Status Register (IICSTAT)                                  |                  |
|    | 11.2.3  | IIC Transmit/Receive Data Register (IICBUF)                    |                  |
|    | 11.2.4  | IIC Status Register (IICCON)                                   | 273              |
|    | 11.2.5  | IIC Transmit/Receive Buffer Register (IICBUFFER)               |                  |
|    | 11.2.6  | IIC IO Configuration Register (IIC_IO_SEL)                     | 276              |
| 1  | 1.3 IIC | CONFIGURATION PROCEDURE                                        | 278              |
| 12 | SPI     |                                                                | 279              |
| 1: | 2.1 Fu  | NCTIONS                                                        |                  |
| 1  | 2.2 Co  | MMUNICATION SEQUENCE                                           |                  |
| 1  | 2.3 SF  | I Registers                                                    |                  |
|    | 12.3.1  | SPI Configuration Register 1 (SPI_CFG1)                        |                  |
|    | 12.3.2  | SPI Configuration Register 2 (SPI_CFG2)                        |                  |
|    | 12.3.3  | SPI Status Register (SPI_STATE)                                |                  |
|    | 12.3.4  | SPI Data Register (SPI_SPID)                                   |                  |
|    | 12.3.5  | SPI Transmit Buffer Start Address Register (SPI_TX_START_ADDR) |                  |
|    | 12.3.6  | SPI Receive Buffer Start Address Register (SPI_RX_START_ADDR)  |                  |
|    | 12.3.7  | SPI Data Buffer Address Number Low 8-bit Register (SPI_NUM_L)  |                  |
|    | 12.3.8  | SPI Data Buffer Address Number High 3-bit Register (SPI_NUM_H) |                  |
|    | 12.3.9  | SPI Host Mode Receiver Clock Selection Register (SPI_MCLK_MOD) |                  |
|    | 12.3.10 | SPI IO High Speed Mode Enable Register (SPI_SPEED_EN)          |                  |
|    | 12.3.11 | SPI IO Selection Register (SPI_IO_SEL)                         |                  |
| 1: | 2.4 SF  | I CONFIGURATION PROCEDURE                                      |                  |
| 13 | UAR     | Τ                                                              |                  |
| 1; | 3.1 De  | SCRIPTION                                                      |                  |
|    | 13.1.1  | Baud Rate Generation                                           |                  |

### BS9000AM Series V1.0

| 13.1.2  | Functions of Emitter                          | 290 |
|---------|-----------------------------------------------|-----|
| 13.1.3  | Functions of Receiver                         | 291 |
| 13.1.4  | Receiver Sampling Method                      |     |
| 13.1.5  | Multi-processor Mode                          | 292 |
| 13.2 UA | RT REGISTER                                   | 293 |
| 13.2.1  | UART Control Register 1 (UART_CON1)           | 293 |
| 13.2.2  | UART Control Register 2 (UART_CON2)           | 294 |
| 13.2.3  | UART Status Flag Register (UART_STATE)        | 294 |
| 13.2.4  | UART Data Register (UART_BUF)                 | 295 |
| 13.2.5  | UART Baud Rate Control Register (UART_BDL)    | 296 |
| 13.2.6  | UART Clock Selection Register (UART_CLK_SEL)  | 296 |
| 13.2.7  | UART IO Selection Register (UART_IO_SEL)      | 296 |
| 13.3 UA | RT CONFIGURATION PROCEDURE                    | 297 |
| 14 SCI  |                                               | 299 |
|         |                                               |     |
|         |                                               |     |
|         | UART Mode                                     |     |
|         | LIN Frame Mode                                |     |
|         | UD RATE GENERATION                            |     |
|         | ITTER FUNCTION                                |     |
|         | CEIVER FUNCTION                               |     |
|         | Receiver Sampling Method                      |     |
|         | Receiver Wakeup from Sleep                    |     |
|         | I CONNECTION MODE                             |     |
|         | W POWER WAKE-UP                               |     |
|         | AME MODE                                      |     |
|         | Frame Format                                  |     |
|         | LIN Communication                             |     |
|         | LIN Software Flow Chart                       |     |
|         | AME MODE STATE MACHINE                        |     |
|         | TRUCTIONS FOR INTERRUPT HANDLING              |     |
|         |                                               |     |
| 14.10.1 |                                               |     |
| 14.10.2 |                                               |     |
|         | Baud Rate Control Low 8-bit Register(SCI_BDL) |     |
|         | Control Register 1 (SCI_C1)                   |     |
|         | Control Register 2 (SCI_C2)                   |     |
|         | Control Register 3 (SCI_C3)                   |     |
|         | Sync Segment Control Register (SCI_S2)        |     |
| 14.10.8 |                                               |     |
|         | SCI Data Register (SCI_D)                     |     |
| 14.10.1 | 0 SCI Interrupt Clear Register (SCI_INT_CLR)  |     |



### BS9000AM Series V1.0

|            |        | DOGOCOAM Series V                                                               |      |
|------------|--------|---------------------------------------------------------------------------------|------|
|            | _      | General-purpose MCU with EEPROM, 12bit-ADC, LIN Communicat                      | tion |
| 14         | .10.11 | LIN Frame Timeout Configuration Register (LIN_FRAME_TIMEOUT)                    | 327  |
| 14         | .10.12 | LIN Configuration Register 1 (LIN_CTL1)                                         | 328  |
| 14         | .10.13 | LIN Configuration Register 0 (LIN_CTL0)                                         | 329  |
| 14         | .10.14 | LIN Transfer Command Register (LIN_LIN_CMD)                                     | 330  |
| 14         | .10.15 | LIN Synchronization Section Baud Rate Count Period Register (LIN_SYNC_CO UNTER) | 332  |
| 14         | .10.16 | LIN Status Register (LIN_STATUS)                                                |      |
| 14         | .10.17 | LIN Data Field Count Value Register (LIN_DATA_IDX)                              | 333  |
| 14         | .10.18 | LIN Interrupt Status Register 1 (LIN_INTR1)                                     | 335  |
| 14         | .10.19 | LIN Interrupt Status Register 2 (LIN_INTR2)                                     |      |
| 14         | .10.20 | LIN Interrupt Enable Register 1 (LIN_INTR1_IE)                                  | 337  |
| 14         | .10.21 | LIN Interrupt Enable Register 2 (LIN_INTR2_IE)                                  |      |
|            | .10.22 | LIN Transmit Register Description                                               |      |
| 14         | .10.23 | LIN Receive Register Description                                                | 340  |
| 15         | PROGR  | AMMING AND DEBUGGING                                                            | .342 |
| 15.1       | SWE    | CIRCUIT CONNECTION                                                              | .342 |
| 15.2       | Сара   | CITIVE TOUCHKEY DATA ASSISTED PROGRAMMING & DEBUGGING                           | .342 |
| 16         | CPU IN | STRUCTIONAL SYSTEM                                                              | 344  |
| 16.1       | INSTR  | UCTION CODE                                                                     | .344 |
| 16.2       | INSTR  | UCTION SET                                                                      | .344 |
| 17         | APPLIC | ATION CIRCUIT FOR REFERENCE                                                     | .351 |
| 18         | ΡΔΩΚΔ  | GE INFORMATION                                                                  | 352  |
| -          |        |                                                                                 |      |
| 18.1       | - •    | 20                                                                              |      |
| 18.2       | TSSC   | DP28                                                                            | 353  |
| 19         | ORDER  |                                                                                 | 354  |
| 20         | REVISI | ON HISTORY                                                                      | .355 |
| 21         |        |                                                                                 | 356  |
| <b>∠ I</b> | DISCLA |                                                                                 | 330  |
|            |        |                                                                                 |      |



### BS9000AM Series V1.0

General-purpose MCU with EEPROM, 12bit-ADC, LIN Communication

#### **BS9000AM Series MCU Overview** 1

#### 1.1 **Features**

- Core: High-speed 8051, 1T Instruction cycle
  - Operating Frequency: 24MHz /16MHz /12MHz/8MHz
  - Clock Offset: ±1% @-20°C~65°C, 5V or 0 ±3% @-40°C ~125°C, 5V
- Memories
  - 30.5KBytes FLASH 0
  - 1024Bytes EEPROM 0
  - 256 Bytes(idata)+2048 Bytes(xdata) SRAM
  - Support IAP online update, memories protection
- Clock Source, Reset and Power Management
  - o Internal Low-speed RC: 32768Hz, clock offset within ±3%@25°C, 5V or ±5% @-
  - 40°C ~125°C, 5V
  - Internal High-speed OSC: 1MHz
  - External OSC: 16MHz/12MHz/8MHz 0
  - o 7 Reset modes, among which the BOR mode is ON with the voltage selectable 2.6V/2.8V/3.7V/4.2V
  - Low voltage detection: 3V/3.3V/3.6V/3.9V/4.5V
- 10
  - 10k Embedded Pull-up/ Pull-down  $\cap$ Resistors
  - Provide multiplexing of Peripheral 0 functions
  - I/O Lines with External Interrupt Capability, INT0 to 2 enable Rising Edge, Falling Edge or both interrupt respectively, INT3 enables both rising and falling interrupt.
- Communications
  - UART

- o IIC slave communication supporting 100/400kHz
- SPI: master with a frequency up to 4M and 2M slave
- SCI: LIN2.1 protocol, up to 115200bps Baud
- 16-bit PWM
  - PWM0 supports 4-channel input/output with 3-channel complementary output
  - PWM1 supports 3-channel input/output
- Operating voltage: 3.0V to 5.5V, 3.3V or 5.0V typ
- Operating temperature: -40°C to 125°C
- High accuracy 12-bit ADC
  - Up to 24 Analog Input channels
  - 2.048V/4.096V internal reference voltage detection
- Interrupt
  - High/Low-Level Interrupt Selection
  - ADC, CSD, INT0/1/2/3, LVDT, Timer0/1/2, RTC, WDT, UART, SCI, IIC, SPI
- Timer
  - 3 16-bit Timer0/1/2 0
  - 16-bit RTC, wake-up in low-power mode
  - Watchdog Timer
- Low-power Mode
  - Wait Mode
  - Sleep Mode, 20µA @5V typ consumption 0
- TouchKey
  - The sensitivity of each key can be set individually
  - o Capacitive TouchKey can be multiplexed with GPIO lines
- 2-wire programming and single-wire debugging emulator IO
- Packages: QFN20/TSSOP28

#### 1.2 Description

BS9000AM series are 8-bit general-purpose microcontrollers that meets the quality requirements of AECQ0-100 Grade 1. Based on 8051 CORE and 1T instruction cycle, it runs faster than the Standard 8051 with 12T. Also, it is compatible with Standard 8051 instructions.

The peripherals of BS9000AM series devices includes WDT, PWM0/1, Timer0, Timer1, Timer2, RTC, IIC, SPI, UART, SCI with Lin2.1 protocol, LV Detection, BOR, 12-bit successive-approximation ADC, Touch-key Detection and Low-power mode. The memory supports EEPROM real-time data storage. The BS9000AM series are available in QFN20 and TSSOP28 packages. The BS9000AMxx is suitable for many applications such as end actuator unit, end sensor detection control.



### 1.3 System Block Diagram

Figure 0.1 BS9000AMxx Block Diagram



### 1.4 Clock Diagram





#### **Main Clock**

- OSC\_125KHz: a timer clock used in Low-consumption Wakeup Interrupt Mode.
- F\_sys\_clk: select clock frequency of 24MHz/16MHz/12MHz/8MHz.

Semiconductor



- f<sub>MASTER:</sub> PWM PLL\_24MHz/XTAL can be selected.
- PLL\_24MHz: a clock for FLASH program and read, SCI/UART/PWM0/PWM1.
- XTAL: External Crystal. When the frequency is at 16M or 12M or 8M, it acts as a timer for Timer2/RTC, also a clock SCI/UART/ PWM0/PWM1.
- RC32KHz: The frequency is 32768Hz, used for Timer2, RTC and WDT setting.

#### 1.5 Selection Table

| P/N               | BS9000AM20-QBBX | BS9000AM28-TBBX |
|-------------------|-----------------|-----------------|
| Operating Voltage | 3.0V to 5.5V    | 3.0V to 5.5V    |
| Core              | 1T 8051         | 1T 8051         |
| Operating         |                 |                 |
| Frequency         | 24M             | 24M             |
| FLASH (Byte)      | 30.5K           | 30.5K           |
| SRAM (Byte)       | 256+2048        | 256+2048        |
| EEPROM (Byte)     | 1024            | 1024            |
| GPIO              | 18              | 26              |
| ADC               | 16              | 24              |
| KEY               | 16              | 24              |
| Timer             | 4               | 4               |
| PWM0              | 4ch             | 4ch             |
| PWM1              | 3ch             | 3ch             |
| SPI               | 1               | 1               |
| INT               | 18              | 26              |
| IIC               | 1               | 1               |
| UART              | 1               | 1               |
| SCI               | 1               | 1               |
| Package           | QFN20           | TSSOP28         |

Table 0.3 Selection Table



#### **1.6 Pin configuration**

#### 1.6.1 QFN20



Figure 0.4 BS9000AM20-QBBX Package and Pinout Drawing



#### 1.6.2 TSSOP28



Figure 0.5 BS9000AM28-TBBX Package and Pinout Drawing



### **1.7 Pin Functions**

| BS9000AM20-xxxx | BS9000AM28-xxxx | Function                                                                                                                                                                                                                                                                                                                                 |  |
|-----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 19              | 1               | By Default: GPIO <pa0><br/>Other functions: ADC00: ADC channel 0<br/>INT0: External Interrupt 0<br/>PGD1: Programming Interface<br/>PGD2: Programming Interface<br/>SWE: Single Wire Emulation IO<br/>SNS0: TouchKey channel 0</pa0>                                                                                                     |  |
| 20              | 2               | By Default: GPIO <pa1><br/>Other functions: ADC01: ADC channel 1<br/>INT3_0: External Interrupt 3_0<br/>TXD0: Transmit Serial Data<br/>TXD1: Transmit Serial Data<br/>MOSI: Master Out Slave In in SPI Master Mode<br/>SDA: IIC serial data line<br/>PGC1: Programming Interface<br/>BRK: Break input<br/>SNS1: TouchKey channel 1</pa1> |  |
| 1               | 3               | By Default: GPIO <pa2><br/>Other functions: ADC02: ADC channel 2<br/>INT3_1: External Interrupt 3_1<br/>RXD0: Receive Serial Data<br/>RXD1: Receive Serial Data<br/>MISO: Master In Slave Out (MISO) in SPI Master mode<br/>SCL: IIC serial clock line<br/>SNS2: TouchKey channel 2</pa2>                                                |  |
| 2               | 4               | By Default: GPIO <pa3><br/>Other functions: ADC03: ADC channel 3<br/>INT3_2: External Interrupt 3_2<br/>SCK: SPI clock line<br/>PWM1_CH1: PWM1 channel<br/>ETR: External interrupt<br/>SNS3: TouchKey channel 3</pa3>                                                                                                                    |  |



#### BS9000AMxx

|   |    | DS9000AIVIXX                                  |
|---|----|-----------------------------------------------|
|   |    | By default: GPIO <pa4></pa4>                  |
|   |    | Other functions: ADC04: ADC channel 4         |
|   | 5  | INT3_3: External interrupt 3_3                |
|   |    | PWM0_CH1_N: PWM0 complementary output channel |
|   |    | SNS4: TouchKey channel 4                      |
|   |    | By default: GPIO <pa5></pa5>                  |
|   |    | Other functions: ADC05: ADC channel 5         |
|   | 6  | INT3_4: external interrupt 3_4                |
|   |    | PWM0_CH2_N: PWM0 complementary output channel |
|   |    | SNS5: TouchKey channel 5                      |
| 3 | 7  | By default: Ground <vss></vss>                |
| 4 | 8  | By default: Power Supply <vcc></vcc>          |
|   |    | By default: GPIO <pd0></pd0>                  |
|   |    | Other functions: ADC6: ADC channel 6          |
| 5 | 9  | INT3_5: external interrupt 3_5                |
| 5 | 9  | SPI_CS0: SPI chip select signal               |
|   |    | PWM1_CH1: PWM1 channel                        |
|   |    | SNS6: TouchKey channel 6                      |
|   |    | By default: GPIO <pd1></pd1>                  |
|   | 10 | Other functions: ADC7: ADC channel 7          |
| 6 |    | INT3_6: external interrupt 3_6                |
| 0 |    | PWM1_CH1: PWM 1channel                        |
|   |    | PWM0_CH1_N: PWM0 complementary output channel |
|   |    | SNS7: TouchKey channel 7                      |
|   |    | By default: GPIO <pd2></pd2>                  |
|   |    | Other functions: ADC8: ADC channel 8          |
| 7 | 11 | INT1: external interrupt 1                    |
|   |    | PWM0_CH1_N: PWM0 complementary output channel |
|   |    | SNS8: TouchKey channel 8                      |
|   |    | By default: GPIO <pd3></pd3>                  |
|   |    | Other functions: ADC9: ADC channel 9          |
| 8 | 12 | INT3_7: external interrupt 3_7                |
|   |    | PWM0_CH2_N: PWM0 complementary output channel |
|   |    | SNS9: TouchKey channel 9                      |
|   |    | By default: GPIO <pd4></pd4>                  |
|   |    | Other functions: ADC10: ADC channel 10        |
| 9 | 13 | INT3_8: external interrupt 3_8                |
| 9 | 15 | PWM0_CH2: PWM0 channel                        |
|   |    | ETR: external interrupt                       |
|   |    | SNS10: TouchKey channel 10                    |
|   |    |                                               |



|    |    | By default: GPIO <pb0></pb0>                      |
|----|----|---------------------------------------------------|
|    |    | Other functions: ADC11: ADC channel 11            |
| 10 |    | INT3 9: external interrupt 3 9                    |
| 10 |    | PWM0_CH1: PWM0 channel                            |
|    |    | BRK: Break output                                 |
|    |    | SNS11: TouchKey channel 11                        |
|    |    | By default: GPIO <pb1></pb1>                      |
|    |    | Other functions: INT3 10: external interrupt 3 10 |
|    | 14 | RXD0: Receive Serial Data                         |
| 11 |    | RXD1: Receive Serial Data                         |
|    |    | PWM0 CH1: PWM0 channel                            |
|    |    | OSC_IN: external oscillator input                 |
|    |    | By default: GPIO <pb2></pb2>                      |
|    |    | Other functions: INT3_11: External interrupt 3_11 |
| 10 | 45 | TXD0: Transmit Serial Data                        |
| 12 | 15 | TXD1: Transmit Serial Data                        |
|    |    | PWM0_CH2: PWM0 channel                            |
|    |    | OSC_OUT: external oscillator output               |
|    |    | By default: GPIO <pb3></pb3>                      |
|    |    | Other functions: ADC12: ADC channel 12            |
|    | 16 | INT3_12: external interrupt 3_12                  |
|    |    | PGC2: programming interface                       |
|    |    | SNS12: TouchKey channel 12                        |
|    |    | By default: GPIO <pb4></pb4>                      |
|    |    | Other functions: ADC13: ADC channel 13            |
|    | 17 | INT3_13: external interrupt 3_13                  |
|    | 17 | TXD0: Transmit Serial Data                        |
|    |    | TXD1: Transmit Serial Data                        |
|    |    | SNS13: TouchKey channel 13                        |
|    |    | By default: GPIO <pb5></pb5>                      |
|    |    | Other functions: ADC14: ADC channel 14            |
|    |    | INT3_14: external interrupt 3_14                  |
|    | 18 | RXD0: Receive Serial Data                         |
|    |    | RXD1: Receive Serial Data                         |
|    |    | PWM0_CH1_N: PWM complementary output channel      |
|    |    | SNS14: TouchKey channel 14                        |
|    |    | By default: GPIO <pb6></pb6>                      |
|    |    | Other functions: ADC15: ADC channel 15            |
| 13 | 19 | INT3_15: external interrupt 3_15                  |
|    |    | TXD0: Transmit Serial Data                        |
|    |    | TXD1: Transmit Serial Data                        |



|    |     | SDA: IIC serial data line                           |
|----|-----|-----------------------------------------------------|
|    |     | PWM0_CH1: PWM0 channel                              |
|    |     | SNS15: TouchKey channel 15                          |
|    |     | By default: GPIO <pb7></pb7>                        |
|    |     | Other functions: ADC16: ADC channel 16              |
|    |     | INT3_16: external interrupt 3_16                    |
| 14 | 20  | RXD0: Receive Serial Data                           |
| 14 | 20  | RXD1: Receive Serial Data                           |
|    |     | SCL: IIC serial clock line                          |
|    |     | PWM0_CH1: PWM0 channel                              |
|    |     | SNS16: TouchKey channel 16                          |
|    |     | By default: GPIO <pc0></pc0>                        |
|    |     | Other functions: ADC17: ADC channel 17              |
|    | 21  | INT3_17: external channel 3_17                      |
|    | 21  | TXD0: Transmit Serial Data                          |
|    |     | TXD1: Transmit Serial Data                          |
|    |     | SNS17: TouchKey channel 17                          |
|    |     | By default: GPIO <pc1></pc1>                        |
|    |     | Other functions: ADC18: ADC channel 18              |
|    | 22  | INT3_18: external interrupt 3_18                    |
|    | ~~~ | RXD0: Receive Serial Data                           |
|    |     | RXD1: Receive Serial Data                           |
|    |     | SNS18: Touch key channel 18                         |
|    |     | By default: GPIO <pc2></pc2>                        |
|    |     | Other functions: ADC19: ADC channel 19              |
| 15 | 23  | INT3_19: external interrupt 3_19                    |
|    |     | SCK: SPI serial clock line                          |
|    |     | PWM1_CH1: PWM1 channel                              |
|    |     | SNS19: TouchKey channel 19                          |
|    |     | By default: GPIO <pc3></pc3>                        |
|    |     | Other functions: ADC20: ADC channel 20              |
| 16 | 24  | INT2: external interrupt 2                          |
|    |     | MISO: Master In Slave Out (MISO) in SPI Master mode |
|    |     | PWM1_CH2: PWM1 channel                              |
|    |     | SNS20: TouchKey channel 20                          |
|    |     | By default: GPIO <pc4></pc4>                        |
|    |     | Other functions: ADC21: ADC channel 21              |
| 17 | 25  | INT3_20: external interrupt 3_20                    |
|    |     | MOSI: Master Out Slave In in SPI Master Mode        |
|    |     | PWM0_CH2: PWM0 channel                              |
|    |     | SNS21: TouchKey channel 21                          |



|    |    | By default: GPIO <pc5></pc5>           |  |  |  |  |  |
|----|----|----------------------------------------|--|--|--|--|--|
|    |    | Other functions: ADC22: ADC channel 22 |  |  |  |  |  |
| 18 | 26 | INT3_21: external interrupt 3_21       |  |  |  |  |  |
| 10 | 20 | SPI_CS1: chip select                   |  |  |  |  |  |
|    |    | PWM0_CH3: PWM0 channel                 |  |  |  |  |  |
|    |    | SNS22: TouchKey channel 22             |  |  |  |  |  |
|    |    | By default: GPIO <pc6></pc6>           |  |  |  |  |  |
|    |    | Other functions: ADC23: ADC channel 23 |  |  |  |  |  |
|    | 27 | INT3_22: external interrupt 3_22       |  |  |  |  |  |
|    | 21 | PWM0_CH1: PWM0 channel                 |  |  |  |  |  |
|    |    | BRK: break input                       |  |  |  |  |  |
|    |    | SNS23: TouchKey channel 23             |  |  |  |  |  |
|    |    | By default: GPIO <pc7></pc7>           |  |  |  |  |  |
|    |    | Other functions: ADC24: ADC channel 24 |  |  |  |  |  |
|    | 28 | INT3_23: external interrupt 3_23       |  |  |  |  |  |
|    |    | PWM0_CH1: PWM0 channel                 |  |  |  |  |  |
|    |    | SNS24: TouchKey channel 24             |  |  |  |  |  |
|    |    |                                        |  |  |  |  |  |

Table 0.6 PIN MAP

Note : Oscillator uses the OSC\_IN pin to input clock.



# 2 Electrical Characteristics

#### 2.1 AC Characteristics

| Parameter     | Symbol                     | Conditions                   | Clock Skew | Unit |
|---------------|----------------------------|------------------------------|------------|------|
|               |                            | Ta=25℃, @5V                  | ±1%        |      |
| Fundamental   |                            | Ta= -40℃ ~ 85℃, @5V          | ±2%        |      |
|               | OSC1M                      | Ta= -40°C ~ 125°C, @5V       | ±3%        |      |
| frequency     |                            | VCC=3.0V ~ 5.5V, environment | ±3%        |      |
|               |                            | temperature 25°C             | ±3%        |      |
|               |                            | Ta=25℃ @5V                   | ±1%        | MHz  |
|               | F_sys_clk                  | Ta= -40℃ ~ 85℃, @5V          | ±2%        | -    |
| System clock  |                            | Ta= -40°C to 125°C, @5V      | ±3%        |      |
|               |                            | VCC=3.0V ~ 5.5V, environment | ±3%        |      |
|               |                            | temperature 25°C             | ±3%        |      |
|               |                            | Ta=25℃, @5V                  | ±3%        |      |
| Internal low- | w- Ta= -40°C to 125°C, @5V |                              | ±5%        | kHz  |
| speed clock   | RC32k                      | VCC=3.0V ~ 5.5V, environment | 150/       | KITZ |
|               |                            | temperature 25°C             | ±5%        |      |

Table 0.1 AC characteristics



Figure 0.2 OSC1MHz Voltage Curve









Figure 0.4 OSC1MHz Temperature Curve Graph



Figure 0.5 RC32KHz Temperature Curve Graph

#### **DC** Characteristics 2.2

#### Table 2.6 DC characteristics (Tamb = $25^{\circ}$ C, unless otherwise specified)

| Parameter | Symbol | Conditions | Min | Тур | Max | Unit |
|-----------|--------|------------|-----|-----|-----|------|
| Operating | VCC    | _          | 3.0 | _   | 5.5 | V    |
| voltage   | 100    |            | 0.0 |     | 0.0 | v    |



#### BS9000AMxx

|                    | -      |                                                                                                        |   |      |   |    |
|--------------------|--------|--------------------------------------------------------------------------------------------------------|---|------|---|----|
|                    |        | @5V, 24M system clock without load, other functions turned off                                         | - | 9.97 |   | mA |
|                    |        | @5V, 16M, system clock without load, other functions turned off                                        | - | 7.40 |   | mA |
|                    |        | @5V, 12M system clock without load, other functions turned off                                         | - | 5.90 |   | mA |
|                    |        | @5V, 8M system clock without load, other functions turned off                                          | - | 4.60 |   | mA |
|                    |        | @3.3V, 24M system clock without load, other functions turned off                                       | - | 9.97 | - | mA |
|                    |        | @3.3V, 16M system clock without load, other functions turned off                                       | - | 7.40 | - | mA |
|                    | Active | @3.3V, 12M system clock without load, other functions turned off                                       | - | 5.90 | - | mA |
|                    |        | @3.3V, 8M system clock without load, other functions turned off                                        | - | 4.57 | - | mA |
|                    |        | @3.0V, 24M system clock without load, other functions turned off                                       |   | 9.97 | - | mA |
|                    |        | @3.0V, 16M system clock without load, other functions turned off                                       | - | 7.40 | - | mA |
| Operating<br>Modes |        | @3.0V, 12M system clock without load, other functions turned off                                       | - | 5.90 | - | uA |
|                    |        | @3.0V, 8M system clock without load, other functions turned off                                        | - | 4.57 | - | uA |
|                    |        | <ul> <li>@5V 24M system clock, IO output low, enter wait mode, other functions turned off</li> </ul>   | _ | 3.73 | - | mA |
|                    |        | @3.3V 24M system clock, IO output low, enter wait mode, other functions turned off                     | - | 3.73 | _ | mA |
|                    |        | <ul> <li>@3.0V 24M system clock, IO output low, enter wait mode, other functions turned off</li> </ul> | - | 3.73 | - | mA |
|                    |        | @5V 16M system clock, IO output low, enter wait mode, other functions turned off                       | - | 3.77 | - | mA |
|                    | Wait   | @3.3V 16M system clock, IO output low, enter wait mode, other functions turned off                     | - | 3.70 | - | mA |
|                    |        | @3.0V 16M system clock, IO output low, enter wait mode, other functions turned off                     | - | 3.70 | - | mA |
|                    |        | @5V 12M system clock, IO output low, enter wait mode, other functions turned off                       | - | 3.77 | - | mA |
|                    |        | @3.3V 12M system clock, IO output low, enter wait mode, other functions turned off                     | - | 3.73 | - | mA |
|                    |        | @3.0V 12M system clock, IO output low, enter wait mode, other functions turned off                     | - | 3.73 | - | mA |
| L                  | 1      | 1                                                                                                      |   |      | 1 |    |



#### BS9000AMxx

|                                     |       | F                                                                                                                            |             |        |         |    |
|-------------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------|-------------|--------|---------|----|
|                                     |       | @5V 8M system clock, IO output low, enter wait mode, other functions turned off                                              | -           | 3.73   | -       | mA |
|                                     |       | @3.3V 8M system clock, IO output low, enter wait                                                                             | -           | 3.70   | -       | mA |
|                                     |       | mode, other functions turned off@3.0V 8M system clock, IO output low, enter wait                                             | _           | 3.67   | -       | mA |
|                                     |       | mode, other functions turned off<br>@5V 24M system clock, PCON = 0x01, IO output                                             |             |        |         |    |
|                                     |       | low,other functions turned off                                                                                               | -           | 21.33  | -       | μA |
|                                     | Sleep | @3.3V 24Msystem clock, PCON = 0x01, IO output<br>low,other functions turned off                                              | -           | 19.33  | -       | uA |
|                                     |       | @3.0V 24Msystem clock, PCON = 0x01, IO output<br>low, other functions turned off                                             | -           | 21.00  | -       | μA |
|                                     |       | @5V, CSD parallel mode, WDT interrupt wakes up<br>after 2s, 2ms working time, IO output low, other<br>functions turned off   | -           | 36.07  | -       | μΑ |
|                                     |       | @3.3V, CSD parallel mode, WDT interrupt wakes<br>up after 2s, 2ms working time, IO output low, other<br>functions turned off | _           | 33.70  | -       | μA |
| CSD                                 |       | @3.0V, CSD parallel mode, WDT interrupt wakes<br>up after 2s, 2ms working time, IO output low, other<br>functions turned off | -           | 35.10  | -       | μA |
| parallel<br>mode                    | Idle  | @5.0V, CSD parallel mode, RTC wakes up after 2s<br>interrupt, 2ms working time, IO output low, other<br>functions turned off | -           | 765.33 | -       | μA |
|                                     |       | @3.3V, CSD parallel mode, RTC wakes up after 2s<br>interrupt, 2ms working time, IO output low, other<br>functions turned off | -           | 754.67 | -       | μΑ |
|                                     |       | @3.0V, CSD parallel mode, RTC wakes up after 2s interrupt, 2ms working time, IO output low, other functions turned off       | -           | 756.33 | -       | μΑ |
| Input low<br>voltage                | VIL   | VCC=3.0~5.5V                                                                                                                 | -           | -      | 0.3*VCC | V  |
| Input high<br>voltage               | VIH   | VCC=3.0~5.5V                                                                                                                 | 0.7*V<br>CC | -      | -       | V  |
| INT0/1/2/3<br>Input low<br>voltage  | Vintl | VCC=3.0~5.5V                                                                                                                 | -           | -      | 0.3*VCC | V  |
| INT0/1/2/3<br>Input high<br>voltage | Vinth | VCC=3.0~5.5V                                                                                                                 | 0.7*V<br>CC | -      | -       | V  |
| Output low<br>voltage               | Vol   | IOL=50mA@VCC=5V                                                                                                              | -           | -      | 0.1*VCC | V  |



| Output<br>high<br>voltage    | Vон               | IOH=15mA@VCC=5V                                                                                                                     | 0.9VC<br>C | -   | - | V  |
|------------------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------|------------|-----|---|----|
| IO sink<br>current           | IOL               | V <sub>OL</sub> =0.1VCC, @VCC=5V                                                                                                    | -          | 50  | - | mA |
| IO source<br>current         | ЮН                | V <sub>OH</sub> =0.9VCC, @VCC=5V                                                                                                    | -          | 15  | - | mA |
| Input<br>Leakage<br>current  | I <sub>Le</sub>   | VCC=5V                                                                                                                              | -          | 1   | - | μA |
| Pull-up<br>resistor          | R <sub>P_u</sub>  | VCC=5V                                                                                                                              | -          | 10  | - | kΩ |
| Pull-down<br>resistor        | R <sub>P_d</sub>  | VCC=5V                                                                                                                              | -          | 10  | - | kΩ |
| ADC<br>Operating<br>current  | Iadc              | @5V, 24M system clock without load, IO output low,<br>enable ADC and turn on one channel, GET_ADC<br>scan, turn off other functions | -          | 1.6 | - | mA |
| LVDT<br>Operating<br>current | Ilvdt             | @5V, 24M system clock without load; in sleep<br>mode, IO output low, enable LVDT, turn off other<br>functions                       | -          | 0.6 | - | μA |
| CSD<br>Operating<br>current  | Icsd              | @5V 24M system clock without load, IO output low,<br>enable 6 channels of CSD and Timer0, turn off other<br>functions               | -          | 1.2 | - | mA |
| PWM0<br>Operating<br>current | I <sub>PWM0</sub> | @5V 24M system clock without load, IO output low,<br>enable PWM0, initate OC1 channel to 4K, turn off<br>other functions            | -          | 1.0 | - | mA |
| PWM1<br>Operating<br>current | Ipwm1             | @5V 24M system clock without load, IO output low,<br>enable PWM1, initate OC1 channel to 4K, turn off<br>other functions            | -          | 0.5 | - | mA |
| EEPROM<br>Erase<br>current   | I_E               | @5V 24M system clock without load, IO output low,<br>erase EEPROM in While, turn off other functions                                | -          | 3.3 | - | mA |
| EEPROM<br>Write<br>current   | I_w               | @5V 24M system clock without load, IO output low, write a byte in While, turn off other functions                                   | -          | 3.9 | - | mA |



## 2.3 ADC characteristics

| Table 0.7 ADC characteristics (Tamb - 25 C, diffess otherwise specified) |                                                                         |                      |      |     |      |         |  |  |
|--------------------------------------------------------------------------|-------------------------------------------------------------------------|----------------------|------|-----|------|---------|--|--|
| ADC electrical o                                                         | ADC electrical characteristics VDD=Vmin-5.5V, GND=0V, TA=+25 $^\circ$ C |                      |      |     |      |         |  |  |
| Parameter                                                                | Symbol                                                                  | Conditions           | Min  | Тур | Max  | Unit    |  |  |
| Supply voltage                                                           | Vad                                                                     | -                    | 3.0  | -   | 5.5  | V       |  |  |
| Accuracy                                                                 | N <sub>R</sub>                                                          | -                    | -    | 9   |      | Bit     |  |  |
| A/D input voltage                                                        | VAIN                                                                    | -                    | VSS  | -   | VREF | V       |  |  |
| A/D input registeres                                                     | D                                                                       | VCC=5V, RC filter    | -    | 12  | -    | kΩ      |  |  |
| A/D input resistance                                                     | RAIN                                                                    | VCC=5V, NO RC filter | -    | 2.3 | -    | kΩ      |  |  |
| A/D operating current                                                    | I <sub>AD</sub>                                                         | -                    | -    | 0.9 | -    | mA      |  |  |
| A/D input current                                                        | I <sub>ADIN</sub>                                                       | -                    | -    | -   | 1    | μA      |  |  |
| Differential Non-linearity error                                         | Dle                                                                     | VDD=5.0V             | -    | ±4  | -    | LSB     |  |  |
| Integral Non-linearity error                                             | LLE                                                                     | VDD=5.0V             | -    | ±4  | -    | LSB     |  |  |
| ADC sampling time                                                        | Tad                                                                     | -                    | 1.33 | -   | 1024 | μs      |  |  |
| ADC conversion time                                                      | TCON                                                                    | -                    | 7.75 | -   | 1079 | μs      |  |  |
| Resolution                                                               | ADCRESO                                                                 | -                    |      | 12  |      | Bit     |  |  |
| Input channel                                                            | -                                                                       | -                    | -    | -   | 25   | Channel |  |  |

Table 0.7 ADC characteristics ( $T_{amb} = 25^{\circ}C$ , unless otherwise specified)



### 2.4 Absolute Maximum Ratings

| Parameter                      | Symbol    | Min     | Тур  | Мах     | Unit |
|--------------------------------|-----------|---------|------|---------|------|
| Supply voltage                 | VCC       | VSS+3.0 | -    | VSS+5.5 | V    |
| Storage temperature            | Tstg      | -55     | -    | 150     | °C   |
| Operating temperature          | Totg      | -40     | -    | 125     | °C   |
| I/O input voltage              | Vin       | VSS-0.5 | -    | VCC+0.5 | V    |
| IOL total current              | IOLA      | -       | 100  | -       | mA   |
| IOH total current              | IOHA      | -       | -100 | -       | mA   |
| I/O ESD voltage                | ESD(HBM)  | -8      | -    | 8       | kV   |
| LATCH UP @T <sub>A</sub> =25°C | I Trigger | -200    |      | 200     | mA   |

Table 0.6Absolute maximum ratings

Note: Stresses beyond those listed absolute maximum ratings may cause permanent damage to the device. The functional operation of the device may not be predicted beyond those indicated under recommended operating conditions. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

### 3 Memories

#### 3.1 FLASH

Consisted of one block of 32KB and one block of 512bytes, the flash of BS9000AMxx can erase and write 10k times, and data is not lost after the brown-out. The allocation inside the Flash is as follows:



1 page = 512Bytes

Figure 0.1 FLASH IP Memory Allocation

The flash has two blocks, which is Main block and information block, The last 1K of the main storage block is used for EEPROM functionality. The Main block can store the IC execution program. The information block is used for the storage of the configuration word information.

FLASH serves to solidify the user's programme and store the execution program.

NVR (KEY sector) is invisible to CPU and can not be written and read. This page can not be erased when the read protection is valid.

EEPROM area, can support CPU read and erase at any time, and is not protected by Flash read and write control.

The size of each page is 512 Bytes. The main block has 64 pages and the information block has 1 page.

FLASH Features is as follows:



- The Flash program uses 2-wire programming by multiplexing the PA[0](PGC) and PA[1](PGD) with the programming frequency ranging from 100K to 5M (allowing an error of 10%) and supports batch programming mode.
- Supports read protection and configuration word write protection
- BOOT program: it can be configured to disable Write protection, erase the Main block page and performs the byte write operation in the user code.
- Read out the code information stored in Flash when CPU is at working.
- Address overflow flag

#### 3.2 FLASH Read and Write Protection

#### 3.2.1 FLASH Write Protection

Write protection is configured by CFG\_WPROTECT\_PAGE. By default, the flash space protection is enabled. See Write Protection Control Range below.

| WPROTECT_PAGE | Write Protection Range |
|---------------|------------------------|
| 0             | Not protected          |
| 1             | NVR+0x0000-0x01FF      |
| 2             | NVR+0x0000-0x03FF      |
| 3             | NVR+0x0000-0x05FF      |
| 4             | NVR+0x0000-0x07FF      |
| 5             | NVR+0x0000-0x09FF      |
| 6             | NVR+0x0000-0x0BFF      |
|               |                        |
| 60            | NVR+0x0000-0x77FF      |
| 61/62/63      | NVR+0x0000-0x79FF      |

Table 0.2 Write Protection Mapping

Note:

- 1. Write protection is solely used for CPU erase and write FLASH and do not limit program mode.
- 2. EEPROM sector supports CPU erase and write operation at any time and is without SFR write protection control.



- 3. INFORMATION sector does not support CPU erase and write operation at any time and is without Write protection control.
- KEY NVR sector do not support CPU erase and write operation at any time and is without Write protection control. Note that 32 bytes from 0x7be0 to 0x7bff do not open to CPU operations and CPU can not read.

#### 3.2.2 FLASH Read Protection

FLASH provides read protection functions including read protection deadlock and read protection encryption. The difference between them is that the latter can temporarily disable read protection by sending a decryption command in programming mode, while the former cannot. See the specific FLASH mapping below.

| Flash address (0x7bf6~0x7bf9)<br>4byte is used to store the number of key<br>attempts                     | Flash address (0x7bfa~0x7bfd)<br>4byte is used to store the key                  | Flash address (0x7bfe)<br>1byte is used to store whether<br>read protection encryption is<br>enabled (0x83) | Flash address (0x7bff)<br>lbyte is used to store whether to<br>enable read protection deadlock<br>(0x68) |
|-----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| When mass production and<br>programming, it is necessary to ensure<br>that the address range data is 0xFF | During mass production, the key, read pu<br>along with the HEX file, and the key | 1                                                                                                           | 1 0 1                                                                                                    |

Figure 3.3 Read Protection

See below the Read Protection Control Flow Chart in programming mode.





Figure 0.4 Read Protection Control Flow Chart in Programming Mode

Note

- When the Read Protection is valid, the debug port is invalid and can not work upon any commands.
- When the Read Protection is invalid, all space can be read by CPU, SWE,PG except the address from 0x7BE0 to 0x7BFF which can not be read by CPU.



#### BS9000AMxx

- When the Read Protection is valid, CPU cannot read the address from 0x7BE0 to 0x7BFF. SWE can not be read in any way except after keys match in programming mode (Read protection lock dose not support KEY Match to unlock).
- No limit on EEPROM (0x7c00 to 0x7fff) and INFORMATION (0x8000 to 0x81ff) to be read at any time.
- If the Read Protection Lock is enabled, it is not allowed to match keys in code mode and support no operations except the command Erase all.
- If only the Read protection encryption is enabled, the code mode allows erase page, write page and read page when keys match, otherwise just Erase all is allowed.
- If only the Read protection encryption is enabled, code mode allows keys match operation. If the number of mismatches is greater than 4, the matching operation is no longer allowed, and only the full erase instruction is allowed to execute.
- The configuration bit of Read protection lock is 0x68. The configuration bit of read protection encryption is 0x83.
- Read the storage value of protection and key once after power-on, change key or enable read protection in the programming mode, and power-on again to make it valid.
- Write key at the programming interface, write hex file through programming at a time instead of writing by Trim Register.



#### 3.3 SRAM

SRAM functions as a memory. As the internal RAM and the extension RAM of BS9000AM series, the main features of SRAM are as follows:

- System clock: 24MHz.
- Including internal RAM (iram) and extension RAM (xram).
  - > The size of Internal RAM is 256 Bytes, 8-bit address ranging from 00~FFH.
  - > The size of extension RAM is 2048 Bytes, 11-bit address ranging from 000~7FFH.

Part of the system register XRAM\_SFR uses XRAM bus, with address ranging from 2000~FFFFH.

Reserve stack space during programming to avoid the stack overflow. The first address of the stack is distributed automatically according to program when the C programming language is used, but it must store at DATA sector or IDATA sector. In Keil, set up the first address of stack in STARTUP.A51.

The SRAM address space is divided as follows:





Figure 0.5 SRAM Address Allocation

The total size of internal SRAM is 256 Bytes with the address from 00H to FFH, including operation register group, bit address and buffers (stacks included).

- Internal Low 128 bytes: from 00H to 7FH totaling128 Bytes. Read out and write data through immediate addressing or indirect addressing.
- Internal High 128 bytes: from 80H to FFH totaling 128 Bytes. Read out and write data through operation register indirect addressing.

SFR: Special functional register at address of 80H to FFH, using direct addressing to read and write data.

XDATA has a total size of 2048Bytes at address from 0000H to 07FFH. User can totally use this block. It uses data pointer or register addressing to read and write data.



XRAM\_SFR is at address from 2000H to FFFFH. User can totally use this block. It uses data pointer or register addressing to read and write data.

|              |       |    |    | R/                  | ٩M    |    |            |            |             |
|--------------|-------|----|----|---------------------|-------|----|------------|------------|-------------|
| 7FH          | (MSB) |    |    |                     |       |    | (L         | <u>SB)</u> | Buffer      |
| 2FH          | 7F    | 7E | 7D | 7C                  | 7B    | 7A | 7 <b>9</b> | 78         | <b>I</b> ↑  |
| 2EH          | 77    | 76 | 75 | 74                  | 73    | 72 | 71         | 70         | ]           |
| 2DH          | 6F    | 6E | 6D | 6C                  | 6B    | 6A | 69         | 68         |             |
| 2CH          | 67    | 66 | 65 | 64                  | 63    | 62 | 61         | 60         |             |
| 2BH          | 5F    | 5E | 5D | 5C                  | 5B    | 5A | 59         | 58         | ]           |
| 2AH          | 57    | 56 | 55 | 54                  | 53    | 52 | 51         | 50         |             |
| 2 <b>9</b> H | 4F    | 4E | 4D | 4C                  | 4B    | 4A | 49         | 48         | Bit         |
| 2 <b>8</b> H | 47    | 46 | 45 | 44                  | 43    | 42 | 41         | 40         | Addressable |
| 27H          | 3F    | 3E | 3D | 3C                  | 3B    | 3A | 39         | 38         |             |
| 2 <b>6</b> H | 37    | 36 | 35 | 34                  | 33    | 32 | 31         | 30         |             |
| 25H          | 2F    | 2E | 2D | 2C                  | 2B    | 2A | 2 <b>9</b> | 28         | ]           |
| 24H          | 27    | 26 | 25 | 24                  | 23    | 22 | 21         | 20         |             |
| 23H          | 1F    | 1E | 1D | 1C                  | В1    | 1A | 19         | 18         |             |
| 22H          | 17    | 16 | 15 | 14                  | 13    | 12 | 11         | 10         | ]           |
| 21H          | 0F    | 0E | 0D | 0C                  | 0B    | 0A | 09         | 08         |             |
| 20H          | 07    | 06 | 05 | 04                  | 03    | 02 | 01         | 00         | ]↓          |
| 1FH<br>18H   |       |    |    | 3 g                 | roups | 3  |            |            |             |
| 17H<br>10H   |       |    |    | Working<br>Register |       |    |            |            |             |
| 0FH<br>08H   |       |    |    | I Register          |       |    |            |            |             |
| 07H<br>00H   |       |    |    |                     | ₩     |    |            |            |             |

Figure 0.6 Bit Addressable Distribution

The table below gives addressing methods of 3 modules from RAM:

| Region | Addressing Method |                 |  |  |
|--------|-------------------|-----------------|--|--|
|        | MOV               | A,direct        |  |  |
|        | MOV               | direct,A        |  |  |
| DATA   | MOV               | direct,#data    |  |  |
| DATA   | MOV               | direct1,direct2 |  |  |
|        | MOV               | Rn,direct       |  |  |
|        | MOV               | direct,Rn       |  |  |
|        | MOV               | A,@Ri           |  |  |
|        | MOV               | @Ri,A           |  |  |
| IDATA  | MOV               | direct,@Ri      |  |  |
|        | MOV               | @Ri,direct      |  |  |
|        | MOV               | @Ri,#data       |  |  |
| XDATA  | MOVX              | @DPTR,A         |  |  |



MOVX A,@DPTR

 Table 0.7
 RAM Evaluation Instructions

#### 3.4 EEPROM

EEPROM is the last 1KBytes of the Main Block.

EEPROM Program: User code can conduct page erase and byte write operations in EEPROM space.

Please use the program to directly access and read out the value of EEPROM. The table below shows 2 BLOCK positions from EEPROM:

| EEPRO<br>M | BLOCK<br>Address | Description                                                                                                                                                                                                                                                          |
|------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BLOCK0     | 0x7E00           | Every block has a size of 512Bytes. One erase operation can<br>erase a space of 512Bytes.<br>SPROG_ADDR_H[1]=1, select block1.<br>SPROG_ADDR_H[1]=0, select block0.<br>SPROG_ADDR_H[0] and SPROG_ADDR_L[7:0] select<br>page address<br>SPROG_ADDR_H[7:2] is invalid. |
| BLOCK1     | 0x7C00           |                                                                                                                                                                                                                                                                      |

#### Table 0.8 EEPROM Address

#### Notes:

- 1. Every address in the EEPROM can only be written into once after the erase operation, erase it first if there is need to write again.
- 2. For a EEPROM, data can be written into in batches after the erase operation.

#### 3.4.1 Page Erase

- 1. SPROG\_TIM[4:0] = 0 to 20 (recommended setting as 10: 30ms). The byte write time is fixed to 62µs. SPROG\_TIM is configured only once in the initiation of the main().
- 2. Disable the general interrupt
- 3. Configure SPROG\_ADDR\_L=0x00.
- 4. Configure SPROG\_ADDR\_H=0x0x(bit[1];0:select block0;1:select block1), choose the page needs to be erased.
- 5. Configure SPROG\_LIN\_CMD=0x96, EEPROM page erase command.
- 6. Write into 4 consecutive NOP commands.
- 7. When the erase starts, CPU enters into IDLE mode and exits automatically after it finished.
- 8. For further data erasing, jump to step 2.



- 9. Configure SPROG ADDR H=0x00,SPROG ADDR L=0x00, recover the interrupt.
- 10. Enable the general interrupt.

#### 3.4.2 Byte Programming

- 1. SPROG\_TIM[4:0] = 0 to 20 (Recommended setting as 10: 30ms). The Byte write time is fixed to 62µs. SPROG\_TIM is configured once in the main() initiation. Disable interrupt.
- 2. Disable the general interrupt.
- 3. Configure SPROG\_ADDR\_L, SPROG\_ADDR\_H, select the address of the byte programming.
- 4. Configure SPROG\_DATA, EEPROM programs the data to be written into.
- 5. Configure SPROG\_LIN\_CMD=0x69, EEPROM bit programming command.
- 6. Write into 4 consecutive NOP commands.
- 7. When the write starts to program, CPU enters into IDLE mode and exits automatically after it completes.
- 8. For further data programming, jump to step 2.
- 9. Configure SPROG\_ADDR\_H=0x00, SPROG\_ADDR\_L=0x00, recover the interrupt.
- 10. Enable the general interrupt.

#### 3.5 IAP Operation

FLASH IAP routines as follows:





Figure 0.9 FLASH IAP Operation Flow Chart

#### 3.5.1 Program Upgrade

At the address block that write protection is invalidated, page erase and byte write operations are allowed through the program to upgrade the BOOT program.

- Enter BOOT upgrade steps: Write 0x12, 0x34, 0x56, 0x78 and 0x9A into SPROG\_LIN\_CMD consecutively, enter BOOT upgrade mode of the FLASH, when all space is write-protected, it can not enter BOOT upgrade mode.
- Exit BOOT upgrade steps: Write 0xFE, 0xDC, 0xBA, 0x98 and 0x76 into SPROG\_LIN\_CMD consecutively, exit FLASH BOOT upgrade mode.
- The steps of Erase and byte programming is the same as the EEPROM.
- {SPROG\_ADDR\_H[6:0], SPROG\_ADDR\_L[7:0]} multiplexed as the FLASH space Address at 0x0000~0x79FF.
- Erase one page once, the size of 1 page is 512Bytes.

#### 3.5.2 FLASH IAP Erase Operation

FLASH\_BOOT Upgrade Steps:

- 1. SPROG\_TIM[4:0] =  $0 \sim 20$  (recommended setting 30ms). The byte writing time is fixed to  $62\mu$ s. SPROG\_TIM is configured only once in the initiation of the function main().
- 2. Disable the interrupt.
- 3. Configure SPROG\_ADDR\_L = 0x00.
- 4. Configure SPROG\_ADDR\_H[5:1], select erase this page.
- 5. Configure SPROG\_LIN\_CMD = 0x96, FLASH page erase command.
- 6. Write 4 consecutive NOP commands.
- 7. When the erase operation starts, CPU disables F\_sys\_clk and enables it once finished.
- 8. For further data erasing, jump to step 2.
- 9. Configure SPROG\_ADDR\_H=0x00, SPROG\_ADDR\_L=0x00, recover the interrupt.
- 10. Enable General Interrupt.

#### 3.5.3 FLASH IAP bit Write

In FLASH\_BOOT Upgrade mode:

- 1. SPROG\_TIM[4:0] =0 to 20 (recommended 30ms). The byte writing time is fixed to 62µs. SPROG\_TIM is configured only once in the initiation of the function main().
- 2. Disable General Interrupt.

- 3. Configure SPROG\_ADDR\_L, SPROG\_ADDR\_H, selects the address of the programming.
- 4. Configure SPROG\_DATA, FLASH programs the data to be written into.
- 5. Configure SPROG\_LIN\_CMD = 0x69, FLASH bits programming command.
- 6. Write into 4 NOP instructions.

Semiconductor

- 7. Start to write, CPU disable F\_sys\_clk and open it again once completed.
- 8. If continue to write data, jump to step 2.
- 9. Configure SPROG\_ADDR\_H=0x00, SPROG\_ADDR\_L=0x00, recover the interrupt.
- 10. Enable General Interrupt.

#### 3.5.4 FLASH IAP Operation

FLASH IAP operations are the following:

| Instruction        | Response          | Data                     |
|--------------------|-------------------|--------------------------|
| Enter Upgrade Mode | FLASH_BOOT_EN = 1 | 0x12、0x34、0x56、0x78、0x9A |
| Exit Upgrade Mode  | FLASH_BOOT_EN = 0 | 0xFE、0xDC、0xBA、0x98、0x76 |

Table 0.10 FLASH IAP Operations

#### Instruction descriptions

- Enter upgrade mode: SPROG\_LIN\_CMD write sequence: 0x12, 0x34, 0x56, 0x78, 0x9A.
- Exit upgrade mode: SPROG\_LIN\_CMD write sequence: 0xFE, 0xDC, 0xBA, 0x98, 0x76.

#### Response

- FLASH\_BOOT\_EN = 1 indicates entering the FLASH BOOT upgrade mode;
- FLASH\_BOOT\_EN = 0 indicates exiting the FLASH BOOT upgrade.

#### Note:

- It is necessary to write the instruction data of SPROG\_LIN\_CMD and BOOT\_LIN\_CMD in order, otherwise it requires to rewrite.
- MCU operating voltage: 3.0V to 5.5V. MCU may occur error at 1.5V~3.0V, resulting in wrong upgrade. It is recommended to test the voltage of ADC or LVDT before the IAP operation, if it is lower than 3.0V, do not conduct the IAP.
- It is recommended to mask the interrupt during the upgrading to ensure that the IAP operation will not be interrupted, recover the interrupt to once finished. Check data after the upgrading to make sure it is correct.



## 3.6 Registers for Memory

#### 3.6.1 Interrupt Vector Table Offset Register (OFFSET\_ADDR\_L)

XRAM\_SFR address: 0x2020

| Bit No.       | 7 | 6                | 5 | 4    | 3      | 2 | 1 | 0 |  |  |  |
|---------------|---|------------------|---|------|--------|---|---|---|--|--|--|
| Symbol        |   | OFFSET_ADDR[7:0] |   |      |        |   |   |   |  |  |  |
| Read/Write    |   |                  |   | Read | /write |   |   |   |  |  |  |
| Power-on      |   |                  |   |      |        |   |   |   |  |  |  |
| initial value |   |                  |   | (    | J      |   |   |   |  |  |  |

| No. | Symbol           | Description                                     |
|-----|------------------|-------------------------------------------------|
| 7~0 | OFFSET_ADDR[7:0] | Vector table offset interrupt address (bit 7-0) |

### 3.6.2 Vector Table Offset Interrupt Address Register (OFFSET\_ADDR\_H)

XRAM\_SFR address: 0x2021

| Bit No.       | 7 | 6                 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|---------------|---|-------------------|---|---|---|---|---|---|--|--|--|
| Symbol        |   | OFFSET_ADDR[15:8] |   |   |   |   |   |   |  |  |  |
| Read/Write    |   | Read/Write        |   |   |   |   |   |   |  |  |  |
| Power-on      |   |                   |   |   |   |   |   |   |  |  |  |
| initial value |   |                   |   | ( | J |   |   |   |  |  |  |

| No. | Symbol            | Description                                       |
|-----|-------------------|---------------------------------------------------|
| 7~0 | OFFSET_ADDR[15:8] | Vector table offset interrupt address high 8 bits |

#### 3.6.3 Address Control Register (SPROG\_ADDR\_H)

| Bit No.       | 7 | 6 | 5                   | 4 | 3 | 2 | 1 | 0 |
|---------------|---|---|---------------------|---|---|---|---|---|
| Symbol        |   |   | -                   | - |   |   |   |   |
| Read/Write    |   |   | Read/Writ Read/Writ |   |   |   |   |   |
| Read/white    |   |   |                     |   |   |   | е | е |
| Power-on      |   |   | 0                   | 0 |   |   |   |   |
| initial value |   |   |                     | 0 | U |   |   |   |



| Bit No. | Symbol | Description                                           |
|---------|--------|-------------------------------------------------------|
| 7~2     |        |                                                       |
|         |        |                                                       |
| 1       |        | Selects EEPROM block (for page erase and bit program) |
|         |        | 0: select block0                                      |
|         |        | 1: select block1                                      |
| 0       |        | Indicates EEPROM block address SPROG_ADDR[8]          |
|         |        | I n FLASH BOOT upgrade mode,                          |
|         |        | {SPROG_ADDR_H[6:0], SPROG_ADDR_L} is multiplexed with |
|         |        | all addresses of FLASH ranging from 0x0000 to 0x79FF  |

## 3.6.4 Address Control Register (SPROG\_ADDR\_L)

XRAM\_SFR address: 0x2063

| No.           | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|---------------|---|------------|---|---|---|---|---|---|--|--|--|
| Symbol        |   |            |   |   |   |   |   |   |  |  |  |
| Read/Write    |   | Read/Write |   |   |   |   |   |   |  |  |  |
| Power-on      |   |            |   |   |   |   |   |   |  |  |  |
| initial value |   |            |   | ( | J |   |   |   |  |  |  |

| Bit No. | Symbol | Description                                                 |
|---------|--------|-------------------------------------------------------------|
| 7~0     |        | Indicates EEPROM block address bits 7 to 0                  |
|         |        | {SPROG_ADDR_H[0], SPROG_ADDR_L[7:0]}indicates block address |

## 3.6.5 Data Register (SPROG\_DATA)

| Bit No.       | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|---------------|---|------------|---|---|---|---|---|---|--|--|--|
| Symbol        |   | -          |   |   |   |   |   |   |  |  |  |
| Read/Write    |   | Read/Write |   |   |   |   |   |   |  |  |  |
| Power-on      |   |            |   |   |   |   |   |   |  |  |  |
| initial value |   |            |   | ( | J |   |   |   |  |  |  |

| Bit No. | Symbol | Description                            |
|---------|--------|----------------------------------------|
| 7~0     |        | EEPROM programming: data to be written |



#### 3.6.6 Command register (SPROG\_CMD)

XRAM\_SFR address: 0x2065

| Bit No.       | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|---------------|---|------------|---|---|---|---|---|---|--|--|--|
| Symbol        |   |            |   |   |   |   |   |   |  |  |  |
| Read/Write    |   | Read/Write |   |   |   |   |   |   |  |  |  |
| Power-on      |   |            |   |   |   |   |   |   |  |  |  |
| initial value |   |            |   | ( | J |   |   |   |  |  |  |

| Bit No. | Symbol | Description                                               |
|---------|--------|-----------------------------------------------------------|
| 7~0     |        | Write into 0x96: EEPROM page erase                        |
|         |        | Write into 0x69: EEPROM bit programming                   |
|         |        | Write 0x12, 0x34, 0x56, 0x78, 0x9A in order to enter into |
|         |        | FLASH BOOT Upgrade Mode.                                  |
|         |        | Write 0xFE, 0xDC, 0xBA, 0x98, 0x76 in order to exit FLASH |
|         |        | BOOT Upgrade Mode.                                        |
|         |        | When all space is write-protected, BOOT upgrade mode can  |
|         |        | not be entered.                                           |

## 3.6.7 Erase and Write Time Control Register (SPROG\_TIM)

#### XRAM\_SFR address: 0x2066

| Bit No.                   | 7 | 6 | 5 | 4          | 3          | 2          | 1          | 0          |
|---------------------------|---|---|---|------------|------------|------------|------------|------------|
| Symbol                    | - | - | - | -          | -          | -          | -          | -          |
| Read/Write                | - | - | - | Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Power-on<br>initial value | - | - | - | 0          | 1          | 0          | 1          | 0          |

| Bit No. | Symbol | Description                                                    |
|---------|--------|----------------------------------------------------------------|
| 7~5     |        | Reserved                                                       |
| 4~0     |        | (prog set as 30us)                                             |
|         |        | bit[4:0]: 0~20: Erase time = 20 to 40ms (in increments of 1ms) |
|         |        | >20: Erase time = 30ms                                         |

## 3.6.8 BOOT Status Register (FLASH\_BOOT\_EN)



| Bit No.       | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0             |
|---------------|---|---|---|---|---|---|---|---------------|
| Symbol        | - | - | - | - | - | - | - | FLASH_BOOT_EN |
| Read/Write    | - | - | - | - | - | - | - | Read          |
| Power-on      |   |   |   |   |   |   |   | 0             |
| initial value | - | - | - | - | - | - | - | 0             |

| Bit No. | Symbol        | Description                                           |
|---------|---------------|-------------------------------------------------------|
| 0       | FLASH_BOOT_EN | 1: Enter FLASH BOOT Upgrade mode.                     |
|         |               | 0: Exit FLASH BOOT Upgrade mode.                      |
|         |               | In this mode, registers SPROG_ADDR_H, SPROG_ADDR_L,   |
|         |               | SPROG_DATA, SPROG_LIN_CMD, SPROG_TIM multiplexed as   |
|         |               | BOOT upgrade                                          |
|         |               | {SPROG_ADDR_H, SPROG_ADDR_L} multiplexed with address |
|         |               | space range 0x0000~0x79FF in FLASH.                   |

## 3.6.9 Write Protect Range Configuration Register (FLASH\_WPROTECT\_PAGE)

XRAM\_SFR address 1: 0x7A00

XRAM\_SFR address 2: 0x7A01

Note: The data at address 2 is the inverse of the data in address 1, that is, the data at address 2 is complementary to the data at address 1. The configuration is valid only when both address 1 and address 2 are configured.

| Bit No.                   | 7 | 6 | 5                 | 4          | 3 | 2 | 1 | 0 |
|---------------------------|---|---|-------------------|------------|---|---|---|---|
| Symbol                    | - | - | CFG_WPROTECT_PAGE |            |   |   |   |   |
| Read/Write                | - | - |                   | Read/Write |   |   |   |   |
| Power-on<br>initial value | - | - | 1                 | 1          | 1 | 1 | 1 | 1 |

| Bit No. | Symbol            | Description                                                 |
|---------|-------------------|-------------------------------------------------------------|
| 5~0     | CFG_WPROTECT_PAGE | Flash address write protection range configuration register |
|         |                   | by page.Full-space protection is enabled by default.        |



## 4 System

## 4.1 Clock







**OSC\_125K**: Low Power Consumption Wake-up Clock.

**F\_sys\_clk**: System Clock, select frequency from 24MHz/16MHz/12MHz/8MHz.

**PLL\_48MHz**: PLL generated 48MHz clock used as CSD and system clock after frequency division.

**PLL\_24MHz**: PLL generated 24MHz clock directly used as controllers like UART, FLASH and PWM.

XTAL16MHz/12MHz/8MHz: mainly used for peripheral clock like Timer2, SCI and PWM.

**PLL\_CLK\_DIV**: divide the frequency of PLL\_24Mhz and XTAL,where n is from 0 to 7 for 2<sup>n</sup> **RC32KHz**: The CLOCK frequency is 32768Hz, used as clock source of WDT, Timer2 and RTC.

| Function          | Clock Source                                        |
|-------------------|-----------------------------------------------------|
| Low power         |                                                     |
| consumption Wake- | OSC_125K                                            |
| up                |                                                     |
| CSD               | PLL_48MHz                                           |
| ADC               | 3MHz/2MHz/1.5MHz/1MHz                               |
| CPU               | System Clock F_sys_clk(24MHz/16MHz/12MHz/8MHz)      |
| SFR               | System Clock F_sys_clk(24MHz/16MHz/12MHz/8MHz)      |
| SRAM              | System Clock F_sys_clk(24MHz/16MHz/12MHz/8MHz)      |
| RST               | System Clock F_sys_clk(24MHz/16MHz/12MHz/8MHz)      |
| Timer0/1          | System Clock F_sys_clk(24MHz/16MHz/12MHz/8MHz)/12   |
| SPI               | System Clock F_sys_clk(24MHz/16MHz/12MHz/8MHz)      |
| IIC               | System Clock F_sys_clk(24MHz/16MHz/12MHz/8MHz)      |
| FLASH             | PLL_24MHz                                           |
| SCI               | PLL_24MHz or XTAL(16MHz/12MHz/8MHz)                 |
| UART              | PLL_24MHz or XTAL(16MHz/12MHz/8MHz)                 |
| PWM0              | PLL_24MHz or XTAL(16MHz/12MHz/8MHz)                 |
| PWM1              | PLL_24MHz or XTAL(16MHz/12MHz/8MHz)                 |
| TIMER2/RTC        | PLL_CLK_DIV Frequency division of PLL_24MHz/XTAL or |
|                   | RC32KHz                                             |
| WDT               | PLL_24MHz or RC32KHz                                |

Table 0.2 List of Peripheral Clock Source

## 4.2 Reset System

The digital pasrt of BS9000AMxx has 7 reset sources: Power-on Reset (po\_n), Brown-out Reset (bo\_n), Program Reset (prog\_en), Software Reset (soft\_rst), WDT Reset (wdt\_rst), Address Overflow Reset (addr\_overflow) and Debug Reset (debug\_rst\_out\_n). If any kind of reset occurs and generates the global reset signal, it will reset the device. According to reset status register, check which reset has happened. Reset status bits require software to clear. See Reset diagram below.

See POR/BOR sequence diagram below.



Figure 0.3 POR Diagram

See PON/BOR parameters below.

| Symbol  | Parameter                              | Min  | Тур  | Max    | Unit |
|---------|----------------------------------------|------|------|--------|------|
| VSPOR   | POR Startup voltage                    | -    | -    | 300    | mV   |
| KPRO    | POR slew rate                          | 0.38 | -    | -      | V/ms |
| VPOR    | POR Voltage                            | 1.21 | 1.59 | 2.04   | V    |
|         | BOR Voltage (±10%), Hysteresis is 0.2V | -    | 2.6  | -      | V    |
| VBOR    | BOR Voltage (±10%), Hysteresis is 0.2V | -    | 2.8  | -      | V    |
| VOOR    | BOR Voltage (±10%), Hysteresis is 0.2V | -    | 3.7  | -      | V    |
|         | BOR Voltage (±10%), Hysteresis is 0.2V | -    | 4.2  | -      | V    |
| VDD_min | Minimum Operating Voltage              | 3.0  | -    | -      | V    |
| T1      | VDD hold time for VSPOR                | 0.1  | -    | -      | ms   |
| T2      | VPOR to VDD_min time                   | -    | -    | 0.6*T3 | ms   |
| Т3      | POR_BOR_N hold time                    | -    | 7.8  | -      | ms   |
| T4      | General reset valid time               | -    | 3    | -      | ms   |

Figure 0.4 POR Characteristics Parameters

When VDD is impacted by loads or severe disturbance, if voltage falls into the voltage deadtime and the device is not within the operating voltage range, it may cause system fault, such as EEPROM data loss. The BOR serves as a monitor when VDD falls to BOR voltage, MCU can trigger BOR in advance in case the system faults occur.

Tips on preventing the voltage falling into dead**time** which may cause the system fault: ramp up the falling slope.

## 4.3 LVDT

BS9000AMxx supports Low Voltage Detection, which monitors the voltage status change. It has 5 different voltage levels: 3.0V/3.3V/3.6V/3.9V/4.5V (Preset Point voltage drop interrupt, 0.1V hysteresis generates the corresponding voltage rising interrupt). When the voltage monitor configures the threshold value above-mentioned, voltage drops to this threshold will trigger Low Voltage interrupt. During the low voltage interrupt, the system can handle it according to application requirements.

See LVDT configuration flow chart as bellow.



Figure 0.5 LVDT Configuration



## 4.4 Operating Modes

BS9000AMxx supports 3 operating modes based on different situations. BS9000AMxx supports register SYS\_CLK\_CFG, configure its Bit 2 to enter Wait Mode. BS9000AMxx supports PCON register, configure its Bit 0 and MCU enters sleep mode.

• Active Mode: Modules operates normally, their functions are controlled by software configurations.

• Wait Mode: Write 1 into SYS\_CLK\_CFG .2 to enter wait mode. In wait mode, analog clock is not OFF. To reach the low consumption state, only disable the clocks related to digital system core. Except the Core-related modules and SPI module, the rest modules can work and exit the wait mode by interrupt.

• **Sleep Mode:** Configure IDLE\_EN=1 to enter sleep mode. Then, disable OSC1M and PLL, enable RC32K, enable WDT/TIMER2/RTC, IIC interrupt/SCI edge interrupt set to wake up, disable CPU and the rest digital modules.

Both Reset and valid interrupt can exit wait or sleep mode. The wake-up interrupt differs in different modes. See below:



Figure 0.6 Operating Mode Conversion

#### Ways to exit the Waiting Mode

• Enable IIC, External Interrupt0, External Interrupt1, External Interrupt2, External Interrupt3,

WDT, Timer2, RTC, CSD, ADC, LVDT, UART, SCI and PWM0/1. Any kind of interrupt among them can wake up the device to exit the wait mode. CPU executes the interrupt program.

#### Ways to exit the Sleep Mode

Enable External Interrupt 0, External Interrupt1, External Interrupt2, External Interrupt3, IIC, WDT, Timer2, RTC and SCI edge. Any kind of interrupt among them can wake up the device to exit the sleep mode. When interrupt occurs, CPU executes interrupt vector-related interrupt service routine. After executing RETI return command, CPU comes back to run next program, which is after the program allowing CPU to enter sleep mode.

Table 4.9 shows the clock source in different operating states.

| Modes  | conditions                | R     | esults             |  |
|--------|---------------------------|-------|--------------------|--|
|        |                           | RC32K | Enable             |  |
|        |                           | XTAL  | Depend on software |  |
| Active | IDLE_EN=0;<br>WAIT_MODE=0 | ATAL  | configuration      |  |
|        | WAIT_MODE-0               | OSC1M | Enable             |  |
|        |                           | PLL   | Enable             |  |
|        |                           | RC32K | Enable             |  |
|        | IDLE_EN=0;<br>WAIT_MODE=1 | XTAL  | Depend on software |  |
| Wait   |                           | A TAL | configuration      |  |
|        |                           | OSC1M | Enable             |  |
|        |                           | PLL   | Enable             |  |
|        |                           | RC32K | Enable             |  |
|        |                           | XTAL  | Depend on software |  |
| Sleep  | IDLE_EN=1                 |       | configuration      |  |
|        |                           | OSC1M | Disable            |  |
|        |                           | PLL   | Disable            |  |

 Table 0.7 Clock Source in Different Modes

Table 4.8 shows the states of digital modules in different modes.

| NO | Module    | Clock source | Operating state |      |       |  |
|----|-----------|--------------|-----------------|------|-------|--|
|    | NO WOQUIE |              | Active          | Wait | Sleep |  |
| 1  | s8051     | F_sys_clk    | $\checkmark$    | ×    | ×     |  |
|    |           | F_sys_clk/12 | According to    |      |       |  |
| 2  | Timer0    |              | program         | ×    | ×     |  |
|    |           |              | configuration   |      |       |  |
|    |           | F_sys_clk/12 | According to    |      |       |  |
| 3  | Timer1    |              | program         | ×    | ×     |  |
|    |           |              | configuration   |      |       |  |



|    |            | RC32KHz, XTAL,        | According to  | According to  | According to  |
|----|------------|-----------------------|---------------|---------------|---------------|
| 4  | Timer2/RTC | PLL 24MHz             | program       | program       | program       |
|    |            |                       | configuration | configuration | configuration |
|    |            |                       | According to  | According to  | According to  |
| 5  | WDT        | 24MHz, RC32K          | program       | program       | program       |
|    |            |                       | configuration | configuration | configuration |
|    |            | F_sys_clk, XTAL       | According to  | According to  |               |
| 6  | PWM0/1     |                       | program       | program       | ×             |
|    |            |                       | configuration | configuration |               |
|    |            |                       | According to  | According to  |               |
| 7  | UART       | F_sys_clk, XTAL       | program       | program       | ×             |
|    |            |                       | configuration | configuration |               |
|    |            | F_sys_clk, XTAL       | According to  | According to  | According to  |
| 8  | SCI        |                       | program       | program       | program       |
|    |            |                       | configuration | configuration | configuration |
|    |            |                       | According to  | According to  |               |
| 9  | SPI        | F_sys_clk             | program       | program       | ×             |
|    |            |                       | configuration | configuration |               |
|    |            |                       | According to  | According to  | According to  |
| 10 | IIC(S)     | F_sys_clk             | program       | program       | program       |
|    |            |                       | configuration | configuration | configuration |
|    |            |                       | According to  | According to  |               |
| 11 | ADC        | 3MHz/2MHz/1.5MHz/1MHz | program       | program       | ×             |
|    |            |                       | configuration | configuration |               |
|    |            |                       | According to  | According to  |               |
| 12 | CSD        | PLL_48MHz             | program       | program       | ×             |
|    |            |                       | configuration | configuration |               |
|    |            |                       |               |               |               |

Table 0.8 Digital Modules in different modes

**F\_sys\_clk**: System clock with frequency 24MHz/16MHz/12MHz/8MHz to select. **XTAL**: external crystal with frequency 6MHz/12MHz/8MHz to select.

## 4.5 Watchdog Timer (WDT)

WDT circuit uses RC32K or PLL\_24MHz to set time as 2<sup>n</sup>\*18ms (n=0, 1, 2, 3, 4, 5, 6, 7) where n is the set value of timer configuration register.

WDT reset signal consists of general reset and configuration reset. The signal supports synchronous release by WDT clock in the Reset module. Clear operation is generated each time CPU configures WDT configuration register, then WDT restarts. Concurrently, WDT counter has its counter enable control. When the counter is enabled and WDT generates overflow (reset or interrupt), the WDT counter restarts as long as the counter is not disabled.





■ When system is under normal mode and WDT occurs overflow, then the overflow signal is the WDT overflow reset signal. Since the WDT overflow reset impacts the general reset, at this time the system implements general reset and reload the configuration information.

If WDT overflows when system is in sleep or wait mode, then the overflow signal is the WDT interrupt signal, which wakes up the device to exit sleep or wait mode and executes WDT interrupt services function.

## 4.6 System Registers

#### 4.6.1 Software Reset Register (SOFT\_RST)

| Bit No.       | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------|---|------------|---|---|---|---|---|---|
| Symbol        |   | -          |   |   |   |   |   |   |
| Read/Write    |   | Read/Write |   |   |   |   |   |   |
| Power-on      |   | 0          |   |   |   |   |   |   |
| initial value |   |            |   | ( | J |   |   |   |

XRAM\_SFR address: 0x2022

| Bit No. | Symbol | Description                                                         |
|---------|--------|---------------------------------------------------------------------|
| 7~0     |        | Software reset register will trigger software reset if the register |
|         |        | value is 0x55.                                                      |

#### 4.6.2 Reset Flag Register (RST\_STAT)

| Bit No.                       | 7 | 6           | 5        | 4        | 3            | 2        | 1        | 0                |
|-------------------------------|---|-------------|----------|----------|--------------|----------|----------|------------------|
| Symbol                        | - | DEBUG_<br>F | SOFT_F   | PROG_F   | ADDROF_<br>F | BO_F     | PO_F     | WDT<br>RST_<br>F |
| Read/Wri                      | - | Read/Wri    | Read/Wri | Read/Wri | Read/Writ    | Read/Wri | Read/Wri | Read             |
| te                            |   | te          | te       | te       | е            | te       | te       | /Write           |
| Power-<br>on initial<br>value | - | 0           | 0        | 0        | 0            | 0        | 1        | 0                |



## BS9000AMxx

| Bit No. | Symbol   | Descriptions                  |
|---------|----------|-------------------------------|
| 6       | DEBUG_F  | 1: enables debug reset        |
|         |          | 0: stay in the previous state |
| 5       | SOFT_F   | 1: enables software reset     |
|         |          | 0: stay in the previous state |
| 4       | PROG_F   | 1: enables program reset      |
|         |          | 0: stay in the previous state |
| 3       | ADDROF_F | 1: enables PC overflow reset  |
|         |          | 0: stay in the previous state |
| 2       | BO_F     | 1: enables Brown-out reset    |
|         |          | 0: stay in the previous state |
| 1       | PO_F     | 1: enables Power-on reset     |
|         |          | 0: stay in the previous state |
| 0       | WDTRST_F | 1: enables WDT overflow reset |
|         |          | 0: stay in the previous state |

Note:

Reset value represents the reset values in different modes. For example, the value of rst\_state is 0x02 for Power-on Reset; for other reset modes, the corresponding reset flag bit of rst\_state is 1, other flag indicates it stays in the previous mode.

## 4.6.3 Module Switching Control Register (PD\_ANA)

| Bit No.     | 7           | 6           | 5           | 4           |
|-------------|-------------|-------------|-------------|-------------|
| Symbol      | -           | -           | LDO_LOAD2   | LDO_LOAD1   |
| Read /write | -           | -           | Read /write | Read /write |
| PO initial  | _           | _           | 0           | 0           |
| value       | -           | -           | 0           | 0           |
| Bit No.     | 3           | 2           | 1           | 0           |
| symbol      | XTAL_SEL    | PD_XTAL     | PD_CSD      | PD_ADC      |
| Read /write |
| PO initial  | 0           | 1           | 1           | 1           |
| value       | 0           | I           | I           | 1           |

| Bit No. | Symbol    | Description                                               |
|---------|-----------|-----------------------------------------------------------|
| 5       | LDO_LOAD2 | In WAIT mode, DC Loads 450µA control, reset value is 0.   |
|         |           | 0: indicates DC loads 450µA Control                       |
|         |           | 1: No DC loads                                            |
| 4       | LDO_LOAD1 | In Active mode, DC Loads 450µA control, reset value is 0. |



|   |          | 0: indicates DC loads 450µA                   |
|---|----------|-----------------------------------------------|
|   |          | 1: No DC loads                                |
| 3 | XTAL_SEL | Oscillator/Crystal selects register           |
|   |          | 0: selects crystal                            |
|   |          | 1: selects oscillator                         |
| 2 | PD_XTAL  | Crystal circuit control register              |
|   |          | 1: Disabled;                                  |
|   |          | 0: enabled ( disabled by default)             |
| 1 | PD_CSD   | Analog CSD (control system designed) register |
|   |          | PD_CSD=0 CSD in active mode                   |
|   |          | PD_CSD=1 CSD does not work                    |
| 0 | PD_ADC   | Analog ADC control register                   |
|   |          | PD_ADC=0 ADC in active mode                   |
|   |          | PD_ADC=1 ADC does not work                    |

## 4.6.4 BOR Threshold Selection Register (BOR\_SEL)

XRAM\_SFR Address: 0x2025

| Bit No.             | 7 | 6 | 5 | 4 | 3 | 2 | 1          | 0          |
|---------------------|---|---|---|---|---|---|------------|------------|
| Symbol              | - | - | - | - | - | - | SEL_BO     | DR_VTH     |
| Read/Write          | - | - | - | - | - | - | Read/Write | Read/Write |
| Po initial<br>value | - | - | - | - | - | - | 0          | 0          |

| Bit No. | Symbol      | Description                            |  |  |  |  |
|---------|-------------|----------------------------------------|--|--|--|--|
| 1~0     | SEL_BOR_VTH | BOR threshold selection                |  |  |  |  |
|         |             | 00: 2.6V; 01:2.8V; 10: 3.7V; 11: 4.2V; |  |  |  |  |

See the BOR voltage threshold selection table below.

| Threshold selection | BOR                  |                       |                           |            |  |  |  |
|---------------------|----------------------|-----------------------|---------------------------|------------|--|--|--|
| SEL_BOR_VTH         | BOR threshold<br>(V) | Reset<br>threshold(V) | voltage<br>hysteresis(mV) | Delay (µs) |  |  |  |
| 00                  | 2.6                  | 2.7                   | 114.7                     | 72.62      |  |  |  |
| 01                  | 2.8                  | 2.9                   | 132                       | 81.78      |  |  |  |
| 10                  | 3.7                  | 3.8                   | 155.4                     | 125.8      |  |  |  |
| 11                  | 4.2                  | 4.3                   | 101.5                     | 148.6      |  |  |  |

Table 0.11 BOR Threshold Selection Table



## 4.6.5 LVDT Control Register (LVDT\_SEL)

XRAM\_SFR Address: 0x2026

| Bit No.             | 7 | 6 | 5 | 4 | 3          | 2          | 1          | 0          |
|---------------------|---|---|---|---|------------|------------|------------|------------|
| Symbol              | - | - | - | - | PD_LVDT    | S          | EL_LVDT_VT | Ή          |
| Read/Write          | - | - | - | - | Read/Write | Read/Write | Read/Write | Read/Write |
| Po initial<br>value | - | - | - | - | 1          | 0          | 0          | 0          |

| Bit No. | Symbol       | Description                                    |  |  |  |
|---------|--------------|------------------------------------------------|--|--|--|
| 3       | PD_LVDT      | LVDT control register                          |  |  |  |
|         |              | 1: disabled; 0: enabled ( disabled by default) |  |  |  |
| 2~0     | SEL_LVDT_VTH | LVDT threshold selection                       |  |  |  |
|         |              | 000: 3.0V; 001: 3.3V; 010: 3.6V;               |  |  |  |
|         |              | 011: 3.9V; 1xx: 4.5V;                          |  |  |  |

See Power-on threshold value selection table below.

| Threshold Selection | LVDT              |                                    |       |            |  |  |  |  |  |
|---------------------|-------------------|------------------------------------|-------|------------|--|--|--|--|--|
| SEL LVDT VTH        | BOR threshold (V) | OB threads and (1) Reset threshold |       |            |  |  |  |  |  |
| SEL_LVD1_VIH        | BOR ITTESTION (V) | (V)                                | (mV)  | Delay (µs) |  |  |  |  |  |
| 000                 | 3.0               | 3.1                                | 98.92 | 6.622      |  |  |  |  |  |
| 001                 | 3.3               | 3.4                                | 120.5 | 7.639      |  |  |  |  |  |
| 010                 | 3.6               | 3.7                                | 105.9 | 8.536      |  |  |  |  |  |
| 011                 | 3.9               | 4.0                                | 84.09 | 9.594      |  |  |  |  |  |
| 1xx                 | 4.5               | 4.6                                | 108.9 | 11.32      |  |  |  |  |  |

Table 0.12Po threshold selection table

## 4.6.6 Test Clock Register (SFR\_TEST\_SEL1)

| Bit No.    | 7           | 6            | 5           | 4            |  |  |  |
|------------|-------------|--------------|-------------|--------------|--|--|--|
| Symbol     | -           | -            | TEST_XTAL_I | TEST_XTAL_EN |  |  |  |
| Read/Write | -           | -            | Read/Write  | Read/Write   |  |  |  |
| Po initial |             |              | 0           | 0            |  |  |  |
| value      | -           | -            | 0           | 0            |  |  |  |
| Bit No.    | 3           | 2            | 1           | 0            |  |  |  |
| Symbol     | TEST_CLK_EN | TEST_CLK_SEL |             |              |  |  |  |
| Read/Write | Read/Write  | Read/Write   |             |              |  |  |  |



| Po initial |   |                                       |
|------------|---|---------------------------------------|
| FUIIIIai   | 0 | 0                                     |
| value      | 0 | C C C C C C C C C C C C C C C C C C C |

| Bit No. | Symbol       | Description                                                 |
|---------|--------------|-------------------------------------------------------------|
|         |              | Oscillator bias current test.                               |
| 5       | TEST_XTAL_I  | 0: No test.                                                 |
|         |              | 1: Test.                                                    |
|         |              | Whether enable XTAL when selecting test clock output        |
|         |              | enable, the default value is 0.                             |
| 4       | TEST_XTAL_EN | 1: enable                                                   |
| 4       | TEST_XIAL_EN | 0: disable                                                  |
|         |              | Note: it is only valid when outputting the test clock       |
|         |              | (TEST_CLK_EN=1)                                             |
|         |              | Select if output test clock.                                |
| 3       | TEST CLK EN  | 1: output enable                                            |
| 5       |              | 0: output disable.                                          |
|         |              | The default value is 0.                                     |
|         |              | PA2/PA3 test at the same time.                              |
|         |              | 000: selects 1MHz oscillator clock (OSC_1M);                |
| 2~0     | TEST CLK SEL | 001: selects 32KHz oscillator clock (OSC_32k);              |
| 2.0     |              | 010: selects 2MHz clock (PLL_24M after frequency is divided |
|         |              | by 12)011: selects 1MHz oscillator clock (OSC_1M)           |
|         |              | 100: selects XTAL clock (XTAL frequency is divided by 32)   |

## 4.6.7 Sleep Control Register (PCON)

Address: 0x87

| Bit No.    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|------------|---|---|---|---|---|---|---|--------|
| Symbol     |   |   |   |   |   |   |   | SLEEP  |
| Symbol     | - | - | - | - | - | - | - | _MODE  |
| Read/Write |   |   |   |   |   |   |   | Read/W |
| Reau/White | - | - | - | - | - | - | - | rite   |
| Po initial |   |   |   |   |   |   |   | 0      |
| value      | - | - | - | - | - | - | - | 0      |

| Bit No. | Symbol    | Description                      |
|---------|-----------|----------------------------------|
| 7~1     |           | Reserved                         |
|         |           | SLEEP mode enable.               |
| 0       | 0 IDLE_EN | 1: the device enters SLEEP mode. |
|         |           | 0: the device exits SLEEP mode.  |

## 4.6.8 Clock control register (SYS\_CLK\_CFG)

XRAM\_SFR Address: 0x2028

| Bit No.             | 7 | 6 | 5 | 4 | 3 | 2          | 1      | 0      |
|---------------------|---|---|---|---|---|------------|--------|--------|
| Symbol              | - | - | - | - | - | WAIT_MODE  | PLL_CL | K_SEL  |
| Read/Write          | - | - | - | - | - | Read/Write | Read   | /Write |
| Po initial<br>value | - | - | - | - | - | 0          | 1      | 0      |

| Bit No. | Symbol      | Description                                  |  |  |  |  |
|---------|-------------|----------------------------------------------|--|--|--|--|
| 2       |             | WAIT mode enabled                            |  |  |  |  |
|         | WAIT_MODE   | 1: the device enters WAIT mode               |  |  |  |  |
|         |             | 0: the device exits WAIT mode                |  |  |  |  |
| 1 to 0  | PLL_CLK_SEL | PLL Clock frequency divider selects register |  |  |  |  |
|         |             | 00: 24MHz 01: 16MHz                          |  |  |  |  |
|         |             | 10: 12MHz 11: 8MHz                           |  |  |  |  |

# 4.6.9 LVDT Rising/Falling Voltage Interrupt Status Register (INT\_POBO\_STAT)

| Bit No.    | 7 | 6 | 5 | 4 | 3 | 2 | 1           | 0           |
|------------|---|---|---|---|---|---|-------------|-------------|
| Symbol     | - | - | - | - | - | - | INT_PO_STAT | INT_BO_STAT |
| Read/Write | - | - | - | - | - | - | Read/Write  | Read/Write  |
| Po initial |   |   |   |   |   |   | 0           | 0           |
| value      | - | - | - | - | - | - | 0           | 0           |

| Bit No. | Symbol      | Description                             |
|---------|-------------|-----------------------------------------|
| 1       | INT_PO_STAT | Lvdt rising voltage interrupt status    |
|         |             | 1: rising voltage interrupt is valid    |
|         |             | 0: rising voltage interrupt is invalid  |
| 0       | INT_BO_STAT | Lvdt falling voltage interrupt status   |
|         |             | 1: falling voltage interrupt is valid   |
|         |             | 0: falling voltage interrupt is invalid |



## 4.6.10 WDT Test Mode Register (WDT\_TEST\_EN)

XRAM\_SFR Address: 0x2060

| Bit No.             | 7 | 6 | 5 | 4 | 3 | 2 | 1          | 0          |
|---------------------|---|---|---|---|---|---|------------|------------|
| Symbol              | - | - | - | - | - | - |            |            |
| Read/Write          | - | - | - | - | - | - | Read/Write | Read/Write |
| Po initial<br>value | - | - | - | - | - | - | 0          | 0          |

| Bit No. | Symbol | Description                                           |
|---------|--------|-------------------------------------------------------|
| 1~0     |        | WDT test mode register                                |
|         |        | Set value 0x02 to configure WDT_CLK_SEL, other values |
|         |        | cannot configure the register.                        |

### 4.6.11 WDT Clock Selection Register (WDT\_CLK\_SEL)

XRAM\_SFR Address: 0x2061

| Bit No.             | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|---------------------|---|---|---|---|---|---|---|------------|
| Symbol              | - | - | - | - | - | - | - |            |
| Read/Write          | - | - | - | - | - | - | - | Read/Write |
| Po initial<br>value | - | - | - | - | - | - | - | 0          |

| Bit No. | Symbol | Description                                              |  |  |  |  |  |
|---------|--------|----------------------------------------------------------|--|--|--|--|--|
| 0       |        | WDT clock selection register                             |  |  |  |  |  |
|         |        | 0: selects the RC32KHz                                   |  |  |  |  |  |
|         |        | 1: selects the 24MHz clock ( only used for testing WDT ) |  |  |  |  |  |

#### 4.6.12 WDT Overflow Configuration Register (WDT\_CTRL)

| Bit No.             | 7 | 6 | 5 | 4 | 3 | 2  | 1          | 0 |
|---------------------|---|---|---|---|---|----|------------|---|
| Symbol              | - | - | - | - | - | WD | T_TIME_SEL |   |
| Read/Write          | - | - | - | - | - | F  | Read/Write |   |
| Po initial<br>value | - | - | - | - | - | 0  |            |   |



| Bit No. | Symbol       | Description                                   |
|---------|--------------|-----------------------------------------------|
| 2~0     | WDT_TIME_SEL | WDT overflow configuration register settings: |
|         |              | 0x00: 18ms; 0x01: 36ms;                       |
|         |              | 0x02: 72ms; 0x03: 144ms;                      |
|         |              | 0x04: 288ms; 0x05: 576ms;                     |
|         |              | 0x06: 1152ms; 0x07: 2304ms;                   |

WDT uses RC32768Hz to implement the timer function ranging from 18ms to 2.3s, of which time is controlled by WDT\_CTRL.

#### 4.6.13 WDT Enable Configuration Register (WDT\_EN)

XRAM\_SFR address: 0x2069

| Bit No.    | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
|------------|---|------------|---|---|---|---|---|---|--|--|--|--|
| Symbol     |   | WDT_EN     |   |   |   |   |   |   |  |  |  |  |
| Read/Write |   | Read/Write |   |   |   |   |   |   |  |  |  |  |
| Po initial |   |            |   |   |   |   |   |   |  |  |  |  |
| value      |   |            |   | ( | J |   |   |   |  |  |  |  |

| Bit No. | Symbol | Description                                                 |
|---------|--------|-------------------------------------------------------------|
| 7~0     | WDT_EN | WDT Enable configuration register: when the value is set as |
|         |        | 0x55, WDT is disabled.                                      |

Write 0x55 to disable the WDT, and write other values to enable it. WDT keeps working once reset. WDT clear is completed through writing WDT\_CTRL. No matter what value is written to this register, it will clear WDT.

## 4.6.14 WDT/Timer2 Interrupt Status Register (INT\_PE\_STAT)

Address: 0x91

| Bit No.             | 7 | 6 | 5 | 4 | 3 | 2 | 1            | 0               |
|---------------------|---|---|---|---|---|---|--------------|-----------------|
| Symbol              | - | - | - | - | - | - | INT_WDT_STAT | INT_TIMER2_STAT |
| Read/Write          | - | - | - | - | - | - | Read/Write   | Read/Write      |
| Po initial<br>value | - | - | - | - | - | - | 0            | 0               |

| Bit No. | Symbol       | Description                                          |  |  |  |  |  |  |  |  |
|---------|--------------|------------------------------------------------------|--|--|--|--|--|--|--|--|
| 1       | INT_WDT_STAT | WDT interrupt status flag bit: write 0 to clear; wri |  |  |  |  |  |  |  |  |
|         |              | WDT_CTRL can also clear.                             |  |  |  |  |  |  |  |  |
|         |              | 1: Valid Interrupt                                   |  |  |  |  |  |  |  |  |



|   |                 | 0: Invalid Interrupt                                |
|---|-----------------|-----------------------------------------------------|
| 0 | INT_TIMER2_STAT | TIMER2 interrupt status flag bit: write 0 to clear; |
|   |                 | Write TIMER2_CFG can also to clear.                 |
|   |                 | 1: valid interrupt                                  |
|   |                 | 0: Invalid Interrupt                                |



## 5 GPIO

## 5.1 Description

Some pins of GPIO lines multiplex the peripherals functions of the device. It can not be configured with many functions at the same time, otherwise it causes functional chaos. IIC with open drain output, requires an external pull-up resistor.

The pull-up and pull-down resistance value are 10K for all I/Os.



Figure 0.1 SNS IO Structure





Figure 0.2 IO with Open Drain Output Structure

**TRISX (direction register):** TRISX set 1 to configure the corresponding pin as input, while set 0 to configure that as output.

**DATAX\_IN (data input register):** Read-only. The read value represents the current level of the present I/O (input).

**DATAX\_OUT (data output register):** configure the output current level when I/O of PX group as GPIO, which reads out the configuration output value.

**PULLUP\_PX (pull-up resistor enable register):** PULLUP\_PX set 1 to enable the pull-up resistor on the corresponding pin, set 0 to disable that.

**PULLDOWN\_PX (pull-down resistor enable register):** PULLDOWN\_PX set 1 to enable the pulldown resistor on the corresponding pin, set 0 to disable that.

**ODRAIN\_EN:** ODRAIN\_EN set 1 to enable the open drain output on the corresponding pin, set 0 to disable that function. After enabling IIC, it automatically turn on the open drain output. It is recommended to use external pull-up resistor for IIC/UART.



## 5.2 **GPIO Registers**

#### 5.2.1 Data Registers

#### 5.2.1.1 PA Data Input Register (DATAA\_IN)

Address: 0x84

| Bit No.             | 7 | 6 | 5     | 4     | 3     | 2     | 1     | 0     |
|---------------------|---|---|-------|-------|-------|-------|-------|-------|
| Symbol              | - | - | PA5   | PA4   | PA3   | PA2   | PA1   | PA0   |
| Read/Write          | - | - | Read  | Read  | Read  | Read  | Read  | Read  |
| Po Initial<br>Value | - | - | state | state | state | state | state | state |

| Bit No. | Symbol | Description                                                    |
|---------|--------|----------------------------------------------------------------|
| 5~0     |        | PA data input register.                                        |
|         |        | Read-out value is the current level of the present IO (input). |

PA data register always reads out 1 for sensor/adc functions; for other functions, it reads out the current level of PAD.

#### 5.2.1.2 PB Data Input Register(DATAB\_IN)

Address: 0x85

| Bit No.    | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Symbol     | PB7   | PB6   | PB5   | PB4   | PB3   | PB2   | PB1   | PB0   |
| Read/Write | Read  |
| Po Initial | state |
| Value      |       |       |       |       |       |       |       |       |

| Bit No. | Symbol | Description                                                    |
|---------|--------|----------------------------------------------------------------|
| 7~0     |        | PB data input register.                                        |
|         |        | Read-out value is the current level of the present IO (input). |

PB data input register always reads out 1 for sensor/adc functions; for other functions, it reads out the current level of PBD.



#### 5.2.1.3 PC Data Input Register (DATAC\_IN)

Address: 0x86

| Bit No.    | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Symbol     | PC7   | PC6   | PC5   | PC4   | PC3   | PC2   | PC1   | PC0   |
| Read/Write | Read  |
| Po Initial | state |
| Value      |       |       |       |       |       |       |       |       |

| Bit No. | Symbol | Description                                                    |
|---------|--------|----------------------------------------------------------------|
| 7~0     |        | PC data input register.                                        |
|         |        | Read-out value is the current level of the present IO (input). |

PC data input register always reads out 1 for sensor/adc functions; for other functions, it reads out the current level of PCD.

#### 5.2.1.4 PD Data Input Register (DATAD\_IN)

Address: 0x8E

| Bit No.    | 7 | 6 | 5 | 4     | 3     | 2     | 1     | 0     |
|------------|---|---|---|-------|-------|-------|-------|-------|
| Symbol     | - | - | - | PD4   | PD3   | PD2   | PD1   | PD0   |
| Read/Write | - | - | - | Read  | Read  | Read  | Read  | Read  |
| Po Initial |   |   |   | state | state | state | state | state |
| Value      | - | - | - |       |       |       |       |       |

|   | Bit No. | Symbol | Description                                                    |
|---|---------|--------|----------------------------------------------------------------|
| ſ | 4~0     |        | PD data input register.                                        |
|   |         |        | Read-out value is the current level of the present IO (input). |

PD data input register always reads out 1 for sensor/adc functions; for other functions, it reads out the current level of PDD.

#### 5.2.1.5 PA Data Output Register (DATAA\_OUT)

Address: 0xB0

| Bit No.   | 7 | 6 | 5         | 4         | 3         | 2         | 1         | 0         |
|-----------|---|---|-----------|-----------|-----------|-----------|-----------|-----------|
| Symbol    | - | - | PA5       | PA4       | PA3       | PA2       | PA1       | PA0       |
| Read/Writ | _ | _ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ |
| е         | - | - | е         | е         | е         | е         | е         | е         |



| Po Initial |   |   | 0 | 0 | 0 | 0 | 0 | 0 |
|------------|---|---|---|---|---|---|---|---|
| Value      | - | - | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit No. | Symbol | Description                                                                                                                                 |
|---------|--------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 5~0     |        | PA data output register.<br>Configure the output current level of PA group IOs as GPIOs,<br>which reads out the configuration output value. |

#### 5.2.1.6 PB Data Output Register (DATAB\_OUT)

Address: 0x80

| Bit No.             | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
|---------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Symbol              | PB7       | PB6       | PB5       | PB4       | PB3       | PB2       | PB1       | PB0       |
| Read/Writ           | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ |
| е                   | е         | е         | е         | е         | е         | е         | е         | е         |
| Po Initial<br>Value | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |

| Bit No. | Symbol | Description                                                  |
|---------|--------|--------------------------------------------------------------|
| 7~0     |        | PB data output register.                                     |
| 7~0     |        | Configure the output current level of PB group IOs as GPIOs, |
|         |        | which reads out the configuration output value.              |

#### 5.2.1.7 PC Data Output Register (DATAC\_OUT)

Address: 0x90

| Bit No.             | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
|---------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Symbol              | PC7       | PC6       | PC5       | PC4       | PC3       | PC2       | PC1       | PC0       |
| Read/Writ           | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ |
| е                   | е         | е         | е         | е         | е         | е         | е         | е         |
| Po Initial<br>Value | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |

| Bit No. | Symbol | Description                                                                                                                                 |
|---------|--------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 7~0     |        | PC data output register.<br>Configure the output current level of PC group IOs as GPIOs,<br>which reads out the configuration output value. |



#### 5.2.1.8 PD Data Output Register (DATAD\_OUT)

Address: 0x98

| Bit No.             | 7 | 6 | 5 | 4          | 3          | 2          | 1          | 0          |
|---------------------|---|---|---|------------|------------|------------|------------|------------|
| Symbol              | - | - | - | PD4        | PD3        | PD2        | PD1        | PD0        |
| Read/Write          | - | - | - | Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | - | - | - | 0          | 0          | 0          | 0          | 0          |

| Bit No. | Symbol | Description                                                                                                                                 |
|---------|--------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 4~0     |        | PD data output register.<br>Configure the output current level of PD group IOs as GPIOs,<br>which reads out the configuration output value. |

#### 5.2.2 Output Control Hold Register When Reset (PD\_HOLD\_EN)

XRAM\_SFR Address: 0x202F

| Bit No.    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|------------|---|---|---|---|---|---|---|------------|
| Symbol     | - | - | - | - | - | - | - | -          |
| Read/Write | - | - | - | - | - | - | - | Read/Write |
| Po Initial | - | - | - | - | - | - | - | 0          |
| Value      |   |   |   |   |   |   |   | 0          |

| Bit No. | Symbol | Description                                      |
|---------|--------|--------------------------------------------------|
|         |        | Whether DATAD_OUT/TRISD holds output when reset. |
| 0       |        | 1: reset configuration holding                   |
|         |        | 0: reset configuration failure                   |

#### 5.2.3 Direction Registers

#### 5.2.3.1 PA Direction Register(TRISA)

| Bit No.    | 7 | 6 | 5          | 4          | 3          | 2          | 1          | 0          |
|------------|---|---|------------|------------|------------|------------|------------|------------|
| Symbol     | - | - | PA5        | PA4        | PA3        | PA2        | PA1        | PA0        |
| Read/Write | - | - | Read/Write | Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial | - | - | 1          | 1          | 1          | 1          | 1          | 1          |



|       |  |  |  | <br>• • • • • • • • • • • • • • • • • • • • |
|-------|--|--|--|---------------------------------------------|
|       |  |  |  |                                             |
| Value |  |  |  |                                             |

| Bit No. | Symbol | Description            |  |  |  |
|---------|--------|------------------------|--|--|--|
| 5~0     |        | PA direction register. |  |  |  |
|         |        | 0: output              |  |  |  |
|         |        | 1: input               |  |  |  |

#### 5.2.3.2 PB Direction Register (TRISB)

XRAM\_SFR Address: 0x2031

| Bit No.             | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
|---------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Symbol              | PB7       | PB6       | PB5       | PB4       | PB3       | PB2       | PB1       | PB0       |
| Read/Writ           | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ |
| е                   | е         | е         | е         | е         | е         | е         | е         | е         |
| Po Initial<br>Value | 1         | 1         | 1         | 1         | 1         | 1         | 1         | 1         |

| Bit No. | Symbol | Description            |
|---------|--------|------------------------|
| 7~0     |        | PB direction register. |
|         |        | 0: output              |
|         |        | 1: input               |

#### 5.2.3.3 PC Direction Register (TRISC)

XRAM\_SFR Address: 0x2032

| Bit No.             | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
|---------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Symbol              | PC7       | PC6       | PC5       | PC4       | PC3       | PC2       | PC1       | PC0       |
| Read/Writ           | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ |
| е                   | е         | е         | е         | е         | е         | е         | е         | е         |
| Po Initial<br>Value | 1         | 1         | 1         | 1         | 1         | 1         | 1         | 1         |

| Bit No. | Symbol | Description            |
|---------|--------|------------------------|
| 7~0     |        | PC direction register. |
|         |        | 0: output              |
|         |        | 1: input               |

## 5.2.3.4 PD Direction Register (TRISD)



| Bit No.             | 7 | 6 | 5 | 4          | 3          | 2          | 1          | 0          |
|---------------------|---|---|---|------------|------------|------------|------------|------------|
| Symbol              | - | - | - | PD4        | PD3        | PD2        | PD1        | PD0        |
| Read/Write          | - | - | - | Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | - | - | - | 1          | 1          | 1          | 1          | 1          |

| Bit No. | Symbol | Description            |
|---------|--------|------------------------|
| 4~0     |        | PD direction register. |
|         |        | 0: output              |
|         |        | 1: input               |

## 5.2.4 Pull-up Resistor Enable Registers

#### 5.2.4.1 PA Pull-up Resistor Control Register (PULLUP\_PA)

XRAM\_SFR Address: 0x2034

| Bit No.             | 7 | 6 | 5          | 4          | 3          | 2          | 1          | 0          |
|---------------------|---|---|------------|------------|------------|------------|------------|------------|
| Symbol              | - | - | PA5        | PA4        | PA3        | PA2        | PA1        | PA0        |
| Read/Write          | - | - | Read/Write | Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | - | - | 0          | 0          | 0          | 0          | 0          | 0          |

| Bit No. | Symbol | Description                                |
|---------|--------|--------------------------------------------|
|         |        | PA port pull-up resistor control register. |
| 5~0     |        | 1: Enabled                                 |
|         |        | 0: Disabled                                |

#### 5.2.4.2 PB Pull-up Resistor Control Register (PULLUP\_PB)

| Bit No.    | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Symbol     | PB7       | PB6       | PB5       | PB4       | PB3       | PB2       | PB1       | PB0       |
| Read/Writ  | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ |
| е          | е         | е         | е         | е         | е         | е         | е         | е         |
| Po Initial | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |
| Value      |           |           |           |           |           |           |           |           |



| Bit No. | Symbol | Description                                                             |
|---------|--------|-------------------------------------------------------------------------|
| 7~0     |        | PB port pull-up resistor control register.<br>1: Enabled<br>0: Disabled |

#### 5.2.4.3 PC Pull-up Resistor Control Register (PULLUP\_PC)

XRAM\_SFR Address: 0x2036

| Bit No.    | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Symbol     | PC7       | PC6       | PC5       | PC4       | PC3       | PC2       | PC1       | PC0       |
| Read/Writ  | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ |
| е          | е         | е         | е         | е         | е         | е         | е         | е         |
| Po Initial | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |
| Value      |           |           |           |           |           |           |           |           |

| Bit No. | Symbol | Description                                |
|---------|--------|--------------------------------------------|
| 7~0     |        | PC port pull-up resistor control register. |
|         |        | 1: Enabled                                 |
|         |        | 0: Disabled                                |

#### 5.2.4.4 PD Pull-up Resistor Control Register (PULLUP\_PD)

| Bit No.             | 7 | 6 | 5 | 4          | 3          | 2          | 1          | 0          |
|---------------------|---|---|---|------------|------------|------------|------------|------------|
| Symbol              | - | - | - | PD4        | PD3        | PD2        | PD1        | PD0        |
| Read/Write          | - | - | - | Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | - | - | - | 0          | 0          | 0          | 0          | 0          |

| Bit No. | Symbol | Description                                                             |
|---------|--------|-------------------------------------------------------------------------|
| 4~0     |        | PD port pull-up resistor control register.<br>1: Enabled<br>0: Disabled |



#### 5.2.5 Pull-down Resistor Enable Registers

#### 5.2.5.1 PA Pull-down Resistor Control Register (PULLDOWN\_PA)

| Bit No.             | 7 | 6 | 5          | 4          | 3          | 2          | 1          | 0          |
|---------------------|---|---|------------|------------|------------|------------|------------|------------|
| Symbol              | - | - | PA5        | PA4        | PA3        | PA2        | PA1        | PA0        |
| Read/Write          | - | - | Read/Write | Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | - | - | 0          | 0          | 0          | 0          | 0          | 0          |

XRAM\_SFR Address: 0x2038

| Bit No. | Symbol | Description                                                          |
|---------|--------|----------------------------------------------------------------------|
| 5~0     |        | PA pull-down resistor control register.<br>1: Enabled<br>0: Disabled |

#### 5.2.5.2 PB Pull-down Resistor Control Register (PULLDOWN\_PB)

XRAM\_SFR Address: 0x2039

| Bit No.    | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Symbol     | PB7       | PB6       | PB5       | PB4       | PB3       | PB2       | PB1       | PB0       |
| Read/Writ  | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ |
| е          | е         | е         | е         | е         | е         | е         | е         | е         |
| Po Initial | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |
| Value      |           |           |           |           |           |           |           |           |

| Bit No. | Symbol | Description                             |
|---------|--------|-----------------------------------------|
|         |        | PB pull-down resistor control register. |
| 7~0     |        | 1: Enabled                              |
|         |        | 0: Disabled                             |

#### 5.2.5.3 PC Pull-down Resistor Control Register (PULLDOWN\_PC)

| Bit No.   | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Symbol    | PC7       | PC6       | PC5       | PC4       | PC3       | PC2       | PC1       | PC0       |
| Read/Writ |



|            |   |   |   |   |   |   |   | ••••••• |
|------------|---|---|---|---|---|---|---|---------|
| е          | е | е | е | е | е | е | е | е       |
| Po Initial | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0       |
| Value      |   |   |   |   |   |   |   |         |

| Bit No. | Symbol | Description                                                          |
|---------|--------|----------------------------------------------------------------------|
| 7~0     |        | PC pull-down resistor control register.<br>1: Enabled<br>0: Disabled |

#### 5.2.5.4 PD Pull-down Resistor Control Register (PULLDOWN\_PD)

XRAM\_SFR Address: 0x203B

| Bit No.             | 7 | 6 | 5 | 4          | 3          | 2          | 1          | 0          |
|---------------------|---|---|---|------------|------------|------------|------------|------------|
| Symbol              | - | - | - | PD4        | PD3        | PD2        | PD1        | PD0        |
| Read/Write          | - | - | - | Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | - | - | - | 0          | 0          | 0          | 0          | 0          |

| Bit No. | Symbol | Description                                                          |
|---------|--------|----------------------------------------------------------------------|
| 4~0     |        | PD pull-down resistor control register.<br>1: Enabled<br>0: Disabled |

## 5.2.6 Open Drain Output Enable Register(ODRAIN\_EN)

| Bit No.             | 7 | 6 | 5 | 4 | 3          | 2          | 1          | 0          |
|---------------------|---|---|---|---|------------|------------|------------|------------|
| Symbol              | - | - | - | - | -          | -          | -          | -          |
| Read/Write          | - | - | - | - | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | - | - | - | - | 0          | 0          | 0          | 0          |

| Bit No. | Symbol | Description                            |
|---------|--------|----------------------------------------|
|         |        | PA1 Open Drain Output Enable Register. |
| 3       |        | 1: Open drain output                   |
|         |        | 0: CMOS output                         |
|         |        | PA2 Open Drain Output Enable Register. |
| 2       |        | 1: Open drain output                   |
|         |        | 0: CMOS output                         |



|   | PB6 Open Drain Output Enable Register. |
|---|----------------------------------------|
| 1 | <br>1: Open drain output               |
|   | 0: CMOS output                         |
|   | PB7 Open Drain Output Enable Register. |
| 0 | 1: Open drain output                   |
|   | 0: CMOS output                         |

## 5.3 I/O Multiplexing Tables

#### 5.3.1 SPI I/O Multiplexing (SPI\_IO\_SEL)

XRAM\_SFR address: 0x2044

| Bit No. | Symbol      | I/O Description        | I/O Multiplexing |
|---------|-------------|------------------------|------------------|
| 7~4     |             |                        |                  |
| 3       | MISO_IO_SEL | SPI master input       | MISO selection   |
|         |             |                        | 0: PA2; 1: PC3   |
| 2       | MOSI_IO_SEL | SPI master output      | MOSI selection   |
|         |             |                        | 0: PA1; 1: PC4   |
| 1       | SCK_IO_SEL  | SPI clock line         | SCK selection    |
|         |             |                        | 0: PA3; 1: PC2   |
| 0       | CS_IO_SEL   | SPI chip select signal | CS selection     |
|         |             |                        | 0: PD0; 1:PC5    |

#### 5.3.2 UART I/O Multiplexing (UART\_IO\_SEL)

| Bit No. | Symbol       | I/O Description      | I/O Multiplexing    |
|---------|--------------|----------------------|---------------------|
| 7~6     |              |                      |                     |
| 5~3     | UART_RXD_SEL | Transmit Serial Data | UART_RXD Selection  |
|         |              |                      | 0: PA2;             |
|         |              |                      | 1: PB1;             |
|         |              |                      | 2: PB5;             |
|         |              |                      | 3: PB7;             |
|         |              |                      | 4: PC1              |
| 2~0     | UART_TXD_SEL | Transmit Serial Data | UART_TXD selection: |
|         |              |                      | 0: PA1;             |
|         |              |                      | 1: PB2;             |



| 2: PB4; |
|---------|
| 3: PB6; |
| 4: PC0  |

## 5.3.3 SCI I/O Multiplexing (SCI\_IO\_SEL)

XRAM\_SFR address: 0x2046

| Bit No. | Symbol      | I/O Description | I/O Multiplexing                |
|---------|-------------|-----------------|---------------------------------|
| 7~6     |             |                 |                                 |
| 5~3     | SCI_RXD_SEL | SCI receive     | SCI_RXD selection               |
|         |             |                 | 0: PA2; 1: PB1; 2: PB5; 3: PB7; |
|         |             |                 | 4: PC1                          |
| 2~0     | SCI_TXD_SEL | SCI transmit    | SCI_TXD selection               |
|         |             |                 | 0: PA1; 1: PB2; 2: PB4; 3: PB6; |
|         |             |                 | 4: PC0                          |

#### 5.3.4 PWM I/O Multiplexing

■ PWM\_IO\_SEL0

XRAM\_SFR address: 0x2047

| Bit | Symbol     | I/O Description             | I/O Multiplexing       |
|-----|------------|-----------------------------|------------------------|
| No. |            |                             |                        |
| 7   | PWM_ETR_EN | PWM External Trigger Enable | PWM_ETR I/O Enable     |
|     |            |                             | 0: Disable; 1: Enable  |
| 6   | PWM_ETR    | PWM External Trigger        | PWM_ETR Selection      |
|     |            |                             | 0: PA3; 1: PD4         |
| 5~4 | PWM0_CH3_S | PWM0 Channel 2              | PWM0_CH3 selection     |
|     | EL         |                             | 0: PD4; 1: PB2; 2: PC4 |
| 3~2 | PWM0_CH2_S | PWM0 Channel 1              | PWM0_CH2 selection     |
|     | EL         |                             | 0: PB0; 1: PB6; 2: PC6 |
| 1~0 | PWM0_CH1_S | PWM0 Channel 0              | PWM0_CH1 selection     |
|     | EL         |                             | 0: PB1; 1: PB7; 2: PC7 |

#### PWM\_IO\_SEL1

| Bit No. | Symbol     | I/O Description      | I/O Multiplexing |
|---------|------------|----------------------|------------------|
| 7       | PWM_BRK_EN | PWM Break I/O Enable | PWM_BRK Enable   |



|     |              |                    | 0: Disable; 1: Enable  |
|-----|--------------|--------------------|------------------------|
| 6~5 | PWM_BRK      | PWM Break I/O      | PWM_BRK selection      |
|     |              |                    | 0: PA1; 1: PB0; 2: PC6 |
| 4   | PWM0_CH3N_SE | PWM0 Complementary | PWM0_CH3N selection    |
|     | L            | Channel 2          | 0: PA5; 1: PD3         |
| 3   | PWM0_CH2N_SE | PWM0 Complementary | PWM0_CH2N selection    |
|     | L            | Channel 2          | 0: PA4; 1: PD2         |
| 2   | PWM0_CH1N_SE | PWM0 Complementary | PWM0_CH1N selection    |
|     | L            | Channel 2          | 0: PD1; 1: PB5         |
| 1   | PWM1_CH2_SEL | PWM1Channel 1      | PWM1_CH2 selection     |
|     |              |                    | 0: PD1; 1: PC2         |
| 0   | PWM1_CH1_SEL | PWM1Channel 0      | PWM1_CH1 selection     |
|     |              |                    | 0: PA3; 1: PD0         |

## 5.3.5 IIC I/O Multiplexing (IIC\_IO\_SEL)

| Bit No. | Symbol         | I/O Description      | I/O Multiplexing                        |
|---------|----------------|----------------------|-----------------------------------------|
| 7~4     |                |                      |                                         |
| 3       | IIC_AFIL_SEL   | IIC Analog Filter    | IIC I/O analog filter selection         |
|         |                |                      | enable                                  |
|         |                |                      | 1: Select Analog Filter;                |
|         |                |                      | 0: Do not select Analog filter          |
| 2       | IIC_DFIL_SEL   | IIC Digital Filter   | IIC I/O Digital filter selection enable |
|         |                |                      | 1: Select digital filter;               |
|         |                |                      | 0: Do not select digital filter.        |
| 1       | 'IICSDA_IO_SEL | IIC serial data line | IIC_SDA selection                       |
|         |                |                      | 0: PA1; 1: PB6                          |
| 0       | 'IICSCL_IO_SEL | IIC serial data line | IIC_SCL Selection                       |
|         |                |                      | 0: PA2; 1: PB7                          |



# 5.4 GPIO Configuration Flow Diagram

To configure IOs as GPIO requires corresponding settings for the 3 registers below.



Figure 0.4 IO Configuration Flow Diagram

Note:

By default, the typical I/O current driver is 15mA and the sink current driver is 50mA @5V VCC.



# 6 Interrupt

The system has 18 interrupts, such as IIC(S), External Interrupt0, External Interrupt1, External Interrupt2, External Interrupt3, Timer0, Timer1, Timer2, RTC, UART, SCI, CSD, ADC, LVDT, INT\_WDT, SPI, PWM and PWM1. INT\_WDT and Timer2 are multiplexed with one interrupt request flag, which can be set from software or hardware.



# 6.1 Interrupt Sources and Entries

When the MCU generates a reset signal, the program begins to execute from 0x0000. When an interrupt signal is generated, the program jumps to the address of interrupt vector routine to execute the interrupt service routine.

| Interrup<br>t<br>Sources | Conditions                                                                                         | Interruj | ot Flag           | Enable<br>Control | Priority<br>control | Interrupt<br>vector<br>address | Trigge<br>r Type | Interrup<br>t No. | Flag<br>Clear<br>Method       | Wake up<br>Iow<br>consumptio<br>n |
|--------------------------|----------------------------------------------------------------------------------------------------|----------|-------------------|-------------------|---------------------|--------------------------------|------------------|-------------------|-------------------------------|-----------------------------------|
| INTO                     | External<br>interrupt 0<br>current level<br>means the<br>configuratio<br>n of Trigger<br>Polarity. | IE0      | TCO<br>N[1]       | IEN0[0]           | IPL0[0]             | 0x0003                         | Falling<br>edge  | 0                 | Must be<br>cleared<br>by user | YES                               |
| Timer0                   | Timer0<br>Overflow                                                                                 | TF0      | TCO<br>N[5]       | IEN0[1]           | IPL0[1]             | 0x000B                         | High<br>level    | 1                 | Must be<br>cleared<br>by user | NO                                |
| INT1                     | External<br>interrupt 1<br>current level<br>means the<br>configuratio<br>n of Trigger<br>Polarity. | IE1      | TCO<br>N[3]       | IEN0[2]           | IPL0[2]             | 0x0013                         | Falling<br>edge  | 2                 | Must be<br>cleared<br>by user | YES                               |
| Timer1                   | Timer1<br>overflow                                                                                 | TF1      | ТСО<br>N[7]       | IEN0[3]           | IPL0[3]             | 0x001B                         | High<br>level    | 3                 | Must be<br>cleared<br>by user | NO                                |
| INT2                     | External<br>interrupt 2<br>current level<br>means the<br>configuratio<br>n of Trigger<br>Polarity. | IE2      | IRC<br>ON1<br>[2] | IEN1[2]           | IPL1[2]             | 0x004B                         | Falling<br>edge  | 9                 | Must be<br>cleared<br>by user | YES                               |
| INT3                     | External<br>interrupt 3<br>current level<br>means the                                              | IE3      | IRC<br>ON1<br>[3] | IEN1[3]           | IPL1[3]             | 0x0053                         | Falling<br>edge  | 10                | Must be<br>cleared<br>by user | YES                               |

# Semiconductor



|        | ı            |             | 1   |         | I       |         | <u> </u> |         | 23000   | HIVIXX  |    |
|--------|--------------|-------------|-----|---------|---------|---------|----------|---------|---------|---------|----|
|        | configuratio |             |     |         |         |         |          |         |         |         |    |
|        | n of Trigger |             |     |         |         |         |          |         |         |         |    |
|        | Polarity.    |             |     |         |         |         |          |         |         |         |    |
|        | ADC          |             | IRC |         |         |         | Falling  |         | Must be |         |    |
| ADC    | conversion   | IE4         | ON1 | IEN1[4] | IPL1[4] | 0x005B  | -        | 11      | cleared | YES     |    |
|        | completed    |             | [4] |         |         |         | edge     |         | by user |         |    |
|        |              |             | IRC |         |         |         |          |         | Must be |         |    |
| CSD    | Conversion   | IE5         | ON1 | IEN1[5] | IPL1[5] | 0x0063  | Falling  | 12      | cleared | YES     |    |
|        | completed    |             | [5] |         |         |         | edge     |         | by user |         |    |
|        | <b>_</b>     |             | IRC |         |         |         |          |         | Must be |         |    |
| SPI    |              | Received or | IE6 | ON1     | IEN1[6] | IPL1[6] | 0x006B   | Falling | 13      | cleared | NO |
|        | transmitted  | smitted     | [6] |         |         |         | edge     |         | by user |         |    |
|        |              |             | IRC |         |         |         |          |         | Must be |         |    |
| WDT/   | WDT/Timer2   | IE7         | ON1 | IEN1[7] | IPL1[7] | 0x0073  | Falling  | 14      | cleared | YES     |    |
| Timer2 | overflow     |             | [7] |         |         |         | edge     |         | by user |         |    |
|        |              |             | IRC |         |         |         |          |         | Must be |         |    |
| LVDT   | VCC lower    | IE8         | ON2 | IEN2[0] | IPL2[0] | 0x007B  | Falling  | 15      | cleared | YES     |    |
|        | than LVDT    |             | [0] |         |         |         | edge     |         | by user |         |    |
|        | Received or  |             | IRC |         |         |         |          |         | Must be |         |    |
| UART   | transmitted  | IE9         | ON2 | IEN2[1] | IPL2[1] | 0x0083  | Falling  | 16      | cleared | YES     |    |
|        | and error    | -           | [1] |         |         |         | edge     | -       | by user |         |    |
|        | Received or  |             | IRC |         |         |         |          | 17      | Must be |         |    |
| SCI    | transmitted  | IE10        | ON2 | IEN2[2] | IPL2[2] | 0x008B  | Falling  |         | cleared | YES     |    |
| -      | and error    | -           | [2] |         |         |         | edge     |         | by user |         |    |
|        |              |             | IRC |         |         | 0x0093  |          |         | Must be |         |    |
| RTC    | RTC          | RTC IE11    | ON2 |         | IPL2[3] |         | Falling  | 18      | cleared | YES     |    |
| _      | overflow     |             | [3] |         |         |         | edge     |         | by user |         |    |
|        |              |             | [0] |         |         |         |          |         |         |         |    |
|        |              |             | IRC |         |         |         |          |         |         |         |    |
|        | PWM0         |             |     |         |         |         |          |         |         |         |    |
|        | Overflow,    |             |     |         |         |         |          |         | Must be |         |    |
| PWM0   | output       | IE12        | ON2 | IEN2[4] | IPL2[4] | 0x009B  | Falling  | 19      | cleared | YES     |    |
| 1 1110 | compare,     |             |     |         |         | 0,0030  | edge     | 15      | by user | TL0     |    |
|        | input        |             |     |         |         |         |          |         | by user |         |    |
|        | capture      |             | [4] |         |         |         |          |         |         |         |    |
|        |              |             | [4] |         |         |         |          |         |         |         |    |
|        | PWM1         |             |     |         |         |         |          |         |         |         |    |
|        | Overflow,    |             |     |         |         |         |          |         |         |         |    |
|        | output       |             | IRC |         |         |         | Falling  |         | Must be |         |    |
| PWM1   | compare,     | IE13        | ON2 | IEN2[5] | IPL2[5] | 0x00A3  | edge     | 20      | cleared | YES     |    |
|        | input        |             | [5] |         |         |         | Cuye     |         | by user |         |    |
|        | capture      |             |     |         |         |         |          |         |         |         |    |
| L      | capiule      |             |     |         |         |         |          |         |         |         |    |



|    |    | Slave       |      |     |         |         |        |         |    |         |     |
|----|----|-------------|------|-----|---------|---------|--------|---------|----|---------|-----|
|    |    | address     |      | IRC |         |         |        | Falling |    | Must be |     |
| II | IC | match,      | IE14 | ON2 | IEN2[6] | IPL2[6] | 0x00AB |         | 21 | cleared | YES |
|    |    | Received or |      | [6] |         |         |        | edge    |    | by user |     |
|    |    | transmitted |      |     |         |         |        |         |    |         |     |

Table 0.1 Interrupt Information

WDT and Timer2 both use this interrupt number, which can be distinguished by interrupt flag.

# 6.2 Interrupt Functions

### 6.2.1 Interrupt Response

When an interrupt request is generated, CPU determines the kind of interrupt according to the interrupt service routine (ISR) and executes ISR completely, unless an interrupt source with higher priority level requests the interrupt. After each ISR, there is a return from interrupt command (RETI). CPU executes RETI command, then continues to execute the program before the interrupt. ISR can only be requested by an interrupt with higher priority level, which means low priority ISR will

be requested to interrupt by high priority interrupt.

BS9000AMxx responses to interrupt request only after executing the present command. If the present command is RETI or accessing IPL and IEN registers, it requires to execute another more instruction before responding to the interrupt request.

### 6.2.2 Interrupt Handling

Each interrupt source can be individually enabled/disabled through the interrupt enable register. Besides, interrupt request has its own flag bit register, which can trigger interrupt not only by hardware but also via software writing.

BS9000AMxx has two interrupt priority levels, including interrupt level and default priority level. Interrupt level (including highest level, high level and low level) is prior to the default priority level.

Before CPU enters ISR, the default selection of many interrupt sources is decided by natural priority level. Generally, lower bits of interrupt enable registers have a higher priority level. When programmed as higher priority level, these bits will be handled first by the interrupt source, even though others may have a higher natural priority. This means programmed priority level is higher than natural priority level. When the programmed priority levels are the same, it is up to natural priority level to decide the interrupt execution order.

Some interrupt flag bits will be cleared automatically by software after the interrupt response, including Timer0/1 and all external interrupt sources. Other interrupt request flag bits must be cleared by software in the ISR.

CPU has a very short interrupt response time. It takes CPU 2 clock cycles from interrupt request flagged to the start of the execution of ISR.



### 6.2.3 Interrupt Sampling

Internal modules such as internal timer and serial data generate the interrupt request through their own interrupt flag bit in SFR. When the first clock period (C1) of each instruction cycle completes, it begins to sample for external interrupt on the rising edge of the clock.

To ensure that edge-triggered interrupts are detected, the corresponding port is first kept high for two clocks

To ensure that edge-triggered interrupts are detected, the corresponding port is first kept high for two clocks, then another 2 cycles' low level. The diagram below is the time sequence for interrupt sampling.

The interrupt response time is decided by the present status of system. The fastest response time is 5 instruction cycles: 1 cycle for detecting interrupt request and the other 4 cycles for executing LCALL into ISR.

When system executes RETI command and the MUL or DIV command is waiting in line, it has the longest waiting time, which is 13 instruction cycles, including 1 cycle for detecting interrupt request, 3 cycles for completing RETI command, 5 for DIV or MUL command and 4 for LCALL into ISR. In this case, the response time is 13 clock cycles.

# 6.3 Interrupt Wakeup

In wait mode, analog clock is not off, only disable F\_sys\_clk to achieve low consumption mode. In this mode, modules Timer0/1, SPI and CPU do not work, but other modules can be configured to work, which can be waken up by any kinds of interrupt (including int\_wdt) except Timer0/1 and SPI. After the wake-up, CPU can work directly.

In sleep mode, disable OSC1M, PLL and other analog modules to save the power, which can be waken up by interrupts such as int\_wdt, int\_Timer2, int\_rtc, int\_ext0, int\_ext1, int\_ext2, int\_ext3, int\_ic, int\_sci or reset.

If many interrupts occurs in the sleep mode, enable the clock at the first interrupt, wait for the clock to be stable and then transmit the interrupt signals to MCU at the same time. After the MCU exits sleep mode, it responds to interrupts in the order of interrupt priority.

#### Notes:

- The command that configures CPU to enter sleep mode needs not to be conducted with interrupt trigger at the same time, otherwise the command to enter sleep mode will be neglected. It is recommended to use if statement to decide whether to enter sleep mode. Concurrently, after exiting sleep mode, wait at least for 50us, then configure to enter sleep mode again.
- 2. During the waiting for wake-up, it requires a interrupt signal length longer than 6 cycles of PLL\_24Mhz plus 1 cycle of F\_sys\_clk, otherwise the interrupt signal may be neglected.



# 6.4 Interrupt Registers

# 6.4.1 Interrupt Enable Register 0(IEN0)

Address: 0xA8

| Bit No.    | 7     | 6 | 5     | 4 | 3     | 2     | 1     | 0     |
|------------|-------|---|-------|---|-------|-------|-------|-------|
| Symbol     | EA    | - | ET2   | - | ET1   | EX1   | ET0   | EX0   |
| Read/      | Read/ |   | Read/ |   | Read/ | Read/ | Read/ | Read/ |
| Write      | Write | - | Write | - | Write | Write | Write | Write |
| Po Initial | 0     |   | 0     |   | 0     | 0     | 0     | 0     |
| Value      | 0     | - | 0     | - |       |       |       |       |

| Bit No. | Symbol | Description                                                                  |  |  |  |  |  |  |
|---------|--------|------------------------------------------------------------------------------|--|--|--|--|--|--|
|         |        | Interrupt Permit bit.                                                        |  |  |  |  |  |  |
|         |        | 0: Mask all interrupts (EA is prior to the interrupt enable bit of interrupt |  |  |  |  |  |  |
| 7       | EA     | sources).                                                                    |  |  |  |  |  |  |
|         |        | 1: enable interrupt. Whether permitting the interrupt request of every       |  |  |  |  |  |  |
|         |        | interrupt source or not depends on its own Permit bit.                       |  |  |  |  |  |  |
| 6       |        | Reserved                                                                     |  |  |  |  |  |  |
|         |        | Timer 2 Interrupt enable bit.                                                |  |  |  |  |  |  |
| 5       | ET2    | 0: Disabled                                                                  |  |  |  |  |  |  |
|         |        | 1: Enabled                                                                   |  |  |  |  |  |  |
| 4       |        | Reserved                                                                     |  |  |  |  |  |  |
|         |        | Timer 1 Interrupt enable bit.                                                |  |  |  |  |  |  |
| 3       | ET1    | 0: Disabled                                                                  |  |  |  |  |  |  |
|         |        | 1: Enabled                                                                   |  |  |  |  |  |  |
|         |        | INT_EXT1 Permit bit                                                          |  |  |  |  |  |  |
| 2       | EX1    | 0: Disabled                                                                  |  |  |  |  |  |  |
|         |        | 1: Enabled                                                                   |  |  |  |  |  |  |
|         |        | Timer 0 Interrupt enable bit.                                                |  |  |  |  |  |  |
| 1       | ET0    | 0: Disabled                                                                  |  |  |  |  |  |  |
|         |        | 1: Enabled                                                                   |  |  |  |  |  |  |
|         |        | INT_EXT0 Permit bit                                                          |  |  |  |  |  |  |
| 0       | EX0    | 0: Disabled                                                                  |  |  |  |  |  |  |
|         |        | 1: Enabled                                                                   |  |  |  |  |  |  |



# 6.4.2 Interrupt Priority Register 0 (IPL0)

Address: 0xB8

| Bit No.             | 7 | 6 | 5 | 4 | 3          | 2          | 1          | 0          |
|---------------------|---|---|---|---|------------|------------|------------|------------|
| Symbol              | - | - | - | - | PT1        | PX2        | PT0        | PX0        |
| Read/Write          | - | - | - | - | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | - | - | - | - | 0          | 0          | 0          | 0          |

| Bit No. | Symbol | Description                           |  |  |  |  |
|---------|--------|---------------------------------------|--|--|--|--|
| 7~6     | -      | Reserved bit.                         |  |  |  |  |
|         |        | Timer2 Interrupt Priority Register.   |  |  |  |  |
| 5       | PT2    | 0: selects low priority level.        |  |  |  |  |
|         |        | 1: selects high priority level.       |  |  |  |  |
| 4       | _      | Reserved bit.                         |  |  |  |  |
|         |        | Timer1 Interrupt Priority Register.   |  |  |  |  |
| 3       | PT1    | 0: selects low priority level.        |  |  |  |  |
|         |        | 1: selects high priority level.       |  |  |  |  |
|         |        | INT_EXT1 Interrupt Priority Register. |  |  |  |  |
| 2       | PX2    | 0: selects low priority level.        |  |  |  |  |
|         |        | 1: selects high priority level.       |  |  |  |  |
|         |        | Timer0 Interrupt Priority Register.   |  |  |  |  |
| 1       | PT0    | 0: selects low priority level.        |  |  |  |  |
|         |        | 1: selects high priority level.       |  |  |  |  |
|         |        | INT_EXT0 Interrupt Priority Register. |  |  |  |  |
| 0       | PX0    | 0: selects low priority level.        |  |  |  |  |
|         |        | 1: selects high priority level.       |  |  |  |  |

# 6.4.3 Interrupt Flag Register (TCON)

#### Address: 0x88

| Bit No.             | 7              | 6              | 5              | 4              | 3              | 2 | 1              | 0 |
|---------------------|----------------|----------------|----------------|----------------|----------------|---|----------------|---|
| Symbol              | TF1            | TR1            | TF0            | TR0            | IE1            | - | IE0            | - |
| Read/Write          | Read/<br>Write | Read/<br>Write | Read/<br>Write | Read/<br>Write | Read/<br>Write | - | Read/<br>Write | - |
| Po Initial<br>Value | 0              | 0              | 0              | 0              | 0              | - | 0              | - |

| Bit No. Symbol | Description |
|----------------|-------------|
|----------------|-------------|



| 7 | 7 TF1 | Timer1 overflow flag. When Timer1 occurs overflow, hardware is set 1, or  |  |  |  |  |
|---|-------|---------------------------------------------------------------------------|--|--|--|--|
| / |       | the TH0 of Timer0 overflows in mode 3.                                    |  |  |  |  |
| 6 | TR1   | Timer1 enable, set to 1 to enable Timer1 or enable TH0 to count in Time0  |  |  |  |  |
| 0 | IKI   | mode 3.                                                                   |  |  |  |  |
| 5 | TF0   | TF0 TImer0 overflow flag bit. When Timer0 overflows, hardware is set to 1 |  |  |  |  |
|   | TR0   | Timer0 enable.                                                            |  |  |  |  |
| 4 |       | 1: enable Timer0                                                          |  |  |  |  |
|   |       | 0: disable Timer0                                                         |  |  |  |  |
| 3 | IE1   | External interrupt 1 flag bit. Set hardware to 1 to clear software.       |  |  |  |  |
| 2 |       | Reserved.                                                                 |  |  |  |  |
| 1 | IE0   | External interrupt 0 flag bit. Set hardware to 1 to clear software.       |  |  |  |  |

# 6.4.4 Interrupt Enable Register 1 (IEN1)

Address: 0xE6

| Bit No.    | 7          | 6      | 5     | 4      | 3     | 2     | 1 | 0 |
|------------|------------|--------|-------|--------|-------|-------|---|---|
| Symbol     | WDT_T2_I   | SPI IE | CSD_I | ADC_IE | EX3_I | EX2_I |   | _ |
| Symbol     | E          |        | Е     | ADC_IL | Е     | Е     | - |   |
| Read/Write | Read/Write | Read/  | Read/ | Read/W | Read/ | Read/ |   |   |
| Read/white |            | Write  | Write | rite   | Write | Write | - | - |
| Po Initial | 0          | 0      | 0     | 0      | 0     | 0     |   |   |
| Value      |            |        |       |        |       |       | - | - |

| Bit No. | Symbol    | Description                  |
|---------|-----------|------------------------------|
|         |           | WDT/Timer2 interrupt enable. |
| 7       | WDT_T2_IE | 1: enabled.                  |
|         |           | 0: disabled.                 |
|         |           | SPI interrupt enable.        |
| 6       | SPI_IE    | 1: enabled.                  |
|         |           | 0: disabled.                 |
|         |           | CSD interrupt enable.        |
| 5       | CSD_IE    | 1: enabled.                  |
|         |           | 0: disabled.                 |
|         |           | ADC interrupt enable.        |
| 4       | ADC_IE    | 1: enabled.                  |
|         |           | 0: disabled.                 |
|         |           | EX3_IE interrupt enable.     |
| 3       | EX3_IE    | 1: enabled.                  |
|         |           | 0: disabled.                 |



| 2   | EX2_IE | EX2_IE interrupt enable.<br>1: enabled.<br>0: disabled. |
|-----|--------|---------------------------------------------------------|
| 1~0 |        | Reserved.                                               |

# 6.4.5 Interrupt Priority Register 1 (IPL1)

Address: 0xF6

| 7             | 6         | 5                                            | 4                                                     | 3                                                                    | 2                                                                                   | 1                                                                                                  | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|-----------|----------------------------------------------|-------------------------------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WDT_T2_I<br>P | SPI_IP    | CSD_IP                                       | ADC_IP                                                | EX3_IP                                                               | EX2_IP                                                                              | -                                                                                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Read/Write    | Read/Writ | Read/Writ                                    | Read/Writ                                             | Read/Writ                                                            | Read/Writ                                                                           |                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|               | е         | е                                            | е                                                     | е                                                                    | е                                                                                   | -                                                                                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0             | 0         | 0                                            | 0                                                     | 0                                                                    | 0                                                                                   | -                                                                                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|               | P         | WDT_T2_I<br>P SPI_IP<br>Read/Write Read/Writ | WDT_T2_I<br>PSPI_IPCSD_IPRead/WriteRead/WritRead/Writ | WDT_T2_I<br>PSPI_IPCSD_IPADC_IPRead/WriteRead/WritRead/WritRead/Writ | WDT_T2_I<br>PSPI_IPCSD_IPADC_IPEX3_IPRead/WriteRead/WritRead/WritRead/WritRead/Writ | WDT_T2_I<br>PSPI_IPCSD_IPADC_IPEX3_IPEX2_IPRead/WriteRead/WritRead/WritRead/WritRead/WritRead/Writ | WDT_T2_I       SPI_IP       CSD_IP       ADC_IP       EX3_IP       EX2_IP       -         Read/Write       Read/Writ       Read/Writ |

| Bit No. | Symbol    | Description                           |
|---------|-----------|---------------------------------------|
|         |           | WDT/Timer 2 Interrupt Priority level. |
| 7       | WDT_T2_IP | 0: low priority level.                |
|         |           | 1: high priority level.               |
|         |           | SPI Interrupt Priority level.         |
| 6       | SPI_IP    | 0: low priority level.                |
|         |           | 1: high priority level.               |
|         |           | CSD Interrupt Priority level.         |
| 5       | CSD_IP    | 0: low priority level.                |
|         |           | 1: high priority level.               |
|         |           | ADC Interrupt Priority level.         |
| 4       | ADC_IP    | 0: low priority level.                |
|         |           | 1: high priority level.               |
|         |           | EX3_IP Interrupt Priority level.      |
| 3       | EX3_IP    | 0: low priority level.                |
|         |           | 1: high priority level.               |
|         |           | EX2_IP Interrupt Priority level.      |
| 2       | EX2_IP    | 0: low priority level.                |
|         |           | 1: high priority level.               |
| 1~0     |           | Reserved                              |



# 6.4.6 Interrupt Flag Register 1(IRCON1)

Address: 0xF1

| Bit No.    | 7             | 6         | 5         | 4         | 3         | 2         | 1 | 0 |
|------------|---------------|-----------|-----------|-----------|-----------|-----------|---|---|
| Symbol     | WDT_T2_I<br>F | SPI_IF    | CSD_IF    | ADC_IF    | EX3_IF    | EX2_IF    | - | - |
| Read/Writ  | Read/Write    | Read/Writ | Read/Writ | Read/Writ | Read/Writ | Read/Writ | - | - |
| е          |               | е         | е         | е         | е         | е         |   |   |
| Po Initial | 0             | 0         | 0         | 0         | 0         | 0         | - | - |
| Value      | 0             |           |           |           |           |           |   |   |

| Bit No. | Symbol    | Description                |
|---------|-----------|----------------------------|
|         |           | WDT/Timer2 interrupt flag. |
| 7       | WDT_T2_IF | 1: flagged.                |
|         |           | 0: not flagged.            |
|         |           | SPI interrupt flag.        |
| 6       | SPI_IF    | 1: flagged.                |
|         |           | 0: not flagged.            |
|         |           | CSD interrupt flag.        |
| 5       | CSD_IF    | 1: flagged.                |
|         |           | 0: not flagged.            |
|         |           | ADC interrupt flag.        |
| 4       | ADC_IF    | 1: flagged.                |
|         |           | 0: not flagged.            |
|         |           | EX3_IF interrupt flag.     |
| 3       | EX3_IF    | 1: flagged.                |
|         |           | 0: not flagged.            |
|         |           | EX2_IF interrupt flag.     |
| 2       | EX2_IF    | 1: flagged.                |
|         |           | 0: not flagged.            |
| 1~0     |           | Reserved                   |

# 6.4.7 Interrupt Enable Register 2(IEN2)

Address: 0xE7

| Bit No.  | 7 | 6        | 5        | 4           | 3        | 2        | 1        | 0        |
|----------|---|----------|----------|-------------|----------|----------|----------|----------|
| Symbol   | - | IIC_IE   | PWMI_IE  | PWM0_I<br>E | RTC_IE   | SCI_IE   | UART_IE  | LVDT_IE  |
| Read/Wri | - | Read/Wri | Read/Wri | Read/Wri    | Read/Wri | Read/Wri | Read/Wri | Read/Wri |



| te         |   | te |
|------------|---|----|----|----|----|----|----|----|
| Po Initial |   | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Value      | - |    |    |    |    |    |    | 0  |

| Bit No. | Symbol  | Description            |  |  |  |
|---------|---------|------------------------|--|--|--|
| 7~0     |         | Reserved.              |  |  |  |
|         |         | IIC interrupt enable.  |  |  |  |
| 6       | IIC_IE  | 1: enabled.            |  |  |  |
|         |         | 0: disabled.           |  |  |  |
|         |         | PWM1 interrupt enable. |  |  |  |
| 5       | PWM1_IE | 1: enabled.            |  |  |  |
|         |         | 0: disabled.           |  |  |  |
|         |         | PWM0 interrupt enable. |  |  |  |
| 4       | PWM0_IE | 1: enabled.            |  |  |  |
|         |         | 0: disabled.           |  |  |  |
|         | 570 15  | RTC interrupt enable.  |  |  |  |
| 3       | RTC_IE  | 1: enabled.            |  |  |  |
|         |         | 0: disabled.           |  |  |  |
|         |         | SCI interrupt enable.  |  |  |  |
| 2       | SCI_IE  | 1: enabled.            |  |  |  |
|         |         | 0: disabled.           |  |  |  |
|         |         | UART interrupt enable. |  |  |  |
| 1       | UART_IE | 1: enabled.            |  |  |  |
|         |         | 0: disabled.           |  |  |  |
|         |         | LVDT interrupt enable. |  |  |  |
| 0       | LVDT_IE | 1: enabled.            |  |  |  |
|         |         | 0: disabled.           |  |  |  |

# 6.4.8 Interrupt Priority Register 2 (IPL2)

Address: 0xF4

| Bit No.    | 7 | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
|------------|---|----------|----------|----------|----------|----------|----------|----------|
| Symbol     |   | IIC_IP   | PWM1_I   | PWM0_I   | RTC_IP   | SCI_IP   | UART_IP  | LVDT_IP  |
| Cyrribol   |   |          | Р        | Р        |          |          |          |          |
| Read/Wri   |   | Read/Wri |
| te         | - | te       |
| Po Initial |   | 0        | 0        | 0        | 0        | 0        | 0        | 0        |
| Value      | - | 0        | 0        | 0        | 0        | 0        | 0        | 0        |

| Bit No. | Symbol | Description |
|---------|--------|-------------|
| 7       |        | Reserved.   |



|   |         | IIC Interrupt Priority Register.  |
|---|---------|-----------------------------------|
| 6 | IIC_IP  | 0: low priority level.            |
|   |         | 1: high priority level.           |
|   |         | PWM1Interrupt Priority Register.  |
| 5 | PWM1_IP | 0: low priority level.            |
|   |         | 1: high priority level.           |
|   |         | PWM0 Interrupt Priority Register. |
| 4 | PWM0_IP | 0: low priority level.            |
|   |         | 1: high priority level.           |
|   |         | RTC Interrupt Priority Register.  |
| 3 | RTC_IP  | 0: low priority level.            |
|   |         | 1: high priority level.           |
|   |         | SCI Interrupt Priority Register.  |
| 2 | SCI_IP  | 0: low priority level.            |
|   |         | 1: high priority level.           |
|   |         | UART Interrupt Priority Register. |
| 1 | UART_IP | 0: low priority level.            |
|   |         | 1: high priority level.           |
|   |         | LVDT Interrupt Priority Register. |
| 0 | LVDT_IP | 0: low priority level.            |
|   |         | 1: high priority level.           |

# 6.4.9 Interrupt Flag Register 2 (IRCON2)

Address: 0xE1

| Bit No.    | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
|------------|----------|----------|----------|----------|----------|----------|----------|----------|
| Symbol     |          |          | PWM1_I   | PWM0_I   | RTC_IF   | SCI_IF   | UART_IF  | LVDT_IF  |
| Symbol     | - IIC_IF |          | F        | F        |          |          |          |          |
| Read/Wri   |          | Read/Wri |
| te         | -        | te       |
| Po Initial |          | 0        | 0        | 0        | 0        | 0        | 0        | 0        |
| Value      | -        |          |          |          |          |          |          | 0        |

| Bit No. | Symbol  | Description          |  |  |
|---------|---------|----------------------|--|--|
| 7       |         | Reserved             |  |  |
|         |         | IIC interrupt flag.  |  |  |
| 6       | IIC_IF  | 1: flagged.          |  |  |
|         |         | 0: not flagged.      |  |  |
| 5       | PWM1_IF | PWM1 interrupt flag. |  |  |
| 5       |         | 1: flagged.          |  |  |



|   |         | 0: not flagged.      |
|---|---------|----------------------|
|   |         | PWM0 interrupt flag. |
| 4 | PWM0_IF | 1: flagged.          |
|   |         | 0: not flagged.      |
|   |         | RTC interrupt flag.  |
| 3 | RTC_IF  | 1: flagged.          |
|   |         | 0: not flagged.      |
|   |         | SCI interrupt flag.  |
| 2 | SCI_IF  | 1: flagged.          |
|   |         | 0: not flagged.      |
|   |         | UART interrupt flag. |
| 1 | UART_IF | 1: flagged.          |
|   |         | 0: not flagged.      |
|   |         | LVDT interrupt flag. |
| 0 | LVDT_IF | 1: flagged.          |
|   |         | 0: not flagged.      |

# 6.4.10 INT3 Selection Enable Register 3 (EXT3\_INT\_SEL3)

| Bit No.             | 7              | 6              | 5              | 4              |
|---------------------|----------------|----------------|----------------|----------------|
| Symbol              | INT3_23_IO_SEL | INT3_22_IO_SEL | INT3_21_IO_SEL | INT3_20_IO_SEL |
| Read/Write          | Read/Write     | Read/Write     | Read/Write     | Read/Write     |
| Po Initial<br>Value | 0              | 0              | 0              | 0              |
| Bit No.             | 3              | 2              | 1              | 0              |
| Symbol              | INT3_19_IO_SEL | INT3_18_IO_SEL | INT3_17_IO_SEL | INT3_16_IO_SEL |
| Read/Write          | Read/Write     | Read/Write     | Read/Write     | Read/Write     |
| Po Initial<br>Value | 0              | 0              | 0              | 0              |

| Bit No. | Symbol                     | Description                                   |  |  |
|---------|----------------------------|-----------------------------------------------|--|--|
| 7~0     | INT3_n_IO_SEL<br>(n=23~16) | INT3_n IO selection enable.<br>1: enable INT. |  |  |
| 7~0     |                            | 0: disable INT.                               |  |  |



# 6.4.11 INT3 Selection Enable Register 2 (EXT3\_INT\_SEL2)

| Bit No.             | 7              | 6              | 5              | 4              |
|---------------------|----------------|----------------|----------------|----------------|
| Symbol              | INT3_15_IO_SEL | INT3_14_IO_SEL | INT3_13_IO_SEL | INT3_12_IO_SEL |
| Read/Write          | Read/Write     | Read/Write     | Read/Write     | Read/Write     |
| Po Initial<br>Value | 0              | 0              | 0              | 0              |
| Bit No.             | 3              | 2              | 1              | 0              |
| Symbol              | INT3_11_IO_SEL | INT3_10_IO_SEL | INT3_9_IO_SEL  | INT3_8_IO_SEL  |
| Read/Write          | Read/Write     | Read/Write     | Read/Write     | Read/Write     |
| Po Initial<br>Value | 0              | 0              | 0              | 0              |

XRAM\_SFR Address: 0x204C

| Bit No. | Symbol                    | Description                                                      |  |  |
|---------|---------------------------|------------------------------------------------------------------|--|--|
| 7~0     | INT3_n_IO_SEL<br>(n=15~8) | INT3_n IO selection enable.<br>1: enable INT.<br>0: disable INT. |  |  |

### 6.4.12 INT3 Selection Enable Register 1 (EXT3\_INT\_SEL1)

XRAM\_SFR Address: 0x204D

| Bit No.             | 7             | 6             | 5             | 4             |
|---------------------|---------------|---------------|---------------|---------------|
| Symbol              | INT3_7_IO_SEL | INT3_6_IO_SEL | INT3_5_IO_SEL | INT3_4_IO_SEL |
| Read/Write          | Read/Write    | Read/Write    | Read/Write    | Read/Write    |
| Po Initial<br>Value | 0             | 0             | 0             | 0             |
| Bit No.             | 3             | 2             | 1             | 0             |
| Symbol              | INT3_3_IO_SEL | INT3_IO_2_SEL | INT3_1_IO_SEL | INT3_0_IO_SEL |
| Read/Write          | Read/Write    | Read/Write    | Read/Write    | Read/Write    |
| Po Initial<br>Value | 0             | 0             | 0             | 0             |

| Bit No. | Symbol                   | Description                                                      |  |
|---------|--------------------------|------------------------------------------------------------------|--|
| 7~0     | INT3_n_IO_SEL<br>(n=7~0) | INT3_n IO selection enable.<br>1: enable INT.<br>0: disable INT. |  |



# 6.4.13 INT Selection Enable Register (EXT\_INT\_SEL)

XRAM\_SFR Address: 0x204E

| Bit No.    | 7 | 6           | 5           | 4           |
|------------|---|-------------|-------------|-------------|
| Symbol     | - | -           | -           | -           |
| Read/Write | - | -           | -           | -           |
| Po Initial | - | -           | -           | -           |
| Value      |   |             |             |             |
| Bit No.    | 3 | 2           | 1           | 0           |
| Symbol     | - | INT2_IO_SEL | INT1_IO_SEL | INT0_IO_SEL |
| Read/Write | - | Read/Write  | Read/Write  | Read/Write  |
| Po Initial | - | 0           | 0           | 0           |
| Value      |   |             |             | U           |

| Bit No. | Symbol      | Description               |  |  |
|---------|-------------|---------------------------|--|--|
|         |             | INT2 IO selection enable. |  |  |
| 2       | INT2_IO_SEL | 1: enable INT2.           |  |  |
|         |             | 0: disable INT2.          |  |  |
|         |             | INT1 IO selection enable. |  |  |
| 1       | INT1_IO_SEL | 1: enable INT1.           |  |  |
|         |             | 0: disable INT1.          |  |  |
|         |             | INT0 IO selection enable. |  |  |
| 0       | INT0_IO_SEL | 1: enable INT0.           |  |  |
|         |             | 0: disable INT0.          |  |  |

### 6.4.14 External Interrupt Polarity Control Register (EXT\_INT\_CON)

XRAM\_SFR Address: 0x204F

| Bit No.    | 7             | 6             | 5             | 4          |
|------------|---------------|---------------|---------------|------------|
| Symbol     | -             | INT3_POLARITY | INT2_POLARITY |            |
| Read/Write | -             | Read/Write    | Read/Write    | Read/Write |
| Po Initial | _             | 0             | 0             | 1          |
| Value      | -             | 0             | 0             | I          |
| Bit No.    | 3             | 2             | 1             | 0          |
| Symbol     | INT1_POLARITY |               | INT0_P        | OLARITY    |
| Read/Write | Read/Write    | Read/Write    | Read/Write    | Read/Write |
| Po Initial | 0             | 1             | 0             | 1          |
| Value      | 0             | Ι             | 0             | I          |



| Bit No. | Symbol        | Description                                                       |
|---------|---------------|-------------------------------------------------------------------|
|         |               | External interrupt 3_x trigger polarity selection.                |
| 6       | INT3_POLARITY | 1: rising edge (High level wake-up in low power mode)             |
|         |               | 0: falling edge (Low level wake-up in low power mode)             |
|         |               | External interrupt 2 trigger polarity selection:                  |
| 5~4     | INT2 POLARITY | 01: falling edge (Low level wake-up in low power mode)            |
| 5~4     |               | 10: rising edge (High level wake-up in low power mode)            |
|         |               | 00/11: rising/falling edges (Low level wake-up in low power mode) |
|         |               | External interrupt 1 trigger polarity selection:                  |
| 3~2     | INT1 POLARITY | 01: falling edge (Low level wake-up in low power mode)            |
| 5-2     |               | 10: rising edge (High level wake-up in low power mode)            |
|         |               | 00/11: rising/falling edges (Low level wake-up in low power mode) |
|         |               | External interrupt 0 trigger polarity selection:                  |
| 1~0     | INTO_POLARITY | 01: falling edge (Low level wake-up in low power mode)            |
| 1,~0    |               | 10: rising edge (High level wake-up in low power mode)            |
|         |               | 00/11: rising/falling edges (Low level wake-up in low power mode) |

#### Note :

INT3 registers use a common interrupt vector, which can only respond to one external interrupt at the same time. When external interrupts on the rising edge or falling edge of the multiplexing I/Os are enabled, it requires all the enabled external interrupt IOs to be released before responding to the present signal during the detection (when falling edge is triggered, release the high level; when rising edge is triggered, release the low level.)

# 6.5 External Interrupt Configuration Procedures

External interrupts do not involve the filter handling. They need to configure polarity. For external interrupt INT0/1/2, there are three configurations including rising edge, falling edge and both edges in normal mode. For INT3\_0~3\_23, it supports rising edge and falling edge in normal mode. Low-power mode supports high-level and low-level wake-up.

See the configuration for INT0/1/2/3 below.

Semiconductor





Figure 0.2 INT0/1/2/3 Configuration Flow Chart

First, configure INTx\_POLARITY to select polarity. Then, open the interrupt port of the GPIO to enable INTx\_IO\_SEL.

In both edges mode, if the current level of the present interrupt IO needs to read out, it must to configure TRIS as Input ("1"). Determine the current leve by reading out the DATA, which distinguishes between the rising edge and falling edge.

INT3\_0~3\_23,must configure the corresponding TRIS of the external interrupt as input ('1"), then read out DATA to determine the present level, which distinguishes which IO has been interrupted. (This involves only mechanical keyboard application, usually it rakes a long time for pressing the



buttons.)

Note:  $INT3_0~3_23$  has a common interrupt number for all input signals " or " transmitting interrupt signals. Therefore, when many interrupt IOs of  $INT3_x_IO_SEL$  are configured validly, make sure only one signal input is valid at the moment, because one of the enabled input signals is within the valid level, changes in others can not trigger interrupt response.

# Semiconductor

# 7 Timer

BS9000AMxx has 2 timers (TIMER0, TIMER1) form the core and 2 external timers (TIMER2, RTC). Each Timer contains a 16-bit register that is visible in the form of 2 byte when accessed, including a low byte (TL0 or TL1) and a high byte (TH0 or TH1). The register of Timer2 is a low byte from TIMER2\_SET\_L and a high byte from TIMER2\_SET\_H. The register of RTC is a low bye from RTC\_SET\_L and a high byte from RTC\_SET\_H.

Timer functions:

- 4 16-bit Timer
- Timer0 connects to the system clock with F\_sys\_clk /12
- Timer1connects to the system clock with F\_sys\_clk /12
- Timer2 can select internal RC32K, external oscillator or PLL\_24Mhz, and the last two support frequency divider.
- RTC can choose internal RC32K, external oscillator or PLL\_24Mhz, and the last two support frequency divider.
- Timer0 supports 8-bit auto-reload timer/counter, 16-bit manual-reload timer/counter.
- Timer1 supports 8-bit auto-reload timer/counter, 16-bit manual-reload timer/counter.
- Timer2 supports 16-bit auto-reload timer and manual-reload timer as well as wake-up from interrupt.

• RTC supports 16-bit auto-reload timer and manual-reload timer as well as wake-up from interrupt.



# 7.1 Timer0 and Timer1

Set the ET0 bit in the IEN0 register to enable Timer0 interrupt, and set the ET1 bit in the IEN0 to enable the Timer1 interrupt. Set the TR0/1 to enable timer, and decide if the timer overflows through TF0/1. Timer0/1 is controlled by registers TMOD and TCON, they have four operating modes as following:

- 1. Mode 0: 13-bit timer/counter
- 2. Mode 1: 16-bit timer/counter
- 3. Mode 2: auto-reload the 8-bit counter of initial value.
- 4. Mode 3: two 8-bit timer/counter (only for timer/counter 0)

#### Mode 0: 13-bit timer logic structure:



Figure0.1 Mode 0 Logic Structure Diagram

Figure 7.1 shows that Timer0 and Timer1 have the same procedure. In Mode 0, Timer0 is a 13-bit counter that consists of 8 bits of TH0 and low 5 bits of TL0. Timer1 is also a 13-bit counter consisting of 8 bits of TH1 and low 5 bits of TL1. Just ignore the high 3 bits of TL0 and TL1. The enable bit (TR0/TR1) in the TCON register is to control timer ON/OFF.

Timer starts to count for selected system clock source (F\_sys\_clk/12), when the 13-bit counter accumulates to all 1, the counter will clear to 0 (all 0), and set TF0(or TF1) to 1,. The counter enable is only controlled by TR0/1.

#### Mode 1: 16-bit timer logic structure:



Figure 0.2 Mode 1 Logic Structure Diagram

As shown in Figure 7.2, Timer 0 and Timer 1 have the same Mode 1. In mode 1, both Timer0 and



Timer1 are 16-bit counter consisting of 8 bits from TH0 and 8 bits from TL0. When counter accumulates to 0xFFFF, the counter will clear to all 0. Besides, like Mode 0, the counter of Mode 1 is controlled only by TR0/1.



#### Mode 2: 8-bit timer that auto-reloads the initial value, see its logic structure below:

Figure0.3 Mode 2 Logic Structure Diagram

Timer 0 and Timer1 have the same logic in Mode 2. In mode 2, timer is an 8-bit counter with autoreload initial value function, also know as LSB register (TL0 or TL1), the initial value that needs to auto-reload is stored in the MSB register (TH0 or TH1).

As shown in Figure 7.3, the counter control in mode 2 is the same as in Mode 0 and Mode 1. However, in Mode 2, when TLn accumulates to FFh, the value stored in THn will reload to TLn. The counter is controlled only by TR0/1.

#### Mode 3: Two 8-bit Timers



Figure 0.4 Mode 3 Logic Structure Diagram

In Mode 3, Timer0 is two 8-bit timers, then Timer1 stops counting and stores its value. As shown in Figure 7.4, TL0 is an 8-bit register controlled by the control bit of Timer0. The counter uses GATE as enable interface to control the signal transmit and receive of INT\_EXT.

TH0 has a individual 8-bit timer. TH0 can only be used to count the clock cycle. The enable bit and



flag bit of Timer1(TR1 and TF1) can serve as the enable bit and flag bit of TH0. When the Timer0 is in Mode 3, Timer1 will be limited, because Timer0 has used the enable bit (TR1) and interrupt flag bit (TF1) in Timer1. For Timer1. it can still be used to generate the baud rate, and the values in registers TL1 and TH1 are valid.

When Timer0 is in Mode 3, it controls Timer1 through the mode bit from Timer1. To enable Timer1 requires to set the Timer1 as Mode 0 or 1 or 2. To disable Timer1 requires to set its mode to 3. Timer1can serves as a timer (F\_sys\_clk/12), but it can not generate overflow to interrupt due to the TR1 and TF1 is borrowed by Timer0. When Time0 in Mode 3, the counter enable is controlled by TR0/1.

# 7.2 Timer2/RTC

RTC module has the same function as Timer2.

The Timer2/RTC modules mainly features a 16-bit counter, which implements its timer function by counting input clock. The counting of Timer2/RTC is based on summation, the counter will trigger interrupt when accumulating to the setting value. Timer2/RTC timer can select internal RC, external oscillator or PLL\_24Mhz clock, and the last two clocks support frequency division, which is depended on the clock selection register, computing the time setting range is 0s to 2s.

Enable the Timer2 by configuring the register TIMER2\_EN, TIMER2\_RLD has auto-reload or manual-reload mode, timer can be set in the registers TIMER2\_SET\_L and TIMER2\_SET\_H. RTC has the same configuration as Timer2.

Both Timer2 and RTC support interrupt wake-up from Wait mode and Sleep mode, and require software to clear interrupt flag in the interrupt handler function.

Timer2 and RTC supports two operating modes including single-cycle timing mode and auto-reload mode. No matter what mode it is, it will trigger interrupt after the time is up.

- Single-cycle timing mode: when time is up, the hardware will automatically pull down TIMER2\_EN/RTC\_EN and stop counting.
- Auto-reload mode: hardware will reload the set value, TIMER2\_EN/RTC\_EN continues to hold high level, restarting the next counting. Software writes 0 in the register TIMER2\_EN/RTC\_EN or modify the timer mode in the middle to stop Timer2/RTC.

 $T_{\text{TIMER2}}$  can be calculated as follows:

T<sub>TIMER2</sub>=T<sub>TIMER2\_CLK</sub>\*({TIMER2\_SET\_H, TIMER2\_SET\_L}+1)

Note:

Any configuration for TIMER2\_SET\_H, TIMER2\_SET\_L, TIMER2\_CFG can clear the counter.  $T_{RTC}$  can be calculated as follows:

T<sub>RTC</sub>=T<sub>RTC\_CLK</sub>\*({RTC\_SET\_H, RTC\_SET\_L}+1)

Note: any configuration for RTC\_SET\_H, RTC\_SET\_L or RTC\_CFG can clear the counter.



# 7.3 Timer Registers

### 7.3.1 Timer0/1 Registers

### 7.3.1.1 Timer Control Register (TCON)

Address: 0x88

| Bit No.             | 7              | 6              | 5              | 4              | 3              | 2 | 1              | 0 |
|---------------------|----------------|----------------|----------------|----------------|----------------|---|----------------|---|
| Symbol              | TF1            | TR1            | TF0            | TR0            | IE1            | - | IE0            | - |
| Read/Write          | Read/Wri<br>te | Read/Wri<br>te | Read/Wri<br>te | Read/Wri<br>te | Read/Wri<br>te | - | Read/Writ<br>e | - |
| Po Initial<br>Value | 0              | 0              | 0              | 0              | 0              | - | 0              | - |

| Bit No. | Symbol | Description                                                   |
|---------|--------|---------------------------------------------------------------|
| 7       | TF1    | Timer1 Overflow flag. When Timer1 overflows, hardware sets    |
| /       |        | to 1, or TH0 in the Timer0 overflows in Mode 3.               |
| 6       | TR1    | Timer1 enable. Set 1 to enable Timer1 or enable TH0 in the    |
| 0       |        | Time0 to count in Mode 3.                                     |
| 5       | TEO    | TImer0 overflow flag. When Timer0 overflows, hardware sets    |
| 5       | TF0    | to 1.                                                         |
| 4       | TR0    | Timer0 enable. Set to 1 to enable Timer0.                     |
| 3       | IE1    | External interrupt 1 flag. Hardware sets to 1, which supports |
| 3       | IC I   | software clearing.                                            |
| 2       |        | Reserved                                                      |
| 1       |        | External interrupt 0 flag. Hardware sets to 1, which supports |
| 1       | IE0    | software clearing.                                            |
| 0       |        | Reserved                                                      |

### 7.3.1.2 Timer Mode Register (TMOD)

Address: 0x89

| Bit No.             | 7 | 6          | 5          | 4 | 3  | 2          | 1          | 0 |   |    |   |   |
|---------------------|---|------------|------------|---|----|------------|------------|---|---|----|---|---|
| Symbol              | - | T1         | M1         |   | M1 |            | M1         |   | - | TO | N | 0 |
| Read/Write          | - | Read/Write | Read/Write |   | -  | Read/Write | Read/Write |   |   |    |   |   |
| Po Initial<br>Value | - | 0          | 0          |   | -  | 0          | (          | ) |   |    |   |   |



| Bit No. | Symbol | Description                                                 |  |
|---------|--------|-------------------------------------------------------------|--|
| 7       |        | Reserved                                                    |  |
| 6       | T1     | Timer 1 count/timing selection. By default, 0: Timing mode. |  |
|         |        | Timer 1 run mode selection.                                 |  |
|         |        | 00: Mode 0, 13-bit timer/counter                            |  |
| 5~4     | M1     | 01: Mode 1, 16-bit timer.counter                            |  |
|         |        | 10: Mode 2, 8-bit counter with auto-reload initial value    |  |
|         |        | 11: Mode 3 disabled (Timer 1 disabled)                      |  |
| 3       |        | Reserved                                                    |  |
| 2       | T0     | Timer 0 count/timing selection. By default, 0: Timing mod   |  |
|         |        | Timer 0 run mode selection.                                 |  |
|         |        | 00: Mode 0, 13-bit timer/counter                            |  |
| 1~0     | MO     | 01: Mode 1, 16-bit timer.counter                            |  |
|         |        | 10: Mode 2, 8-bit counter with auto-reload initial value    |  |
|         |        | 11: Mode 3, two 8-bit timer/counter                         |  |

### 7.3.1.3 Timer 0 Counter Low 8 bits (TL0)

Address: 0x8A

| Bit No.    | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|---|------------|---|---|---|---|---|---|
| Symbol     |   | TL0[7:0]   |   |   |   |   |   |   |
| Read/Write |   | Read/Write |   |   |   |   |   |   |
| Po Initial |   |            |   |   | h |   |   |   |
| Value      |   |            |   | ( | J |   |   |   |

| Bit No. | Symbol   | Description                 |
|---------|----------|-----------------------------|
| 7~0     | TL0[7:0] | Timer 0 counter low 8 bits. |

### 7.3.1.4 Timer 0 Counter High 8 bits (TH0)

Address: 0x8C

| Bit No.    | 7 | 6          | 5 | 4 | 3        | 2 | 1 | 0 |
|------------|---|------------|---|---|----------|---|---|---|
| Symbol     |   | TH0[7:0]   |   |   |          |   |   |   |
| Read/Write |   | Read/Write |   |   |          |   |   |   |
| Po Initial |   |            |   | ( | <u>`</u> |   |   |   |
| Value      |   |            |   | ( | J        |   |   |   |
|            |   |            |   |   |          |   |   |   |

| Bit No. | Symbol | Description |
|---------|--------|-------------|
|         |        |             |



|  | 7~0 | TH0[7:0] | Timer 0 Counter High 8 bits |
|--|-----|----------|-----------------------------|
|--|-----|----------|-----------------------------|

### 7.3.1.5 Timer 1 Counter Low 8 bits (TL1)

Address: 0x8B

| Bit No.    | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|---|------------|---|---|---|---|---|---|
| Symbol     |   | TL1[7:0]   |   |   |   |   |   |   |
| Read/Write |   | Read/Write |   |   |   |   |   |   |
| Po Initial |   |            |   |   | 2 |   |   |   |
| Value      |   |            |   | ( | J |   |   |   |

| Bit No. | Symbol   | Description                |
|---------|----------|----------------------------|
| 7~0     | TL1[7:0] | Timer 1 Counter Low 8 bits |

#### 7.3.1.6 Timer 1 Counter High 8 bits (TH1)

Address: 0x8D

| Bit No.    | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------|---|------------|---|---|---|---|---|---|--|
| Symbol     |   | TH1[7:0]   |   |   |   |   |   |   |  |
| Read/Write |   | Read/Write |   |   |   |   |   |   |  |
| Po Initial |   |            |   |   |   |   |   |   |  |
| Value      |   |            |   | ( | J |   |   |   |  |

| Bit No. | Symbol   | Description                 |  |  |  |
|---------|----------|-----------------------------|--|--|--|
| 7~0     | TH1[7:0] | Timer 1 Counter High 8 bits |  |  |  |

### 7.3.2 Timer2/RTC Registers

#### 7.3.2.1 Timer2 Configuration Register (TIMER2\_CFG)

XRAM\_SFR Address: 0x206A

| Bit No.    | 7~5 | 6~4            | 3~2            | 1          | 0          |
|------------|-----|----------------|----------------|------------|------------|
| Symbol     |     | TIMER2_CLK_FRE | TIMER2_CLK_SEL | TIMER2_RLD | TIMER2_EN  |
| Read/Write |     | Read/Write     | Read/Write     | Read/Write | Read/Write |
| Po Initial |     | 0              | 0              | 0          | 0          |
| Value      |     |                | 0              | 0          | 0          |



| Bit No. | Symbol         | Description                                            |  |  |  |  |
|---------|----------------|--------------------------------------------------------|--|--|--|--|
|         |                | Timer2 XTAL or PLL_24MHz Clock Frequency               |  |  |  |  |
|         |                | Division Selection.                                    |  |  |  |  |
|         |                | 000: select the clock frequency/1                      |  |  |  |  |
|         |                | 001: select the clock frequency/2                      |  |  |  |  |
|         |                | 010: select the clock frequency/4                      |  |  |  |  |
|         |                | 011: select the clock frequency/8                      |  |  |  |  |
| 6~4     | TIMER2_CLK_FRE | 100: select the clock frequency/16                     |  |  |  |  |
|         |                | 101: select the clock frequency/32                     |  |  |  |  |
|         |                | 110: select the clock frequency/64                     |  |  |  |  |
|         |                | 111: select the clock frequency/128                    |  |  |  |  |
|         |                | No matter in which mode, configure the register will   |  |  |  |  |
|         |                | clear the counter during the counting. If the present  |  |  |  |  |
|         |                | counting enable is valid, it will refresh the counter. |  |  |  |  |
|         |                | Timer2 Clock Selection Register                        |  |  |  |  |
| 3~2     | TIMER2 CLK SEL | 0: select RC32KHz                                      |  |  |  |  |
| 5-2     |                | 1: select XTAL                                         |  |  |  |  |
|         |                | 2/3: select PLL_24MHz                                  |  |  |  |  |
|         |                | Timer2 auto-reload enable register                     |  |  |  |  |
| 1       | TIMER2_RLD     | 1: auto-reload mode.                                   |  |  |  |  |
|         |                | 0: manual reload mode.                                 |  |  |  |  |
|         |                | Timer2 counter enable register.                        |  |  |  |  |
|         |                | 1: start the counting.                                 |  |  |  |  |
|         |                | 0: stop counting.                                      |  |  |  |  |
|         |                | In manual reload mode, hardware will auto-clear        |  |  |  |  |
| 0       | TIMER2_EN      | the register after the counting and stop the clock.    |  |  |  |  |
|         |                | In auto-reload mode, the register holds the enable     |  |  |  |  |
|         |                | after the counting, and clock starts to count from 0   |  |  |  |  |
|         |                | again. In either mode, configure the register as 1     |  |  |  |  |
|         |                | will enable the clock to count from 0.                 |  |  |  |  |

Configure the register TIMER2\_CLK\_SEL/TIMER2\_CLK\_FRE to select the operation of Timer2.

Note:

- Check if the clock is enabled.
- PD\_XTAL=0x1, disable XTAL clock. PD\_XTAL=0x0, enable XTAL. By default, this clock is off.
- In single-cycle timing mode, when the timing is up, it transmits an interrupt signal, then the interrupt falling edge will auto-clear the register.
- In auto-reload mode, when the timing is completed, interrupt signal is sent, enable register holding, the clock goes to the next round of timing.
- Configure the register at any time will reset it, therefore, after the interrupt signal is sent,



the register will auto-clear the counter and the flag. If the configuration is 1 at this time, it will count from 0.

• In auto-reload mode, concerning the accuracy, it may not to configure the timer registers in the interrupt handler functions, because such operations will clear the counter.

#### 7.3.2.2 Timer2 Configuration Register (TIMER2\_SET\_H)

XRAM\_SFR Address: 0x206B

| Bit No.    | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|---|------------|---|---|---|---|---|---|
| Symbol     |   | -          |   |   |   |   |   |   |
| Read/Write |   | Read/Write |   |   |   |   |   |   |
| Po Initial |   |            |   |   |   |   |   |   |
| Value      |   |            |   | ( | J |   |   |   |

| Bit No. | Symbol | Description                                                                                                                                |  |  |  |  |
|---------|--------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7~0     |        | Timer2 count value configuration register, high 8 bits.<br>Configure the register during the scanning process will<br>refresh the counter. |  |  |  |  |

#### 7.3.2.3 Timer2 Configuration Register (TIMER2\_SET\_L)

#### XRAM\_SFR Address: 0x206C

| Bit No.    | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|---|------------|---|---|---|---|---|---|
| Symbol     |   |            |   |   |   |   |   |   |
| Read/Write |   | Read/Write |   |   |   |   |   |   |
| Po Initial |   | 0          |   |   |   |   |   |   |
| Value      |   |            |   | ( | J |   |   |   |

| Bit No. | Symbol | Description                                                                                                                               |  |  |  |  |
|---------|--------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7~0     |        | Timer2 count value configuration register, low 8 bits.<br>Configure the register during the scanning process will<br>refresh the counter. |  |  |  |  |

The registers TIMER2\_SET\_H and TIMER2\_SET\_L are used to configure the time setting. TTimer2 can be calculated as follows:

TTIMER2=TTIMER2\_CLK\*({TIMER2\_SET\_H, TIMER2\_SET\_L}+1)



### 7.3.2.4 RTC Configuration Register (RTC\_CFG)

XRAM\_SFR Address: 0x206D

| Bit No.    | 7~5 | 6~4         | 3~2         | 1          | 0          |
|------------|-----|-------------|-------------|------------|------------|
| Symbol     |     | RTC_CLK_FRE | RTC_CLK_SEL | RTC_RLD    | RTC_EN     |
| Read/Write |     | Read/Write  | Read/Write  | Read/Write | Read/Write |
| Po Initial |     | 0           | 0           | 0          | 0          |
| Value      |     |             | 0           | 0          | 0          |

| Bit No. | Symbol      | Description                                                 |  |  |  |  |
|---------|-------------|-------------------------------------------------------------|--|--|--|--|
|         |             | RTC module XTAL or PLL_24KHz clock frequency                |  |  |  |  |
|         |             | division selection.                                         |  |  |  |  |
|         |             | 000: selects clock frequency/1                              |  |  |  |  |
|         |             | 001: selects clock frequency/2                              |  |  |  |  |
|         |             | 010: selects clock frequency/4                              |  |  |  |  |
|         |             | 011: selects clock frequency/8                              |  |  |  |  |
| 6~4     | RTC_CLK_FRE | 100: selects clock frequency/16                             |  |  |  |  |
|         |             | 101: selects clock frequency/32                             |  |  |  |  |
|         |             | 110: selects clock frequency/64                             |  |  |  |  |
|         |             | 111: selects clock frequency/128                            |  |  |  |  |
|         |             | No matter in which mode, configure the register during      |  |  |  |  |
|         |             | the counting will clear the counter. If the present counter |  |  |  |  |
|         |             | enable is valid, it will count from 0 again.                |  |  |  |  |
|         |             | RTC clock selection register.                               |  |  |  |  |
| 3~2     | RTC_CLK_SEL | 00: select RC32KHz                                          |  |  |  |  |
| 02      |             | 01: select XTAL                                             |  |  |  |  |
|         |             | 10/11: select PLL_24MHz clock frequency division            |  |  |  |  |
|         |             | RTC auto-reload enable register.                            |  |  |  |  |
| 1       | RTC_RLD     | 1: auto-reload mode.                                        |  |  |  |  |
|         |             | 0: manual-reload mode.                                      |  |  |  |  |
|         |             | RTC counter enable register.                                |  |  |  |  |
|         |             | Configure 1 to enable the clock.                            |  |  |  |  |
|         |             | Configure 0 to stop it.                                     |  |  |  |  |
|         |             | In manual reload mode, hardware will auto-clear the         |  |  |  |  |
| 0       | RTC_EN      | register after the counting and stop the clock. In auto-    |  |  |  |  |
|         |             | reload mode, the register holds the enable after the        |  |  |  |  |
|         |             | counting, and clock starts to count from 0 again. In either |  |  |  |  |
|         |             | mode, configure the register as 1 will enable the clock to  |  |  |  |  |
|         |             | count from 0.                                               |  |  |  |  |

Configure the RTC\_CLK\_SEL/RTC\_CLK\_FRE to select RTC counter operation.



Note:

- Check if the clock is enabled.
- PD\_XTAL=0x1, disable XTAL clock. PD\_XTAL=0x0, enable XTAL. By default, this clock is off.
- In single-cycle timing mode, when the timing is up, it transmits an interrupt signal, then the interrupt falling edge will auto-clear the register.
- In auto-reload mode, when the timing is completed, interrupt signal is sent, enable register holding, the clock goes to the next round of timing.
- Configure the register at any time will reset it, therefore, after the interrupt signal is sent, the register will auto-clear the counter and the flag. If the configuration is 1 at this time, it will count from 0.
- In auto-reload mode, concerning the accuracy, it may not to configure the timer registers in the interrupt handler functions, because such operations will clear the counter.

#### 7.3.2.5 RTC Configuration Register (RTC\_SET\_H)

| Bit No.    | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------|---|------------|---|---|---|---|---|---|--|
| Symbol     |   | -          |   |   |   |   |   |   |  |
| Read/Write |   | Read/Write |   |   |   |   |   |   |  |
| Po Initial |   |            |   |   |   |   |   |   |  |
| Value      |   | 0          |   |   |   |   |   |   |  |

| XRAM | SFR | Address: | 0x206E |
|------|-----|----------|--------|
| XRAM | SFR | Address: | 0x206E |

| Bit No. | Symbol | Description                                                                                                                             |
|---------|--------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 7~0     |        | RTC count value configuration register, high 8 bits. Configure<br>the register during the scanning process will refresh the<br>counter. |

#### 7.3.2.6 RTC Configuration Register (RTC\_SET\_L)

#### XRAM SFR Address: 0x206F

| Bit No.    | 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|------------|---|---|---|---|---|---|---|
| Symbol     |            | - |   |   |   |   |   |   |
| Read/Write | Read/Write |   |   |   |   |   |   |   |
| Po Initial | 0          |   |   |   |   |   |   |   |
| Value      | 0          |   |   |   |   |   |   |   |

| Bit No. | Symbol | Description |
|---------|--------|-------------|
|---------|--------|-------------|



|     |  | RTC count value configuration register, low 8 bits. Configur |  |  |  |
|-----|--|--------------------------------------------------------------|--|--|--|
| 7~0 |  | the register during the scanning process will refresh the    |  |  |  |
|     |  | counter.                                                     |  |  |  |

RTC \_SET\_H and RTC \_SET\_L are used for time setting.

TRTC can be calculated as follows:

TRTC=TRTC\_CLK\*({RTC\_SET\_H, RTC\_SET\_L}+1)

# 7.4 Timer Configuration Flow Diagram

### 7.4.1 Timer0/1 Configuration Flow

Timer0/1 configuration flow as follows:



Figure 0.5 Timer0/1 Configuration

In the configuration process of Timer0/1,the initial timer value of Timer0/1 is calculated according to different timing modes.

```
16bit mode.TH0=(65536-N) /256, TL0=(65536-N)%256, N=t/Tclk
```

- 13bit mode.TH0=(8192-N) /32, TL0=(8192-N)%32, N=t/Tclk
- > 8bit mode TH0=(256-N), TL0=(256-N), N=t/Tclk。

where t is the timing time set according to the demand,Tclk is the system clock F\_sys\_clk.



### 7.4.2 Timer2/RTC Configuration Flow Diagram

Configure TIMER2\_CLK\_SEL/TIMER2\_CLK\_FRE to select the Timer2 clock.

PD\_XTAL=0x1, disable XTAL. PD\_XTAL=0x0, enable XTAL. By default, it is off. Check if the selected clock is enabled. RTC has the same configuration as the Timer2.



Figure0.6 Timer2/RTC configuration

Timer2/RTC Configuration Steps:

- 1. First, to set the frequency and clock source, configure {TIMER2\_CLK\_SEL/TIMER2\_CLK\_FRE}/{RTC\_CLK\_SEL/RTC\_CLK\_FRE}.
- 2. Then, Configure auto-reload enable of TIMER2\_RLD/RTC\_RLD accordingly. Set to 1 for auto cycle counting, otherwise set to 0.

3. Finally, configure the TIMER2\_EN/RTC\_EN. Set {TIMER2\_EN=1}/{RTC\_EN=1} to enable the counting.

4. Stop the counting. {TIMER2\_EN=0}/{RTC\_EN=0}.

Note:

- Put the configuration of {TIMER2\_EN=0x1}/{RTC\_EN=0x1} to the end.
- During the Timer2/RTC running, it is not recommended to change the configurations. If change is necessary, stop the timing first.
- If accuracy is concerned in auto-reload mode, it is not allowed to configure Timer2/RTC and reload the mode during the interrupt handling.



# 8 PWM

### **Timer Functions Comparison**

| Timer                               | Counter<br>width | Туре        | Prescaler<br>factor         | Capture/<br>Compare<br>Channel | Complementary<br>outputs | Repetition<br>counter | External<br>trigger<br>input | External<br>break<br>input | Timer<br>Synchronous<br>cascade |
|-------------------------------------|------------------|-------------|-----------------------------|--------------------------------|--------------------------|-----------------------|------------------------------|----------------------------|---------------------------------|
| <b>PWM0</b><br>Advanced<br>Timer    |                  | Up/<br>Down | 1 to<br>65536               | 4                              | 3                        | Yes                   | 1                            | 1                          | With<br>PWM1                    |
| PWM1<br>General<br>purpose<br>Timer | 16-bit           | Up          | 2 <sup>n</sup><br>n=1 to 15 | 3                              | No                       | No                    | 0                            | 0                          | Yes                             |

Figure 0.1 Timers Comparison

### Timer Signal Terminology

| Internal Signal<br>Name         | Description                                     | Related Diagram                                           |  |  |  |
|---------------------------------|-------------------------------------------------|-----------------------------------------------------------|--|--|--|
| BI                              | Break Interrupt                                 |                                                           |  |  |  |
| CCxI, CC1I, CC2I,<br>CC3I, CC4I | Capture/Compare Interrupt                       | <u>Figure 8.3 PWM0 Diagram</u>                            |  |  |  |
| CK_CNT                          | Counter                                         |                                                           |  |  |  |
| CK_PSC                          | Prescaler                                       | Figure 8.8 Prescaler factor 2 Counter<br>without Preload  |  |  |  |
| CNT_EN                          | Counter Enable                                  |                                                           |  |  |  |
| CNT_INIT                        | Counter initiation                              | Figure 0.20 External Clock Source Mode 1<br>Block Diagram |  |  |  |
| ETR                             | TIMx_ETR signal                                 | Figure 8.22 External Trigger Input Diagram                |  |  |  |
| ETRF                            | External Trigger Filter                         | Figure 0.22 External Trigger Input                        |  |  |  |
| ETRP                            | External Trigger Prescaler                      | Block Diagram                                             |  |  |  |
| f <sub>MASTER</sub>             | Peripheral Clock from Clock<br>Controller (CLK) | Figure 1.2 Clock Diagram                                  |  |  |  |
| ICx, IC1, IC2                   | Input Capture                                   | Figure 8.41 PWM0 Channel 1 Input                          |  |  |  |



| ICxPS, IC1PS,<br>IC2PS                       | Input Capture Prescaler                              |                                                                                                                                    |  |  |  |
|----------------------------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| MATCH1                                       | Compare Match                                        | Figure 8.32 Mster/Slave Mode Connection<br>Diagram                                                                                 |  |  |  |
| OCx, OC1, OC2                                | Timer Output Channel                                 | Figure 8 46 Detailed Output Medule                                                                                                 |  |  |  |
| OCxREF,<br>OC1REF,<br>OC2REF                 | Output Compare Reference<br>Signal                   | Figure 8.46 Detailed Output Module<br><u>Diagram (channel 1) with Complementary</u><br><u>Output</u>                               |  |  |  |
| TGI                                          | Trigger Interrupt                                    |                                                                                                                                    |  |  |  |
| Tlx, Tl1, Tl2                                | Timer Input                                          |                                                                                                                                    |  |  |  |
| TIxF, TI1F, TI2F                             | Timer Input Filter                                   |                                                                                                                                    |  |  |  |
| TI1_ED                                       | Timer Input edge detection                           |                                                                                                                                    |  |  |  |
| TIxFPx, TI1FP1,<br>TI1FP2,<br>TI2FP1, TI2FP2 | Timer Input Filter Prescaler                         | Figure 8.41 PWM0 Channel 1 Input                                                                                                   |  |  |  |
| TRC                                          | Trigger Capture                                      |                                                                                                                                    |  |  |  |
| TRGI                                         | Clock/Trigger/Slave Mode<br>Controller Trigger Input | <u>Figure 8.19 Control circuit sequence</u><br><u>diagram in Normal Mode with f<sub>MASTER</sub><br/><u>Prescaler Factor 1</u></u> |  |  |  |
| UEV                                          | Update Event                                         | Figure 8.12 Figure 0.12 Non-preload                                                                                                |  |  |  |
| UIF                                          | Update Interrupt                                     | Counter with Prescaler Factor of 2                                                                                                 |  |  |  |

Table 0.2 Internal Timer Signal Terminology

# 8.1 16-bit Advanced Timer PWM0

PWM0 consists of a 16-bit up/down auto-reload counter and a programmable prescaler that serves as a driver. In this chapter, x represents 1, 2, 3, 4, corresponding to 4 different capture/compare channels, respectively. Advanced control timer is suitable for various applications.

- 1. Basic Timing.
- 2. Measure pulse width of input signal (Input Capture)
- 3. generate output waveform (Output Compare, PWM and One Pulse Mode)
- 4. Correspond to interrupts of different events (capture, compare, overflow, break, trigger).
- 5. Sync with PWM1 or External Signals (external clock, reset signal, trigger and enable signal.

Advanced timers are widely used in all kinds of control applications, including those PWM requiring

Semiconductor



center-aligned mode. This mode supports complementary output and dead-time control. The clock source of advanced timer can be PLL\_24MHz, or external oscillator XTAL, which can be configured the register to select.

#### 8.1.1 Features

PWM0:

- 16-bit up, down, up/down auto-reload counter.
- Repetition counter allowing to update the timer register after the designated cycles
- 16-bit programmable (support real-time modification) prescaler PWM0\_PSC, the prescaler factor is within 1 to 65536.
- Synchronous circuit used in external signal control timer and timer interconnection.
- 4 independent channels support the configuration as follows:
  - Input Capture
  - Output Compare
  - > PWM Generation (edge-aligned or center-aligned)
  - Six steps for PWM output
  - > Output in one pulse mode
  - > 3 dead-time programmable channels with complementary output and
- Break input signal can put timer output signal into reset state or a known state.
- Events that triggers interrupt are including:
  - Update: counter overflow/underflow, counter initiation (via software or internal/external trigger)
  - > Trigger events (counter startup, stop, initiation or internal/external trigger)
  - Input capture
  - Output compare
  - Break signal input





Figure 0.3 PWM0 Diagram

### 8.1.2 Time Base Unit

Time Base Unit includes a 16-bit up/down counter, a prescaler, a 16-bit auto-reload register and repetition counter register. The read/write can be configured in software.





Figure 0.4 Time Base Unit

Auto-reload register consists of preload registers and shadow registers, supporting the write autoreload register in two modes below:

1. **Auto-preload enabled** (set the ARPE bit in the PWM0\_CR1), data written into auto reload register will be stored in preload register and passed to shadow register when the next update event happens.

2. **Auto-preload disabled** (clear the ARPE bit in the PWM0\_CR1), data written into auto reload register will immediately be written into shadow register.

Update events may generate three conditions as follows:

- 1. Counter overflow or underflow.
- 2. Set the UG bit in the PWM0\_EGR.
- 3. Clock/trigger controller generates a trigger event.

When preload is enabled (ARPE=1), if an update event occurs, data in preload register (PWM0\_ARR) will be written into shadow register, and data in PWM0\_PSCR register will be written to prescaler. Set the UDIS bit in PWM0\_CR1 will disable update events (UEV).

Counter is driven by CK\_CNT of prescaler, however, CK\_CNT is only valid when CEN bit in PWM0 CR1 is enabled.

Note:

After the CEN bit is enabled for a cycle, the counter starts to count.

#### 8.1.2.1 Read/Write 16-bit Counter

Write operation on counter is not cached and can write registers PWM0\_CNTRH and PWM0\_CNTRL at any time. Therefore, it is not recommended to write a new value in it when counter is running, in case any wrong value is written into it.

Read operation on counter has an 8-bit cache. After user reads high byte, low byte will be automatically cached. Cached data will not change before the16-bit read operation is completed.



(See figure 8.5)



Figure 0.5 Read a 16-bit counter (PWM0\_CNTR)

Note: Do not read out low byte first, because the read-out value is wrong.

## 8.1.2.2 Read/Write 16-bit register PWM0\_ARR

Write the value of Preload register into the 16-bit register PWM0\_ARR with high byte first and low byte next. Shadow register will be locked during the high byte write operation and holding the state till the low byte write operation is competed.

Note: Do not write low byte first, which will result in data error.

To read out the PWM0\_ARR requires to preload the register.

#### 8.1.2.3 Prescaler

PWM0 prescaler is based on a 16-bit counter controlled by a 16-bit register (PWM0\_PSCR). Since the control register has a buffer, therefore, it can be changed during the running. Prescaler can divide the clock frequency of counter by any integer from 1 to 65536. Counter frequency can be calculated as follows:

 $f_{CK\_CNT} = f_{CK\_psc} / (PSCR[15:0] + 1)$ 

Write the value of prescaler via preload register. Shadow register contained the present value is loaded when LSB is written into.

Prescaler value requires two independent write operations to write the 16-bit register. Write high bits first and do not use LDW command to write low bits.

The new value of prescaler will be adopted for the next update event.

Read the PWM0\_PSCR through preload register, which requires no special attention.

## 8.1.2.4 Up-counting Mode

In up-counting mode, counter first counts from 0 to the compare value (value of PWM0\_ARR register) that defined by user, then restart to count and generate an overflow event. Concurrently, if UDIS bit of PWM0\_CR1 is 0, it will generate an update event (UEV) that will update the flag bit UIF. If update



interrupt enables UIE=1, it generates an update interrupt. Figure 8.6 shows the up-counting mode.





Set the UG bit in PWM0\_EGR (via software or slave controller) can also generate an update event. Use software to set UDIS bit in PWM0\_CR1 to ban update events, which can avoid updating shadow register while updating the preload register. No update event will be generated before the UDIS bit is cleared. Although when there should be an update event, the counter shall still be cleared to 0, concurrently prescaler will be cleared too (its value remains unchanged). Moreover, if the URS bit is set in the PWM0\_CR1 (select update request). Set UG bit will generate an update event. However, hardware does not set UIF flag, which means it does not generate an interrupt request. This is to avoid generating an update and capture interrupt while clearing the counter in capture mode. When an update event occurs, all registers will be updated. Concurrently, hardware sets the update flag bit (UIF bit in the PWM0\_SR) according to the URS bit.

- > auto-reload the value of shadow register that reset into preload register (PWM0 ARR).
- > Set the value of preload register PWM0\_PSC into the buffer of prescaler.

Figure 8.7 shows the update sequence of an up counter when ARPE=1(ARR preload enable).





Figure 0.7 Up Counter Sequence Diagram (In PWM0\_CR1, ARPE=1)

Figure 8.8 shows an example of counter behavior at different clock frequencies when PWM0\_ARR=0x36.

#### Example 1

When ARPE=0 (ARR without preload), the counter be updated with prescaler factor of 2.



Figure 0.8 Non-preload Counter with Prescaler Factor of 2

Since the prescaler factor is 2, the counter (CK\_CNT) is half the frequency of prescaler (CK\_PSC). The counter overflows when reaching to 0x36 because the auto-reload function is disabled (ARPE=0), then the shadow register will be updated and generates an Update Event.

#### Example 2

When ARPE=1(ARR preload enable), the counter be updated with prescaler factor of 1.





Figure 0.9 Preload Counter with Prescaler Factor of 1

Prescaler Factor is 1, therefore the frequency of CK\_CNT is the same with CK\_PSC. Enable auto-reload as ARPE=1, therefore counter will overflows when reaching to 0xFF, then 0x36 will be written upon overflow, generating an update event at the same time.

## 8.1.2.5 Down-counting Mode

In down-counting mode, counter counts down from the the auto-reload value (contained in PWM0\_ARR) to 0, then starts to count from the auto-reload value again and generate an underflow event. If UDIS bit in PWM0\_CR1 is cleared, it will generate an UEV,which will update the flag bit UIF. If update interrupt enable is set UIE=1, it will trigger an update interrupt. Figure 8.10 demonstrates the down counter.



Set the UG bit in PWM0\_EGR via software or slave controller can also generate an UEV. Use software to set UDIS bit in PWM0\_CR1 can banUEVs, avoiding to update the shadow register while updating the preload register. No UEV occurs before the UDIS bit is cleared. Nevertheless,



counter still restarts to count from the present auto-reload value, and the counter of prescaler begins to count from 0 again (prescaler cannot be modified). Moreover, if set URS bit in PWM0\_CR1 to select update request, setting UG bit will generate an UEV. However, hardware does not set UIF bit, which means it does not trigger interrupt request. This is to avoid generating an update and capture interrupt while clearing the counter in capture mode.

When an UEV occurs, all registers will be updated and reset the update flag bit (UIF in PWM0\_SR) according to URS bit setting.

- > Reset the value of preload register (PWM0\_ARR) into auto-reload shadow register.
- Reset the value of PWM0\_PSC into Buffer of prescaler.

The present auto-reload register is updated into the preload value in PWM0\_ARR. It is noted that auto-reload register is updated before the counter reloads, therefore, the expected value is in the next cycle.

Figure 8.11 shows the down counter update sequence diagram when ARPE=1(ARR preload enable).



Figure 0.11 Down Counter Sequence Diagram (In PWM0\_CR1, ARPE=1)

Figure 8.12 shows an example of counter behavior at different clock frequencies when PWM0 ARR=0x36.

#### Example 1

When ARPE=0 (ARR without preload), the counter be updated with prescaler factor of 2.





Figure 0.12 Non-preload Counter with Prescaler Factor of 2

## Example 2

When ARPE=1(ARR preload enable), counter with prescaler factor of 1 will be updated.



Figure 0.13 Preload Counter with Prescaler Factor of 1

## 8.1.2.6 Center Aligned Mode (Count Up/Down)

In center aligned mode, counter counts up from 0 to the auto-reload value (PWM0\_ARR) minus 1, which generates an overflow event. Then, it counts down from auto-reload value to 0 and generates an underflow event. After that, it counts from 0 again.

In this mode, direction bit DIR of PWM0\_CR1 can not be written, which is updated by hardware and



points to the present counting direction. Figure 8.14 shows the center aligned mode.



If the repetition counter of timer does not equal to 0, then it will generate an UEV after repeating the designated times (value of PWM0\_RCR) of overflow and underflow. Otherwise, for every overflow or underflow, an update event will be generated.

Set the UG bit in PWM0\_EGR via software or slave controller can also generate an update event. At this time, counter initializes and restarts to count, and prescaler also initializes and restarts to count.

Set the UDIS bit to 1 in PWM0\_CR1 to ban UEV, which avoids updating shadow register when updating the preload register. Therefore, no update event occurs before the UDIS bit is cleared to 0. However, counter still counts up or down according to auto-reload value. For timer with a repetition counter, new repeat value will be immediately valid because there is no double buffer in repetition register, so be careful when modifying it.

Moreover, if set the URS bit in PWM0\_CR1 (select update request), then setting the UG bit will generate an UEV. However, hardware does not set UIF flag bit, which means it does not trigger interrupt request. This is to avoid generating an update and capture interrupt while clearing the counter in capture mode.

When an UEV occurs, all registers will be updated and set the update flag bit (UIF in PWM0\_SR) according to URS bit setting.

- If the ARPE bit of PWM0\_CR1 is set to 1, auto-reload shadow register will be set with the value of preload register (PWM0\_ARR).
- > Prescaler buffer is set with the value of preload register (PWM0\_PSCR).

The present auto-reload register is updated to the preload value of PWMx\_ARR. It is noted that if it is counter overflow that generates the update, auto-reload register is updated before the counter reloads, so the expected value is in the next cycle, which means counter will be loaded with new value.

Figure 8.15 shows the center aligned counter update sequence when ARPE=1 (ARR preload enabled).



|                     | +           | 计数时钟 f <sub>MASTER</sub>    | *                             | 计数时钟: f <sub>MASTER</sub> /3        |                                 |
|---------------------|-------------|-----------------------------|-------------------------------|-------------------------------------|---------------------------------|
| f <sub>MASTER</sub> |             |                             |                               |                                     | mm                              |
| CNT_EN_             |             |                             |                               |                                     |                                 |
| TIME_CNT_           | 0 X 1 X 2 X | (23 X 24 X 23 X 22 X 21 X X | (1X 0 X 1 X )                 | 44 X 45 X 44 X                      | X 2 X 1 X 0                     |
| PWM0_ARR            | 24          | χ 45                        |                               |                                     |                                 |
| PWM0_ARR_SHADOW     | 24          |                             | X 45                          |                                     |                                 |
| PWM0_UIF-           |             | <b>→</b><br>3*mcu_clk       |                               |                                     |                                 |
| SCALED-             |             |                             |                               |                                     |                                 |
| MCU_CNT             |             |                             | 0 X 1 X 2 X 0 X 1 X 2 X X 2 X | 0 X 1 X 2 X 0 X 1 X 2 X 0 X 1 X 2 X | X 2 X 0 X 1 X 2 X 0 X 1 X 2 X 0 |
| CK_CNT_             |             |                             |                               |                                     |                                 |
| CNT_UNDERFLOW_      |             |                             |                               |                                     |                                 |
| CNT_OVERFLOW_       |             |                             |                               |                                     |                                 |
| PWM0_PSCR_          |             | 0 X 2                       |                               | i i                                 |                                 |
| PWM0_PSCR_SHADOW    |             | 0                           | X 2                           |                                     |                                 |

Figure 0.15 Center Aligned Counter Sequence Diagram (In PWM0\_CR1, enable ARPE=1)

Figure 8.16 shows the counter sequence diagram when internal clock with a prescaler factor of 1 PWM0\_ARR=0x6, ARPE=1.



Figure 0.16 Preload Counter Sequence Diagram with Prescaler Factor of 1

#### Notes on center aligned mode:

- Enabled center aligned mode, counter will count according to the previous up/down configuration, which means the DIR bit of PWM0\_CR1 will decide to count up or count down. Software cannot modify the DIR and CMS bit at the same time.
- It is not recommended to write on counter during the counting in this mode, which will result



Semiconductor

in unexpected results as follows:

- Down counter writes a value larger than auto-reload value to counter (PWM0\_CNT> PWM0\_ARR), but its counting direction will not change. For example, counter has overflowed, but it still counts up.
- > Down counter writes into 0 or value of PWM0\_ARR, but no UEV occurs.
- The safe way to use center aligned counter is to use software to generate an UEV before the counter enabled (set the UG bit of PWM0\_EGR) and do not change its value during the counting.
- After a cycle (CK\_CNT) of CEN bit is enabled, the counter begins to count.
- After the counter is enabled, it is not allowed to change edge aligned mode to center aligned mode.
- In this mode, encoder mode (in PWM0\_SMCR, SMS=001, 010, 011) must be banned.
- If initial counting direction is configured as down in center aligned mode, configure DIR =1 in PWM0\_CR1 first, and configure CMS after delays.

#### 8.1.2.7 Repetition Down Counter

The repeat counter is a counter that counts down. This is because the update event (UEV) can only be generated when the value of the repeat counter reaches 0, which means that every N times of counting overflow or underflow, data is transferred from the preload registers to the shadow registers (auto-reload register PWM0\_ARR, preload register PWM0\_PSC, as well as the capture/compare register PWM0\_CCRx in compare mode), and N is the value in the repeat counter register PWM0\_RCR. The repetition counter decrements when either of the following conditions holds:

- > Each time the counter overflows in up-counting mode
- > Each time the counter underflows in Down-counting mode
- > Each time the counter overflows or underflows in center aligned mode

Although this limits the maximum repetition times of PWM to 128, it is able to update the duty cycle 2 times per PWM cycle. In central aligned mode, the waveform should be symmetrical and the maximum resolution is 2xTck\_psc if the compare register is refreshed only once in each PWM cycle. The repetition counter is automatically loaded and the repeat rate is defined by the value of PWM0\_RCR register, which can be referred to Figure 8.17 below.





Figure 0.17 Example of update rate in different modes and PWMx\_RCR setting

When an update event is generated by software (by setting the UG bit in PWM0\_EGR) or by the hardware slave controller, the update event occurs immediately regardless of the repetition counter value, and the contents of the PWM0\_RCR register are reloaded into the repetition counter.

## 8.1.3 Clock/Trigger Controller

The clock/trigger controller allows the user to select the clock source, input trigger signal and output signal for counter.







## 8.1.3.1 Prescaler Clock (CK\_PSC)

The prescaler (CK\_PSC) of the Time Base Unit can be provided by the following sources:

- 1. Internal clock ( $f_{MASTER}$ )
- 2. External clock mode 1: External clock input (TIx)
- 3. External clock mode 2: External trigger input ETR
- Internal Trigger Input (ITR): Use the general-purpose timer PWM1 as the prescaler for advanced timer PWM0. For more information, please refer to *Figure 0.32 Master/Slave* <u>Connection</u> for more information.

#### 8.1.3.2 Internal clock source (f<sub>MASTER</sub>)

If both the trigger controller and the external trigger input are disabled (SMS=000 in the PWM0\_SMCR register and ECE=0 in the PWM0\_ETR register), the CEN, DIR and UG bits are effectively control bits and can only be modified by software (the UG bit is automatically cleared). Once the CEN bit is set to 1, the clock of prescaler is provided by the internal clock  $f_{MASTER}$ . Figure 8.19 demonstrates the operation of the control circuit and up counter in normal mode without prescaler (fMASTER prescaler factor of 1).



Figure 0.19 Timing diagram of the control circuit in normal mode with f<sub>MASTER</sub> prescaler factor of 1

## 8.1.3.3 External Clock Source Mode 1

This mode is selected when SMS=111 in PWM0\_SMCR register. The counter can count on each rising or falling edge of the selected input, as shown in Figure 8.20.





Figure 0.20 External Clock Source Mode 1 Block Diagram

For example, to configure the up counter to count on the rising edge of the TI2 input, use the following steps:

- 1) Configure the PWM0\_CCMR2 register with CC2S=01 and use channel 2 (CC2) to detect the rising edge of TI2 input.
- Configure the IC2F[3:0] bits of the PWM0\_CCMR2 register to select the input filter bandwidth (if no filter is needed, keep IC2F=0000).
   Note: The capture prescaler is not used for triggering and therefore does not need to be configured.
- 3) Configure the PWM0\_CCER1 register with CC2P=0 to select the rising edge polarity.
- 4) Configure PWM0\_SMCR register with SMS=111 to set the counter to use external clock mode 1.
- 5) Configure the PWM0\_SMCR register with TS=110 and select TI2 as the input source.
- 6) Set CEN=1 of PWM0\_CR1 register to start the counter.

When the rising edge occurs at the selected input, the counter counts once and the trigger flag bit (TIF bit in PWM0\_SR1 register) is set to 1. If the interrupt is enabled (configured in PWM0\_IER register), an interrupt request is generated.

The delay between the rising edge of TI2 and the counter clock depends on the resynchronization circuit at the TI2 input.







## 8.1.3.4 External Clock Source Mode 2

The counter is capable of counting on each rising or falling edge of the External Trigger Input (ETR) signal. This mode can be selected by writing 1 to the ECE bit of the PWM0\_ETR register. Figure 8.22 demonstrates the general block diagram of the external trigger input.



Figure 0.22 External Trigger Input Block Diagram

For example, to configure the counter to count up once every 2 rising edges of the ETR signal, use the following steps:

- 1) In this example, no filter is needed, configure the PWM0\_ETR register with ETF[3:0]=0000
- 2) Set prescaler, configure ETPS[1:0]=01 of PWM0\_ETR register
- 3) Select the rising edge detection of ETR, configure ETP=0 of PWM0\_ETR register
- 4) Enable external clock mode 2, configure ECE=1 in PWM0\_ETR register
- 5) Start the counter, write CEN=1 in PWM0\_CR1 register



- 6) The counter counts every 2 rising edges of the ETR.
- 7) The delay between the rising edge of the ETR and the counter clock depends on the resynchronization circuit at the ETRP signal side.



Figure 0.23 Control Circuit in External Clock Mode 2

## 8.1.3.5 Trigger Synchronization

The counter allows four trigger inputs (Refer to *Table 0.2 Internal Timer Signal Terminology*)

- 1) ETR
- 2) TI1
- 3) TI2
- 4) TRGO from PWM1

The PWM0 counter uses three modes to synchronize with the external trigger signal: standard trigger mode, reset trigger mode, and gate trigger mode.

When TRGI occurs a rising edge, the counter starts counting driven by the internal clock  $f_{MASTER}$  and set TIF flag bit. The delay between the rising edge of the TRGI and the counter beginning counting depends on the resynchronization circuit at the TRGI input.

#### 8.1.3.5.1 Standard Trigger Mode

The counter enable depends on the event from the selected input.

In Figure 8.24, the counter starts counting up on the rising edge of the TI2 input.

- Configure channel 2 (CC2) to detect the rising edge of TI2. Configure the input filter bandwidth (in this example, no filter is needed, keep IC2F=0000). The capture prescaler is not used in trigger operation and does not need to be configured. Configure the PWM0\_CCER1 register with CC2P = 0 and select the rising edge as the trigger condition.
- > Configure SMS=110 of PWM0\_SMCR register to select counter as trigger mode; configure



TS=110 in PWM0\_SMCR register to select TI2 as input source.

When a rising edge appears on TI2, the counter starts counting driven by the internal clock and the TIF flag is set at the same time.

The delay between the rising edge of TI2 and the start of the counter depends on the resynchronization circuit at the TI2 input.



Figure 0.24 Control Circuit for Standard Trigger Mode

See Standard Trigger timing diagram below.



Figure 0.25 Standard Trigger Timing Diagram

#### 8.1.3.5.2 Reset Trigger Mode

When a trigger input event occurs, the counter and its prescaler can be reinitialized; at the same time, an UEV is also generated if the URS bit of the PWM0\_CR1 register is low; then all the preload registers (PWM0\_ARR, PWM0\_PSCR, PWM0\_CCRx) are updated.

In the following examples, the rising edge on the TI1 input causes the up counter to be cleared to 0.

Configure channel 1 to detect the rising edge of TI1. Configure the bandwidth of the input filter (in this example, no filter is needed, so keep IC1F=0000). The capture prescaler is not used in the trigger operation, so no configuration is required. The CC1S bit is only used to

# Semiconductor

# BS9000AMxx

select the input capture source which also does not need to be configured. Configure the PWM0 CCER1 register with CC1P=0 to select the polarity (rising edge detection only).

- > Configure SMS=100 in PWM0 SMCR to select timer as reset trigger mode; configure TS=101 in PWM0 SMCR to select TI1 as input source.
- Configure CEN=1 of PWM0\_CR1 register to start the counter.  $\succ$

The counter starts counting according to the internal clock until a rising edge appears on TI1; also, the counter is cleared and starts counting from 0 again. At the same time, the trigger flag (TIF bit in PWM0\_SR1 register) is set and an interrupt request is generated if the interrupt is enabled (TIE bit in PWM0 IER register).

The delay between the rising edge of TI1 and the actual reset of the counter depends on the resynchronization circuit at the TI1 input. The figure below shows the behavior at the auto-reload register PWM0 ARR = 0x36.



Figure 0.26 Control Circuit in Reset Trigger Mode



Figure 0.27 Reset Trigger Timing Diagram

## 8.1.3.5.3 Gate Trigger Mode

The counter is enabled by the current level of the selected input signal. In the following example, the counter only counts up when TI1 is low:

# Semiconductor

# BS9000AMxx

- Configure channel 1 for detecting the low level on TI1. Configure the input filter bandwidth (in this example, no filtering is required, so keep IC1F=0000). The capture prescaler is not needed in the trigger operation, so no configuration is required. The CC1S bit is used to select the input capture source and also does not need to be configured. Configure the PWM0\_CCER1 register with CC1P=1 to determine the polarity (detect low level only).
- 2) Configure SMS=101 in PWM0\_SMCR register to select timer as gate trigger mode; configure TS=101 in PWM0\_SMCR register to select TI1 as input source.
- 3) Configure the PWM0\_CR1 register with CEN=1 to start the counter (in gate control mode, if CEN=0, the counter cannot be started, regardless of the trigger input level).

The counter starts counting according to the internal clock as long as TI1 is low, and stops counting once TI1 becomes high. The TIF flag bit is set when the counter either starts or stops.

The delay between the rising edge of TI1 and the actual stop of the counter depends on the resynchronization circuit at the TI1 input.



Figure 0.28 Control Circuit in Gate Trigger Mode



Figure 0.29 Gate Trigger Timing Diagram

## 8.1.3.5.4 External Clock Mode 2 + Trigger Mode

External clock mode 2 can be used with another input signal in trigger mode. In this case, the ETR signal is used as an input to the external clock and the other input signal can be used as a trigger mode (standard trigger mode, reset trigger mode and gate trigger mode are supported).



Note: The ETR signal cannot be configured as input signal TRGI at this time (via the TS bit in the PWM0\_SMCR register).

In the following example, the counter counts up once on each rising edge of the ETR once a rising edge occurs on TI1.

- Configure the external trigger input circuit via the PWM0\_ETR register. In this example, ETF = 0000 since no filtering is used. Configure ETPS = 00 to disable prescaler, ETP = 0 to monitor the rising edge of the ETR signal, and ECE = 1 to enable external clock mode 2.
- Use channel 1 to monitor the rising edge of TI1. Configure input filter (since no filter is required there, configure IC1F=0000). Since the trigger operation does not use prescaler, so there is no need to configure it and the CC1S bit is only used to select the input capture source and therefore does not need to be configured. Configure the PWM0\_CCER1 register with CC1P=0 to select the rising edge trigger.
- Configure SMS=110 in PWM0\_SMCR register to select timer as trigger mode. Configure TS=101 in PWM0\_SMCR register to select TI1 as input source.

When a rising edge occurs on TI1, the TIF flag is set and the counter starts counting on the rising edge of ETR.

The delay between the rising edge of the TI1 signal and the actual counter clock depends on the resynchronization circuit at the TI1 input.

The delay between the rising edge of the ETR signal and the actual counter clock depends on the resynchronization circuit at the ETRP input.



Figure 0.30 Control Circuit in External Clock Mode 2 + Trigger Mode

## 8.1.3.6 Sync with General Purpose Timer PWM1

Timers are interconnected inside the chip for synchronization or linking. When a timer is configured as master mode, it can output a trigger signal (TRGO) to those timers configured as slave mode to



complete reset, start, stop operations, or as a drive clock for those timers.



Figure 0.31 Trigger Master/Slave Mode Selection

## 8.1.3.6.1 Use a Timer as a Prescaler for Another Timer

Figure 8.32 shows an example of trigger Master/Slave Mode.



Figure 0.32 Master/Slave Connection

For example, the user can configure Timer A as a prescaler for Timer B, which requires configurations as follows:

Semiconductor



- Configure Timer A as the master mode so that a periodic trigger signal is output at each update event (UEV). Configure the PWMx\_CR2 register with MMS=010 so that TRGO1 can output a rising edge at each update event.
- 2) The TRGO1 signal output from Timer A is linked to Timer B. Timer B needs to be configured to trigger slave mode, using ITR1 as the input trigger signal. The above-mentioned operation can be achieved by configuring the TS bit in the PWMx\_SMCR register (configure the TS=100 in the PWM0\_SMCR register).
- Configuring SMS=111 in the PWMx\_SMCR register sets the clock/trigger controller to external clock mode 1. This operation will enable the rising edge of the periodic trigger signal (generated by the overflow of Timer A) output from Timer A to drive the clock of Timer B.
- 4) Finally, set the CEN bit of both timers (in PWMx\_CR1 register) to enable them.

Note: If OCx is selected as the trigger signal for Timer A output (MMS=1xx), its rising edge will drive the clock of Timer B.

#### 8.1.3.6.2 Use One Timer to Enable Another Timer

Figure 8.33 shows that Timer B is enabled by the comparison output of Timer A. Please refer to the following diagram for the connection of the timers <u>*Figure 0.32 Master/Slave Connection*</u>. Timer B only counts according to its own drive clock when the OC1REF signal of Timer A is high. Both timers use a  $f_{MASTER}$  with prescaler factor of 4 as the clock ( $f_{CK_CNT} = f_{MASTER}/4$ ).

- 1) Configure Timer A as the master mode and output the comparison output signal (OC1REF) as the trigger signal. (Configure PWMx\_CR2 register with MMS=100).
- 2) Configure the waveform of Timer A OC1REF signal (PWMx\_CCMR1 register).
- 3) Configure Timer B to use the output of Timer A as its own trigger input signal (configure the PWMx\_SMCR register with TS=100).
- 4) Configure Timer B as gate trigger mode (configure SMS=101 of PWMx\_SMCR register).
- 5) Set the CEN bit (PWMx\_CR1 register) to enable Timer B.
- 6) Set the CEN bit (PWMx\_CR1 register) to enable Timer A.

#### Note:

The clocks of the two counters are not synchronized, which affects only the enable signal of Timer B.

Figure 8.33 shows Timer A output gate triggering Timer B.





Figure 0.33 Timer A Output Gate Triggering Timer B

Both the counter and prescaler of Timer B above are not initialized before startup, so both start counting from the existing value. If the two timers are reset before starting Timer A, the user can write the desired value to the timer's counter to make it count from the specified value. The reset operation of the timers can be achieved by software writing the UG bit of the PWMx\_EGR register.

 In the next example, we synchronize Timer A and Timer B. Timer A is in master mode and starts counting from 0. Timer B is triggered slave mode and starts counting from 0xE7.
 Both timers use the same prescaler factor. When the CEN bit of PWMx CR1 register is

cleared, Timer A is disabled and Timer B stops counting at the same time.

- 2. Configure Timer A as the master mode and the comparison output signal (OC1REF) as the trigger signal to output. (Configure PWMx\_CR2 register with MMS=100).
- 3. Configure the waveform of OC1REF signal of Timer A (PWMx\_CCMR1 register).
- 4. Configure Timer B to use the output of Timer A as its own trigger input signal (configure the PWMx\_SMCR register with TS=100).
- 5. Configure Timer B as gate trigger mode (configure SMS=101 of PWMx\_SMCR register).
- 6. Reset Timer A by writing 1 to the UG bit (PWMx\_EGR register).
- 7. Reset Timer B by writing 1 to the UG bit (PWMx\_EGR register).
- 8. Initialize Timer B by writing 0xE7 into Timer B counter (PWMx\_CNTRL).
- 9. Enable Timer B by writing 1 to the CEN bit (PWMx\_CR1 register).
- 10. Timer A is started by writing 1 to the CEN bit (PWMx\_CR1 register).
- 11. Stop Timer A by writing 0 to the CEN bit (PWMx\_CR1 register).

Figure 8.34 shows the counter enable signal (CNT\_EN) of timer A gated to trigger timer B.





Figure 0.34 Counter enable signal (CNT\_EN) of timer A gates to trigger timer B

#### 8.1.3.6.3 Use One Timer to Start Another Timer

Timer B is enabled with an update event from Timer A. Timer B counts from its existing value (which can be a non-zero value) according to Timer B's own drive clock when an update event occurs from Timer A. Timer B automatically enables the CEN bit when it receives a trigger signal and continues until the user writes a 0 to the PWMx\_CR1 register. Timer B automatically enables the CEN bit upon receipt of a trigger signal and starts counting until the user writes 0 to the CEN bit of the PWMx\_CR1 register. Both timers use a  $f_{MASTER}$  with a prescaler factor of 4 as the drive clock ( $_{fCK}$  CNT =  $f_{MASTER}/4$ ).

- 1) Configure Timer A as the master mode and output the update signal (UEV). (Configure PWMx\_CR2 register with MMS=010).
- 2) Configure the period of timer A (PWMx\_ARR register).
- 3) Configure Timer B to use the output of Timer A as the trigger signal for the input (configure the PWMx\_SMCR register with TS=100).
- 4) Configure Timer B as trigger mode (configure SMS=110 of PWMx\_SMCR register).
- 5) Set the CEN bit (PWMx\_CR1 register) to start Timer A.

Figure 8.35 shows the timing diagram of Timer A update event (TIMERA-UEV) triggering Timer B.

# Semiconductor

## BS9000AMxx



Figure 0.35 Timer A Update Event (TIMERA-UEV) Triggers Timer B

As in the previous example, the user can also initialize the counters before starting them. The example below uses the same configuration with *Figure 8.34 Counter enable signal (CNT EN) of timer A gates to trigger timer B*, but with the normal trigger mode (configuring SMS=110 of PWMx\_SMCR register) instead of the gated trigger mode.



Figure 0.36 Counter enable signal CNT\_EN of Timer A triggers Timer B



#### 8.1.3.6.4 Trigger Two Timers Synchronously with External Signals

Timer A is enabled using the rising edge of TI1, and Timer B is enabled at the same time. Timer is connected as shown in *Figure 0.32* Master/Slave Connection. To maintain the timer link, Timer A needs to be configured as master/slave mode (slave mode for TI1 signal and master mode for Timer B).

- 1) Configure Timer A as the master mode and output enable signal as the trigger of Timer B (configure MMS=001 of PWMx CR2 register).
- 2) Configure Timer A as slave mode and use TI1 signal as the input trigger signal (configure the PWMx\_SMCR register with TS=100).
- 3) Configure the trigger mode of Timer A (configure SMS=110 of PWMx\_SMCR register).
- 4) Configure Timer A as master/slave mode (configure MSM=1 of PWMx\_SMCR register).
- 5) Configure Timer B to use the output of Timer A as the input trigger signal (configure the PWMx\_SMCR register with TS=100).
- 6) Configure the trigger mode of Timer B (configure SMS=110 of PWM0\_SMCR register).

When a rising edge occurs on TI1 (Timer A's), both timers start counting synchronously and the TIF bits are set.

Note: In this example, both timers are initialized (set UG bit) before starting, so they both start counting from 0. However, the user can also insert an offset by modifying the counter register (PWMx\_CNT), in which case a delay will be inserted between the CK\_PSC signal and the CNT\_EN signal in timer A.



Figure 0.37 TI1 Signal from Timer A triggers Timer A and Timer B



## 8.1.4 Capture/Compare Channels

The timer I/Os (PWM0\_CCx) can be used as input capture or output compare. This function can be implemented by configuring the CCxS channel selection bit of Register (PWM0\_CCMRx) in Capture/Compare Channel Mode, where the x represents the number of channels.

Each capture/compare channel is built around a capture/compare register (containing shadow registers), including the capture input (digital filter, multiplexer, and prescaler), and capture output (comparator and output control).



Figure 0.38 Main Circuit for Capture/Compare Channel 1

The capture/compare module consists of a preload register and a shadow register. The read/write operates only on the preload register.

In capture mode, the capture occurs on the shadow register and is then copied to the preload register. In compare mode, the contents of the preload register are copied to the shadow register, and then the contents of the shadow register are compared with the counter.

When the channel is configured as output mode (CCxS=0 in PWM0\_CCMRx register), the PWM0\_CCRx register can be accessed at any time. (The x here refers to the number of channels) When the channel is configured as input mode, the read operation on the PWM0\_CCRx register is similar to the counter read operation (See Figure 8.39). When a capture occurs, the counter contents are captured to the PWM0\_CCRx shadow register and later copied to the preload register. The preload register is frozen while the read operation is in progress.





Figure 0.39 Read Operation of the 16-bit PWM0\_CCRx register in capture mode

Figure 8.39 demonstrates how the 16-bit CCRx register reads. The cached data will remain unchanged until the read operation ends.

At the end of the whole read process, if only the PWM0\_CCRxL register is read, the low bit (LS) of the counter value is returned.

If the high (MS) data is read after the low (LS) data, this low data will not be returned.

## 8.1.4.1 Read/Write the 16-bit PWM0\_CCRx Register

When the channel is configured as output mode, the write operation of the 16-bit PWM0\_CCRx register is implemented through the preload register. The high byte must be written first. While writing the high byte, shadow register update is disabled until the low byte write operation is completed, which is similar to PWM0\_ARR register write operation.

The read operation of the PWM0\_CCRx register is implemented through the pre-load register.

When the channel is configured as input mode, the PWM0\_CCRx register is read-only at this time. The read operation of the PWM0\_CCRx register is similar to that of the counter. When a capture occurs, the contents of the counter are captured into the PWM0\_CCRx shadow register and later copied into the preload register. The preload register is frozen while the read operation is in progress.



#### 8.1.4.2 Input Module



Figure 0.40 Input Module Block Diagram

As shown below, input the corresponding TIx input signal to sample and generates a filtered signal TIxF. An edge monitor with polarity selection then generates a signal (TIxFPx) that can be used as an input trigger for the trigger mode controller or as a capture control. This signal is prescaled into a capture register (ICxPS).



Figure 0.41 Inputs of PWM0 Channel 1

#### 8.1.4.3 Input Capture Mode

In the input capture mode, the present value of the counter is latched into the capture/compare register (PWM0\_CCRx) when the corresponding edge on the ICx signal is detected. When a capture event occurs, the corresponding CCxIF flag (PWM0\_SR register) is set to 1.

If the CCxIE bit of the PWM0\_IER register is set, which means an interrupt is enabled, then an interrupt request will be generated. If the CCxIF flag is already high when a capture event occurs, the repeat capture flag CCxOF (PWM0\_SR2 register) is set to 1. Writing CCxIF=0 or reading the capture data stored in the PWM0\_CCRxL register clears CCxIF. Writing CCxOF=0 clears CCxOF. The examples below describe how to capture the counter value to the PWM0\_CCR1 register on the rising edge of the TI1 input. See steps as follows:

- 1) Select a valid input: for example, PWM0\_CCR1 is connected to the TI1 input, so write CC1S=01 to the PWM0\_CCMR1 register, at which point the channel is configured as an input and the PWM0\_CCR1 register becomes read-only.
- 2) According to the characteristics of the input signal TIx, the filtering time of the corresponding input filter can be set by configuring the ICxF bit in the PWM0\_CCMRx register. Assuming that the input signal is jittered for a maximum of 5 clock cycles, the bandwidth of the filter shall be configured to be longer than 5 clock cycles; therefore, it can be sampled 8 times in succession to confirm a true edge transition on TI1, i.e., write IC1F=0011 in the PWM0\_CCMR1 register, at which point, the signal is valid only if 8 identical TI1 signals are sampled in succession (sampling frequency is f<sub>MASTER</sub>).
- Select the valid conversion edge of TI1 channel and write CC1P=0 (rising edge) in PWM0\_CCER1 register.
- 4) Configure the input prescaler. In this example, we want the capture to occur at every active level transition moment, so the prescaler is disabled (write IC1PS=00 in PWM0\_CCMR1 register).
- 5) Set CC1E=1 in PWM0\_CCER1 register to allow the counter value captured into the capture register.
- 6) If required, allow the associated interrupt request by setting the CC1IE bit in the PWM0\_IER register.

When an input capture occurs,

- When a active level transition is generated, the counter value is transferred to the PWM0\_CCR1 register.
- The CCxIF flag is set (interrupt flag). CCxOF is also set to 1 when at least 2 consecutive captures occur and CCxIF has not been cleared.
- If the CCxIE bit is set, an interrupt will be generated.

Note:

To handle overcapture (CC1OF bit), it is recommended to read the data before reading the repetition capture flag, which is to avoid losing repetition capture information that may



be generated after reading the overcapture flag and before reading the data.

- Setting the corresponding CCxG bit in the PWM0\_EGR register allows the input capture interrupt to be generated by software.
- The PWM0\_CCMRx register is configured in two steps: the first configuration of the CCxS bit in the PWM0\_CCMRx register to select the input mode mapping; the second configuration of the ICxF and ICxPSC in the PWM0\_CCMRx register to select the filter and prescaler coefficients.



Figure 0.42 Input Capture Sequence

#### 8.1.4.3.1 Measure the PWM Input Signal

This mode is a special case of the input capture mode and the operation is the same as the input capture mode except for the following differences:

- 1) Both ICx signals are mapped to the common TIx input.
- 2) The polarity of the active edges of these two ICx signals is reversed.
- 3) One of the TIxFP signals is used as the trigger input signal, and the trigger mode controller is configured to reset the trigger mode.





Figure 0.43 Measure PWM Input Signal

For example, you can measure the period (PWM0\_CCR1 register) and duty cycle (PWM0\_CCR2 register) of the PWM signal input on TI1 in the following way. (depending on the frequency of the  $f_{MASTER}$  and the value of prescaler)

- Select active input for PWM0\_CCR1: Set CC1S=01 in PWM0\_CCMR1 register (TI1FP1 is selected).
- 2) Select the active polarity for TI1FP1 (used to capture data into PWM0\_CCR1 and clear the counter): Set CC1P=0 (active on rising edge).
- 3) Select active input for PWM0\_CCR2: Set CC2S=10 in PWM0\_CCMR2 register (TI1FP2 is selected).
- 4) Select the active polarity of TI1FP2 (capture data to PWM0\_CCR2): Set CC2P=1 (active on falling edge).
- 5) Select a valid trigger input signal: Set TS=101 in PWM0\_SMCR register (TI1FP1 is selected).
- 6) Configure the trigger mode controller in reset trigger mode: Set SMS=100 in PWM0\_SMCR.
- 7) Enable capture: Set CC1E=1 and CC2E=1 in PWM0\_CCER1 register.





Figure 0.44 Example of PWM input signal measurement

Note:

- To handle overcapture event (CCxOF bit), it is recommended to read the data before reading the repetition capture flag, this is to avoid losing repetition capture information that may be generated after reading the overcapture flag and before reading the data.
- 2. Input capture interrupts can be generated by software by setting the corresponding CCxG bits in the PWM0\_EGR register.

3. Configure the PWM0\_CCMRx register in two steps: first, configure the CCxS bit in the PWM0\_CCMRx register to select the input mode mapping; second, configure the ICxF and ICxPSC in the PWM0\_CCMRx register to select the filter and prescaler coefficients.

## 8.1.4.4 Output Module

The output module generates an intermediate waveform used for reference, called OCxREF (active high). Break functions and polarity act at the end of the chain.









Figure 0.46 Detailed block diagram of the output module with complementary outputs (channel 1)

## 8.1.4.5 Forced Output Mode

In output mode (CCxS=0 in the PWM0\_CCMRx register), the output compare signal can be forced by software to a high or low state, independent of the result of the comparison between the output compare register and the counter.

The output comparison signal is forced to be active by setting the corresponding OCxM=101 in the PWM0\_CCMRx register. Thus, OCxREF is forced as high level (OCxREF is always active high), and the output of OCx is high or low depending on the CCxP polarity flag bit.

For example, if CCxP=0 (OCx is active high level), then OCx is forced to high level.

Set OCxM=100 in PWM0\_CCMRx register to force the OCxREF signal to low.

In this mode, the comparison between the PWM0\_CCRx shadow register and the counter is still ongoing, the corresponding flags are modified and the corresponding interrupts are still generated as well.



Figure 0.47 Forced Output inactive level

# emiconductor

# BS9000AMxx



Figure 0.48 Forced Output Active Level

## 8.1.4.6 Output Compare Mode

This mode is used to control an output waveform or to indicate that a given period of time has been elapsed.

When a match is found between the capture/compare register and the counter (CCRx), execute the following operations:

- According to the different output compare modes, the corresponding OCx output signals:
  - Hold (OCxM=000)
  - Set to active level (OCxM=001)
  - Set to inactive level (OCxM=010)
  - Flip (OCxM=011)
- Set the flag bit in the interrupt status register (CCxIF bit in the PWM0\_SR1 register).
- If the corresponding interrupt enable bit (CCxIE bit in PWM0\_IER register) is set, an interrupt is generated.

The OCxM bit of the PWM0\_CCMRx register is used to select the output compare mode, while the CCxP bit of the PWM0\_CCMRx register is used to select the active and inactive level polarity. The OCxPE bit of the PWM0\_CCMRx register is used to select whether the PWM0\_CCRx register

needs to use the preload register or not.

In the output compare mode, the update event has no effect on the OCxREF and OCx outputs. The timing resolution is one cycle of the counter. The output compare mode can also be used to output a single pulse.

Configuration steps for output compare mode.

- 1. Selects the counter clock (internal, external, prescaler).
- 2. Write the corresponding data into the PWM0\_ARR and PWM0\_CCRx registers.
- 3. If an interrupt request is to be generated, set the CCxIE bit.
- 4. Select output mode steps:
  - Toggle the output pin of OCxM when the counter is required to match CCRx, set OCxM=011



- Disable preload register by writing OCxPE=0
- Write CCxP=0 to select high level as active level
- Set CCxE=1 to enable output

Semiconductor

5. Set the CEN bit of the PWM0\_CR1 register to start the counter

The PWM0\_CCRx register can be updated by software at any time to control the output waveform, provided that the pre-load register is not used (OCxPE='0', otherwise the shadow register of PWM0\_CCRx can only be updated when the next update event occurs). The following figure shows an example.







#### 8.1.4.7 **PWM Mode**

emiconductor

The pulse width modulation (PWM) mode generates a signal with a frequency determined by the PWM0\_ARR register and a duty cycle determined by the PWM0\_CCRx register.

The PWM mode can be selected independently on each channel (one PWM per OCx output) by writing 110 (PWM mode 1) or 111 (PWM mode 2) in the OCxM bits in the PWM0\_CCMRx

registers. The OCxPE bit in the PWM0\_CCMRx register must be set to enable the corresponding preload register, or the ARPE bit of the PWM0\_CR1 register can be set to enable the preload register for automatic reload (in up-counting mode or center aligned mode).

Note: Since the preload registers can be passed to the shadow registers only when an update event occurs, all registers must be initialized by setting the UG bit of the PWM0\_EGR register before the counter starts counting.

The polarity of OCx can be set by software using the CCxP bit in the PWM0\_CCERx register, which can be set to active high or active low. The output enable of OCx is controlled by a combination of CCxE, MOE, OISx and OSSR bits and OSSI bits in the PWM0\_CCERx and PWM0\_BKR registers. See the description of the PWM0\_CCERx register for details.

In PWM mode (mode 1 or mode 2), PWM0\_CNT and PWM0\_CCRx are always being compared(based on the counting direction of the counter) to determine whether PWM0\_CCRx  $\leq$  PWM0\_CNT or PWM0\_CNT  $\leq$  PWM0\_CCRx is met.

According to the state of the CMS bit field in the PWM0\_CR1 register, the timer is capable of generating either edge-aligned PWM signals or center-aligned PWM signals.

#### 8.1.4.7.1 PWM Edge Aligned Mode

• Up-counting configuration

Up-counting when the DIR bit in the PWM0\_CR1 register is low.

The following is an example of PWM mode 1. In PWM mode 1, when PWM0\_CNT< PWM0\_CCRx, the PWM reference signal OCxREF is high, otherwise it is low. If the comparison value in PWM0\_CCRx is greater than the Auto-reload value (PWM0\_ARR),



OCxREF remains '1'. If the compare value is 0, OCxREF remains '0'.

In PWM mode 2, the PWM reference signal OCxREF is low when PWM0\_CNT< PWM0\_CCRx, otherwise it is high. If the compare value in PWM0\_CCRx is greater than the Auto-reload value (PWM0\_ARR), OCxREF remains '0'. If the compare value is 0, OCxREF remains '1'.

Figure 8.53 shows an example of the edge-aligned PWM waveform when PWM0\_ARR=8.

| COUNTER<br>REGISTER | 0 X 1 X 2 X 3 X 4 X 5 X 6 X 7 X 8 X 0 X 1 X |
|---------------------|---------------------------------------------|
| CCRx=4              | OCxREF OCxIF                                |
| CCRx=8              | OCxREF OCxIF                                |
| CCRx>8              | OCxREF '1'<br>OCxIF                         |
| CCRx=0              | OCxREF '0'<br>OCxIF                         |

Figure 0.53 Edge-aligned, PWM mode 1 waveform (ARR=8)

• Down-counting configuration

Down-counting is active when the DIR bit in the PWM0\_CR1 register is high. Please refer to *Down-counting Mode*.

In PWM mode 1, the reference signal OCxREF is low when PWM0\_CNT> PWM0\_CCRx, otherwise it is high. If the comparison value in PWM0\_CCRx is greater than or equal to the auto-reload value in PWM0\_ARR, OCxREF remains '1'. A 0% PWM waveform cannot be generated in this mode.

In PWM mode 2, the reference signal OCxREF is high when PWM0\_CNT> PWM0\_CCRx, otherwise it is low. If the comparison value in PWM0\_CCRx is greater than or equal to the auto-reload value in PWM0\_ARR, OCxREF remains '0'. This mode cannot generate 100% PWM waveform.





#### 8.1.4.7.2 PWM Central Aligned Mode

UEV

Output compare flag emiconductor

Central aligned mode is enabled when the CMS bit in the PWM0\_CR1 register is not '00' (all other configurations have the same effect on the OCxREF/OCx signals).

Depending on the setting of CMS bits, the compare flag can be set to 1 when the counter counts up, counts down, or counts up and down. The count direction bit (DIR) in the PWM0\_CR1 register is updated by hardware, do not modify it by software. Please refer to <u>Central Aligned Mode (Count</u> <u>Up/Count</u>).

Figure 8.56 shows an example of a center-aligned PWM waveform.

- PWM0\_ARR=8
- PWM mode 1
- The flag bit is set in the following three cases (marked with an arrow)
  - > Only when the counter counts down (CMS=01)
  - > Only when the counter counts up (CMS=10)
  - > When the counter counts up and down (CMS=11)



Figure 0.56 Center-aligned PWM waveform (ARR=8)

#### 8.1.4.7.3 One Pulse Mode

The one pulse mode (OPM) is a special case of the many modes described earlier. This mode allows the counter to respond to an stimulus and to generate a pulse with a programmable length after a programmable delay. The counter can be started by the clock/trigger controller to generate waveforms in output compare mode or PWM mode. Setting the OPM bit in the PWM0\_CR1 register will select the one pulse mode, when the counter automatically stops at the next UEV.

A pulse can be generated only if the comparison value is different from the initial counter value. Before starting (when the timer is waiting to be triggered), it must be configured as follows.

• up-counting mode:  $CNT < CCRx \le ARR$ .

emiconductor

• Down-counting mode: CNT > CCRx.





Figure 0.57 One Pulse Mode

For example, you need to delay  $t_{delay}$  after a rising edge is detected from the TI2 input pin to generate a positive pulse of  $t_{pulse}$  width on OC1.

It is assumed that IC2 is the trigger source for trigger channel 1:

- Write CC2S=01 of PWM0\_CCMR2 register to map IC2 to TI2.
- Write CC2P=0 of PWM0\_CCER1 register to enable IC2 to detect rising edge.
- Write TS=110 of PWM0\_SMCR register to make IC2 as the trigger source of clock/trigger controller (TRGI).
- Write SMS=110 (trigger mode) in PWM0\_SMCR register, IC2 is used to start the counter.
- The waveform of the OPM is determined by the value written to the comparison register (taking into account the clock frequency and the counter prescaler)
- t<sub>delay</sub> is defined by the value in the PWM0\_CCR1 register.
- The t<sub>pulse</sub> is defined by the difference between the auto-reload value and the comparison value (PWM0\_ARR-PWM0\_CCR1).
- Assume that a waveform from 0 to 1 is to be generated when a comparison match occurs, and a waveform from 1 to 0 is to be generated when the counter reaches the preload value; first set OCxM=111 in the PWM0\_CCMR1 register to enter PWM mode 2; selectively set OC1PE=1 in the PWM0\_CCMR1 register as needed, set ARPE in the PWM0\_CR1 register to enable the preload register; then fill in the comparison value in the PWM0\_CCR1 register, fill in the auto-reload value in the PWM0\_ARR register, and set the UG bit to generate an update event and wait for an external trigger event on TI2.

In this example, the DIR and CMS bits in the PWM0\_CR1 register should be low.

Since only one pulse is needed, set OPM=1 in the PWM0\_CR1 register to stop counting at the next update event (when the counter flips from the auto-reload value to 0).

Note: In one pulse mode, The CEN bit can be configured only after the UG bit is configured and a period time is delayed, because the UG bit will pull down the CEN bit in hardware after a period of



time.

#### 8.1.4.7.4 Special case: OCx fast enable

In one pulse mode, edge detection of the TIx sets the CEN to 1, indicating that the counter is enabled. The output will toggle when a comparison between the counter value and the comparison value occurs. However, multiple clock cycles are required to complete these operations, which can limit the minimum possible delay ( $t_{delay}$  minimum).

If the waveform needs to be output with minimum delay, you can set OCxFE bit in the PWM0\_CCMRx register to 1. This will force OCxRef (and OCx) to respond to the stimulus signal and no longer consider the result of the comparison. Its new level is the same as when the comparison match occurs. OCxFE only works when the channel is configured as PWM1 or PWM2 mode.

#### 8.1.4.7.5 Complementary Output and Deadtime Insertion

PWM0 can output two complementary signals and managing the transient on and off of the outputs. Please refer to Figure 8.3.

This period of time is generally called deadtime. The user should adjust the deadtime according to the characteristics of the devices connected to the outputs (delay of level transition, delay of power switch, etc.). Please refer to Figure 8.46.

Configuring the CCxP and CCxNP bits in the PWM0\_CCERx register allows you to select the polarity (main output OCx or OCxN) for each output independently.

The complementary signals OCx and OCxN are controlled by a combination of the following control bits: the CCxE and CCxNE bits in the PWM0\_CCERx register, and the MOE, OISx, OISxN, OSSI, and OSSR bits in the PWM0\_BKR register, as detailed in the following table.

Note: Deadtime Control is activated at the transition to the IDLE state (MOE drops to 0).

|     | Control bit |          |      | Output st | atus                                            |                                                   |
|-----|-------------|----------|------|-----------|-------------------------------------------------|---------------------------------------------------|
| MOE | OSSI        |          | CCxE |           |                                                 | OCxNE output                                      |
| bit | bit         | OSSR bit | bit  | CCxNE bit | Ocx output status                               | status                                            |
|     |             |          |      |           | Output disabled                                 | Output disabled                                   |
|     |             |          |      |           | (disconnected from                              | (disconnected                                     |
|     |             | 0        | 0    | 0         | timer)                                          | from timer)                                       |
| 1   | Х           | 0        | 0    | 1         | Output disabled<br>(disconnected from<br>timer) | OCxREF +<br>polarity<br>OCx = OCxREF<br>xor CCxNP |
|     |             | 0        | 1    | 0         | OCxREF + polarity<br>OCx = OCxREF xor<br>CCxP   | Output disabled<br>(disconnected<br>from timer)   |



| 1 |   |   |   |   |                           |                      |
|---|---|---|---|---|---------------------------|----------------------|
|   |   |   |   |   |                           | OCxREF               |
|   |   |   |   |   |                           | Inverted +           |
|   |   |   |   |   | OCxREF + polarity +       | Polarity +           |
|   |   | 0 | 1 | 1 | deadband                  | Deadband             |
|   |   |   |   |   | Output disabled           | Output disabled      |
|   |   |   |   |   | (disconnected from        | (disconnected        |
|   |   | 1 | 0 | 0 | timer)                    | from timer)          |
|   |   |   |   |   | Off state (output         | OCxREF +             |
|   |   | 1 | 0 | 1 | enabled and disabled      | polarity             |
|   |   | I | 0 | I | level)                    | OCx = OCxREF         |
|   |   |   |   |   | OCx = OCxP                | xor CCxNP            |
|   |   |   |   |   |                           | Off state (output    |
|   |   | 1 | 1 | 0 | OCxREF + polarity         | enabled and null     |
|   |   | I | I | U | OCx = OCxREF xor          | level)               |
|   |   |   |   |   | CCxP                      | OCxN = OCxNP         |
|   |   |   |   |   |                           | OCxREF               |
|   |   |   |   |   |                           | Inverted +           |
|   |   |   |   |   | OCxREF + polarity +       | Polarity +           |
|   |   | 1 | 1 | 1 | deadband                  | Deadband             |
|   | 0 |   |   |   |                           |                      |
|   | 0 |   |   |   | Output disabled (dise     | connected from       |
|   | 0 |   |   |   | timer                     | )                    |
|   | 0 |   |   |   |                           |                      |
|   | 1 |   |   |   | Off state (output enal    | bled and inactive    |
|   | 1 |   |   |   | level)                    |                      |
| 0 | 1 | Х | Х | Х | Asynchronously:           | OCx=CCxP,            |
|   |   |   |   |   | OCxN=CCxNP.               |                      |
|   |   |   |   |   | Then, if the clock exists | s: after a dead time |
|   | 1 |   |   |   | OCx=OISx and OCxN         | =OISiN, assuming     |
|   | I |   |   |   | that OISx and OISx        | N do not both        |
|   |   |   |   |   | correspond to active le   | evels of OCx and     |
|   |   |   |   |   | OCxN.                     |                      |

Figure 0.58 Complementary Output and Deadtime Insertion Table

Setting both the CCxE and CCxNE bits will insert a deadtime, and because of the break circuit, the MOE bit also needs to be set. There is an 8-bit deadtime generator for each channel. The reference signal OCxREF can generate 2 output channels OCx and OCxN. If OCx and OCxN are active high,

- The Ocx output signal is the same as the reference signal, except that its rising edge has a delay relative to the rising edge of the reference signal.
- The OcxN output signal is the opposite of the reference signal, except that its rising edge has a delay relative to the falling edge of the reference signal.

The following diagrams show the relationship between the output signal of the deadtime generator



and the present reference signal OCxREF. (Assuming CCxP=0, CCxNP=0, MOE=1, CCxE=1 and CCxNE=1)



Figure 0.59 Complementary output with deadtime insertion



Figure 0.60 Deadtime waveform delay greater than negative pulse

The above figure shows that the deadtime delay  $t_{delay}$  is generated at the rising edge of OCxREF when the deadtime waveform delay is greater than the negative pulse.



Figure 0.61 Deadtime waveform delay greater than positive pulse

The figure above shows that the deadtime delay  $t_{delay}$  is generated at the falling edge of OCxREF when the deadtime waveform delay is greater than the positive pulse.

#### Note:

- The dead time delay is the same for each channel and is programmed by the DTG bit in the PWM0\_DTR register. For delay count, please refer to Deadtime Register (PWM0\_DTR ).
- > When the delay is greater than the present active output width, the output PWM waveform will



have an error.

#### 8.1.4.7.6 Redirect OCxREF to OCx or OCxN

In output mode (forced set, output compare or PWM), OCxREF can be redirected to the output of OCx or OCxN by configuring the CCxE and CCxNE bits of the PWM0\_CCERx register.

This function can send a special waveform (e.g. PWM or static active level) on one of the outputs when the complementary output is at a inactive level. Another function is to have both outputs at inactive level or at active level at the same time (when it is still a complementary output with deadtime).

#### Note:

When only OCxN is enabled (CCxE=0, CCxNE=1), it does not invert the phase and is active immediately when OCxREF becomes high. For example, if CCxNP=0, then OCxN=OCxREF. On the other hand, when both OCx and OCxN are enabled (CCxE=CCxNE=1), OCx is active when OCxREF is high; however it is quite opposite for OCxN, OCxN becomes active when OCxREF is low.

#### 8.1.4.7.7 Six-step PWM output for motor control

When complementary outputs are required on a channel, the preload bits are OCxM, CCxE and CCxNE. These preload bits are passed to the shadow register bits when a COM phase change event occurs. This will preset the next configuration and modify the configurations of all channels simultaneously at the same moment. COM can be generated via software by setting the COMG bit in the PWM0\_EGR register or via hardware on the rising edge of TRGI.

Figure 8.62 shows the OCx and OCxN outputs in three different configurations when a COM event occurs.





Figure 0.62 Example of generating a six-step PWM by COM (OSSR=1)

### 8.1.4.8 Break

Break are commonly used in motor control. When the break function is used, the output enable signal and inactive level are modified according to the corresponding control bits (MOE, OSSI and OSSR bits in the PWM0\_BKR register).

After system reset, the break circuit is disabled and the MOE bit is low. Setting the BKE bit in the PWM0\_BKR register enables the break function. The polarity of the break input signal can be selected by configuring the BKP bit in the same register. BKE and BKP bits can be modified at the same time.

The MOE falling edge can be asynchronous with respect to the clock module, so a resynchronization circuit is set up between the actual signal (acting on the output) and the synchronization control bit (in the PWM0\_BKR register). This resynchronization circuit creates a delay between the asynchronous signal and the synchronous signal. In particular, if write MOE=1 when it is low, a delay (null instruction) must be inserted before reading it out to get the correct value. This is because the write is an asynchronous signal and the read is a synchronous signal.

When break occurs (selected level occurs at the break input),

The MOE bit is cleared asynchronously, setting the output in either an invalid state, an idle state, or a reset state (as selected by OSSI). This feature remains in effect when the MCU

oscillator is off.

- Once MOE=0, each output channel outputs the level set by the OISx bit of the PWM0\_OISR register. If OSSI=0, the timer no longer controls the output enable signal, otherwise the output enable signal is always high.
- When using complementary output,

Semiconductor

- The output is first set in a reset state, that is, an invalid state (depending on polarity). This is an asynchronous operation and is valid even when the timer is not clocked.
- If the timer clock is still present, the deadtime generator will be re-enabled after the deadtime according to the levels of OISx and OISxN. Note: The dead time is a bit longer than usual because of the resynchronized MOE.
- If the BIE bit of PWM0\_IER register is set, an interrupt is generated when the break status flag (BIF bit in PWM0\_SR1 register) is '1'.
- If the AOE bit in the PWM0\_BKR register is set, the MOE bit is automatically set on the next UEV. This can be used for waveform control, for example. Otherwise, the MOE always remains low until it is '1' again. This feature can be used for safety purposes, where you can connect the break input to a power-driven alarm output, thermal sensor, or other safety device.

#### Note:

The break inputs act on signal level. Therefore, when the break input is active, the MOE cannot be set at the same time (automatically or by software), and the status flag BIF cannot be cleared.

The break is generated by the BRK input (BKIN), which has a programmable active polarity and is enabled or disabled by the BKE bit of the PWM0\_BKR register.

In addition to the break input and output management, the break circuit implements write protection to secure the application. It allows the user to freeze several configuration parameters (OCx polarity and state when disabled, OCxM configuration, break enable and polarity). The user can select one of the three levels of protection via the LOCK bit in the PWM0\_BKR register. The LOCK bit field can only be modified once after MCU reset. Figure 8.63 shows an example of break response output.



Figure 0.63 Break Response Output without Complementary Output Channel



Figure 8.64 shows an example of the break response with complementary output.



Figure 0.64 Output of break response (PWM0 complementary output)

### 8.1.4.9 Clear OCREF Signal on External Event

For a given channel, a high level at the ETRF input (setting the corresponding OCxCE bit in the PWM0\_CCMRx register to 1) can pull the OCxREF signal low, and the OCxREF signal will remain low until the next UEV. This function can only be used in output compare and PWM mode and not in forced mode.

For example, the OCxREF signal can be linked to the output of a comparator for current control. In this case, the ETR must be configured as follows.

- 1) The external trigger prescaler must be off: ETPS[1:0] in the PWM0\_ETR register = 00.
- 2) External clock mode 2 must be disabled: ECE=0 in PWM0\_ETR register.
- 3) The external trigger polarity (ETP) and external trigger filter (ETF) can be configured as required.

Please refer to Figure 8.22 External trigger input block diagram.



The following figures shows the behavior of the OCxREF signal when the ETRF input becomes high, corresponding to different OCxCE values. In this example, timer PWM0 is set as PWM mode.



Figure 0.66 Timing Diagram that ETR clears OCxREF of PWM0

### 8.1.4.10 Encoder Interface Mode

This mode is generally used for motor control. The encoder interface mode is selected by setting SMS=001 in the PWM0\_SMCR register if the counter counts only on the edge of TI2, by setting SMS=010 if it counts only on the edge of TI1, or by setting SMS=011 if the counter counts on both the TI1 and TI2 edges.

Setting the CC1P and CC2P bits in the PWM0\_CCER1 register allows you to select TI1 and TI2 polarities; you can also program the input filter if necessary.

The two inputs TI1 and TI2 are used as interfaces to the incremental encoder (Table 0.67 Relationship between Count Direction and Encoder Signal

). Assume that the counter has been started (CEN=1 in the PWM0\_CR1 register), the counter counts each time a valid jump is generated on TI1FP1 or TI2FP2. TI1FP1 and TI2FP2 are the signals of TI1 and TI2 after passing through the input filter and polarity control. Without filter and polarity transformation, TI1FP1 = TI1, TI2FP2=TI2. The counting pulse and direction signal are generated according to the jump order of the two input signals. The counter counts up or down based on the





jump order of the two input signals, while the hardware sets the DIR bit of the PWM0\_CR1 register accordingly. Regardless of whether the counter counts on TI1, on TI2, or on both TI1 and TI2, the DIR bit is recalculated on the jump edge of either input (TI1 or TI2).

The encoder interface mode is basically similar to an external clock with direction selection. This means that the counter only counts continuously between 0 and the auto-reload value of the PWM0\_ARR register (either 0 to ARR or ARR to 0, depending on the direction). So PWM0\_ARR must be configured before counting can start; again, the catcher, comparator, prescaler, repetition counter, trigger output characteristics still work normally.

Note: Encoder mode and external clock mode 2 are not compatible and therefore cannot be operated simultaneously.

In this mode, the counter is automatically modified according to the speed and direction of the incremental encoder, so that the content of the counter always points to the position of the encoder. The counting direction corresponds to the direction of rotation of the connected sensor. Table 8.67 shows all possible combinations, assuming that TI1 and TI2 do not change at the same time.

|               | Level of corresponding                        | TI1FP1   | signal  | TI2FP2 | 2 signal |
|---------------|-----------------------------------------------|----------|---------|--------|----------|
| Active edge   | signal<br>(TI1FP1 for TI2,<br>TI2FP2 for TI1) | Rising   | Falling | Rising | Falling  |
|               | High                                          | Count    | Count   | No     | No       |
| Only count at | High                                          | down     | up      | Count  | Count    |
| TI1           | L ou r                                        | Countin  | Count   | No     | No       |
|               | Low                                           | Count up | down    | Count  | Count    |
|               | High                                          | No Count | No      | Count  | Count    |
| Only count at | High                                          |          | Count   | up     | down     |
| TI2           |                                               | No Count | No      | Count  | Count    |
|               | Low                                           |          | Count   | down   | up       |
|               | Lliab                                         | Count    | Count   | Count  | Count    |
| Count on TI1  | High                                          | down     | up      | up     | down     |
| and TI2       |                                               | Count up | Count   | Count  | Count    |
|               | Low                                           |          | down    | down   | up       |

Table 0.67 Relationship between Count Direction and Encoder Signal

An external incremental encoder can be connected directly to the MCU without the need for external interface logic. However, a comparator is generally used to convert the differential output of the encoder into a digital signal, which greatly increases the noise immunity. The third signal from the encoder outputs represents the mechanical zero point, which can be connected to an external



Semiconductor

interrupt input and triggers a counter reset.

Figure 8.68 is an example of counter operation, showing the generation and direction control of the count signal. It also shows how input jitter is compensated where both edges are selected. This might occur if the sensor is positioned near one of the switching points. In this example, we assume the configuration as follows:

- CC1S='01' (PWM0\_CCMR1 register, IC1FP1 mapped to TI1)
- CC2S='01' (PWM0\_CCMR2 register, IC2FP2 mapped to TI2)
- CC1P='0' (PWM0\_CCER1 register, IC1 is not inverted, IC1=TI1)
- CC2P='0' (PWM0\_CCER1 register, IC2 is not inverted, IC2=TI2)
- SMS='011' (PWM0\_SMCR register, all inputs are valid on rising and falling edges)
- CEN='1' (PWM0\_CR1 register, counter enabled)



Figure 0.68 Example of counter operation in encoder mode

Figure 8.69 shows an example of counter operation when IC1 polarity is reversed (CC1P='1', other configurations are the same as the example above ).



Figure 0.69 Example of encoder interface mode with IC1 inverted

When the timer is configured in encoder interface mode, information about the current position of the sensor is provided. Information on the dynamics (velocity, acceleration, deceleration) can be obtained by measuring the interval between two encoder events using another timer configured in capture mode. The encoder output indicating the mechanical zero point can be used for this purpose. Depending on the interval between the two events, the counter can be read out at a certain time interval. If possible, you can latch the counter value to a third input capture register (the capture

# Semiconductor

signal must be periodic and can be generated by another timer).

### 8.1.5 Interrupt

PWM0 has 8 interrupt request sources.

- Break interrupt
- > Trigger interrupt
- COM event interrupt
- Input capture/output compare interrupt 4
- Input capture/output compare interrupt 3
- Input capture/output compare interrupt 2
- Input capture/output compare interrupt 1
- > Update event interrupts (e.g., counter overflow, underflow and initialization)

To use the interrupt feature, set the corresponding interrupt enable bits in the PWM0\_IER register for each interrupt channel being used: i.e. BIE, TIE, COMIE, CCxIE, UIE bits.

Each of the above interrupt sources can also be generated via software by setting the corresponding bit in the PWM0\_EGR register.

# 8.2 **16-bit General Purpose Timer PWM1**

The general-purpose timer consists of a 16-bit auto-reload counter with a programmable prescaler. The timer can be driven by an external crystal or PLL\_24MHz.

It is suitable for a variety of applications, including.

- Basic Timing
- > Measure the pulse length of the input signal (input capture)
- Generate output waveforms (output comparison, PWM and single pulse)
- > Sync with other timers or external signals (external clock, reset, trigger and enable signals)

This chapter only introduces the main functions of the general-purpose timer, for more information on the functions, please refer to <u>8.1 16-bit Advanced Timer</u> PWM0.

### 8.2.1 Main Functions

The main functions of PWM1 are as follows.

• 16-bit auto-reload up counter.

• 4-bit programmable(Support real-time modification) prescaler allowing the counter clock frequency to be divided by any power of 2 from 1 to 32768.Synchronous circuit for timer control by external signals and timer interconnection.

- The 3 independent channels can be configured to.
  - Input capture.



- Output comparison.
- PWM generation (edge aligned mode).
- One pulse mode output.
- Events that generate interruptions include:
  - Update: counter overflow, counter initialization (via software).
  - Trigger events
  - Input capture.
  - Output compare.



Figure 0.70 PWM1 General Purpose Timer Block Diagram

### 8.2.2 Time Base Unit

The Time Base Unit includes a 16-bit up counter, a prescaler and a 16-bit auto-reload register. It has no repetition counter. The counter uses an internal clock ( $f_{MASTER}$ ), which is provided by CK\_PSC and divided by a prescaler to generate the counter clock CK\_CNT.





Figure 0.71 Time Base Unit

For more information, please refer to PWM0 Time Base Unit.

### 8.2.2.1 Prescaler

The prescaler for PWM1 is based on a 16-bit counter controlled by a 4-bit register (PWM1\_PSCR). Since the control register has a buffer, it can be changed at runtime. The counter frequency can be divided by any power of 2 from 1 to 32768. The clock frequency of the counter can be calculated as follows:

$$f_{CK\_CNT} = f_{CK\_PSC}/2^{(PSCR[3:0])}$$

The value of the prescaler is written by the preload register. Once the low 8 bits of the preload register are written, the shadow register with the current value to be used is written with the new value. The prescaler value requires two separate write operations to write the 16-bit register, with the high bit written first. Do not use the LDW instruction to write the low bit first.

The new prescaler value is adopted when the next update event occurs.

The read operation of PWM1\_PSCR register is via the preload register, so the read is not restricted.

### 8.2.2.2 Read/Write 16-bit Counter

The operation of writing counter has no cache and can write the PWM1\_CNTRH and PWM1\_CNTRL registers at any time. Therefore, it is recommended not to write a new value while the counter is running to avoid writing the wrong value.

The operation of reading counter comes with an 8-bit cache. After the high byte is read, the low byte is automatically cached and the cached data does not change until the 16-bit read operation is completed.

Note: Do not read the lower byte first, as the value read out this way is wrong. For more information, please refer to PWM0 *8.1.2.1 Read/Write 16-bit* Counter.

### 8.2.2.3 Read/Write 16-bit PWM1\_ARR

The value of the preload register will be written to the 16-bit PWM1\_ARR register, with the high byte



written first and the low byte next. The shadow register is locked when the high byte is written and held until the low byte is written.

Note: Do not write the low byte first, as the value written this way is wrong.

For more information, please refer to the PWM08.1.2.2.

#### 8.2.2.4 up-counting mode

In up-counting mode, the counter counts from 0 to a user-defined comparison value (the value of the PWM1\_ARR register), then restarts counting and generates an overflow event. Also, if the UDIS bit of the PWM1\_CR1 register is 0, an update event will be generated which will update the flag bit UIF. If the update interrupt enabled UIE=1, an update interrupt will be generated.

Setting the UG bit of the PWM1\_EGR register (either by software or using a slave mode controller) can also generate an update event.



Figure 0.72 up-counting mode

Using software to set the UDIS bit in the PWM1\_CR1 register disables the update event, but the counter is still cleared to 0 and the prescaler is also cleared to 0. In the case of UDIS=0, if URS=1 is set, setting the UG bit at this time will generate an update event, but the hardware does not set the UIF flag (i.e., no interrupt request is generated). This is to avoid generating both update and capture interrupts when the counter is cleared in capture mode.

When an update event occurs, all registers will be updated and (depending on the setting of the URS bit) the update flag bit (UIF bit of the PWM1\_SR register) will also be set.

(1) If the ARPE bit of the PWM1\_CR1 register is 1, the auto-reload shadow register is updated with the value of the preload register (PWM1\_ARR).

2) The buffer of the prescaler is reloaded with the value of the preload register (PWM1\_PSCR). **Note**:

The counter starts counting only after the CEN bit is enabled and one clock cycle (CK\_CNT) has passed.





Figure 0.73 Count up Timing Sequence

For more information, please refer to PWM0 up-counting mode.

### 8.2.3 Clock/Trigger Controller

The clock/trigger controller allows the user to select the clock source, input trigger signal and output signal for the counter. See Figure 8.74.



Figure 0.74 Clock/Trigger Controller Block Diagram

For more information, please refer to PWM0 Clock/Trigger Controller.

# Semiconductor

### 8.2.3.1 Prescaler (CK\_PSC)

The prescaled clock (CK\_PSC) of Time Base Unit can be provided by the following sources.

- Internal clock (f<sub>MASTER</sub>)
- External clock mode 1: External clock input (TIx)
- Internal Trigger Input (ITR): Use the advanced control timer PWM0 as the prescaled clock for the general-purpose timer PWM1.

### 8.2.3.2 Internal Clock Source ( $f_{MASTER}$ )

If both the trigger mode controller and the external trigger input are disabled (SMS=000 in the PWM1\_SMCR register), the CEN, DIR and UG bits are effectively control bits and can only be modified by software (the UG bit is automatically cleared). Once the CEN bit is set to 1, the prescaler is clocked by the internal clock  $f_{MASTER}$ .

For more information, please refer to PWM0 Internal Clock Source (f<sub>MASTER</sub>).

### 8.2.3.3 External Clock Source Mode 1

This mode is selected when SMS=111 in the PWM1\_SMCR register. The counter can count on each rising or falling edge of the selected input. When a rising edge occurs at the selected input, the counter increases by 1 and the trigger flag bit (TIF bit in PWM1\_SR1 register) is set to 1. If an interrupt is enabled (configured in PWM1\_IER register), an interrupt request is generated.





|                  | - Com                                 | count clock OLPSC |                |        |               | elocks(X_PSC/3                                                                                                  | _  |
|------------------|---------------------------------------|-------------------|----------------|--------|---------------|-----------------------------------------------------------------------------------------------------------------|----|
| <b>f</b> MANTER  | mmmm mmmm                             | hud               | mm mm          | hnn    | uuuuu         |                                                                                                                 | บา |
| CNT_EN           |                                       |                   |                |        |               |                                                                                                                 |    |
| TRIG             |                                       |                   |                |        |               |                                                                                                                 |    |
| CK_PSC           |                                       |                   |                |        |               |                                                                                                                 |    |
| MCU_CNT          | 0 X 1 X 0 X 1 X 0 X 1 X X 1 X 0 X 1 X | 0 X 1             | <u> </u>       | 0 X 1) | 0 X 1 X 2 X 3 | 0 X 1 X 2 X 3X                                                                                                  |    |
| CK_CNT           |                                       |                   |                |        |               | <b>_</b>                                                                                                        |    |
| TIME_CNT         | 0 X 1 X 2 X X 23 X                    | 24                | 0 X 1 X X 44 X | (45)   | 0             | <u>1 X</u>                                                                                                      | 2  |
| PWM1_ARR         | 24 X 45                               |                   | X 66           |        |               |                                                                                                                 |    |
| PWM1_ARR_SHADOW  | 24                                    |                   | 45             |        | 66            |                                                                                                                 |    |
| PWMI_PSCR        | 0                                     |                   | X 2            |        |               |                                                                                                                 |    |
| PWM1_PSCR_SHADOW | 0                                     |                   |                |        | 2             |                                                                                                                 |    |
| CNT_OVERFLOW     |                                       |                   |                |        |               |                                                                                                                 |    |
|                  |                                       |                   |                |        |               | the second se |    |

Figure 0.76 External Clock Source Mode 1 Count Up Timing Diagram

For more information, please refer to the PWM0 External Clock Source Mode 1.

### 8.2.3.4 Sync Trigger

The counter allows three trigger inputs.

- ► TI
- ➤ T2
- TRGO from PWM0

The PWM1 counter uses three modes to synchronize with the external trigger signal: standard trigger mode, reset trigger mode, and gated trigger mode.

For more information, please refer to PWM0 Trigger Synchronization.

#### 8.2.3.4.1 Standard Trigger Mode

This mode is selected when SMS=110 of PWM1\_SMCR register. The counter is started on the rising edge of the trigger input TRGI, and only the start of counter is controlled. The counter is enabled depending on events on the selected input (at this point the count enablement is independent of the CEN bit in the PWM1\_CR1 register).

When there is a rising edge on TRGI, the counter starts counting driven by the internal clock  $f_{MASTER}$ , and set the TIF flag bit. The delay between the rising edge of the TRGI and the start of the counter depends on the resynchronization circuit at the TRGI input.





# Semiconductor

### 8.2.3.4.2 Reset Trigger Mode

This mode is selected when SMS = 100 in the PWM1\_SMCR register. When a trigger input event occurs, the counter and its prescaler can be reinitialized; at the same time, an UEV is also generated if the URS bit of the PWM1\_CR1 register is low; then all the preload registers (PWM1\_ARR, PWM1\_PSCR, PWM1\_CCRx) are updated. Set CEN=1 in the PWM1\_CR1 register, the counter starts counting according to the internal clock  $f_{MASTER}$  until a rising edge appears at TRGI, when the counter is initialized and starts counting again. At the same time, the trigger flag (TIF bit of PWM1\_SR1 register) is set and an interrupt request is generated if an interrupt is enabled (TIE bit of PWM1\_IER register). The delay between the rising edge of the TRGI and the actual reset of the counter depends on the resynchronization circuit at the TRGI input.



Figure 0.78 Reset Trigger Timing Sequence

### 8.2.3.4.3 Gated trigger mode

This mode is selected when SMS=101 of PWM1\_SMCR register. The counter is enabled by the TRGI level of the selected input signal. In the gated mode, if CEN=0, the counter cannot start, regardless of the trigger input level. As long as the TRGI level is valid, the counter starts counting based on the internal  $clockf_{MASTER}$  and stops counting once the TRGI level is invalid. The TIF flag bit will be set when the counter starts or stops counting. The delay between the active edge of TRGI and the actual stop of the counter depends on the resynchronization circuit at the TRGI input.





Figure 0.79 Gated Trigger Timing Diagram

### 8.2.3.5 Sync with Advanced Timer PWM0

Timers are interconnected inside the chip for synchronization or linking. When a timer is configured as master mode, it can output a trigger signal (TRGO) to those timers configured as slave mode to complete reset, start, stop operations, or be a driving clock for those timers.



Figure 0.80 Trigger Master/Slave Mode Selection

### 8.2.4 Capture/Compare Channels

### 8.2.4.1 Read/Write 16-bit PWM1\_CCRx Register

When the channel is configured as output mode, the writing operation of the 16-bit PWM1\_CCRx register is completed via the preload register. The high byte must be written first. While writing the high byte, update to the shadow register is disabled until the low byte writing operation is completed, which is similar to writing operation of PWM1\_ARR register. The read operation to the PWM1\_CCRx register is completed via the preload register, so special attention is not needed.



When the channel is configured as input mode, the PWM1\_CCRx register is read-only at this time. The read operation of the PWM1\_CCRx register is similar to the read operation of the counter. When a capture occurs, the contents of the counter are captured into the PWM1\_CCRx shadow register and later copied into the preload register.

The preload register is frozen while the read operation is in progress.

### 8.2.4.2 Input Capture Mode

Figure 8.81 shows a timer with two input channels, channel 1 is internally linked to the comparator.





In input capture mode, the present value of the counter is latched into the capture/compare register (PWM1\_CCRx) when the corresponding edge on the ICx signal is detected. When a capture event occurs, the corresponding CCxIF flag (PWM1\_SR register) is set to 1. If the CCxIE bit of the PWM1\_IER register is set, that is, interrupts are enabled, an interrupt request will be generated. If the CCxIF flag is already high when a capture event occurs, the repetition capture flag CCxOF (PWM1\_SR2 register) is set to 1. CCxIF is cleared by writing CCxIF=0 or by reading the capture data stored in the PWM1\_CCRxL register. CCxOF is cleared by writing CCxOF=0.

When an input capture occurs,

- When a active level transition is generated, the value of the counter is passed to the PWM1\_CCR1 register.
- The CCxIF flag is set (interrupt flag). CCxOF is also set to 1 when at least 2 consecutive captures occur and CCxIF has not been cleared.



• If the CCxIE bit is set, an interrupt will be generated.

**Note:** To handle overcapture (CCxOF bit), it is recommended to read the data before reading the repetition capture flag, which is to avoid losing repetition capture information that may be generated after reading the overcapture flag and before reading the data.

Note 2: Setting the corresponding CCxG bit in the PWM1\_EGR register allows you to generate an input capture interrupt by software.

Note 3: When configuring the PWM1\_CCMRx register, it is configured in two steps: first, configure the CCxS bit in the PWM1\_CCMRx register to select the input mode mapping; second, configure the ICxF and ICxPSC in the PWM1\_CCMRx register to select the filter and prescaler coefficients.



Figure 0.82 Input Capture Timing Sequence

### 8.2.4.3 Forced Output Mode

In output mode (CCxS=0 in the PWM1\_CCMRx register), the output compare signal can be directly forced to a high or low state by software, independent of the comparison result between the output compare register and the counter.

The output comparison signal is forced at active by setting the corresponding OCxM=101 in the PWM1\_CCMRx register. Thus OCxREF is forced at high (OCxREF is always active high), and the output of OCx is high or low depending on the CCxP polarity flag bit.

Set OCxM=100 in the PWM1\_CCMRx register to force the OCxREF signal to low.

In this mode, the comparison between the PWM1\_CCRx shadow register and the counter is still ongoing, the corresponding flags are modified, and the interrupts are still generated accordingly.



Figure 0.83 Forced output inactive level



Figure 0.84 Forced output active level

For details, please refer to 16-bit advanced timer PWM0 Forced Output Mode.

### 8.2.4.4 Output Compare Mode

Semiconductor

This mode is used to control an output waveform or to indicate that a given period of time has been reached.

When the counter has the same contents as the capture/compare register (CCRx), operations as follows:

- According to the different output compare modes, the corresponding OCx outputs signals,
  - Hold (OCxM=000)
  - Set to active level (OCxM=001)
  - Set to inactive level (OCxM=010)
  - Reverse (OCxM=011)
- Set the flag bit in the interrupt status register (CCxIF bit in the PWM1\_SR1 register).
- If the corresponding interrupt enable bit (CCxIE bit in PWM1\_IER register) is set, an interrupt is generated.

In output compare mode, the update event has no effect on the OCxREF and OCx outputs. The time accuracy is one cycle of the counter.



Configuration steps for output compare mode:

Semiconductor

- 1. Selects the counter clock (internal, external, prescaler).
- 2. Write the corresponding data into the PWM1\_ARR and PWM1\_CCRx registers.
- 3. If an interrupt request is to be generated, set the CCxIE bit.
- 4. Select output mode steps:
  - 1) Reverse the output pin of OCxM when the counter matches CCRx, set OCxM=011
  - 2) Disable preload register by setting OCxPE=0
  - 3) Set CCxP=0 to select high level as active level
  - 4) Set CCxE=1 to enable output

Set the CEN bit of the PWM1\_CR1 register to start the counter

The PWM1\_CCRx register can be updated by software at any time to control the output waveform, provided that the pre-load register is not used (OCxPE='0', otherwise the shadow register of PWM1\_CCRx can only be updated when the next update event occurs).

For details, please refer to 16-bit advanced timer PWM0 Output Compare Mode.8.1.4.6

#### 8.2.4.5 **PWM Mode**

The pulse width modulation (PWM) mode generates a signal with a frequency determined by the PWM1\_ARR register and a duty cycle determined by the PWM1\_CCRx register.

Writing '110' (PWM mode 1) or '111' (PWM mode 2) to the OCxM bit in the PWM1\_CCMRx register enables each OCx output channel to generate one PWM independently. The OCxPE bit of the PWM1\_CCMRx register must be set to enable the corresponding preload register, or the ARPE bit of the PWM1\_CR1 register can be set to enable the preload register for automatic reload (in up-counting mode or center-symmetric mode).

Note: Since the preload registers can be passed to the shadow registers only when an update event occurs, all registers must be initialized by setting the UG bit of the PWM1\_EGR register before the counter starts counting.

The polarity of OCx can be set via software by the CCxP bit in the PWM1\_CCERx register, which can be set to active high or active low. The output enable of OCx is controlled through CCxE in the PWM1\_CCERx register. See the description of the PWM1\_CCERx register for details.



For details, please refer to 16-bit Advanced Timer PWM0 Mode.

#### 8.2.4.5.1 PWM Edge Aligned Mode

Semiconductor

#### **Up-counting configuration**



In PWM mode 1, the PWM reference signal OCxREF is high when PWM1\_CNT< PWM1\_CCRx, otherwise it is low. If the comparison value in PWM1\_CCRx is greater than the auto-reload value (PWM1\_ARR), OCxREF remains '1'. If the compare value is 0, OCxREF remains '0'. In PWM mode 2, the PWM reference signal OCxREF is low when PWM1\_CNT< PWM1\_CCRx, otherwise it is high. If the compare value in PWM1\_CCRx is greater than the Auto-reload value (PWM1\_ARR), OCxREF remains '0'. If the comparison value is 0, OCxREF remains '1'.



Figure 0.89 PWM Edge Aligned Mode 2 (Count Up Configuration)

#### 8.2.4.5.2 One Pulse Mode

The one pulse mode (OPM) is a special case of the many modes described earlier. This mode allows the counter to respond to an stimulus and generate a pulse with controllable pulse width after a programmable delay.

The counter can be started by the clock/trigger controller and generate waveforms in output compare mode or PWM mode. Setting the OPM bit of the PWM1\_CR1 register will select the one pulse mode, when the counter automatically stops at the next UEV.



A pulse can be generated only if the compare value is different from the initial value of counter. Before starting (when the timer is waiting to be triggered), it must be configured as follows.

- Up-counting mode:  $CNT < CCRx \le ARR$ .
- Down-counting mode: CNT > CCRx.



**Note:** In one pulse mode, the configuration of the UG bit should be delayed for a period of time before the CEN bit can be configured, because the UG bit will pull down the CEN bit in hardware after a period of time.

#### 8.2.4.6 Encoder Interface Mode

This mode is generally used for motor control. The encoder interface mode is selected by setting SMS=001 in the PWM1\_SMCR register if the counter counts only on the edge of TI2, by setting SMS=010 if it counts only on the edge of TI1, or by setting SMS=011 if the counter counts on both the TI1 and TI2 edges.

Setting the CC1P and CC2P bits in the PWM1\_CCER1 register allows you to select TI1 and TI2 polarities, you can also program the input filter if you would like.

The two inputs TI1 and TI2 are used as interfaces to the incremental encoder. The relationship between the count direction and the encoder signal is shown in the following table.

|                   | Signal level<br>(TI1FP1                              | TI1FP1 signal |                                                                                                                                                                                   | TI2FP2 signal |         |
|-------------------|------------------------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------|
| Effective edge    | corresponds to TI2,<br>TI2FP2 corresponds<br>to TI1) | Rising        | Falling                                                                                                                                                                           | Rising        | Falling |
|                   | High                                                 | Count         | Count                                                                                                                                                                             | No            | No      |
| Count at TI1 only | High                                                 | down          | up                                                                                                                                                                                | count         |         |
| Count at TI1 only | Low                                                  | Count         | Count                                                                                                                                                                             | No            | No      |
|                   | LOW                                                  | up            | CountNoupcountcountcountCountNodowncountNoCountCountupCountupNoCountCountupNoCountCountupNoCountNoCountupup                                                                       |               |         |
|                   | High                                                 | No            | No                                                                                                                                                                                | Count         | Count   |
| Count at TI2 only | riigii                                               | count         | count                                                                                                                                                                             | up            | down    |
| Count at The only | Low                                                  | No            | No                                                                                                                                                                                | Count         | Count   |
|                   | LOW                                                  |               |                                                                                                                                                                                   |               | up      |
|                   | High                                                 | Count         | Count                                                                                                                                                                             | Count         | Count   |
| Count at TI1 and  | підп                                                 | down          | FallingRisingFallingCountNoNoupcountcountCountNoNodowncountcountMoCountcountNoCountcountNoCountupNoCountupNoCountupNoCountupOuntCountupNoCountcountUpCountCountupupupUpupupUpUpup | down          |         |
| TI2               | Low                                                  | Count         | Count                                                                                                                                                                             | Count         | Count   |
|                   | LOW                                                  | up            | down                                                                                                                                                                              | down          | up      |

Table 0 .91 Relationship between count direction and encoder signal

Assume that the counter has been started (CEN=1 in the PWM1\_CR1 register), the counter counts each time a valid jump is generated on TI1FP1 or TI2FP2=TI2. TI1FP1 and TI2FP2 are the signals of TI1 and TI2 after passing through the input filter and polarity control; if there is no filter and polarity shift, TI1FP1 = TI1, TI2FP2 = TI2. And the counting pulse and direction signal are generated according to the jump order of the two input signals. Also, the counter counts up or down while the hardware sets the DIR bit of the PWM1\_CR1 register accordingly based on the jump order of the two input signals. Regardless of whether the counter counts on TI1, on TI2, or on both TI1 and TI2, the DIR bit is recalculated on the jump edge of either input (TI1 or TI2).

The encoder interface mode is basically similar to an external clock with direction selection. This means that the counter only counts continuously between 0 and the auto-reload value of the PWM1\_ARR register (either 0 to ARR counting or ARR to 0 counting, depending on the direction). So PWM1\_ARR must be configured before counting can start; again, the catcher, comparator, prescaler, trigger output characteristics still work normally.

### 8.2.5 Interrupt

PWM1 has 5 interrupt request sources:

- 1. Trigger interrupt
- 2. Input capture/output compare interrupt 3
- 3. Input capture/output compare interrupt 2
- 4. Input capture/output compare interrupt 1
- 5. Update event interrupt (e.g. counter overflow)

Semiconductor



To use the interrupt feature, set the corresponding interrupt enable bits in the PWM1\_IER register for each interrupt channel being used: i.e., the TIE, CCxIE, and UIE bits. Each of the above interrupt sources can also be generated in software by setting the corresponding

bit in the PWM1\_EGR register.

# 8.3 **PWM Registers**

### 8.3.1 PWM0 Registers

### 8.3.1.1 Control Register 1(PWM0\_CR1)

Address: 0xC3

| Bit No.             | 7          | 6          | 5          | 4          |
|---------------------|------------|------------|------------|------------|
| Symbol              | ARPE       | CN         | ЛS         | DIR        |
| Read/Write          | Read/Write | Read       | /Write     | Read/Write |
| Po Initial<br>Value | 0          | (          | 0          |            |
| Bit No.             | 3          | 2          | 1          | 0          |
| Symbol              | OPM        | URS        | UDIS       | CEN        |
| Read/Write          | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | 0          | 0          | 0          | 0          |

| Bit No. | Symbol | Description                                                         |
|---------|--------|---------------------------------------------------------------------|
|         |        | Auto-preload enable bit.                                            |
| 7       | ARPE   | 0: PWM0_ARR has no buffer and can be directly written into.         |
|         |        | 1: PWM0_ARR is buffered by a preload buffer.                        |
|         |        | Selection center aligned mode.                                      |
|         |        | 00: edge aligned mode. Counter counts up or down according to       |
|         |        | DIR bit.                                                            |
|         |        | 01: center aligned mode 1. counter counts up and down               |
|         |        | alternatively, The output compare interrupt flag bit of the channel |
|         |        | configured as output (CCxS=00 in PWM0_CCRx register) is set to      |
| 6~5     | CMS    | 1 only when the counter counts down.                                |
|         |        | 10: Central aligned mode 2. The counter counts up and down          |
|         |        | alternately. The output compare interrupt flag bit of the channel   |
|         |        | configured as output (CCxS=00 in PWM0_CCRx register) is set to      |
|         |        | 1 only when the counter counts up.                                  |
|         |        | 11: Central alignment mode 3. The counter counts up and down        |
|         |        | alternately. The output compare interrupt flag bit of the channel   |



| - |      |                                                                              |
|---|------|------------------------------------------------------------------------------|
|   |      | configured as output (CCxS=00 in PWM0_CCRx register) is set to               |
|   |      | 1 when the counter counts up and down.                                       |
|   |      | Note 1: When the counter is on (CEN=1), the transition from edge-            |
|   |      | aligned mode to center-aligned mode is not allowed.                          |
|   |      | Note 2: In the central aligned mode, the encoder mode (SMS=001,              |
|   |      | 010, 011 in PWM0_SMCR register) must be disabled.                            |
|   |      | Directions.                                                                  |
|   |      | 0: counter counts up.                                                        |
| 4 | DIR  | 1: counter counts down.                                                      |
|   |      | Note: This bit is read-only when the counter is configured in central        |
|   |      | aligned mode or encoder mode.                                                |
|   |      | One pulse mode.                                                              |
| 0 | 0014 | 0: the counter does not stop when an update event occurs.                    |
| 3 | OPM  | 1: The counter stops when the next update event (clearing the CEN            |
|   |      | bit) occurs.                                                                 |
|   |      | Update the request source.                                                   |
|   |      | 0: If UDIS allows the generation of update events, an update                 |
|   |      | interrupt is generated by any of the following events.                       |
|   |      | 1) Registers are updated (counter overflow/underflow)                        |
| 2 | URS  | 2) Software setting UG bit                                                   |
|   |      | 3) Updates generated by the clock/trigger controller                         |
|   |      | 1: If UDIS allows the generation of update events, the update                |
|   |      | interrupt will be generated and UIF set to 1 only when the following         |
|   |      | events occur: the register is updated (counter overflow/underflow)           |
|   |      | Updates are prohibited.                                                      |
|   |      | 0: Generates an update (UEV) event once the following events                 |
|   |      | occur.                                                                       |
|   |      | 1) Counter overflow/underflow                                                |
|   |      | 2) Generate software update events                                           |
|   |      | 3)Hardware reset generated by the clock/trigger mode                         |
| 1 | UDIS | controller.                                                                  |
|   |      | The cached registers are loaded with their preloaded values.                 |
|   |      | 1: No update event is generated and the shadow registers (ARR,               |
|   |      |                                                                              |
|   |      | PSC, CCRx) hold their values. The counters and prescaler are                 |
|   |      | reinitialized if the UG bit is set or if the clock/trigger controller issues |
|   |      | a hardware reset.                                                            |
|   |      | Counter enable.                                                              |
|   |      | 0: disables the counter.                                                     |
| 0 | CEN  | 1: Enables the counter.                                                      |
|   |      | Note: The external clock, gated mode and encoder mode will not               |
|   |      | work until the CEN bit is set in software.                                   |
|   |      | However, the trigger mode can automatically set the CEN bit by               |



|  |  | hardware. |
|--|--|-----------|
|--|--|-----------|



### 8.3.1.2 Control register 2 (PWM0\_CR2)

Address: 0xC4

| Bit No.             | 7          | 6          | 5 | 4          |  |  |
|---------------------|------------|------------|---|------------|--|--|
| Symbol              | TI1S       | MMS        |   |            |  |  |
| Read/Write          | Read/Write | Read/Write |   |            |  |  |
| Po Initial<br>Value | 0          |            | 0 |            |  |  |
| Bit No.             | 3          | 2          | 1 | 0          |  |  |
| Symbol              | -          | COMS       | - | CCPC       |  |  |
| Read/Write          | -          | Read/Write | - | Read/Write |  |  |
| Po Initial<br>Value | -          | 0          | - | 0          |  |  |

| Bit No. | Symbol | Description                                                                  |
|---------|--------|------------------------------------------------------------------------------|
|         |        | TI1 selection.                                                               |
| 7       | TI1S   | 0: CC1 input pin connected to TI1 (input of the digital filter).             |
|         |        | 1: CC1, CC2 and CC3 pins are connected to TI1 after XOR.                     |
|         |        | Master mode selection.                                                       |
|         |        | This bit is used to select the synchronization information (TRGO) sent to    |
|         |        | the ADC or other slave timers in master mode. The possible                   |
|         |        | combinations are as follows:                                                 |
|         |        | 000: Reset. The UG bit of the PWM0_EGR register is used as the trigger       |
|         |        | output (TRGO). If the trigger input (clock/trigger controller configured for |
|         |        | reset mode) generates a reset, there is a delay in the signal on TRGO        |
|         |        | relative to the actual reset.                                                |
|         |        | 001: Enable. The counter enable signal is used as a trigger output           |
|         |        | (TRGO), which is used to start multi-timers or ADCs in order to enable       |
|         |        | slave timer or ADC in a period of time. The counter enable signal is         |
| 6~4     | MMS    | generated by the logical of the trigger input signal in the CEN control bit  |
|         |        | and gated mode. Unless Master/Slave mode is selected (see the                |
|         |        | description of the MSM bit in the PWM0_SMCR register), there is a delay      |
|         |        | on the TRGO when the counter enable signal is controlled by the trigger      |
|         |        | input.                                                                       |
|         |        | 010: Update. The update event is selected as trigger output.                 |
|         |        | 011: Compare pulse (MATCH1). Once a capture or a successful                  |
|         |        | comparison has occurred, the trigger output sends a positive pulse           |
|         |        | (TRGO) when the CC1IF flag is set to 1 (even if it is already high).         |
|         |        | 100: Compare. The OC1REF signal is used as the trigger output                |
|         |        | (TRGO).                                                                      |
|         |        | 101: Compare. The OC2REF signal is used as the trigger output                |



|   |      | (TRGO).                                                                    |
|---|------|----------------------------------------------------------------------------|
|   |      | 110: Compare. The OC3REF signal is used as the trigger output              |
|   |      | (TRGO).                                                                    |
|   |      | 111: Compare. The OC4REF signal is used as the trigger output (TRGO).      |
|   |      | Update control selection for capture/compare control bit.                  |
|   |      | 0: when the control bits for capture/compare are preloaded (CCPC=1),       |
|   |      | these control bits are updated only when COMG sets to 1.                   |
| 2 | COMS | 1: when the capture/compare control bits are preloaded (CCPC=1),           |
|   |      | these control bits are updated only when a rising edge occurs at TRGI      |
|   |      | or COMG sets to 1.                                                         |
|   |      | Note: This bit is only valid for channels that have complementary outputs. |
|   | CCPC | Capture/compare preload control bit.                                       |
|   |      | 0: CCxE, CCxNE, CCxP, CCxNP bits (PWM0_CCERx register),OCxM                |
| 0 |      | bits (PWM0_CCMRx register) are not preloaded.                              |
|   |      | 1: The CCxE, CCxNE, CCxP, CCxNP and OCxM bits are preloaded;               |
|   |      | when this bit is set, they are updated only after the COMG bit             |
|   |      | (PWM0_EGR register) is set.                                                |
|   |      | Note: This bit only works for channels with complementary outputs.         |

# 8.3.1.3 Slave Mode Control Register (PWM0\_SMCR)

#### Address: 0xC5

| Bit No.      | 7                  | 6          | 5          | 4 |
|--------------|--------------------|------------|------------|---|
| Symbol       | MSM                |            | TS         |   |
| Read/Write   | Read/Write         | Read/Write | Read/Write |   |
| Po Initial   | 0                  | 0          |            | 0 |
| Value        | 0                  |            |            |   |
| Bit No.      | 3                  | 2          | 1          | 0 |
| Symbol - SMS |                    | SMS        |            |   |
| Read/Write   | Vrite - Read/Write |            |            |   |
| Po Initial   | -                  | 0          |            |   |
| Value        |                    |            |            |   |

| Bit No. | Symbol | Description                                                          |
|---------|--------|----------------------------------------------------------------------|
| 7       | MSM    | Master/Slave Mode.                                                   |
|         |        | 0: no effect.                                                        |
|         |        | 1: The event on the trigger input (TRGI) is delayed to allow perfect |
|         |        | synchronization between Timer 1 and its slave timer (via TRGO).      |
| 6~4     | TS     | Trigger selection, used to select the trigger input for the          |





## 8.3.1.4 External Trigger Register (PWM0\_ETR)

| Bit No.    | 7          | 6          | 5          | 4 |
|------------|------------|------------|------------|---|
| Symbol     | ETP        | ECE        | ETPS       |   |
| Read/Write | Read/Write | Read/Write | Read/Write |   |
| Po Initial | 0          | 0          |            | 0 |
| Value      | 0          | 0          |            |   |
| Bit No.    | 3          | 2          | 1          | 0 |
| Symbol     | ETF        |            |            |   |
| Read/Write | Read/Write |            |            |   |
| Po Initial | 0          |            |            |   |
| Value      |            |            |            |   |

| Bit No. | Symbol | Description                                                           |
|---------|--------|-----------------------------------------------------------------------|
|         | ETP    | External trigger polarity. This bit determines whether the ETR or the |
| 7       |        | inverse of the ETR is used to trigger the operation.                  |
| 1       |        | 0: ETR is not inverted, i.e. high or rising edge active.              |
|         |        | 1: ETR is inverted, i.e. low or falling edge is active.               |
|         |        | External Clock Enable. This bit is used to enable external clock      |
|         |        | mode 2.                                                               |
|         |        | 0: disabled.                                                          |
|         |        | 1: Enable external mode 2, the counter is clocked to the active edge  |
|         |        | of ETRF.                                                              |
| 6       | ECE    | Note 1: The effect of ECE set 1 is the same as the option to connect  |
| 0       | EGE    | TRGI to external clock mode 1 of ETRF (SMS=111 and TS=111 in          |
|         |        | PWM0_SMCR register).                                                  |
|         |        | Note 2: External mode 2 can be used simultaneously with the           |
|         |        | following modes: trigger standard mode, trigger reset mode, trigger   |
|         |        | gated mode. However, TRGI must not be connected to ETRF at this       |
|         |        | time (in PWM0_SMCR register, TS cannot be 111)                        |
|         |        | External trigger prescaler.                                           |
|         |        | The maximum frequency of the external trigger signal ETRP             |
|         |        | cannot exceed $f_{MASTER}/4$ . A prescaler can be used to reduce      |
|         |        | the frequency of ETRP, which is very useful when the                  |
| 5~4     | ETPS   | frequency of ETRP is high.                                            |
|         |        | 00: Prescaler off.                                                    |
|         |        | 01: Frequency of ETRP/2.                                              |
|         |        | 10: Frequency of ETRP/4.                                              |
|         |        | 11: Frequency of ETRP/8.                                              |
| 3~0     | ETF    | External trigger filter selection.                                    |



|  | The sampling frequency of the ETRP and the length of the                     |  |
|--|------------------------------------------------------------------------------|--|
|  | digital filter are defined. The digital filter consists of an event          |  |
|  | counter that records N events and then generates a jump for                  |  |
|  | the output.                                                                  |  |
|  | 0000: No filter, sampled with f <sub>MASTER</sub>                            |  |
|  | 0001: Sampling frequency f <sub>SAMPLING</sub> =f <sub>MASTER</sub> , N=2    |  |
|  | 0010: Sampling frequency f <sub>SAMPLING</sub> =f <sub>MASTER</sub> , N=4    |  |
|  | 0011: Sampling frequency f <sub>SAMPLING</sub> =f <sub>MASTER</sub> , N=8    |  |
|  | 0100: Sampling frequency f <sub>SAMPLING</sub> =f <sub>MASTER</sub> /2, N=6  |  |
|  | 0101: Sampling frequency f <sub>SAMPLING</sub> =f <sub>MASTER</sub> /2, N=8  |  |
|  | 0110: Sampling frequency f <sub>SAMPLING</sub> =f <sub>MASTER</sub> /4, N=6  |  |
|  | 0111: Sampling frequency f <sub>SAMPLING</sub> =f <sub>MASTER</sub> /4, N=8  |  |
|  | 1000: Sampling frequency f <sub>SAMPLING</sub> =f <sub>MASTER</sub> /8, N=6  |  |
|  | 1001: Sampling frequency f <sub>SAMPLING</sub> =f <sub>MASTER</sub> /8, N=8  |  |
|  | 1010: Sampling frequency fsampling=fmaster/16, N=5                           |  |
|  | 1011: Sampling frequency f <sub>SAMPLING</sub> =f <sub>MASTER</sub> /16, N=6 |  |
|  | 1100: Sampling frequency fsampling=fmaster/16, N=8                           |  |
|  | 1101: Sampling frequency f <sub>SAMPLING</sub> =f <sub>MASTER</sub> /32, N=5 |  |
|  | 1110: Sampling frequency f <sub>SAMPLING</sub> =f <sub>MASTER</sub> /32, N=6 |  |
|  | 1111: Sampling frequency f <sub>SAMPLING</sub> =f <sub>MASTER</sub> /32, N=8 |  |

## 8.3.1.5 Interrupt Enable Register (PWM0\_IER)

| Bit No.             | 7          | 6          | 5          | 4          |
|---------------------|------------|------------|------------|------------|
| Symbol              | BIE        | TIE        | COMIE      | CC4IE      |
| Read/Write          | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | 0          | 0          | 0          | 0          |
| Bit No.             | 3          | 2          | 1          | 0          |
| Symbol              | CC3IE      | CC2IE      | CC1IE      | UIE        |
| Read/Write          | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | 0          | 0          | 0          | 0          |

| Bit No. | Symbol | Description               |
|---------|--------|---------------------------|
|         |        | Break interrupt enable.   |
| 7       | BIE    | 0: disabled               |
|         |        | 1: enabled                |
| 6       | TIE    | Trigger Interrupt Enable. |



|       |       | 0: disabled                                    |
|-------|-------|------------------------------------------------|
|       |       | 1: enabled                                     |
|       |       | COM interrupt enable.                          |
| 5     | COMIE | 0: disabled                                    |
|       |       | 1: enabled                                     |
|       |       | Capture/Compare 4 interrupt enable.            |
| 4     | CC4IE | 0: disabled                                    |
|       |       | 1: enabled                                     |
| 2     | 00015 | Capture/Compare 3 interrupt enable.0: disabled |
| 3     | CC3IE | 1: enabled                                     |
| 0.000 |       | Capture/Compare 2 interrupt enable.0: disabled |
| 2     | CC2IE | 1: enabled                                     |
| 4     |       | Capture/Compare 1 interrupt enable.0: disabled |
| 1     | CC1IE | 1: enabled                                     |
|       | UIE   | Update Interrupt enable.                       |
| 0     |       | 0: disabled                                    |
|       |       | 1: enabled                                     |

## 8.3.1.6 Status Register 1 (PWM0\_SR1)

| Bit No.             | 7          | 6          | 5          | 4          |
|---------------------|------------|------------|------------|------------|
| Symbol              | BIF        | TIF        | COMIF      | CC4IF      |
| Read/Write          | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | 0          | 0          | 0          | 0          |
| Bit No.             | 3          | 2          | 1          | 0          |
| Symbol              | CC3IF      | CC2IF      | CC1IF      | UIF        |
| Read/Write          | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial          | 0          | 0          | 0          | 0          |
| Value               |            |            |            |            |

| Bit No. | Symbol                | Description                                                              |
|---------|-----------------------|--------------------------------------------------------------------------|
|         | Break Interrupt flag. |                                                                          |
|         |                       | Once the break is valid, the bit is set to 1 by hardware. If the break   |
| 7       | BIF                   | input is invalid, the bit can be written 0 and cleared to 0 by software. |
|         |                       | 0: No break events.                                                      |
|         |                       | 1: Active level is detected on the break input.                          |



# BS9000AMxx

|   |       | Trigger interrupt flag.                                               |
|---|-------|-----------------------------------------------------------------------|
| 6 |       | When a trigger event occurs (a active edge is detected at the TRGI    |
|   |       | input when the slave mode controller is in a mode other than gated    |
|   | TIF   | mode. Or any edge in gated mode), hardware sets it to 1. The bit      |
|   |       | can be written 0 and cleared to 0 by software.                        |
|   |       | 0: no trigger events occur.                                           |
|   |       | 1: Trigger an interrupt to wait for response.                         |
|   |       | COM interrupt flag.                                                   |
|   |       | Once a COM event is generated (when the capture/compare               |
| _ |       | control bits: CCxE, CCxNE, OCxM have been updated) this bit is        |
| 5 | COMIF | set to 1 by hardware. it is written to 0 or cleared to 0 by software. |
|   |       | 0: no COM events generated.                                           |
|   |       | 1: COM interrupt waiting                                              |
|   |       | Capture/compare 4 interrupt flag.                                     |
| 4 | CC4IF | Refer to CC1IF description.                                           |
|   |       | Capture/compare 3 interrupt flag.                                     |
| 3 | CC3IF | Refer to CC1IF description.                                           |
|   |       | Capture/compare 2 interrupt flag.                                     |
| 2 | CC2IF | Refer to CC1IF description.                                           |
|   |       | Capture/compare 1 interrupt flag.                                     |
|   |       | If channel CC1 is configured as output mode.                          |
|   |       | This bit is set to 1 by hardware when the counter value matches the   |
|   |       | comparison value, except in center aligned mode (refer to the CMS     |
|   |       | bit of the PWM0_CR1 register). it is written to 0 or cleared to 0 by  |
|   |       | software.                                                             |
|   |       | 0: no match occurs.                                                   |
|   |       | 1: The value of PWM0_CNT matches the value of PWM0_CCR1.              |
|   |       | Note: In center aligned mode, when the counter is 0, it counts up,    |
|   |       | and when the counter is ARR, it counts down (it counts up from 0      |
| 1 | CC1IF | to ARR-1, and then from ARR counts down to 1). Therefore, for all     |
|   |       | SMS values, both values are not flagged. However, if CCR1>ARR,        |
|   |       | CC1IF is set to 1 when CNT reaches ARR.                               |
|   |       | If channel CC1 is configured as input mode.                           |
|   |       | This bit is set to 1 by hardware when a capture event occurs, and it  |
|   |       | is written to 0/cleared to 0 by software or by reading PWM0 CCR1      |
|   |       | to clear to 0.                                                        |
|   |       | 0: no input capture generates.                                        |
|   |       | 1: The counter value has been captured (copied) to PWM0_CCR1          |
|   |       | (an edge with the same polarity as the selected one is detected on    |
|   |       | IC1).                                                                 |
|   |       | Update interrupt flag. This bit is set to 1 by hardware when an       |
| 0 | UIF   | update event is generated. It is written to 0 or cleared to 0 by      |
|   |       |                                                                       |



| software.                                                               |  |
|-------------------------------------------------------------------------|--|
| 0: no update events generated.                                          |  |
| 1: Update event wait accordingly. This bit is set to 1 by hardware      |  |
| when the register is updated.                                           |  |
| if UDIS=0 in the PWM0_CR1 register, when the register                   |  |
| overflows or underflows.                                                |  |
| if UDIS=0 and URS=0 of PWM0_CR1 register when setting the               |  |
| UG bit of PWM0_ETR register software to reinitialize the counter        |  |
| CNT.                                                                    |  |
| If UDIS=0 and URS=0 of PWM0_CR1 register, when the counter              |  |
| CNT is reinitialized by a trigger event (refer to slave mode controller |  |
| PWM0_SMCR).                                                             |  |

## 8.3.1.7 Status Register 2 (PWM0\_SR2)

| Bit No.    | 7          | 6          | 5          | 4          |
|------------|------------|------------|------------|------------|
| Symbol     | -          |            |            | CC4OF      |
| Read/Write | -          |            |            | Read/Write |
| Po Initial |            |            |            |            |
| Value      |            | -          |            |            |
| Bit No.    | 3          | 2          | 1          | 0          |
| Symbol     | CC3OF      | CC2OF      | CC10F      | -          |
| Read/Write | Read/Write | Read/Write | Read/Write | -          |
| Po Initial | 0          | 0          | 0          |            |
| Value      |            |            |            | -          |

| Bit No. | Symbol | Description                                                        |
|---------|--------|--------------------------------------------------------------------|
| 4       | 00405  | Capture/compare 4 repetition capture flag                          |
| 4       | CC4OF  | See CC1OF description.                                             |
| 3       | CC3OF  | Capture/compare 3 repetition capture flag                          |
| 3       | CC3OF  | See CC1OF description.                                             |
| 2       | CC2OF  | Capture/compare 2 repetition capture flag                          |
| 2       | CC2OF  | See CC1OF description.                                             |
|         |        | Capture/compare 1 repetition capture flag                          |
|         |        | This flag can be set to 1 by hardware only when the corresponding  |
| 1       | CC10F  | channel is configured for input capture. Writing 0 clears the bit. |
|         |        | 0: No repetition capture is generated.                             |
|         |        | 1: The value of the counter is captured to the PWM0_CCR1 register  |



## 8.3.1.8 Event Generation Register (PWM0\_EGR)

| Bit No.             | 7          | 6          | 5          | 4          |
|---------------------|------------|------------|------------|------------|
| Symbol              | BG         | TG         | COMG       | CC4G       |
| Read/Write          | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | 0          | 0          | 0          | 0          |
| Bit No.             | 3          | 2          | 1          | 0          |
| Symbol              | CC3G       | CC2G       | CC1G       | UG         |
| Read/Write          | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial          | 0          | 0          | 0          | 0          |
| Value               |            |            |            |            |

| Bit No. | Symbol | Description                                                                                                                                                                                                                                                                                                                                                |
|---------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7       | BG     | <ul> <li>Generate a break event.</li> <li>This bit is set to 1 by software to generate a break event, which is automatically cleared to 0 by hardware.</li> <li>0: no behavior.</li> <li>1: Generate a break event. At this time, MOE=0 and BIF=1. If the corresponding interrupt is on (BIE=1), the corresponding interrupt will be generated.</li> </ul> |
| 6       | TG     | <ul> <li>Generate a trigger event.</li> <li>This bit is set to 1 by software to generate a trigger event that is automatically cleared to 0 by hardware.</li> <li>0: no behavior.</li> <li>1: TIF=1 of PWM0_SR register, if the corresponding interrupt is turned on (TIE=1), the corresponding interrupt is generated.</li> </ul>                         |
| 5       | COMG   | Capture/compare events and generate control updates.<br>This bit is set to 1 by software and cleared to 0 automatically by<br>hardware.<br>0: no behavior.<br>1: When CCPC=1, it is allowed to update CCxE, CCxNE, CCxP,<br>CCxNP, OCxM bits.<br>Note: This bit is only valid for channels that have complementary<br>outputs.                             |
| 4       | CC4G   | Generate capture/compare 4 events.<br>Refer to CC1G description.                                                                                                                                                                                                                                                                                           |
| 3       | CC3G   | Generate capture/compare 3 events.                                                                                                                                                                                                                                                                                                                         |



|   |      | Refer to CC1G description.                                             |  |
|---|------|------------------------------------------------------------------------|--|
| 2 | 0000 | Generate capture/compare 2 events.                                     |  |
| 2 | CC2G | Refer to CC1G description.                                             |  |
|   |      | Generate capture/compare 1 events.                                     |  |
|   |      | This bit is set to 1 by software to generate a capture/compare event,  |  |
|   |      | which is automatically cleared to 0 by hardware.                       |  |
|   |      | 0: no behavior.                                                        |  |
|   |      | 1: Generate a capture/compare event on channel CC1.                    |  |
|   |      | If channel CC1 is configured as output.                                |  |
| 1 | CC1G | Set CC1IF=1 to generate the corresponding interrupt if the             |  |
|   |      | corresponding interrupt is turned on.                                  |  |
|   |      | If channel CC1 is configured as input.                                 |  |
|   |      | The current counter value is captured to the PWM0_CCR1 register,       |  |
|   |      | set CC1IF=1, and if the corresponding interrupt is turned on, the      |  |
|   |      | corresponding interrupt is generated. If CC1IF is already 1, then set  |  |
|   |      | CC1OF=1.                                                               |  |
|   |      | Generates an update event. This bit is set to 1 by software and        |  |
|   |      | automatically cleared to 0 by hardware.                                |  |
|   |      | 0: no behavior.                                                        |  |
| 0 | UG   | 1: Reinitialize the counter and generate an update event. Note that    |  |
| U | 00   | the counter of the prescaler is also cleared to 0 (but the prescaler   |  |
|   |      | factor is unchanged). The counter is cleared to 0 if in center aligned |  |
|   |      | mode or if DIR=0 (counting up); if DIR=1 (counting down) the           |  |
|   |      | counter takes the value of PWM0_ARR.                                   |  |

#### 8.3.1.9 Capture/Compare Mode Register 1 (PWM0\_CCMR1)

The channel can be used for input (capture mode) or output (compare mode), and the direction of the channel is defined by the corresponding CC1S bit. The other bits of this register have different functions in input and output mode. OCxx describes the function of the channel in output mode and ICxx describes the function of the channel in input mode. Therefore it must be noted that the same bit has a different function in output mode and in input mode.

Address: 0xCB

• Input Capture Mode

| Bit No.    | 7          | 6 | 5 | 4 |
|------------|------------|---|---|---|
| Symbol     | IC1F       |   |   |   |
| Read/Write | Read/Write |   |   |   |
| Po Initial |            |   | 0 |   |
| Value      |            |   | U |   |



| Bit No.    | 3          | 2 | 1                  | 0     |    |
|------------|------------|---|--------------------|-------|----|
| Symbol     | IC1PSC     |   | Symbol IC1PSC CC1S |       | 1S |
| Read/Write | Read/Write |   | Read/              | Write |    |
| Po Initial | 0          |   | 0                  |       |    |
| Value      |            | - |                    |       |    |

| Bit No. | Symbol | Description                                                                  |
|---------|--------|------------------------------------------------------------------------------|
|         |        | Input capture 1 filter.                                                      |
|         |        | These bits define the sampling frequency of the TI1 input and the            |
|         |        | size of the digital filter. The digital filter consists of an event counter, |
|         |        | and the output jumps are considered valid only after N events have           |
|         |        | occurred.                                                                    |
|         |        | 0000: No filter, fsampling=fmaster                                           |
|         |        | 0001: fsampling=fmaster , N=2                                                |
|         |        | 0010: fsampling=fmaster , N=4                                                |
|         |        | 0011: fsampling=fmaster , N=8                                                |
|         |        | 0100: fsampling=fmaster/2, N=6                                               |
|         |        | 0101: fsampling=fmaster/2, N=8                                               |
| 7~4     | IC1F   | 0110: f <sub>SAMPLING</sub> =f <sub>MASTER</sub> /4, N=6                     |
| 7~4     |        | 0111: fsampling=fmaster/4, N=8                                               |
|         |        | 1000: fsampling=fmaster/8, N=6                                               |
|         |        | 1001: fsampling=fmaster/8, N=8                                               |
|         |        | 1010: fsampling=fmaster/16, N=5                                              |
|         |        | 1011: fsampling=fmaster/16, N=6                                              |
|         |        | 1100: fsampling=fmaster/16, N=8                                              |
|         |        | 1101: fsampling=fmaster/32, N=5                                              |
|         |        | 1110: fsampling=fmaster/32, N=6                                              |
|         |        | 1111: fsampling=fmaster/32, N=8                                              |
|         |        | Note: Even for channels with complementary outputs, this bit field is        |
|         |        | non-preloaded and does not take into account the value of CCPC               |
|         |        | (PWM0_CR2 register).                                                         |
|         |        | Input/capture 1 prescaler.                                                   |
|         |        | These 2 bits define the prescaler factor of the CC1 input (IC1).             |
|         |        | Once CC1E=0 (in PWM0_CCER register), the prescaler is reset.                 |
| 3~2     | IC1PSC | 00: without prescaler, one capture is triggered for each edge                |
| 3~2     |        | detected on the capture input.                                               |
|         |        | 01: capture triggered every 2 events.                                        |
|         |        | 10: capture triggered every 4 events.                                        |
|         |        | 11: Capture is triggered every 8 events.                                     |
|         |        | Capture/Compare 1 Selection.                                                 |
| 1~0     | CC1S   | These 2 bits define the direction of the channel (input/output), and         |
|         |        | the selection of the input pin.                                              |



| 00: CC1 channel is configured as an output.                      |
|------------------------------------------------------------------|
| 01: CC1 channel is configured as input and IC1 is mapped on      |
| TI1FP1.                                                          |
| 10: CC1 channel is configured as input and IC1 is mapped on      |
| TI2FP1.                                                          |
| 11: CC1 channel is configured as input and IC1 is mapped on TRC. |
| This mode works only when the internal trigger input is selected |
| (selected by the TS bit of the PWM0_SMCR register).              |
| Note: CC1S can be written only when the channel is off           |
| (PWM0_CCER1 register CC1E=0, CC1NE=0 and has been                |
| updated).                                                        |

#### • Output Compare Mode

| Bit No.             | 7          | 6          | 5          | 4     |
|---------------------|------------|------------|------------|-------|
| Symbol              | OC1CE      |            | OC1M       |       |
| Read/Write          | Read/Write |            | Read/Write |       |
| Po Initial<br>Value | 0          |            | 0          |       |
| Bit No.             | 3          | 2          | 1          | 0     |
| Symbol              | OC1PE      | OC1FE      | CC         | 1S    |
| Read/Write          | Read/Write | Read/Write | Read/      | Write |
| Po Initial<br>Value | 0          | 0          | 0          |       |

| Bit No. | Symbol | Description                                                                 |
|---------|--------|-----------------------------------------------------------------------------|
|         |        | Output compare 1 clear enable.                                              |
|         |        | This bit is used to enable the use of an external event on the ETR          |
| 7       | OC1CE  | pin to clear the output signal of channel 1 (OC1REF). Refer to <u>Clear</u> |
| 1       | OCICE  | the OCREF signal when an external event occurs.                             |
|         |        | 0: OC1REF is not affected by the ETRF input (from the ETR pin).             |
|         |        | 1: OC1REF=0 once ETRF input is detected high.                               |
|         | OC1M   | Output compare 1 mode.                                                      |
|         |        | These 3 bits define the behavior of the output reference signal             |
|         |        | OC1REF which determines the value of OC1. OC1REF is active                  |
|         |        | high, while the active level of OC1 depends on the CC1P bit.                |
| 6~4     |        | 000: Frozen. The comparison between the output compare register             |
| 0~4     |        | PWM0_CCR1 and the counter PWM0_CNT does not work for                        |
|         |        | OC1REF.                                                                     |
|         |        | 001: Set the output of channel 1 to active level when matching. Force       |
|         |        | OC1REF to high when the value of counter PWM0_CNT is the same               |
|         |        | as capture/compare register 1 PWM0_CCR1).                                   |





|   |         | 010: Set the output of channel 1 to inactive level when matching.                           |
|---|---------|---------------------------------------------------------------------------------------------|
|   |         | Force OC1REF to low when the value of counter PWM0_CNT is the                               |
|   |         | same as capture/compare register 1 (PWM0_CCR1).                                             |
|   |         | 011: reverse. Reverse the level of OC1REF when PWM0_CCR1=                                   |
|   |         | PWM0_CNT.                                                                                   |
|   |         | 100: Forced to inactive level. Forces OC1REF to low.                                        |
|   |         | 101: Force to active level. Force OC1REF to high.                                           |
|   |         | 110: PWM mode 1- In count up, channel 1 is active once                                      |
|   |         | PWM0_CNT< PWM0_CCR1, otherwise it is inactive; in count down,                               |
|   |         | channel 1 is inactive once PWM0_CNT> PWM0_CCR1                                              |
|   |         | (OC1REF=0), otherwise it is active (OC1REF=1).                                              |
|   |         | 111: PWM mode 2- In count up, channel 1 is inactive once                                    |
|   |         | PWM0_CNT< PWM0_CCR1, otherwise it is active; in count down,                                 |
|   |         | channel 1 is active once PWM0_CNT> PWM0_CCR1, otherwise it is inactive.                     |
|   |         | Note 1: Once the LOCK level is set to 3 (LOCK bit in PWM0_BKR                               |
|   |         |                                                                                             |
|   |         | register) and CC1S=00 (the channel is configured as an output) this bit cannot be modified. |
|   |         |                                                                                             |
|   |         | Note 2: In PWM mode 1 or PWM mode 2, the OC1REF level changes                               |
|   |         | only when the comparison result is changed or when switching from                           |
|   |         | froze mode to PWM mode in the output compare mode. (Reference                               |
|   |         | <u>PWM mode</u> )                                                                           |
|   |         | Note 3: On channels with complementary outputs, these bits are                              |
|   |         | preloaded. If the PWM0_CR2 register has CCPC=1, the OCM bit                                 |
|   |         | takes a new value from the preload bit only when a COM event                                |
|   |         | OCCURS.                                                                                     |
|   |         | Output Compare 1 Preload Enable.                                                            |
|   |         | 0: Preload function of PWM0_CCR1 register is disabled,                                      |
|   |         | PWM0_CCR1 register can be written at any time, and the newly                                |
|   |         | written value takes effect immediately.                                                     |
|   |         | 1: Enable the preload function of PWM0_CCR1 register, the                                   |
|   |         | read/write operation only operates on the preload register, and the                         |
| 3 | OC1PE   | preload value of PWM0_CCR1 is loaded into the current register                              |
|   |         | when the update event comes.                                                                |
|   |         | Note 1: Once the LOCK level is set to 3 (LOCK bit in PWM0_BKR                               |
|   |         | register) and CC1S=00 (the channel is configured as an output) this                         |
|   |         | bit cannot be modified.                                                                     |
|   |         | Note 2: In order to operate correctly, the preload function must be                         |
|   |         | enabled in PWM mode. However, in onepulse mode (PWM0_CR1                                    |
|   |         | register with OPM=1), it is not necessary.                                                  |
|   | 0.00455 | Output Compare 1 Fast Enable.                                                               |
| 2 | OC1FE   | This bit is used to speed up the response of the CC output to a trigger                     |
| L | 1       |                                                                                             |



# BS9000AMxx

|     |      | input event.                                                           |
|-----|------|------------------------------------------------------------------------|
|     |      | 0: Depending on the value of the counter and CCR1, CC1 operates        |
|     |      | normally, even if the trigger is on. The minimum delay to activate the |
|     |      | CC1 output is 5 clock cycles when the input of the trigger has active  |
|     |      | edge.                                                                  |
|     |      | 1: The active edge of the input to the trigger acts as if a comparison |
|     |      | match has occurred. Therefore, OC is set to the comparison level       |
|     |      | independent of the comparison result. The delay between the active     |
|     |      | edge of the sampling trigger and the CC1 output is reduced to 3 clock  |
|     |      | cycles.                                                                |
|     |      | OC1FE only works when the channel is configured to PWM1 or             |
|     |      | PWM2 mode.                                                             |
|     |      | CC1S[1:0]: Capture/Compare 1 Selection.                                |
|     |      | These 2 bits define the direction of the channel (input/output), and   |
|     |      | the selection of the input pin.                                        |
|     |      | 00: CC1 channel is configured as output.                               |
|     |      | 01: CC1 channel is configured as input and IC1 is mapped on            |
|     |      | TI1FP1.                                                                |
| 1~0 | CC1S | 10: CC1 channel is configured as input and IC1 is mapped on            |
| 10  | 0010 | TI2FP1.                                                                |
|     |      | 11: CC1 channel is configured as input and IC1 is mapped on TRC.       |
|     |      | This mode works only when the internal trigger input is selected       |
|     |      | (selected by the TS bit of the PWM0_SMCR register).                    |
|     |      | Note: CC1S can be written only when the channel is off                 |
|     |      | (PWM0_CCER1 register CC1E=0, CC1NE=0 and has been                      |
|     |      | updated).                                                              |

## 8.3.1.10 Capture/Compare Mode Register 2 (PWM0\_CCMR2)

Address: 0xCC

• Input Capture Mode

| Bit No.    | 7                     | 6 | 5     | 4 |
|------------|-----------------------|---|-------|---|
| Symbol     | IC2F                  |   |       |   |
| Read/Write | Read/Write            |   |       |   |
| Po Initial | 0                     |   |       |   |
| Value      | 0                     |   |       |   |
| Bit No.    | 3 2 1 0               |   |       |   |
| Symbol     | IC2PSC CC2S           |   | 2S    |   |
| Read/Write | Read/Write Read/Write |   | Write |   |



| Po Initial | 0 | 0 |
|------------|---|---|
| Value      |   |   |

| Bit No. | Symbol | Description                                                          |
|---------|--------|----------------------------------------------------------------------|
| 7~4     | IC2F   | Input capture 2 filter.                                              |
| 3~2     | IC2PSC | Input capture 2 prescaler.                                           |
|         |        | Input capture 2 selection.                                           |
|         |        | These 2 bits define the direction of the channel (input/output), and |
|         |        | the selection of the input pin.                                      |
|         |        | 00: CC2 channel is configured as output.                             |
|         |        | 01: CC2 channel is configured as input and IC2 is mapped on          |
|         |        | TI2FP2.                                                              |
| 1~0     | CC2S   | 10: CC2 channel is configured as input and IC2 is mapped on          |
|         |        | TI1FP2.                                                              |
|         |        | 11: CC2 channel is configured as input and IC2 is mapped on TRC.     |
|         |        | This mode works only when the internal trigger input is selected     |
|         |        | (selected by the TS bit of the PWM0_SMCR register).                  |
|         |        | Note: CC2S can be written only when the channel is off (CC2E=0       |
|         |        | and CC2NE=0 of PWM0_CCER1 register and has been updated).            |

#### • Output Compare Mode

| Bit No.             | 7          | 6          | 5          | 4  |
|---------------------|------------|------------|------------|----|
| Symbol              | OC2CE      | OC2M       |            |    |
| Read/Write          | Read/Write | Read/Write |            |    |
| Po Initial<br>Value | 0          |            | 0          |    |
| Bit No.             | 3          | 2          | 1          | 0  |
| Symbol              | OC2PE      | OC2FE      | CC         | 2S |
| Read/Write          | Read/Write | Read/Write | Read/Write |    |
| Po Initial          | 0          | 0          | 0          |    |
| Value               |            |            |            |    |

| Bit No. | Symbol  | Description                                                          |
|---------|---------|----------------------------------------------------------------------|
|         | 7 OC2CE | Output Compare 2 Clear Enable.                                       |
|         |         | This bit is used to enable the use of an external event on the ETR   |
| 7       |         | pin to clear the output signal of channel 2 (OC2REF), with reference |
| 1       |         | to Clear the OCREF signal when an external event occurs              |
|         |         | 0: OC2REF is not affected by the ETRF input (from the ETR pin).      |
|         |         | 1: OC2REF=0 once ETRF input is detected high.                        |



| 6~4 | OC2M  | Output compare 2 mode.                                              |  |
|-----|-------|---------------------------------------------------------------------|--|
| 3   | OC2PE | Output Compare 2 Preload Enable.                                    |  |
| 2   | OC2FE | Output compare 2 fast enable.                                       |  |
|     |       | The bit defines the direction of the channel (input/output) and the |  |
|     |       | selection of the input pin.                                         |  |
|     |       | Capture/compare 2 selection.                                        |  |
|     |       | 00: CC2 is configured as output.                                    |  |
|     |       | 01: CC2 is configured as input, IC2 is mapped on TI2FP2.            |  |
| 1~0 | CC2S  | 10: CC2 is configured as input, IC2 is mapped on TI1FP2.            |  |
|     |       | 11: CC2 is configured as input and IC2 is mapped on TRC. This       |  |
|     |       | mode works only when the internal trigger input is selected         |  |
|     |       | (selected by the TS bit of the PWM0_SMCR register).                 |  |
|     |       | Note: CC2S can be written only when the channel is off (CC2E=0      |  |
|     |       | and CC2NE=0 of PWM0_CCER1 register and has been updated).           |  |

## 8.3.1.11 Capture/Compare Mode Register 3 (PWM0\_CCMR3)

Address: 0xCD

Input Capture Mode

| Bit No.    | 7           | 6 | 5     | 4     |
|------------|-------------|---|-------|-------|
| Symbol     | IC3F        |   |       |       |
| Read/Write | Read/Write  |   |       |       |
| Po Initial | 0           |   |       |       |
| Value      | 0           |   |       |       |
| Bit No.    | 3 2 1       |   |       |       |
| Symbol     | IC3PSC CC3S |   |       | 3S    |
| Read/Write | Read/Write  |   | Read/ | Write |
| Po Initial | 0           |   | 0     |       |
| Value      |             |   |       |       |

| Bit No. | Symbol | Description                                                          |  |
|---------|--------|----------------------------------------------------------------------|--|
| 7~4     | IC3F   | Input capture 3 filter.                                              |  |
| 3~2     | IC3PSC | Input/capture 3 prescaler.                                           |  |
|         |        | Input/capture 3 selection.                                           |  |
|         |        | These 2 bits define the direction of the channel (input/output), and |  |
|         |        | the selection of the input pin.                                      |  |
| 1~0     | CC3S   | 00: CC3 channel is configured as output.                             |  |
|         |        | 01: CC3 channel is configured as input and IC3 is mapped on          |  |
|         |        | TI3FP3.                                                              |  |
|         |        | 10: CC3 channel is configured as input and IC3 is mapped on          |  |



| TI4FP3.                                                          |
|------------------------------------------------------------------|
| 11: CC3 channel is configured as input and IC3 is mapped on TRC. |
| This mode works only when the internal trigger input is selected |
| (selected by the TS bit of the PWM0_SMCR register).              |
| Note: CC3S can be written only when the channel is off           |
| (PWM0_CCER2 register CC3E=0, CC3NE=0 and has been                |
| updated).                                                        |

#### • Output Capture Mode

| Bit No.             | 7          | 6          | 5          | 4 |
|---------------------|------------|------------|------------|---|
| Symbol              | OC3CE      |            | OC3M       |   |
| Read/Write          | Read/Write |            | Read/Write |   |
| Po Initial<br>Value | 0          |            | 0          |   |
| Bit No.             | 3          | 2          | 1          | 0 |
| Symbol              | OC3PE      | OC3FE CC3S |            |   |
| Read/Write          | Read/Write | Read/Write | Read/Write |   |
| Po Initial<br>Value | 0          | 0          | 0          |   |

| Bit No. | Symbol | Description                                                           |
|---------|--------|-----------------------------------------------------------------------|
|         |        | Output compare 3 clear enable.                                        |
|         |        | This bit is used to enable the use of an external event on the ETR    |
| 7       | OC3CE  | pin to clear the output signal of channel 3 (OC3REF), with reference  |
| I       | OCSCE  | to Clear the OCREF signal when an external event occurs.              |
|         |        | 0: OC3REF is not affected by the ETRF input (from the ETR pin).       |
|         |        | 1: OC3REF=0 once ETRF input is detected high.                         |
| 6~4     | OC3M   | Output compare 3 mode.                                                |
| 3       | OC3PE  | Output compare 3 preload enable.                                      |
| 2       | OC3FE  | Output compare 3 fast enable.                                         |
|         |        | Capture/compare 3 selection.                                          |
|         |        | This bit defines the direction of the channel (input/output), and the |
|         |        | selection of the input pin.                                           |
|         |        | 00: CC3 channel is configured as output.                              |
| 1~0     | CC3S   | 01: CC3 channel is configured as input and IC3 is mapped on           |
| 1/20    | 0000   | TI3FP3.                                                               |
|         |        | 10: CC3 channel is configured as input and IC3 is mapped on           |
|         |        | TI4FP3.                                                               |
|         |        | 11: CC3 channel is configured as input and IC3 is mapped on TRC.      |
|         |        | This mode works only when the internal trigger input is selected      |



| (selected by the TS bit of the PWM0_SMCR register).    |  |
|--------------------------------------------------------|--|
| Note: CC3S can be written only when the channel is off |  |
| (PWM0_CCER2 register CC3E=0, CC3NE=0 and has been      |  |
| updated).                                              |  |

## 8.3.1.12 Capture/Compare Mode Register 4 (PWM0\_CCMR4)

Address: 0xCE

• Input Capture Mode

| Bit No.    | 7    | 7 6                   |         | 4  |  |  |  |
|------------|------|-----------------------|---------|----|--|--|--|
| Symbol     |      | IC                    | C4F     |    |  |  |  |
| Read/Write |      | Read                  | d/Write |    |  |  |  |
| Po Initial |      |                       | 0       |    |  |  |  |
| Value      | 0    |                       |         |    |  |  |  |
| Bit No.    | 3    | 2                     | 1       | 0  |  |  |  |
| Symbol     | IC4  | PSC                   | CC      | 4S |  |  |  |
| Read/Write | Read | Read/Write Read/Write |         |    |  |  |  |
| Po Initial | 0 0  |                       |         |    |  |  |  |
| Value      |      |                       |         |    |  |  |  |

| Bit No. | Symbol | Description                                                          |  |  |
|---------|--------|----------------------------------------------------------------------|--|--|
| 7~4     | IC4F   | Input capture 4 filter.                                              |  |  |
| 3~2     | IC4PSC | Input/capture 4 prescaler.                                           |  |  |
|         |        | Capture/Compare 4 selection.                                         |  |  |
|         |        | These 2 bits define the direction of the channel (input/output), and |  |  |
|         |        | the selection of the input pin.                                      |  |  |
|         |        | 00: CC4 channel is configured as output.                             |  |  |
|         |        | 01: CC4 channel is configured as input and IC4 is mapped on the      |  |  |
|         |        | TI4FP4.                                                              |  |  |
| 1~0     | CC4S   | 10: CC4 channel is configured as input and IC4 is mapped on          |  |  |
|         |        | TI3FP4.                                                              |  |  |
|         |        | 11: CC4 channel is configured as input and IC4 is mapped on TRC.     |  |  |
|         |        | This mode works only when the internal trigger input is selected     |  |  |
|         |        | (selected by the TS bit of the PWM0_SMCR register).                  |  |  |
|         |        | Note: CC4S can be written only when the channel is off (CC4E=0       |  |  |
|         |        | of PWM0_CCER2 register).                                             |  |  |

#### • Output Compare Mode

| Bit No. | 7 | 6 | 5 | 4 |
|---------|---|---|---|---|
|---------|---|---|---|---|



| Symbol     | OC4CE      | OC4M       |            |  |  |  |
|------------|------------|------------|------------|--|--|--|
| Read/Write | Read/Write | Read/Write |            |  |  |  |
| Po Initial | 0          | 0          |            |  |  |  |
| Value      | 0          | 0          |            |  |  |  |
| Bit No.    | 3          | 2 1 0      |            |  |  |  |
| Symbol     | OC4PE      | OC4FE CC4S |            |  |  |  |
| Read/Write | Read/Write | Read/Write | Read/Write |  |  |  |
| Po Initial | 0          | 0          | 0          |  |  |  |
| Value      |            |            |            |  |  |  |

| Bit No. | Symbol | Description                                                           |  |  |  |
|---------|--------|-----------------------------------------------------------------------|--|--|--|
|         |        | Output compare 4 clear enable.                                        |  |  |  |
|         |        | This bit is used to enable the use of an external event on the ETR    |  |  |  |
| 7       | OC4CE  | pin to clear the output signal of channel 4 (OC4REF), with reference  |  |  |  |
| ,       | OC4CE  | to <u>Clear the OCREF signal when an external event occurs.</u>       |  |  |  |
|         |        | 0: OC4REF is not affected by the ETRF input (from the ETR pin).       |  |  |  |
|         |        | 1: OC4REF = 0 once ETRF input is detected high.                       |  |  |  |
| 6~4     | OC4M   | Output compare 4 mode.                                                |  |  |  |
| 3       | OC4PE  | Output compare 4 preload enable.                                      |  |  |  |
| 2       | OC4FE  | Output compare 4 fast enable.                                         |  |  |  |
|         |        | Capture/Compare 4 selection.                                          |  |  |  |
|         |        | This bit defines the direction of the channel (input/output), and the |  |  |  |
|         |        | selection of the input pin.                                           |  |  |  |
|         |        | 00: CC4 channel is configured as output.                              |  |  |  |
|         |        | 01: CC4 channel is configured as input and IC4 is mapped on the       |  |  |  |
|         |        | TI4FP4.                                                               |  |  |  |
| 1~0     | CC4S   | 10: CC4 channel is configured as input and IC4 is mapped on           |  |  |  |
|         |        | TI3FP4.                                                               |  |  |  |
|         |        | 11: CC4 channel is configured as input and IC4 is mapped on TRC.      |  |  |  |
|         |        | This mode works only when the internal trigger input is selected      |  |  |  |
|         |        | (selected by the TS bit of the PWM0_SMCR register).                   |  |  |  |
|         |        | Note: CC4S can be written only when the channel is off (CC4E=0        |  |  |  |
|         |        | of PWM0_CCER2 register).                                              |  |  |  |

## 8.3.1.13 Capture/Compare Enable Register 1 (PWM0\_CCER1)

| Bit No.    | 7          | 6          | 5          | 4          |
|------------|------------|------------|------------|------------|
| Symbol     | CC2NP      | CC2NE      | CC2P       | CC2E       |
| Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |

Semiconductor

## BS9000AMxx

| Po Initial | 0          | 0          | 0          | 0          |
|------------|------------|------------|------------|------------|
| Value      | 0          | 0          |            |            |
| Bit No.    | 3          | 2          | 1          | 0          |
| Symbol     | CC1NP      | CC1NE      | CC1P       | CC1E       |
| Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial | 0          | 0          | 0          | 0          |
| Value      |            |            |            |            |

| Bit No. | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|---------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7       | CC2NP  | Input capture/compare 2 complementary output polarity. Refer to the description of CC1NP.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 6       | CC2NE  | Input Capture/Compare 2 complementary output enable. Refer to the description of CC1NE.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| 5       | CC2P   | Input capture/compare 2 output polarity. Refer to the description of CC1P.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| 4       | CC2E   | Input Capture/Compare 2 output enable. Refer to the description of CC1E.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 3       | CC1NP  | Input capture/compare 1 complementary output polarity.<br>0: OC1N is active high.<br>1: OC1N is active low.<br>Note 1: This bit cannot be modified once the LOCK level (LOCK bit<br>in PWM0_BKR register) is set to 3 or 2 and CC1S=00 (channel is<br>configured as output).<br>Note 2: For channels with complementary outputs, this bit is<br>preloaded. If CCPC=1 (PWM0_CR2 register), the CC1NP bit takes<br>a new value from the preload bit only when a COM event occurs.                                                                             |  |  |
| 2       | CC1NE  | Input Capture/Compare 1 complementary output enable.<br>0: Off - OC1N disables output, so the output level of OC1N depends<br>on the values of MOE, OSSI, OSSR, OIS1, OIS1N and CC1E bits.<br>1: ON- OC1N signal is output to the corresponding output pin and<br>its output level depends on the values of MOE, OSSI, OSSR, OIS1,<br>OIS1N and CC1E bits.<br>Note: For channels with complementary outputs, this bit is<br>preloaded. If CCPC=1 (PWM0_CR2 register), the CC1NE bit takes<br>a new value from the preload bit only when a COM event occurs. |  |  |
| 1       | CC1P   | Input Capture/Compare 1 Output polarity.<br>The CC1 channel is configured as output.<br>0: OC1 active high.<br>1: OC1 is active low.<br>CC1 channel is configured as trigger (Refer to Figure 0.41 Inputs<br>of PWM0 Channel 1).<br>0: The trigger occurs at a high level or rising edge of TI1F.                                                                                                                                                                                                                                                           |  |  |



|   |      | A. The tripped accurs of the low low Level 1. States of TIAE        |
|---|------|---------------------------------------------------------------------|
|   |      | 1: The trigger occurs at the low level or falling edge of TI1F.     |
|   |      | The CC1 channel is configured as input (Refer to Figure 8.41)       |
|   |      | 0: Capture occurs on the high level or rising edge of TI1F.         |
|   |      | 1: Capture occurs on the low level or falling edge of TI1F.         |
|   |      | Note 1: Once the LOCK level (LOCK bit in PWM0_BKR register) is      |
|   |      | set to 3 or 2 and CC1S=00 (channel is configured as output), this   |
|   |      | bit cannot be modified.                                             |
|   |      | Note 2: For channels with complementary outputs, this bit is        |
|   |      | preloaded. If CCPC=1 (PWM0_CR2 register), the CC1P bit takes a      |
|   |      | new value from the preload bit only when a COM event occurs.        |
|   |      | Input Capture/Compare 1 output enable.                              |
|   |      | CC1 channel is configured as output.                                |
|   |      | 0: Off - OC1 disables output, so the output level of OC1 depends    |
|   |      | on the values of the MOE, OSSI, OSSR, OIS1, OIS1N, and CC1NE        |
|   |      | bits.                                                               |
|   |      | 1: ON- OC1 signal is output to the corresponding output pin and its |
|   |      | output level depends on the values of MOE, OSSI, OSSR, OIS1,        |
|   |      | OIS1N and CC1NE bits.                                               |
| 0 | CC1E | CC1 channel is configured as input.                                 |
|   |      | This bit determines whether the counter value can be captured into  |
|   |      | the PWM0 CCR1 register.                                             |
|   |      | 0: Capture disabled.                                                |
|   |      | 1: Capture enabled.                                                 |
|   |      |                                                                     |
|   |      | Note: For channels with complementary outputs, this bit is          |
|   |      | preloaded. If CCPC=1 (PWM0_CR2 register), the CC1E bit takes a      |
|   |      | new value from the preload bit only when a COM event occurs.        |

|            |             | Control b   | oit         | Con       | trol bit                                        |                                                 |
|------------|-------------|-------------|-------------|-----------|-------------------------------------------------|-------------------------------------------------|
| MOE<br>bit | OSSI<br>bit | OSSR<br>bit | CCxE<br>bit | CCxNE bit | OCx output status                               | OC <i>x</i> N output status                     |
|            |             | 0           | 0           | 0         | Output disabled<br>(disconnected from<br>timer) | Output disabled<br>(disconnected from<br>timer) |
| 1          | 1 X         | 0           | 0           | 1         | Output disabled<br>(disconnected from<br>timer) | OCxREF + polarity.<br>OCxN= OCxREF xor<br>CCxNP |
|            |             | 0           | 1           | 0         | OCxREF + polarity.<br>OCx= OCxREF xor<br>CCxP   | Output disabled<br>(disconnected from<br>timer) |
|            |             | 0           | 1           | 1         | OC <i>x</i> REF + polarity                      | OCxREF inverted +                               |



|   | · · · · · · · · · · · · · · · · · · · |   |   |   |                                                                                   |                                                                            |
|---|---------------------------------------|---|---|---|-----------------------------------------------------------------------------------|----------------------------------------------------------------------------|
|   |                                       |   |   |   | + deadtime                                                                        | polarity + deadtime                                                        |
|   |                                       | 1 | 0 | 0 | Output disabled<br>(disconnected from<br>timer)                                   | Output disabled<br>(disconnected from<br>timer)                            |
|   |                                       | 1 | 0 | 1 | OFF (output<br>enabled and<br>inactive level)<br>OC <i>x</i> =CCxP                | OCxREF + polarity.<br>OCxN= OCxREF xor<br>CCxNP                            |
|   |                                       | 1 | 1 | 0 | OC <i>x</i> REF + polarity,<br>OC <i>x</i> = OC <i>x</i> REF xor<br>CC <i>x</i> P | OFF (output enabled<br>and inactive level)<br>OC <i>x</i> N=CC <i>x</i> NP |
|   |                                       | 1 | 1 | 1 | OCxREF + polarity<br>+ deadtime                                                   | OCxREF inverted +<br>polarity + deadtime                                   |
|   | 0                                     |   |   |   |                                                                                   |                                                                            |
|   | 0                                     |   |   |   | Output disabled (disc                                                             | onnected from timer)                                                       |
|   | 0                                     |   |   |   |                                                                                   |                                                                            |
|   | 0                                     |   |   |   |                                                                                   |                                                                            |
| 0 | 1                                     | Х | Х | Х | OFF(output enabled a                                                              | and inactive level)                                                        |
|   | 1                                     |   |   |   | -                                                                                 | CCxP, OCxN=CCxNP;                                                          |
|   | 1                                     |   |   |   | Then, if the clock exis                                                           | sts: after a dead time<br>J=OISxN, assume that                             |
|   | 1                                     |   |   |   |                                                                                   | not both correspond to                                                     |

 Table 0.92
 Control bits for complementary output channels OCx and OCxN with break

Note: The status of the external I/O pins connected to the complementary OCx and OCxN channels depends on the OCx and OCxN channel status and GPIO registers.

#### 8.3.1.14 Capture/Compare Enable Register 2 (PWM0\_CCER2)

| Bit No.    | 7 | 6 | 5          | 4          |
|------------|---|---|------------|------------|
| Symbol     | - | - | CC4P       | CC4E       |
| Read/Write | - | - | Read/Write | Read/Write |
| Po Initial |   |   | 0          | 0          |
| Value      | - | - |            |            |
| Bit No.    | 3 | 2 | 1          | 0          |



| Symbol     | CC3NP      | CC3NE      | CC3P       | CC3E       |  |
|------------|------------|------------|------------|------------|--|
| Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |  |
| Po Initial | 0          | 0          | 0          | 0          |  |
| Value      |            |            |            |            |  |

| Bit No. | Symbol | Description                                                          |
|---------|--------|----------------------------------------------------------------------|
| 5       | CC4P   | Input capture/compare 4 output polarity. Refer to the description of |
|         |        | CC1P.                                                                |
| 4       | CC4E   | Input Capture/Compare 4 output enable. Refer to the description of   |
|         |        | CC1E.                                                                |
| 3       | CC3NP  | Input capture/compare 3 complementary output polarity. Refer to      |
|         |        | the description of CC1NP.                                            |
| 2       | CC3NE  | Input Capture/Compare 3 complementary output enable. Refer to        |
|         |        | the description of CC1NE.                                            |
| 1       | CC3P   | Input capture/compare 3 output polarity. Refer to the description of |
|         |        | CC1P.                                                                |
| 0       | CC3E   | Input Capture/Compare 3 output enable. Refer to the description of   |
|         |        | CC1E.                                                                |

## 8.3.1.15 Counter High 8 bits (PWM0\_CNTRH)

Address: 0xD2

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|------------------|---|------------|---|---|---|---|---|---|--|--|--|
| Symbol           |   | CNT[15:8]  |   |   |   |   |   |   |  |  |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |  |  |
| Po Initial Value |   | 0          |   |   |   |   |   |   |  |  |  |

| Bit No. | Symbol    | Description         |
|---------|-----------|---------------------|
| 7~0     | CNT[15:8] | Counter high 8 bits |

## 8.3.1.16 Counter Low 8 bits (PWM0\_CNTRL)

| Bit No.          | 7        | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|------------------|----------|------------|---|---|---|---|---|---|--|--|
| Symbol           | CNT[7:0] |            |   |   |   |   |   |   |  |  |
| Read/Write       |          | Read/Write |   |   |   |   |   |   |  |  |
| Po Initial Value |          | 0          |   |   |   |   |   |   |  |  |



| Bit No. | Symbol   | Description                                                                |  |  |
|---------|----------|----------------------------------------------------------------------------|--|--|
|         |          | Counter low 8 bits.                                                        |  |  |
| 7~0     | CNT[7:0] | The bit[2:0] is fixed to 0x00 when reading, i.e., the read value will have |  |  |
|         |          | an error of 0~7 values.                                                    |  |  |

#### 8.3.1.17 Prescaler High 8 bits (PWM0\_PSCRH)

Address: 0xD4

| Bit No.          | 7         | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------------|-----------|------------|---|---|---|---|---|---|--|
| Symbol           | PSC[15:8] |            |   |   |   |   |   |   |  |
| Read/Write       |           | Read/Write |   |   |   |   |   |   |  |
| Po Initial Value |           | 0          |   |   |   |   |   |   |  |

| Bit No. | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7~0     | PSC[15:8] | Prescaler High 8 bits.<br>The prescaler is used to divide the frequency of CK_PSC.<br>The clock frequency of the counter ( $_{fCK\_CNT}$ ) is equal to<br>$f_{CK\_CNT}/(PSCR[15:0] + 1)$ .<br>The PSCR contains the value that is loaded into the current prescaler<br>register when an update event is generated (an update event consists<br>of the counter being cleared to 0 by the UG bit of PWM_EGR or by a<br>slave controller in reset mode). This means that in order for the new<br>value to take effect, an update event must be generated. |

#### 8.3.1.18 Prescaler Low 8 bits (PWM0\_PSCRL)

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|------------------|---|------------|---|---|---|---|---|---|--|--|--|
| Symbol           |   | PSC[7:0]   |   |   |   |   |   |   |  |  |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |  |  |
| Po Initial Value |   | 0          |   |   |   |   |   |   |  |  |  |

| Bit No. | Symbol   | Description                                                            |  |  |  |  |  |  |
|---------|----------|------------------------------------------------------------------------|--|--|--|--|--|--|
|         |          | Prescaler low 8 bits.                                                  |  |  |  |  |  |  |
|         |          | The prescaler is used to divide the frequency of CK_PSC.               |  |  |  |  |  |  |
| 7~0     |          | The clock frequency of the counter $(fCK_CNT)$ is equal to             |  |  |  |  |  |  |
| 7~0     | PSC[7:0] | f <sub>CK_CNT</sub> /( PSCR[15:0] + 1).                                |  |  |  |  |  |  |
|         |          | The PSCR contains the value loaded into the current prescaler register |  |  |  |  |  |  |
|         |          | when an update event is generated (an update event consists of the     |  |  |  |  |  |  |



| counter being cleared to 0 by the UG bit of PWM_EGR or by a slave         |
|---------------------------------------------------------------------------|
| controller in reset mode). This means that, in order for the new value to |
| take effect, an update event must be generated.                           |
|                                                                           |
|                                                                           |

#### 8.3.1.19 Auto-reload Register High 8 bits (PWM0\_ARRH)

Address: 0xD6

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------------|---|------------|---|---|---|---|---|---|--|
| Symbol           |   | ARR[15:8]  |   |   |   |   |   |   |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |
| Po Initial Value | 1 | 1          | 1 | 1 | 1 | 1 | 1 | 1 |  |

| Bit No. | Symbol    | Description                                                          |
|---------|-----------|----------------------------------------------------------------------|
|         |           | Auto-reload Register Low 8 bits.                                     |
|         |           | The ARR contains the value that will be loaded into the actual Auto- |
| 7~0     | ARR[15:8] | reload Register.                                                     |
|         |           | Please refer to the Time Base Unit for details.                      |
|         |           | The counter does not work when the value of auto-reload is empty.    |

#### 8.3.1.20 Auto-reload Register Low 8 bits (PWM0\_ARRL)

Address: 0xD7

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|---|------------|---|---|---|---|---|---|
| Symbol           |   | ARR[7:0]   |   |   |   |   |   |   |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |
| Po Initial Value |   |            |   |   |   |   |   | 1 |

| Bit No. | Symbol   | Description                     |  |  |  |  |  |
|---------|----------|---------------------------------|--|--|--|--|--|
| 7~0     | ARR[7:0] | Auto-reload Register Low 8 bits |  |  |  |  |  |

#### 8.3.1.21 Repetition Count Register (PWM0\_RCR)

| Bit No. 7 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------|---|---|---|---|---|---|
|-------------|---|---|---|---|---|---|

Semiconductor

## BS9000AMxx

| Symbol           | REP[7:0]   |
|------------------|------------|
| Read/Write       | Read/Write |
| Po Initial Value | 0          |

| Bit No. | Symbol   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7~0     | REP[7:0] | Repetition Count Register.<br>With preload enabled, these bits allow the user to set the update rate<br>of the compare registers (i.e., periodically transfer from the preload<br>register to the current register); if an update interrupt is allowed to be<br>generated, this affects the rate at which the update interrupt is<br>generated as well.<br>Each time the down counter REP_CNT reaches 0, an update event is<br>generated and the counter REP_CNT starts counting from the REP<br>value again. Since REP_CNT only reloads the REP value when the<br>cycle update event U_RC occurs, the new value written to the<br>PWM0_RCR register only takes effect when the next cycle update<br>event occurs.<br>This means that in the PWM mode, (REP+1) corresponds to<br>- The number of PWM cycles in edge-aligned mode.<br>- The number of PWM half-cycles in the center aligned mode. |

## 8.3.1.22 Capture/Compare Register 1 High 8 bits (PWM0\_CCR1H)

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|------------------|---|------------|---|---|---|---|---|---|--|--|
| Symbol           |   | CCR1[15:8] |   |   |   |   |   |   |  |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |  |
| Po Initial Value |   | 0          |   |   |   |   |   |   |  |  |

| Bit No. | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7~0     | CCR1[15:8] | High 8-bit value of Capture/compare 1.<br>If the CC1 channel is configured as output (CC1S bit of<br>PWM0_CCMR1).<br>CCR1 contains the value loaded into the current Capture/Compare 1<br>register (preload value).<br>If the preload function is not selected in the PWM0_CCMR1 register<br>(OC1PE bit), the written value is immediately passed to the current<br>register. Otherwise this preload value is passed to the current<br>capture/compare 1 register only when an update event occurs.<br>The value of the current capture/compare register is compared with<br>the value of the counter PWM0 CNT, and an output signal is |



| generated on the OC1 port.                                            |
|-----------------------------------------------------------------------|
| If the CC1 channel is configured as input:                            |
| CCR1 contains the counter value transferred by the last input capture |
| 1 event (IC1) (this register is read-only at this time).              |

#### 8.3.1.23 Capture/Compare Register 1 Low 8 bits (PWM0\_CCR1L)

Address: 0xDA

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|------------------|---|------------|---|---|---|---|---|---|--|--|
| Symbol           |   | CCR1[7:0]  |   |   |   |   |   |   |  |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |  |
| Po Initial Value |   | 0          |   |   |   |   |   |   |  |  |

| Bit No. | Symbol    | Description                           |
|---------|-----------|---------------------------------------|
| 7~0     | CCR1[7:0] | Capture/compare register 1 low 8 bits |

## 8.3.1.24 Capture/Compare Register 2 High 8 bits (PWM0\_CCR2H)

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|------------------|---|------------|---|---|---|---|---|---|--|--|
| Symbol           |   | CCR2[15:8] |   |   |   |   |   |   |  |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |  |
| Po Initial Value |   | 0          |   |   |   |   |   |   |  |  |

| Bit No. | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7~0     | CCR2[15:8] | Capture/compare register 2 high 8 bits.<br>If the CC2 channel is configured as output (CC2S bit of<br>PWM0_CCMR2).<br>CCR2 contains the value loaded into the current Capture/Compare 2<br>register (preload value).<br>If the preload function is not selected in the PWM0_CCMR2 register<br>(OC2PE bit), the written value is immediately passed to the current<br>register. Otherwise this preload value is passed to the current<br>capture/compare 2 register only when an update event occurs.<br>The value of the current capture/compare register is compared with<br>the value of the counter PWM0_CNT, and an output signal is<br>generated on the OC2 port.<br>If the CC2 channel is configured as input.<br>CCR2 contains the counter value transferred by the last input capture |



2 event (IC2) (this register is read-only at this time).

## 8.3.1.25 Capture/Compare Register 2 Low 8 bits (PWM0\_CCR2L)

Address: 0xDC

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------------|---|------------|---|---|---|---|---|---|--|
| Symbol           |   | CCR2[7:0]  |   |   |   |   |   |   |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |
| Po Initial Value |   | 0          |   |   |   |   |   |   |  |

| Bit No. | Symbol    | Description                           |
|---------|-----------|---------------------------------------|
| 7~0     | CCR2[7:0] | Capture/compare register 2 low 8 bits |

## 8.3.1.26 Capture/Compare Register 3 High 8 bits (PWM0\_CCR3H)

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------------|---|------------|---|---|---|---|---|---|--|
| Symbol           |   | CCR3[15:8] |   |   |   |   |   |   |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |
| Po Initial Value |   |            |   | ( | ) |   |   |   |  |

| Bit No. | Symbol     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit No. | CCR3[15:8] | Capture/compare register 3 high 8-bits<br>If tCC3 channel is configured as output (CC3S bit of PWM0_CCMR3).<br>CCR3 contains the value loaded into the current Capture/Compare 3<br>register (preload value).<br>If the preload function is not selected in the PWM0_CCMR3 register<br>(OC3PE bit), the written value is immediately passed to the current<br>register. Otherwise this preload value is passed to the current<br>capture/compare 3 register only when an update event occurs.<br>The value of the current capture/compare register is compared with<br>the value of the counter PWM0_CNT, and an output signal is<br>generated on the OC3 port.<br>If the CC3 channel is configured as input.<br>CCR3 contains the counter value transferred by the last input capture<br>3 event (IC3) (this register is read-only at this time). |

# Semiconductor

#### 8.3.1.27 Capture/Compare Register 3 Low 8 bits (PWM0\_CCR3L)

Address: 0xDE

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------------|---|------------|---|---|---|---|---|---|--|
| Symbol           |   | CCR3[7:0]  |   |   |   |   |   |   |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |
| Po Initial Value |   | 0          |   |   |   |   |   |   |  |

| Bit No. | Symbol    | Description                           |
|---------|-----------|---------------------------------------|
| 7~0     | CCR3[7:0] | Capture/compare register 3 low 8 bits |

#### 8.3.1.28 Capture/Compare Register 4 High 8 bits (PWM0\_CCR4H)

Address: 0xDF

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------------|---|------------|---|---|---|---|---|---|--|
| Symbol           |   | CCR4[15:8] |   |   |   |   |   |   |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |
| Po Initial Value |   |            |   | ( | ) |   |   |   |  |

| Bit No. | Symbol      | Description                                                           |
|---------|-------------|-----------------------------------------------------------------------|
|         |             | Capture/compare register 4 high 8-bits                                |
|         |             | If CC4 channel is configured as output (CC4S bit of PWM0_CCMR4).      |
|         |             | CCR4 contains the value loaded into the current Capture/Compare 4     |
|         |             | register (preload value).                                             |
|         |             | If the preload function is not selected in the PWM0_CCMR4 register    |
|         |             | (OC4PE bit), the written value is immediately passed to the current   |
| 7~0     | CCR4[15:8]  | register. Otherwise this preload value is passed to the current       |
| 1-0     | 001(4[10.0] | capture/compare 4 register only when an update event occurs.          |
|         |             | The value of the current capture/compare register is compared with    |
|         |             | the value of the counter PWM0_CNT, and an output signal is            |
|         |             | generated on the OC4 port.                                            |
|         |             | If the CC4 channel is configured as input.                            |
|         |             | CCR4 contains the counter value transferred by the last input capture |
|         |             | 4 event (IC4) (this register is read-only at this time).              |

#### 8.3.1.29 Capture/Compare Register 4 Low 8 bits (PWM0\_CCR4L)



| Bit No.          | 7         | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|-----------|------------|---|---|---|---|---|---|
| Symbol           | CCR4[7:0] |            |   |   |   |   |   |   |
| Read/Write       |           | Read/Write |   |   |   |   |   |   |
| Po Initial Value | 0         |            |   |   |   |   |   |   |

| Bit No. | Symbol    | Description                           |
|---------|-----------|---------------------------------------|
| 7~0     | CCR4[7:0] | Capture/compare register 4 low 8 bits |

## 8.3.1.30 Break Control Register (PWM0\_BKR)

| Bit No.    | 7          | 6          | 5          | 4          |  |
|------------|------------|------------|------------|------------|--|
| Symbol     | MOE        | AOE        | BKP        | BKE        |  |
| Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |  |
| Po Initial | 0          | 0          | 0          | 0          |  |
| Value      |            |            |            |            |  |
| Bit No.    | 3          | 2          | 1          | 0          |  |
| Symbol     | OSSR       | OSSI       | LO         | СК         |  |
| Read/Write | Read/Write | Read/Write | Read/Write |            |  |
| Po Initial | 0          | 0          | 0          |            |  |
| Value      |            |            |            |            |  |

| Bit No. | Symbol | Description                                                           |
|---------|--------|-----------------------------------------------------------------------|
|         |        | Main output enable.                                                   |
|         |        | This bit is cleared to 0 asynchronously by hardware once the break    |
|         |        | input is active. According to the value set for the AOE bit, this bit |
|         |        | can be set to 1 by software or automatically. it is only valid for    |
| 7       | MOE    | channels configured as outputs.                                       |
| /       | MOE    | 0: disables OC and OCN outputs or forces them to idle.                |
|         |        | 1: If the corresponding enable bit (CCxE bit of PWM0_CCERx            |
|         |        | register) is set, the OC and OCN outputs are enabled.                 |
|         |        | For OC and OCN enable details, refer to <u>Capture/Compare Enable</u> |
|         |        | <u>Register 1 (PWM0_CCER1)</u> .                                      |
|         |        | Auto output enable.                                                   |
|         |        | 0: MOE can only be set to 1 by software.                              |
| 6       | AOE    | 1: MOE can be set to 1 by software or automatically at the next       |
| 0       | AUE    | update event (if the brake input is inactive).                        |
|         |        | Note: Once the LOCK level (LOCK bit in PWM0_BKR register) is          |
|         |        | set to 1, this bit cannot be modified.                                |
| 5       | BKR    | Break input polarity.                                                 |



T

# BS9000AMxx

|     |      | 0: break input is active low.                                            |
|-----|------|--------------------------------------------------------------------------|
|     |      | 1: Break input is active high.                                           |
|     |      | Note: Once the LOCK level (LOCK bit in PWM0_BKR register) is             |
|     |      | set to 1, this bit cannot be modified.                                   |
|     |      | The break function enable.                                               |
|     |      | 0: Break input (BRK) disabled.                                           |
| 4   | BKE  | 1: break input (BRK) enabled.                                            |
|     |      | Note: Once the LOCK level (LOCK bit in PWM0_BKR register) isset          |
|     |      | to 1, this bit cannot be modified.                                       |
|     |      | The "Off state" selection in run mode.                                   |
|     |      | This bit is used when MOE = 1 and the channel is a complementary         |
|     |      | output.                                                                  |
|     |      | For OC and OCN enable details, refer to <u>Capture/Compare Enable</u>    |
|     |      | Register 1 (PWM0_CCER1).                                                 |
|     | 0005 | 0: when the timer is not operating, the OC/OCN output is disabled        |
| 3   | OSSR | (OC/OCN enable output signal = 0).                                       |
|     |      | 1: When the timer is not operating, once CCxE=1 or CCxNE=1, first        |
|     |      | enable OC/OCN and output inactive level, then set OC/OCN enable          |
|     |      | output signal=1.                                                         |
|     |      | Note: Once the LOCK level (LOCK bit in PWM0_BKR register) is             |
|     |      | set to 2, this bit cannot be modified.                                   |
|     |      | The "off state" selection in idle mode.                                  |
|     |      | This bit is used when MOE=0 and the channel is set as output.            |
|     |      | For OC and OCN enable details, refer to <u>Capture/Compare Enable</u>    |
|     |      | <u>Register 1 (PWM0_CCER1)</u> .                                         |
|     |      | 0: when the timer is not operating, the OC/OCN output is disabled        |
| 2   | OSSI | (OC/OCN enable output signal = 0).                                       |
|     |      | 1: When the timer is not operating, once CCxE=1 or CCxNE=1,              |
|     |      | OC/OCN first outputs its idle level, and then OC/OCN enable output       |
|     |      | signal = 1.                                                              |
|     |      | Note: Once the LOCK level (LOCK bit in PWM0_BKR register) is             |
|     |      | set to 2, this bit cannot be modified.                                   |
|     |      | Lock settings.                                                           |
|     |      | This bit provides write protection against software errors.              |
|     |      | 00: lock off, no write protection for registers.                         |
|     |      | 01: lock level 1, cannot write to the BKE, BKP, AOE bits of the          |
| 1.0 |      | PWM0_BKR register and the OIS1 bit of the PWM0_OISR register.            |
| 1~0 | LOCK | 10: Lock level 2, where the bits in lock level 1 cannot be written, nor  |
|     |      | the CC polarity bit (the CC polarity bit is the CCxP bit of the          |
|     |      | PWM0_CCERX register once the channel in question is set as               |
|     |      | output via the CCxS bit) and the OSSR/OSSI bit.                          |
|     |      | 11: Lock level 3, no writing to the bits in lock level 2, and no writing |



| to the CC control bit (the CC control bit is the OCxM/OCxPE bit of |
|--------------------------------------------------------------------|
| the PWM0_CCMRx register once the channel in question is set to     |
| output via the CCxS bit).                                          |
| Note: After system reset, the LOCK bit can only be written once,   |
| and once it is written to the PWM0_BDR register, its content       |
| remains unchanged until reset.                                     |

## 8.3.1.31 Deadtime Register (PWM0\_DTR)

Address: 0xE4

| Bit No.          | 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|------------|---|---|---|---|---|---|---|
| Symbol           | UTG        |   |   |   |   |   |   |   |
| Read/Write       | Read/Write |   |   |   |   |   |   |   |
| Po Initial Value | 0          |   |   |   |   |   |   |   |

| Bit No. | Symbol | Description                                                                                 |
|---------|--------|---------------------------------------------------------------------------------------------|
|         |        | Deadtime generator setting.                                                                 |
|         |        | These bits define the duration of the dead time between the insertion of                    |
|         |        | complementary outputs. Assuming that DT represents its duration and                         |
|         |        | tck_Psc is the clock pulse of PWM0.                                                         |
|         |        | DTG[7:5]=0xx => DT=DTG[7:0]x tdtg, where tdtg=t <sub>CK_PSC</sub> . (f1)                    |
|         |        | $DTG[7:5]=10x \Rightarrow DT=(64+DTG[5:0])x tdtg, where tdtg=2x t_{CK_PSC}$ . (f2)          |
|         |        | DTG[7:5]=110 => DT=(32+DTG[4:0])x tdtg, where tdtg=8x t <sub>CK_PSC</sub> (f3)              |
|         |        | DTG[7:5]=111 => DT=(32+DTG[4:0])x tdtg, where tdtg=16x t <sub>CK_PSC</sub> . (f4)           |
| 7~0     | UTG    | For example,                                                                                |
|         |        | If $t_{CK_{PSC}}$ = 125 ns (8 MHz), the possible dead time is                               |
|         |        | DTG[7:0] = 0 to 7Fh, 0 to 15875 ns with a step time of 125 ns (refer to f1),                |
|         |        | DTG[7:0] = 80h to BFh , 16 $\mu s$ to 31750 ns with a step time of 250 ns (refer            |
|         |        | to f2),                                                                                     |
|         |        | DTG[7:0] = C0h to DFh, 32 $\mu$ s to 63 $\mu$ s, in increments of 1 $\mu$ s (refer to f3),  |
|         |        | DTG[7:0] = E0h to FFh, 64 $\mu$ s to 126 $\mu$ s, in increments of 2 $\mu$ s (refer to f4), |
|         |        | Note: Once the LOCK level (LOCK bit in PWM0_BKR register) is set to 1,                      |
|         |        | 2 or 3, these bits cannot be modified.                                                      |

## 8.3.1.32 Output Idle Status Register (PWM0\_OISR)

| Bit No. | 7 | 6    | 5     | 4    |  |
|---------|---|------|-------|------|--|
| Symbol  | - | OIS4 | OIS3N | OIS3 |  |



| Read/Write | -          | Read/Write | Read/Write | Read/Write |
|------------|------------|------------|------------|------------|
| Po Initial | -          | 0          | 0          | 0          |
| Value      |            |            |            |            |
| Bit No.    | 3          | 2          | 1          | 0          |
| Symbol     | OIS2N      | OIS2       | OIS1N      | OIS1       |
| Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial | 0          | 0          | 0          | 0          |
| Value      |            |            |            |            |

| Bit No. | Symbol | Description                                                       |  |  |  |  |
|---------|--------|-------------------------------------------------------------------|--|--|--|--|
| 6       | OIS4   | Output idle state 4 (OC4 output). See OIS1 bit.                   |  |  |  |  |
| 5       | OIS3N  | Output idle state 3 (OC3N output). See OIS1N bit.                 |  |  |  |  |
| 4       | OIS3   | Output idle state 3 (OC3 output). See OIS1 bit.                   |  |  |  |  |
| 3       | OIS2N  | Output idle state 2 (OC2N output). See OIS1N bit.                 |  |  |  |  |
| 2       | OIS2   | Output idle state 2 (OC2 output). See OIS1 bit.                   |  |  |  |  |
|         |        | Output idle state 1 (OC1N output).                                |  |  |  |  |
|         |        | 0: when MOE=0, then after one dead time, OC1N=0.                  |  |  |  |  |
| 1       | OIS1N  | 1: When MOE=1, then after one dead time, OC1N=1.                  |  |  |  |  |
|         |        | Note: After LOCK level 1, 2 or 3 has been set, this bit cannot be |  |  |  |  |
|         |        | modified.                                                         |  |  |  |  |
|         |        | Output idle state 1 (OC1 output).                                 |  |  |  |  |
|         |        | 0: when MOE = 0, OC1 = 0 after one deadtime if OC1N is enabled.   |  |  |  |  |
| 0       | OIS1   | 1: When MOE=0, if OC1N is enabled, then after one deadtime,       |  |  |  |  |
| 0       | 0131   | OC1=1.                                                            |  |  |  |  |
|         |        | Note: After LOCK (PWM0_BKR register) level 1, 2 or 3 has been     |  |  |  |  |
|         |        | set, this bit cannot be modified.                                 |  |  |  |  |

## 8.3.1.33 Capture/compare Register 5 High 8 bits (PWM0\_CCR5H)

| Bit No.          | 7          | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|------------|------------|---|---|---|---|---|---|
| Symbol           | CCR5[15:8] |            |   |   |   |   |   |   |
| Read/Write       |            | Read/Write |   |   |   |   |   |   |
| Po Initial Value | 0          |            |   |   |   |   |   |   |

| Bit No. | Symbol     | Description                                                          |
|---------|------------|----------------------------------------------------------------------|
|         |            | High 8-bit values of capture/compare register 5.                     |
|         |            | CCR5 contains the value loaded into the current compare 5 register.  |
| 7~0     | CCR5[15:8] | The value of the current compare register is compared with the value |
|         |            | of the counter PWM0_CNT, and only when the comparison matches        |
|         |            | will the delayed TRGO be output to the ADC.                          |



## 8.3.1.34 Capture/compare Register 5 Low 8 bits (PWM0\_CCR5L)

Address: 0xE9

| Bit No.          | 7         | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|-----------|------------|---|---|---|---|---|---|
| Symbol           | CCR5[7:0] |            |   |   |   |   |   |   |
| Read/Write       |           | Read/Write |   |   |   |   |   |   |
| Po Initial Value | 0         |            |   |   |   |   |   |   |

| Bit No. | Symbol    | Description                           |
|---------|-----------|---------------------------------------|
| 7~0     | CCR5[7:0] | Capture/compare Register 5 Low 8 bits |

#### 8.3.1.35 Channel Direction Control Register (PWM0\_DIR)

Address: 0xEA

| Bit No.             | 7          | 6          | 5          | 4          |
|---------------------|------------|------------|------------|------------|
| Symbol              |            |            | -          |            |
| Read/Write          |            |            | -          |            |
| Po Initial          |            |            | 0          |            |
| Value               |            | 0          |            |            |
| Bit No.             | 3          | 2          | 1          | 0          |
| Symbol              | PWM0_CH4   | PWM0_CH3   | PWM0_CH2   | PWM0_CH1   |
| Read/Write          | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial<br>Value | 0          | 0          | 0          | 0          |

| Bit No. | Symbol   | Description                                      |
|---------|----------|--------------------------------------------------|
| 7~4     |          | Reserved.                                        |
| 3       | PWM0_CH4 | PWM0_CH4 direction control. 0: output; 1: input. |
| 2       | PWM0_CH3 | PWM0_CH3 direction control. 0: output; 1: input. |
| 1       | PWM0_CH2 | PWM0_CH2 direction control. 0: output; 1: input. |
| 0       | PWM0_CH1 | PWM0_CH1 direction control. 0: output; 1: input. |



#### 8.3.1.36 Input Capture 1 Filter Register (PWM0\_BKR1)

Address: 0xED

| Bit No.    | 7          | 6 | 5 | 4 |
|------------|------------|---|---|---|
| Symbol     |            |   | - |   |
| Read/Write |            |   | - |   |
| Po Initial |            |   | - |   |
| Value      |            |   |   |   |
| Bit No.    | 3          | 2 | 1 | 0 |
| Symbol     | BKINF      |   |   |   |
| Read/Write | Read/Write |   |   |   |
| Po Initial | 0          |   |   |   |
| Value      |            |   |   |   |

| Bit No.        | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit No.<br>3~0 | Symbol | Description         Input capture 1 filter.         These bits define the sampling frequency of the BKIN break input<br>and the size of the digital filter. The digital filter consists of an event<br>counter, and the output jump is considered valid only after N<br>events have occurred.         0000: No filter, fsampLing=fmaster         0001: fsampLing=fmaster, N=2         0010: fsampLing=fmaster, N=4         0011: fsampLing=fmaster, N=8         0100: fsampLing=fmaster/2, N=6         0101: fsampLing=fmaster/2, N=6         0110: fsampLing=fmaster/4, N=6         0111: fsampLing=fmaster/4, N=6         0111: fsampLing=fmaster/4, N=8         1000: fsampLing=fmaster/8, N=8         1010: fsampLing=fmaster/8, N=8         1010: fsampLing=fmaster/16, N=5         1011: fsampLing=fmaster/16, N=5         1011: fsampLing=fmaster/16, N=6         1102: fsampLing=fmaster/32, N=5         1111: fsampLing=fmaster/32, N=6         1111: fsampLing=fmaster/32, N=6 |

#### 8.3.1.37 Channel Control Register (PWM0\_CHX\_CHXN\_EN)

Address: 0xEE



# Semiconductor

## BS9000AMxx

| Bit No.             | 7           | 6            | 5            | 4            |
|---------------------|-------------|--------------|--------------|--------------|
| Symbol              | -           | PWM0_CH3N_EN | PWM0_CH2N_EN | PWM0_CH1N_EN |
| Read/Write          | -           | Read/Write   | Read/Write   | Read/Write   |
| Po Initial<br>Value | -           | 1            | 1            | 1            |
| Bit No.             | 3           | 2            | 1            | 0            |
| Symbol              | PWM0_CH4_EN | PWM0_CH3_EN  | PWM0_CH2_EN  | PWM0_CH1_EN  |
| Read/Write          | Read/Write  | Read/Write   | Read/Write   | Read/Write   |
| Po Initial<br>Value | 0           | 0            | 0            | 0            |

| Bit No. | Symbol       | Description                            |
|---------|--------------|----------------------------------------|
| 6       | PWM0_CH3N_EN | PWM0_CH3N channel control. 0: OFF 1:ON |
| 5       | PWM0_CH2N_EN | PWM0_CH2N channel control. 0: OFF 1:ON |
| 4       | PWM0_CH1N_EN | PWM0_CH1N channel control. 0: OFF 1:ON |
| 3       | PWM0_CH4_EN  | PWM0_CH4 channel control. 0: OFF 1:ON  |
| 2       | PWM0_CH3_EN  | PWM0_CH3 channel control. 0: OFF 1:ON  |
| 1       | PWM0_CH2_EN  | PWM0_CH2 channel control. 0: OFF 1:ON  |
| 0       | PWM0_CH1_EN  | PWM0_CH1 channel control. 0: OFF 1:ON  |

# 8.3.2 PWM1 Registers

## 8.3.2.1 Control Register 1 (PWM1\_CR1)

Address: 0x9B

| Bit No.    | 7          | 6          | 5          | 4          |
|------------|------------|------------|------------|------------|
| Symbol     | ARPE       |            | -          |            |
| Read/Write | Read/Write |            | -          |            |
| Po Initial | 0          |            |            |            |
| Value      | 0          |            | -          |            |
| Bit No.    | 3          | 2          | 1          | 0          |
| Symbol     | OPM        | URS        | UDIS       | CEN        |
| Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial | 0          | 0          | 0          | 0          |
| Value      |            | 0          | 0          | 0          |

| Bit No. | Symbol | Description                                                    |
|---------|--------|----------------------------------------------------------------|
|         |        | Auto-reload preload enable bit.                                |
| 7       | ARPE   | 0: The PWM1_ARR register has no preload register to buffer and |
| 1       | ARPE   | can be written to directly.                                    |
|         |        | 1: PWM1_ARR register can be buffered by preload register.      |



# BS9000AMxx

|   |      | One pulse mode.                                                     |
|---|------|---------------------------------------------------------------------|
| 3 | ОРМ  | 0: the counter does not stop when an update event occurs.           |
| 5 |      | 1: The counter stops when the next update event (clearing the CEN   |
|   |      | bit) occurs.                                                        |
|   |      | Update the request source.                                          |
|   |      | 0: When the update request is enabled, an update interrupt is       |
| 2 | URS  | generated whenever the register is updated.                         |
|   |      | 1: When the update request is enabled, only the counter overflow    |
|   |      | generates an update interrupt.                                      |
|   |      | Disable Update.                                                     |
|   |      | The software enables/disables the generation of UEV events via      |
|   |      | this bit.                                                           |
|   |      | 0: The update event is generated whenever the counter overflows,    |
| 1 | UDIS | or a software update is generated, or a hardware reset is generated |
|   |      | via the clock/trigger mode controller.                              |
|   |      | 1: No update event is generated and the shadow registers (ARR,      |
|   |      | PSC, CCRx) keep their values. If UG is set then the counter and     |
|   |      | prescaler are reinitialized.                                        |
|   |      | Enable counter.                                                     |
| 0 | CEN  | 0: disabled.                                                        |
|   |      | 1: enabled.                                                         |

## 8.3.2.2 Control Register 2 (PWM1\_CR2)

| Bit No.             | 7          | 6 | 5          | 4 |
|---------------------|------------|---|------------|---|
| Symbol              | TI1S       |   | MMS        |   |
| Read/Write          | Read/Write |   | Read/Write |   |
| Po Initial<br>Value | 0          |   | 0          |   |
| Bit No.             | 3          | 2 | 1          | 0 |
| Symbol              | -          | - | -          | - |
| Read/Write          | -          | - | -          | - |
| Po Initial          | -          | - | -          | - |
| Value               |            |   |            |   |

| Bit No. | Symbol | Description                                                      |
|---------|--------|------------------------------------------------------------------|
|         |        | TI1 selection.                                                   |
| 7       | TI1S   | 0: CC1 input pin connected to TI1 (input of the digital filter). |
|         |        | 1: CC1, CC2 and CC3 pins are connected to TI1 after XOR.         |



|     |     | Master mode selection.                                                   |
|-----|-----|--------------------------------------------------------------------------|
|     |     | These 3 bits are used to select the synchronization information          |
|     |     | (TRGO) sent to PWM0 in master mode. The possible combinations            |
|     |     | are as follows:                                                          |
|     |     | 000: Reset. The UG bit of the PWM1_EGR register is used as the           |
|     |     | trigger output (TRGO). If the trigger input (from the mode controller in |
|     |     | reset mode) generates a reset, there is a delay in the signal on TRGO    |
|     |     | relative to the actual reset.                                            |
|     |     | 001: Enable. The counter enable signal CNT_EN is used as a trigger       |
|     |     | output (TRGO). It is used to start multiple timers at the same time or   |
| 6.4 | MAR | to control the enable of slave timers over a period of time. The counter |
| 6~4 | MMS | enable signal is generated by the logical or of the trigger input signal |
|     |     | in CEN control bit and gated mode. When the counter enable signal        |
|     |     | is controlled by the trigger input, there is a delay on TRGO unless      |
|     |     | master/slave mode is selected (see the description of the MSM bit in     |
|     |     | the PWM1_SMCR register).                                                 |
|     |     | 010: Update. The update event is selected as trigger output.             |
|     |     | 011: Reserved.                                                           |
|     |     | 100: Reserved.                                                           |
|     |     | 101: Compare. OC1REF signal is used as the trigger output (TRGO).        |
|     |     | 110: Compare. OC2REF signal is used as the trigger output (TRGO).        |
|     |     | 111: Compare. OC3REF signal is used as the trigger output (TRGO).        |

## 8.3.2.3 Slave Mode Control Register (PWM1\_SMCR)

| Bit No.    | 7          | 6          | 5    | 4       |
|------------|------------|------------|------|---------|
| Symbol     | MSM        |            | TS   |         |
| Read/Write | Read/Write | Read/Write | Read | d/Write |
| Po Initial | 0          | 0          | 0    |         |
| Value      | 0          |            |      |         |
| Bit No.    | 3          | 2          | 1    | 0       |
| Symbol     | -          | SMS        |      |         |
| Read/Write | -          | Read/Write |      |         |
| Po Initial | -          | 0          |      |         |
| Value      |            |            |      |         |

| Bit No | ). | Symbol | Description                         |
|--------|----|--------|-------------------------------------|
| 7      |    | MSM    | Master/Slave Mode.<br>0: no effect. |



|     |     | 1: The event on the trigger input (TRGI) is delayed to allow perfect    |  |  |
|-----|-----|-------------------------------------------------------------------------|--|--|
|     |     | synchronization between the timer (via TRGO) and its slave timer.       |  |  |
|     |     | Trigger selection. For selecting the trigger input of synchronous       |  |  |
|     |     | counter.                                                                |  |  |
|     |     | 000: Reserved                                                           |  |  |
|     |     | 001: Reserved                                                           |  |  |
|     |     | 010: Reserved                                                           |  |  |
| 6~4 | TS  | 011: Internal trigger ITR connected to PWM0 TRGO                        |  |  |
| 0-4 | 10  | 100: Edge detector for TI1 (TI1F_ED)                                    |  |  |
|     |     | 101: Timer input after filtering (TI1FP1)                               |  |  |
|     |     | 110: Timer input after filtering (TI2FP2)                               |  |  |
|     |     | 111: Reserved                                                           |  |  |
|     |     | Note: These bits can only be changed when they are not used (e.g.       |  |  |
|     |     | SMS=000) to avoid false edge detection when they are changed.           |  |  |
|     |     | Clock/trigger/slave mode selection.                                     |  |  |
|     |     | When an external signal is selected, the active edge of the trigger     |  |  |
|     |     | signal (TRGI) is related to the polarity of the selected external input |  |  |
|     |     | (see Description of the Input Control Register and Control Register)    |  |  |
|     |     | 000: Clock/trigger controller disabled. If CEN = 1, the prescaler is    |  |  |
|     |     | driven directly by the internal clock.                                  |  |  |
|     |     | 001: Encoder mode 1. Depending on the level of TI1FP1, the              |  |  |
|     |     | counter counts up/down on the edge of TI2FP2.                           |  |  |
|     |     | 010: Encoder mode 2. Depending on the level of TI2FP2, the              |  |  |
|     |     | counter counts up/down on the edge of TI1FP1.                           |  |  |
|     |     | 011: Encoder mode 3. Depending on the level of the other input,         |  |  |
|     |     | the counter counts up/down on the edges of TI1FP1 and TI2FP2.           |  |  |
| 2~0 | SMS | 100: Reset mode. The counter is reinitialized on the rising edge of     |  |  |
|     |     | the selected trigger input (TRGI) and a signal is generated to          |  |  |
|     |     | update the register.                                                    |  |  |
|     |     | 101: Gated mode. When the trigger input (TRGI) is high, the             |  |  |
|     |     | counter is clocked on. Once the trigger input becomes low, the          |  |  |
|     |     | counter stops (but does not reset). The started and stopped of          |  |  |
|     |     | counter is in controlled.                                               |  |  |
|     |     | 110: Trigger mode. The counter is started (but not reset) on the        |  |  |
|     |     | rising edge of the trigger input TRGI, and only the start of the        |  |  |
|     |     | counter is in controlled.                                               |  |  |
|     |     | 111: External clock mode 1. The rising edge of the selected trigger     |  |  |
|     |     |                                                                         |  |  |
|     |     | input (TRGI) drives the counter.                                        |  |  |



#### 8.3.2.4 Interrupt Enable Register (PWM1\_IER)

| Bit No.    | 7          | 6          | 5          | 4          |
|------------|------------|------------|------------|------------|
| Symbol     | -          | TIE        | -          | -          |
| Read/Write | -          | Read/Write | -          | -          |
| Po Initial | -          | 0          |            |            |
| Value      |            | 0          | -          | -          |
| Bit No.    | 3          | 2          | 1          | 0          |
| Symbol     | CC3IE      | CC2IE      | CC1IE      | UIE        |
| Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial | 0          | 0          | 0          | 0          |

Address: 0x9E

Value

| Bit No. | Symbol | Description                         |
|---------|--------|-------------------------------------|
|         |        | Trigger Interrupt enable.           |
| 6       | TIE    | 0: Disabled                         |
|         |        | 1: enabled                          |
|         |        | Enable capture/compare 3 interrupt. |
| 3       | CC3IE  | 0: Disabled                         |
|         |        | 1: enabled                          |
|         |        | Enable capture/compare 2 interrupt. |
| 2       | CC2IE  | 0: Disabled                         |
|         |        | 1: enabled                          |
|         |        | Enable capture/compare 1 interrupt. |
| 1       | CC1IE  | 0: Disabled                         |
|         |        | 1: enabled                          |
|         |        | Enable update interrupt.            |
| 0       | UIE    | 0: Disabled                         |
|         |        | 1: enabled                          |

#### 8.3.2.5 Status Register 1 (PWM1\_SR1)

Address: 0x9F

| Bit No.    | 7 | 6          | 5 | 4 |
|------------|---|------------|---|---|
| Symbol     | - | TIF        | - | - |
| Read/Write | - | Read/Write | - | - |
| Po Initial |   | 0          |   |   |
| Value      | - | 0          | - | - |
| Bit No.    | 3 | 2          | 1 | 0 |



| Symbol     | CC3IF      | CC2IF      | CC1IF      | UIF        |
|------------|------------|------------|------------|------------|
| Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial | 0          | 0          | 0          | 0          |
| Value      |            |            |            |            |

| Bit No. | Symbol | Description                                                          |  |
|---------|--------|----------------------------------------------------------------------|--|
|         |        | Trigger interrupt flag.                                              |  |
|         |        | When a trigger event occurs (a active edge is detected at the TRGI   |  |
|         |        | input when the slave mode controller is in a mode other than gated   |  |
| 6       | TIF    | mode. Or any edge in gated mode), it is set to 1 by hardware. it is  |  |
|         |        | written/cleared to 0 by software.                                    |  |
|         |        | 0: no trigger events occur.                                          |  |
|         |        | 1: Trigger an interrupt to wait for response.                        |  |
| 3       | CC3IF  | Capture/compare 3 interrupt flag.                                    |  |
| 3       | CCSIF  | Refer to CC1IF description.                                          |  |
| 2       |        | Capture/compare 2 interrupt flag.                                    |  |
| 2       | CC2IF  | Refer to CC1IF description.                                          |  |
|         |        | Capture/compare 1 interrupt flag.                                    |  |
|         |        | If channel CC1 is configured as output mode:                         |  |
|         |        | This bit is set to 1 by hardware when the counter value matches the  |  |
|         |        | comparison value and is cleared to 0 by software.                    |  |
|         |        | 0: no match occurs.                                                  |  |
|         |        | 1: The value of PWM1_CNT matches the value of PWM1_CCR1.             |  |
| 1       | CC1IF  | If channel CC1 is configured as input mode:                          |  |
|         |        | This bit is set to 1 by hardware when a capture event occurs, and it |  |
|         |        | is cleared to 0 by software or by reading PWM1_CCR1L.                |  |
|         |        | 0: no input capture generated.                                       |  |
|         |        | 1: The counter value has been captured (copied) to PWM1_CCR1         |  |
|         |        | (an edge with the same polarity as the selected one is detected on   |  |
|         |        | IC1).                                                                |  |
|         |        | Update interrupt flag. This bit is set to 1 by hardware when an      |  |
|         |        | update event is generated. it is cleared to 0 by software.           |  |
|         |        | 0: no update events generated.                                       |  |
|         |        | 1: Update event wait accordingly. This bit is set to 1 by hardware   |  |
| 0       | UIF    | when the register is updated,                                        |  |
|         |        | If UDIS=0 in the PWM1_CR1 register, the counter overflows.           |  |
|         |        | if UDIS=0 and URS=0 of the PWM1_CR1 register when setting            |  |
|         |        | the UG bit of the PWM1_EGR register software to reinitialize the     |  |
|         |        | counter CNT.                                                         |  |



#### 8.3.2.6 Status Register 2 (PWM1\_SR2)

Address: 0xA1

| Bit No.    | 7          | 6          | 5          | 4 |
|------------|------------|------------|------------|---|
| Symbol     |            |            | -          |   |
| Read/Write |            |            | -          |   |
| Po Initial |            |            |            |   |
| Value      |            |            | -          |   |
| Bit No.    | 3          | 2          | 1          | 0 |
| Symbol     | CC3OF      | CC2OF      | CC10F      | - |
| Read/Write | Read/Write | Read/Write | Read/Write | - |
| Po Initial | 0          | 0          | 0          |   |
| Value      |            |            |            | - |

| Bit No. | Symbol  | Description                                                          |  |
|---------|---------|----------------------------------------------------------------------|--|
| 3       | CC3OF   | Capture/compare 3 repetition capture flag.                           |  |
| 5       | CC3OF   | See CC1OF description.                                               |  |
| 2       | 00005   | Capture/compare 2 repetition capture flag.                           |  |
| 2       | 2 CC2OF | See CC1OF description.                                               |  |
|         | CC1OF   | Capture/Compare 1 repetition capture flag.                           |  |
|         |         | This flag can be set to 1 by hardware only when the corresponding    |  |
| 1       |         | channel is configured for input capture. writing 0 to clear the bit. |  |
| I       | COTOF   | 0: no repetition capture is generated.                               |  |
|         |         | 1: The value of the counter is captured to the PWM1_CCR1 register    |  |
|         |         | when the status of CC1IF is already 1.                               |  |

### 8.3.2.7 Event Generation Register (PWM1\_EGR)

Address: 0xA2

| Bit No.    | 7          | 6          | 5          | 4          |
|------------|------------|------------|------------|------------|
| Symbol     | -          | TG         | -          | -          |
| Read/Write | -          | Read/Write | -          | -          |
| Po Initial |            | 0          |            |            |
| Value      | -          | 0          | -          | -          |
| Bit No.    | 3          | 2          | 1          | 0          |
| Symbol     | CC3G       | CC2G       | CC1G       | UG         |
| Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial | 0          | 0          | 0          | 0          |
| Value      |            |            |            |            |



| Bit No. | Symbol | Description                                                                                                                                |
|---------|--------|--------------------------------------------------------------------------------------------------------------------------------------------|
|         |        | Generate trigger event.<br>This bit is set to 1 by software to generate a trigger event that is<br>automatically cleared to 0 by hardware. |
| 6       | TG     | 0: no behavior.<br>1: TIF=1 of PWM1_SR1 register, if the corresponding interrupt is turned                                                 |
| 3       | CC3G   | on (TIE=1), the corresponding interrupt will be generated.<br>Generate capture/compare 3 event.                                            |
|         |        | Refer to CC1G description.                                                                                                                 |
| 2       | CC2G   | Generate capture/compare 2 event.<br>Refer to CC1G description.                                                                            |
|         |        | Generate capture/compare 1 event.                                                                                                          |
|         |        | This bit is set to 1 by software to generate a capture/compare event,                                                                      |
|         |        | which is automatically cleared to 0 by hardware.                                                                                           |
|         |        | 0: no behavior.                                                                                                                            |
|         |        | 1: Generate a capture/compare event on channel CC1.                                                                                        |
|         |        | If channel CC1 is configured as output:                                                                                                    |
| 1       | CC1G   | Set CC1IF=1 to generate the corresponding interrupt if the corresponding interrupt is turned on.                                           |
|         |        | If channel CC1 is configured as input:                                                                                                     |
|         |        | The current counter value is captured to the PWM1_CCR1 register, set                                                                       |
|         |        | CC1IF=1, and if the corresponding interrupt is turned on, the                                                                              |
|         |        | corresponding interrupt is generated. If CC1IF is already 1, then set                                                                      |
|         |        | CC10F=1.                                                                                                                                   |
|         |        | Generates an update event. This bit is set to 1 by software and                                                                            |
|         |        | automatically cleared to 0 by hardware.                                                                                                    |
| 0       | UG     | 0: no behavior.                                                                                                                            |
|         |        | 1: Reinitialize the counter and generate an update event. Note that the                                                                    |
|         |        | counter of prescaler is also cleared to 0.                                                                                                 |

### 8.3.2.8 Capture/Compare Mode Register 1 (PWM1\_CCMR1)

The channel can be used in input (capture mode) or output (compare mode), and the direction of the channel is defined by the corresponding CC1S bit. The other bits of the register have different functions in input and output mode. OCxx describes the function of the channel in output mode and ICxx describes the function of the channel in input mode. Therefore it must be noted that the same bit has a different function in output mode and in input mode.

Address: 0xA3

• Channel configured as input capture mode

(ВЧ

# BS9000AMxx

| Bit No.    | 7          | 6    | 5      | 4     |
|------------|------------|------|--------|-------|
| Symbol     | IC1F       |      |        |       |
| Read/Write |            | Read | /Write |       |
| Po Initial | 0          |      |        |       |
| Value      |            |      |        |       |
| Bit No.    | 3          | 2    | 1      | 0     |
| Symbol     | IC1        | PSC  | CC     | 1S    |
| Read/Write | Read/Write |      | Read/  | Write |
| Po Initial | 0          |      | 0      |       |
| Value      |            |      |        |       |

| Bit No. | Symbol | Description                                                                  |
|---------|--------|------------------------------------------------------------------------------|
|         |        | Input capture 1 filter.                                                      |
|         |        | These bits define the sampling frequency of the TI1 input and the            |
|         |        | size of the digital filter. The digital filter consists of an event counter, |
|         |        | and output jump is considered valid only after N events have                 |
|         |        | occurred.                                                                    |
|         |        | 0000: no filter, fsampling=fmaster                                           |
|         |        | 0001: f <sub>sampling</sub> =f <sub>master</sub> , N=2                       |
|         |        | 0010: fsampling=fmaster, N=4                                                 |
|         |        | 0011: fsampling=fmaster, N=8                                                 |
|         |        | 0100: fsampling=fmaster/2, N=6                                               |
|         |        | 0101: fsampling=fmaster/2, N=8                                               |
| 7.4     | 1045   | 0110: fsampling=fmaster/4, N=6                                               |
| 7~4     | IC1F   | 0111: fsampling=fmaster/4, N=8                                               |
|         |        | 1000: f <sub>SAMPLING</sub> =f <sub>MASTER</sub> /8, N=6                     |
|         |        | 1001: fsampling=fmaster/8, N=8                                               |
|         |        | 1010: f <sub>sampling</sub> =f <sub>master</sub> /16, N=5                    |
|         |        | 1011: fsampling=fmaster/16, N=6                                              |
|         |        | 1100: f <sub>SAMPLING</sub> =f <sub>MASTER</sub> /16, N=8                    |
|         |        | 1101: fsampling=fmaster/32, N=5                                              |
|         |        | 1110: fsampling=fmaster/32, N=6                                              |
|         |        | 1111: fsampling=fmaster/32, N=8                                              |
|         |        | Note: Even for channels with complementary outputs, this bit field           |
|         |        | is non-preloaded and does not take into account the value of the             |
|         |        | CCPC (PWM1_CR2 register).                                                    |
|         |        | Input/capture 1 prescaler.                                                   |
|         |        | These 2 bits define the prescaler factor of the CC1 input (IC1).             |
| 2.0     | 101000 | Once CC1E=0 (in PWM1_CCER register), the prescaler is reset.                 |
| 3~2     | IC1PSC | 00: without prescaler, one capture is triggered for each edge                |
|         |        | detected on the capture input.                                               |
|         |        | 01: capture is triggered every 2 events.                                     |



|     | 10: conture is triggered even 4 events |                                                                      |  |  |  |
|-----|----------------------------------------|----------------------------------------------------------------------|--|--|--|
|     |                                        | 10: capture is triggered every 4 events.                             |  |  |  |
|     |                                        | 11: Capture is triggered every 8 events.                             |  |  |  |
|     |                                        | Note: The internal event counter is not reset when IC1PSC is         |  |  |  |
|     |                                        | dynamically changed. In this case, the old value is used for all     |  |  |  |
|     |                                        | captures when CC1E=1. If you want to use the new value               |  |  |  |
|     |                                        | immediately, you can clear the CC1E bit and set it again.            |  |  |  |
|     |                                        | Capture/Compare 1 Select.                                            |  |  |  |
|     |                                        | These 2 bits define the direction of the channel (input/output), and |  |  |  |
|     |                                        | the selection of the input pin.                                      |  |  |  |
|     |                                        | 00: CC1 channel is configured as output.                             |  |  |  |
|     |                                        | 01: CC1 channel is configured as input and IC1 is mapped to          |  |  |  |
|     |                                        | TI1FP1.                                                              |  |  |  |
| 1~0 | CC1S                                   | 10: CC1 channel is configured as input and IC1 is mapped to          |  |  |  |
|     |                                        | TI2FP1.                                                              |  |  |  |
|     |                                        | 11: CC1 channel is configured as input and IC1 is mapped to TRC.     |  |  |  |
|     |                                        | This mode works only when the internal trigger input is selected     |  |  |  |
|     |                                        | (selected by the TS bit of the PWM1_SMCR register).                  |  |  |  |
|     |                                        | Note: CC1S can be written only when the channel is off (CC1E=0       |  |  |  |
|     |                                        | of PWM1_CCER1 register).                                             |  |  |  |

• Channel configured as output compare mode

| Bit No.             | 7          | 6            | 5          | 4     |
|---------------------|------------|--------------|------------|-------|
| Symbol              | -          | OC1M         |            |       |
| Read/Write          | -          |              | Read/Write |       |
| Po Initial<br>Value | -          |              | 0          |       |
| Bit No.             | 3          | 2            | 1          | 0     |
| Symbol              | OC1PE      | - CC1S       |            | 1S    |
| Read/Write          | Read/Write | - Read/Write |            | Write |
| Po Initial<br>Value | 0          | - 0          |            |       |

| Bit No. | Symbol | Description                                                     |  |  |
|---------|--------|-----------------------------------------------------------------|--|--|
| 7       |        | Reserved.                                                       |  |  |
|         |        | Output compare 1 mode.                                          |  |  |
|         | OC1M   | These 3 bits define the action of the output reference signal   |  |  |
|         |        | OC1REF, which determines the value of OC1. OC1REF is active     |  |  |
| 6~4     |        | high, while the active level of OC1 depends on the CC1P bit.    |  |  |
| 0~4     |        | 000: Frozen. Comparison between the output compare register     |  |  |
|         |        | PWM1_CCR1 and the counter PWM1_CNT does not work for            |  |  |
|         |        | OC1REF.                                                         |  |  |
|         |        | 001: Set the output of channel 1 to active level when matching. |  |  |





|     |       | DS9000AWXX                                                           |
|-----|-------|----------------------------------------------------------------------|
|     |       | Forced OC1REF to high when the value of counter PWM1_CNT is          |
|     |       | the same as capture/compare register 1 (PWM1_CCR1).                  |
|     |       | 010: Set the output of channel 1 to inactive level when matched.     |
|     |       | Forced OC1REF to low when the value of counter PWM1_CNT is           |
|     |       | the same as capture/compare register 1 (PWM1_CCR1).                  |
|     |       | 011: Reverse. Reverse the level of OC1REF when PWM1_CCR1=            |
|     |       | PWM1_CNT.                                                            |
|     |       | 100: Forced to inactive level. Forces OC1REF at low.                 |
|     |       | 101: Forced to active level. Force OC1REF at high.                   |
|     |       | 110: PWM Mode 1- In up-counting mode, channel 1 is active once       |
|     |       | PWM1_CNT< PWM1_CCR1, otherwise it is invalid.                        |
|     |       | 111: PWM mode 2- In up-counting mode, channel 1 is invalid once      |
|     |       | PWM1_CNT< PWM1_CCR1, otherwise it is valid.                          |
|     |       | Note: In PWM mode 1 or PWM mode 2, the OC1REF level changes          |
|     |       | only when the comparison result is changed or when switching from    |
|     |       | frozen mode to PWM mode in the output compare mode (refer to         |
|     |       | 8.2.4.5 <u>PWM mode</u> for details)                                 |
|     |       | Output Compare 1 Preload Enable.                                     |
|     |       | 0: Preload function of PWM1_CCR1 register is disabled,               |
|     |       | PWM1_CCR1 register can be written at any time, and the newly         |
|     |       | written value takes effect immediately.                              |
|     |       | 1: Enable the preload function of PWM1_CCR1 register, the            |
| 3   | OC1PE | read/write operation only operates on the preload register, and the  |
|     |       | preload value of PWM1_CCR1 is loaded into the current register       |
|     |       | when the update event comes.                                         |
|     |       | Note: In order to operate correctly, the preload function must be    |
|     |       | enabled in PWM mode. However, in one pulse mode (PWM1_CR1            |
|     |       | register with OPM=1), it is not necessary.                           |
| 2   |       | Reserved.                                                            |
|     |       | CC1S[1:0]: Capture/Compare 1 Selection.                              |
|     |       | These 2 bits define the direction of the channel (input/output), and |
|     |       | the selection of the input pin.                                      |
|     |       | 00: CC1 channel is configured as output.                             |
|     |       | 01: CC1 channel is configured as input and IC1 is mapped to          |
|     |       | TI1FP1.                                                              |
| 1~0 | CC1S  | 10: CC1 channel is configured as input and IC1 is mapped to          |
|     |       | TI2FP1.                                                              |
|     |       | 11: CC1 channel is configured as input and IC1 is mapped to TRC.     |
|     |       | This mode works only when the internal trigger input is selected     |
|     |       | (selected by the TS bit of the PWM1_SMCR register).                  |
|     |       | Note: CC1S can be written only when the channel is off (CC1E=0       |
|     |       | of PWM1_CCER1 register).                                             |
|     |       |                                                                      |
|     |       | OT PVVM1_CCER1 register).                                            |



#### 8.3.2.9 Capture/Compare Mode Register 2 (PWM1\_CCMR2)

Refer to Capture/Compare Mode Register 1 (PWM1\_CCMR1) for more details.

Address: 0xA4

• Input Capture Mode

| Bit No.    | 7                     | 6    | 5       | 4     |
|------------|-----------------------|------|---------|-------|
| Symbol     | IC2F                  |      |         |       |
| Read/Write |                       | Read | I/Write |       |
| Po Initial |                       |      | 0       |       |
| Value      | 0                     |      |         |       |
| Bit No.    | 3                     | 2    | 1       | 0     |
| Symbol     | IC2PSC CC2S           |      |         | 2S    |
| Read/Write | Read/Write Read/Write |      |         | Write |
| Po Initial | (                     | 0    | 0       |       |
| Value      |                       |      |         |       |

| Bit No. | Symbol                                                    | Description                                                            |  |  |
|---------|-----------------------------------------------------------|------------------------------------------------------------------------|--|--|
| 7~4     | IC2F                                                      | Input capture 2 filter.                                                |  |  |
| 3~2     | IC2PSC                                                    | Input capture 2 prescaler.                                             |  |  |
|         |                                                           | Capture/Compare 2 selection.                                           |  |  |
|         |                                                           | This bit defines the direction of the channel (I/O), and the selection |  |  |
|         |                                                           | of the input pin:                                                      |  |  |
|         |                                                           | 00: CC2 channel is configured as output.                               |  |  |
|         |                                                           | 01: CC2 channel is configured as input and IC2 is mapped to            |  |  |
|         |                                                           | TI2FP2.                                                                |  |  |
| 1~0     | CC2S                                                      | 10: CC2 channel is configured as input and IC2 is mapped to            |  |  |
|         |                                                           | TI1FP2.                                                                |  |  |
|         |                                                           | 11: CC2 channel is configured as input and IC2 is mapped to TRC.       |  |  |
|         |                                                           | This mode works only when the internal trigger input is selected       |  |  |
|         |                                                           | (selected by the TS bit of the PWM1_SMCR register).                    |  |  |
|         | Note: CC2S can be written only when the channel is off (C |                                                                        |  |  |
|         |                                                           | of PWM1_CCER1 register).                                               |  |  |

#### • Output Compare Mode

| Bit No.    | 7 | 6    | 5          | 4 |
|------------|---|------|------------|---|
| Symbol     | - | OC2M |            |   |
| Read/Write | - |      | Read/Write |   |
| Po Initial | - |      | 0          |   |



| Value      |            |   |            |   |
|------------|------------|---|------------|---|
| Bit No.    | 3          | 2 | 1          | 0 |
| Symbol     | OC2PE      | - | CC2S       |   |
| Read/Write | Read/Write | - | Read/Write |   |
| Po Initial | 0          |   | 0          |   |
| Value      |            | - |            |   |

| Bit No. | Symbol                                                    | Description                                                            |  |  |
|---------|-----------------------------------------------------------|------------------------------------------------------------------------|--|--|
| 6~4     | OC2M                                                      | Output compare 2 mode.                                                 |  |  |
| 3       | OC2PE                                                     | Output compare 2 prescaler enable.                                     |  |  |
|         |                                                           | Capture/Compare 2 selection.                                           |  |  |
|         |                                                           | This bit defines the direction of the channel (I/O), and the selection |  |  |
|         |                                                           | of the input pin.                                                      |  |  |
|         |                                                           | 00: CC2 channel is configured as output.                               |  |  |
|         |                                                           | 01: CC2 channel is configured as input and IC2 is mapped               |  |  |
|         |                                                           | toTI2FP2.                                                              |  |  |
| 1~0     | CC2S                                                      | 10: CC2 channel is configured as input and IC2 is mapped to            |  |  |
|         |                                                           | TI1FP2.                                                                |  |  |
|         |                                                           | 11: CC2 channel is configured as input and IC2 is mapped to TRC.       |  |  |
|         |                                                           | This mode works only when the internal trigger input is selected       |  |  |
|         |                                                           | (selected by the TS bit of the PWM1_SMCR register).                    |  |  |
|         | Note: CC2S can be written only when the channel is off (C |                                                                        |  |  |
|         |                                                           | of PWM1_CCER1 register).                                               |  |  |

### 8.3.2.10 Capture/Compare Mode Register 3 (PWM1\_CCMR3)

Refer to <u>Capture/Compare Mode Register 1 (PWM1\_CCMR1)</u> for more details.

Address: 0xA5

• Input capture mode

| Bit No.    | 7                     | 6           | 5       | 4     |  |
|------------|-----------------------|-------------|---------|-------|--|
| Symbol     | IC3F                  |             |         |       |  |
| Read/Write |                       | Read        | I/Write |       |  |
| Po Initial |                       |             |         |       |  |
| Value      | 0                     |             |         |       |  |
| Bit No.    | 3                     | 2           | 1       | 0     |  |
| Symbol     | IC3                   | IC3PSC CC3S |         |       |  |
| Read/Write | Read/Write Read/Write |             |         | Write |  |
| Po Initial | 0 0                   |             |         |       |  |
| Value      |                       |             |         |       |  |



| Bit No. | Symbol | Description                                                      |
|---------|--------|------------------------------------------------------------------|
| 7~4     | IC3F   | Input capture 3 filter.                                          |
| 3~2     | IC3PSC | Input capture 3 prescaler.                                       |
|         |        | Capture/Compare 3 Selection.                                     |
|         |        | These 2 bits define the direction of the channel (I/O) and the   |
|         |        | selection of input pin:                                          |
|         |        | 00: CC3 channel is configured as output.                         |
| 1~0     | CC3S   | 01: CC3 channel is configured as input, IC3 is mapped to TI3FP3. |
|         |        | 10: Reserved                                                     |
|         |        | 11: Reserved                                                     |
|         |        | Note: CC3S can be written only when the channel is off (CC3E=0   |
|         |        | of PWM1_CCER2 register).                                         |

### • Output compare mode

| Bit No.    | 7          | 6      | 5            | 4  |  |
|------------|------------|--------|--------------|----|--|
| Symbol     | -          | OC3M   |              |    |  |
| Read/Write | -          |        | Read/Write   |    |  |
| Po Initial |            |        | 0            |    |  |
| Value      | -          | 0      |              |    |  |
| Bit No.    | 3          | 2      | 1            | 0  |  |
| Symbol     | OC3PE      | - CC3S |              | 3S |  |
| Read/Write | Read/Write | -      | - Read/Write |    |  |
| Po Initial | 0          | 0      |              |    |  |
| Value      |            | -      |              |    |  |

| Bit No. | Symbol | Description                                                           |  |  |  |  |
|---------|--------|-----------------------------------------------------------------------|--|--|--|--|
| 6~4     | OC3M   | Output compare 3 mode.                                                |  |  |  |  |
| 3       | OC3PE  | Output compare 3 prescaler enable.                                    |  |  |  |  |
|         |        | Capture/compare 3 selection.                                          |  |  |  |  |
|         |        | This bit defines the direction of the channel (input/output), and the |  |  |  |  |
|         |        | selection of the input pin.                                           |  |  |  |  |
|         |        | 00: CC3 channel is configured as output.                              |  |  |  |  |
| 1~0     | CC3S   | 01: CC3 channel is configured as input and IC3 is mapped to           |  |  |  |  |
| 1~0     | 0035   | TI3FP3.                                                               |  |  |  |  |
|         |        | 10: Reserved                                                          |  |  |  |  |
|         |        | 11: Reserved                                                          |  |  |  |  |
|         |        | Note: CC3S can be written only when CC3E=0) of PWM1_CCER2             |  |  |  |  |
|         |        | register when the channel is off.                                     |  |  |  |  |



### 8.3.2.11 Capture/Compare Enable Register 1 (PWM1\_CCER1)

Address: 0xA6

| Bit No.    | 7 | 6 | 5          | 4          |
|------------|---|---|------------|------------|
| Symbol     | - | - | CC2P       | CC2E       |
| Read/Write | - | - | Read/Write | Read/Write |
| Po Initial |   |   | 0          | 0          |
| Value      | - | - |            |            |
| Bit No.    | 3 | 2 | 1          | 0          |
| Symbol     | - | - | CC1P       | CC1E       |
| Read/Write | - | - | Read/Write | Read/Write |
| Po Initial |   |   | 0          | 0          |
| Value      | - | - |            |            |

| Bit No. | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|---------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 5       | CC2P   | Input capture/compare 2 output polarity. Refer to the description of CC1P.                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| 4       | CC2E   | Input Capture/Compare 2 output enable. Refer to the description of CC1E.                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| 1       | CC1P   | Input Capture/Compare 1 Output polarity.<br>The CC1 channel is configured as output:<br>0: OC1 is active high.<br>1: OC1 is active low.<br>The CC1 channel is configured as input or capture (Refer<br>Figure8.41).<br>0: Captures occurs on the rising edge of TI1F or TI2F.<br>1: Capture occurs on the falling edge of TI1F or TI2F.                                                                                                |  |  |  |
| 0       | CC1E   | <ul> <li>Input Capture/Compare 1 output enable.</li> <li>The CC1 channel is configured as output.</li> <li>0: Off- OC1 disables output.</li> <li>1: On - OC1 signal output to the corresponding output pin.</li> <li>The CC1 channel is configured as input:</li> <li>This bit determines whether the counter value can be captured into the PWM1_CCR1 register:</li> <li>0: Capture disabled.</li> <li>1: Capture enabled.</li> </ul> |  |  |  |

### 8.3.2.12 Capture/Compare Enable Register 2 (PWM1\_CCER2)

Address: 0xA7



| Bit No.    | 7 | 6 | 5          | 4          |  |
|------------|---|---|------------|------------|--|
| Symbol     | - | - | -          | -          |  |
| Read/Write | - | - | -          | -          |  |
| Po Initial |   |   |            | -          |  |
| Value      | - | - | -          |            |  |
| Bit No.    | 3 | 2 | 1          | 0          |  |
| Symbol     | - | - | CC3P       | CC3E       |  |
| Read/Write | - | - | Read/Write | Read/Write |  |
| Po Initial |   |   | 0          | 0          |  |
| Value      | - | - |            |            |  |

| Bit No. | Symbol | Description                                                                |
|---------|--------|----------------------------------------------------------------------------|
| 1       | CC3P   | Input capture/compare 3 output polarity. Refer to the description of CC1P. |
| 0       | CC3E   | Input Capture/Compare 3 output enable. Refer to the description of CC1E.   |

#### 8.3.2.13 Counter High 8 bits (PWM1\_CNTRH)

Address: 0xA9

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|------------------|---|------------|---|---|---|---|---|---|--|--|
| Symbol           |   | CNT[15:8]  |   |   |   |   |   |   |  |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |  |
| Po Initial Value |   |            |   | ( | ) |   |   |   |  |  |

| Bit No. | Symbol    | Description         |
|---------|-----------|---------------------|
| 7~0     | CNT[15:8] | Counter high 8 bits |

# 8.3.2.14 Counter Low 8 bits (PWM1\_CNTRL)

Address: 0xAA

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|------------------|---|------------|---|---|---|---|---|---|--|--|
| Symbol           |   | CNT[7:0]   |   |   |   |   |   |   |  |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |  |
| Po Initial Value |   | 0          |   |   |   |   |   |   |  |  |

| Bit No. | Symbol   | Description         |
|---------|----------|---------------------|
| 7~0     | CNT[7:0] | Counter low 8 bits. |



#### 8.3.2.15 Prescaler Register (PWM1\_PSCR)

Address: 0xAB

| Bit No.             | 7 | 6 | 5 | 4 | 3          | 2 | 1 | 0 |
|---------------------|---|---|---|---|------------|---|---|---|
| Symbol              | - | - | - | - | PSC        |   |   |   |
| Read/Write          | - | - | - | - | Read/Write |   |   |   |
| Po Initial<br>Value | - | - | - | - | 0          |   |   |   |

| Bit No. | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3~0     | PSC    | The value of the prescaler.<br>The prescaler is used to divide the frequency of CK_PSC.<br>The clock frequency of the counter ( $_{fCK_CNT}$ ) is equal to<br>$f_{CK_PSC}/2^{(PSC[3:0])}$ and is cleared to 0 by hardware.<br>The PSCR contains the value that is loaded into the current prescaler<br>register when an update event is generated (the update event consists<br>of the counter being cleared by the UG bit of PWM_EGR). This means<br>that in order for the new value to take effect, an update event must be<br>generated. |

### 8.3.2.16 Auto-reload Register High 8 bits (PWM1\_ARRH)

Address: 0xAC

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------------|---|------------|---|---|---|---|---|---|--|
| Symbol           |   | ARR[15:8]  |   |   |   |   |   |   |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |
| Po Initial Value | 1 | 1          | 1 | 1 | 1 | 1 | 1 | 1 |  |

| Bit No. | Symbol    | Description                                                          |
|---------|-----------|----------------------------------------------------------------------|
|         |           | High octet value of Auto-reload.                                     |
|         |           | The ARR contains the value that will be loaded into the actual Auto- |
| 7~0     | ARR[15:8] | reload Register.                                                     |
|         |           | For details, please refer to <u><i>Time Base Unit.</i></u>           |
|         |           | The counter does not work when the value of auto-reload is empty.    |



### 8.4.2.17 Auto-reload Register Low 8 bits (PWM1\_ARRL)

Address: 0xAD

| Bit No.          | 7 | 6 | 5 | 4    | 3      | 2 | 1 | 0 |
|------------------|---|---|---|------|--------|---|---|---|
| Symbol           |   |   |   | ARR  | [7:0]  |   |   |   |
| Read/Write       |   |   |   | Read | /Write |   |   |   |
| Po Initial Value | 1 | 1 | 1 | 1    | 1      | 1 | 1 | 1 |

| Bit No. | Symbol   | Description                     |
|---------|----------|---------------------------------|
| 7~0     | ARR[7:0] | Auto-reload Register Low 8 bits |

### 8.3.2.18 Capture/Compare Register 1 High 8 bits (PWM1\_CCR1H)

Address: 0xAE

| Bit No.          | 7 | 6 | 5 | 4    | 3      | 2 | 1 | 0 |
|------------------|---|---|---|------|--------|---|---|---|
| Symbol           |   |   |   | CCR1 | [15:8] |   |   |   |
| Read/Write       |   |   |   | Read | /Write |   |   |   |
| Po Initial Value |   |   |   | (    | )      |   |   |   |

| Bit No.               | Symbol               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit No.           7~0 | Symbol<br>CCR1[15:8] | DescriptionCapture/compare 1 high 8-bit value.If the CC1 channel is configured as output the CC1S bit ofPWM1_CCMR1.CCR1 contains the value loaded into the current Capture/Compare 1register (preload value).If the preload function is not selected in the PWM1_CCMR1 register(OC1PE bit), the written value is immediately passed to the currentregister. Otherwise this preload value is passed to the currentcapture/compare 1 register only when an update event occurs.The value of the current capture/compare register is compared withthe value of the counter PWM1_CNT, and an output signal isgenerated on the OC1 port.If the CC1 channel is configured as input:CCR1 contains the counter value at the time of the last input capture |



### 8.3.2.19 Capture/Compare Register 1 Low 8 bits (PWM1\_CCR1L)

Address: 0xAF

| Bit No.          | 7 | 6          | 5 | 4   | 3      | 2 | 1 | 0 |
|------------------|---|------------|---|-----|--------|---|---|---|
| Symbol           |   |            |   | CCR | 1[7:0] |   |   |   |
| Read/Write       |   | Read/Write |   |     |        |   |   |   |
| Po Initial Value |   |            |   | (   | )      |   |   |   |

| Bit No. | Symbol    | Description                           |
|---------|-----------|---------------------------------------|
| 7~0     | CCR1[7:0] | Capture/Compare Register 1 Low 8 bits |

### 8.3.2.20 Capture/Compare Register 2 High 8 bits (PWM1\_CCR2H)

Address: 0xB1

| Bit No.          | 7 | 6 | 5 | 4    | 3      | 2 | 1 | 0 |
|------------------|---|---|---|------|--------|---|---|---|
| Symbol           |   |   |   | CCR2 | [15:8] |   |   |   |
| Read/Write       |   |   |   | Read | /Write |   |   |   |
| Po Initial Value |   |   |   | (    | )      |   |   |   |

| PWM1_CCMR2).CCR2 contains the value loaded into the current Capture/Compare 2<br>register (preload value).If the preload function is not selected in the PWM1_CCMR2 register<br>(OC2PE bit), the written value is passed to the current register<br>immediately. Otherwise this preload value is passed to the current<br>capture/compare 2 register only when an update event occurs.<br>The value of the current capture/compare register is compared with | Bit No. | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| If the CC2 channel is configured as input:                                                                                                                                                                                                                                                                                                                                                                                                                   |         |        | Capture/compare 2 high 8 bits value.<br>If the CC2 channel is configured as output (CC2S bit of<br>PWM1_CCMR2).<br>CCR2 contains the value loaded into the current Capture/Compare 2<br>register (preload value).<br>If the preload function is not selected in the PWM1_CCMR2 register<br>(OC2PE bit), the written value is passed to the current register<br>immediately. Otherwise this preload value is passed to the current<br>capture/compare 2 register only when an update event occurs.<br>The value of the current capture/compare register is compared with<br>the value of the counter PWM1_CNT, and an output signal is<br>generated on the OC2 port. |



### 8.3.2.21 Capture/Compare Register 2 Low 8 bits (PWM1\_CCR2L)

Address: 0xB2

| Bit No.          | 7 | 6          | 5 | 4   | 3      | 2 | 1 | 0 |
|------------------|---|------------|---|-----|--------|---|---|---|
| Symbol           |   |            |   | CCR | 2[7:0] |   |   |   |
| Read/Write       |   | Read/Write |   |     |        |   |   |   |
| Po Initial Value |   |            |   | (   | )      |   |   |   |

| Bit No. | Symbol    | Description                           |
|---------|-----------|---------------------------------------|
| 7~0     | CCR2[7:0] | Capture/Compare Register 2 Low 8 bits |

### 8.3.2.22 Capture/Compare Register 3 High 8 bits (PWM1\_CCR3H)

Address: 0xB3

| Bit No.          | 7 | 6 | 5 | 4    | 3       | 2 | 1 | 0 |
|------------------|---|---|---|------|---------|---|---|---|
| Symbol           |   |   |   | CCR3 | 8[15:8] |   |   |   |
| Read/Write       |   |   |   | Read | /Write  |   |   |   |
| Po Initial Value |   |   |   | (    | )       |   |   |   |

| Bit No. | Symbol     | Description                                                           |  |  |  |  |
|---------|------------|-----------------------------------------------------------------------|--|--|--|--|
|         |            | Capture/compare 3 high 8 bits value.                                  |  |  |  |  |
|         |            | If the CC3 channel is configured as output (CC3S bit of               |  |  |  |  |
|         |            | PWM1_CCMR3).                                                          |  |  |  |  |
|         |            | CCR3 contains the value loaded into the current Capture/Compare 3     |  |  |  |  |
|         |            | register (preload value).                                             |  |  |  |  |
|         |            | If the preload function is not selected in the PWM1_CCMR3 register    |  |  |  |  |
|         |            | (OC3PE bit), the written value is immediately passed to the current   |  |  |  |  |
| 7~0     | CCR3[15:8] | register. Otherwise this preload value is passed to the current       |  |  |  |  |
|         |            | capture/compare 3 register only when an update event occurs.          |  |  |  |  |
|         |            | The value of the current capture/compare register is compared with    |  |  |  |  |
|         |            | the value of the counter PWM1_CNT, and an output signal is            |  |  |  |  |
|         |            | generated on the OC3 port.                                            |  |  |  |  |
|         |            | If the CC3 channel is configured as input.                            |  |  |  |  |
|         |            | CCR3 contains the counter value transferred by the last input capture |  |  |  |  |
|         |            | 3 event (IC3) (this register is read-only at this time).              |  |  |  |  |



### 8.3.2.23 Capture/Compare Register 3 Low 8 bits (PWM1\_CCR3L)

Address: 0xB4

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|---|------------|---|---|---|---|---|---|
| Symbol           |   | CCR3[7:0]  |   |   |   |   |   |   |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |
| Po Initial Value |   | 0          |   |   |   |   |   |   |

| Bit No. | Symbol    | Description                           |
|---------|-----------|---------------------------------------|
| 7~0     | CCR3[7:0] | Capture/Compare Register 3 Low 8 bits |

#### 8.3.2.24 PWM1 Channel Control Register (PWM1\_DIR)

Address: 0xEB

| Bit No.    | 7 | 6          | 5          | 4          |
|------------|---|------------|------------|------------|
| Symbol     | - | -          | -          | -          |
| Read/Write | - | -          | -          | -          |
| Po Initial |   |            |            |            |
| Value      | - | -          | -          | -          |
| Bit No.    | 3 | 2          | 1          | 0          |
| Symbol     | - | PWM1_CH3   | PWM1_CH2   | PWM1_CH1   |
| Read/Write | - | Read/Write | Read/Write | Read/Write |
| Po Initial |   | 0          | 0          | 0          |
| Value      | - | U          | 0          | U          |

| Bit No. | Symbol   | Description                                    |  |  |
|---------|----------|------------------------------------------------|--|--|
| 7~3     |          | Reserved                                       |  |  |
| 2       | PWM1_CH3 | PWM1_CH3 Direction control. 0: output; 1:input |  |  |
| 1       | PWM1_CH2 | PWM1_CH2 Direction control. 0: output; 1:input |  |  |
| 0       | PWM1_CH1 | PWM1_CH1 Direction control. 0: output; 1:input |  |  |

### 8.3.3 PWM0/1 Registers

#### 8.3.3.1 Status Register 3 (PWM\_SR3)

Address: 0xEC

| Bit No.    | 7 | 6         | 5         | 4         |
|------------|---|-----------|-----------|-----------|
| Symbol     | - | PWM1_CC3F | PWM1_CC2F | PWM1_CC1F |
| Read/Write | - | Read      | Read      | Read      |

### BS9000AMxx

| Po Initial |           |           |           | 0         |
|------------|-----------|-----------|-----------|-----------|
| Value      | -         |           |           |           |
| Bit No.    | 3         | 2         | 1         | 0         |
| Symbol     | PWM0_CC4F | PWM0_CC3F | PWM0_CC2F | PWM0_CC1F |
| Read/Write | Read      | Read      | Read      | Read      |
| Po Initial | 0         | 0         | 0         | 0         |
| Value      |           |           |           | 0         |

| Bit No. | Symbol    | Description                                                        |  |  |  |
|---------|-----------|--------------------------------------------------------------------|--|--|--|
| 6       | PWM1_CC3F | PWM1 Module: The default value is 0. See PWM0_CC1F bit.            |  |  |  |
| 5       | PWM1_CC2F | PWM1 Module: The default value is 0. See PWM0_CC1F bit.            |  |  |  |
| 4       | PWM1_CC1F | PWM1 Module: The default value is 0. See PWM0_CC1F bit.            |  |  |  |
| 3       | PWM0_CC4F | PWM0 Module: The default value is 0. See PWM0_CC1F bit.            |  |  |  |
| 2       | PWM0_CC3F | PWM0 Module: The default value is 0. See PWM0_CC1F bit.            |  |  |  |
| 1       | PWM0_CC2F | PWM0 Module: The default value is 0. See PWM0_CC1F bit.            |  |  |  |
|         |           | PWM0Module: The default value is 0.                                |  |  |  |
|         |           | 0: The bit is set to 0 by hardware when a capture event occurs and |  |  |  |
|         |           | is captured on the falling edge of the CC1 input signal.           |  |  |  |
| 0       | PWM0_CC1F | 1: The bit is set to 1 by hardware when a capture event occurs and |  |  |  |
|         |           | is captured on the rising edge of the CC1 input signal.            |  |  |  |
|         |           | Note: When TRGO of PWM1 is captured as TRC data, there is no       |  |  |  |
|         |           | effect on this bit.                                                |  |  |  |

# 8.3.3.2 PWM IO Selection Register 0 (PWM\_IO\_SEL0)

| Bit No.    | 7            | 6          | 5            | 4      |
|------------|--------------|------------|--------------|--------|
| Symbol     | PWM_ETR_EN   | PWM_ETR    | PWM0_CH3_SEL |        |
| Read/Write | Read/Write   | Read/Write | Read/Write   |        |
| Po Initial | 0            | 0          | 0            |        |
| Value      | 0            | 0          | 0            |        |
| Bit No.    | 3            | 2          | 1            | 0      |
| Symbol     | PWM0_CH2_SEL |            | PWM0_C       | H1_SEL |
| Read/Write | Read/Write   |            | Read/        | Write  |
| Po Initial |              | 0          | 0            |        |
| Value      |              | 0          |              |        |

| Bit No. | Symbol     | Description          |
|---------|------------|----------------------|
|         |            | PWM_ETR IO enable.   |
| 7       | PWM_ETR_EN | 1: select ETR        |
|         |            | 0: do not select ETR |



| 6    | PWM_ETR      | PWM_ETR IO selection.  |
|------|--------------|------------------------|
| 6    |              | 0: PA3. 1: PD4         |
| 5~4  | PWM0 CH3 SEL | PWM0_CH3 IO selection. |
| 5.4  | FWW0_CH3_SEL | 0: PD4. 1: PB2. 2: PC4 |
| 3~2  | PWM0 CH2 SEL | PWM0_CH2 IO selection. |
| 5.52 | FWW0_CHZ_SEL | 0: PB0. 1: PB6. 2: PC6 |
| 1~0  |              | PWM0_CH1 IO selection. |
| 1~0  | PWM0_CH1_SEL | 0: PB1. 1: PB7. 2: PC7 |

### 8.3.3.3 PWM IO Selection Register 1 (PWM\_IO\_SEL1)

xram\_sfr Address: 0x2048

| Bit No.             | 7             | 6             | 5            | 4             |
|---------------------|---------------|---------------|--------------|---------------|
| Symbol              | PWM_BRK_EN    | PWM_          | BRK          | PWM0_CH3N_SEL |
| Read/Write          | Read/Write    | Read/         | Read/Write   |               |
| Po Initial<br>Value | 0             | 0             | 0            |               |
| Bit No.             | 3             | 2             | 1            | 0             |
| Symbol              | PWM0_CH2N_SEL | PWM0_CH1N_SEL | PWM1_CH2_SEL | PWM1_CH1_SEL  |
| Read/Write          | Read/Write    | Read/Write    | Read/Write   | Read/Write    |
| Po Initial<br>Value | 0             | 0             | 0            | 0             |

| Bit No. | Symbol        | Description            |
|---------|---------------|------------------------|
|         |               | PWM_BRK IO Enable      |
| 7       | PWM_BRK_EN    | 1: Selected BRK        |
|         |               | 0: Do not select BRK   |
| 6~5     |               | PWM_BRK IO Selection   |
| 0~5     | PWM_BRK       | 0: PA1; 1: PB0; 2: PC6 |
| 4       |               | PWM0_CH3N IO Selection |
| 4       | PWM0_CH3N_SEL | 0: PA5; 1: PD3         |
| 3       |               | PWM0_CH2N IO Selection |
| 5       | PWM0_CH2N_SEL | 0: PA4; 1: PD2         |
| 2       |               | PWM0_CH1N IO Selection |
| 2       | PWM0_CH1N_SEL | 0: PD1; 1: PB5         |
| 1       |               | PWM1_CH2 IO Selection  |
| I       | PWM1_CH2_SEL  | 0: PD1; 1: PC2         |
| 0       |               | PWM1_CH1 IO Selection  |
| 0       | PWM1_CH1_SEL  | 0: PA3; 1: PD0         |



#### 8.3.3.4 PWM Clock Configuration Register (PWM\_SYS\_CFG)

XRAM\_SFR Address: 0x205E

| Bit No.          | 7          | 6          | 5            | 4            |
|------------------|------------|------------|--------------|--------------|
| Symbol           |            |            | -            |              |
| Read/Write       |            |            | -            |              |
| Po Initial Value |            |            | -            |              |
| Bit No.          | 3          | 2          | 1            | 0            |
| Symbol           | PWM1_EN    | PWM0_EN    | PWM1_CLK_SEL | PWM0_CLK_SEL |
| Read/Write       | Read/Write | Read/Write | Read/Write   | Read/Write   |
| Po Initial Value | 0          | 0          | 0            | 0            |

| Bit No. | Symbol       | Description                                            |
|---------|--------------|--------------------------------------------------------|
| 3       |              | PWM1 module enable control                             |
|         | PWM1_EN      | 1: Enabled                                             |
|         |              | 0: Disabled. Counter is reset and clock is turned off. |
| 2       |              | PWM0 module enable control.                            |
|         | PWM0_EN      | 1: Enabled.                                            |
|         |              | 0: Disabled. Counter is reset and clock is turned off. |
| 1       |              | PWM1 Clock selection register.                         |
|         | PWM1_CLK_SEL | 0: Selected PLL_24Mhz clock                            |
|         |              | 1: Selected XRAL                                       |
| 0       |              | PWM0Clock selection register.                          |
|         | PWM0_CLK_SEL | 0: Selected PLL_24Mhz clock.                           |
|         |              | 1: Selected XRAL                                       |

### 8.4 **PWM Configuration Procedures**

#### 8.4.1 **PWM0 Register Configuration Procedures**

#### Configuration process.

- 1) Configure PWM0\_EN=1 (operate enable) in the PWM\_SYS\_CFG register; configure the PWM0\_DIR register to select the direction of the PWM channel.
- 2) Configure PWM0\_CR1, PWM0\_PSCRH, PWM0\_PSCRL, PWM0\_ARRH, PWM0\_ARRL and PWM0\_RCR to select the count mode.
- If in output compare mode, configure the PWM0\_CCR1H, PWM0\_CCR1L PWM0\_CCR2H, PWM0\_CCR2L, PWM0\_CCR3H, PWM0\_CCR3L, PWM0\_CCR4H, and PWM0\_CCR4L registers to configure the compare values.
- 4) If with preload enable, configure the UG bit of the PWM0\_EGR register to update the shadow



register.

- 5) Configure PWM0\_IER to set interrupt enable.
- 6) Configure PWM0\_CCMR1, PWM0\_CCMR2, PWM0\_CCMR3, PWM0\_CCMR4, to select input capture or output compare modes and the parameters in the corresponding modes.
- 7) Configure the PWM0\_CCER1 and PWM0\_CCER2 registers to enable the capture or output compare and to select the polarity of the channel.
- The COMG bit of the PWM0\_EGR register can be configured to generate COM update events such as OCxM, CCxE, CCxNP, CCxNP if preload enable is available.
- 9) Configure the PWM0\_ETR, PWM0\_CR2, PWM0\_SMCR registers to select the trigger mode.
- 10) Configure PWM0\_DTR to select the dead time, PWM0\_OISR to select the idle level of the channel.
- 11) Configure PWM0\_BKR register to set the MOE bit and select the break and polarity.
- 12) Configure CEN=1 of PWM0\_CR1 register to start the counter.

#### Configuration constraints.

- 1) Input signal transformation cannot be too fast when input capture, and output waveform transformation cannot be too short, i.e. if the interval between two interrupts is too short, the system interrupt can not handle, and may miss the interrupt.
- It is not recommended to configure PWM0\_CNTRH and PWM0\_CNTL registers during the counting period.
- 3) If configured as input capture mode, it requires two steps: first, configure the CCxS bit in the PWM0\_CCMRx register to select the mapping in input mode; second, configure the ICxF and ICxPSC in the PWM0\_CCMRx register to select the filter and prescaler factors.
- 4) Note that when reading PWM0\_CR1 immediately after writing the PWM0\_CR1 register, there is a problem with the read value. It is necessary to delay the reading for some time, then the read value is correct. This is because the CEN and DIR bits in the PWM0\_CR1 register are processed twice across the time domain, then the CEN and DIR bits are the correct read values.

#### 8.4.2 PWM1 Register Configuration Procedures

#### Configuration standard process.

- Configure operate enable bit PWM1\_EN=1 in the PWM\_SYS\_CFG register; configure the PWM1\_DIR register to select the direction of the PWM channel.
- Configure PWM1\_CR1, PWM1\_PSCR, PWM1\_ARRH and PWM1\_ARRL to select the counting mode.
- 3) If in output compare mode, configure PWM1\_CCR1H PWM1\_CCR1L, PWM1\_CCR2H, PWM1\_CCR2L, PWM1\_CCR3H and PWM1\_CCR3L registers to configure the compare values.
- 4) If with preload enable, configure the UG bit of the PWM1\_EGR register to update the shadow register.
- 5) Configure PWM1\_IER to set interrupt enable.
- 6) Configure PWM1\_CCMR1, PWM1\_CCMR2, PWM1\_CCMR3 to select the input capture or output compare modes and the parameters in the corresponding modes.



- 7) Configure PWM1\_CCER1 and PWM1\_CCER2 registers to enable the capture or output compare and to select the polarity of the channel.
- 8) Configure PWM1\_CR2 and PWM1\_SMCR registers to select the trigger mode.
- 9) Configure CEN=1 of PWM1\_CR1 register to start the counter.

#### Configuration constraints.

1) Input signal transformation during input capture cannot be too fast, and output waveform transformation cannot be too short, i.e. the interval between two interrupts is too short, the system interrupt can not handle, and may miss the interrupt.

2) It is not recommended to configure the PWM1\_CNTRH, PWM1\_CNTL registers during the counting period.

3) If configured as input capture mode, it requires two steps: first, configure the CCxS bit in the PWM1\_CCMRx register to select the mapping in input mode; second, configure the ICxF and ICxPSC in the PWM1\_CCMRx register to select the filter and prescaler factors.

4) Note that when reading PWM1\_CR1 immediately after writing the PWM1\_CR1 register, there is a problem with the read value. It is necessary to delay the reading for some time, then the read value is correct, because the CEN and DIR bits in the PWM1\_CR1 register are processed twice across the time domain, until then CEN and DIR bits are the read values.

# 9 ADC

# 9.1 Introduction

ADC can perform analog-to-digital conversion for any channel selected by the software. The reference voltage of ADC is connected to the VCC of the chip. All the ADC channels can input independent analog signals. Each time ADC module converts one channel, ADC\_START=0 $\rightarrow$ 1 turns on the conversion, and updates the ADC result register and generates an interrupt when the conversion is complete.

The ADC module of BS9000AMxx has the following features:

- > Single-ended, 12-bit resolution linear successive-approximation ADC
- Single conversion mode
- > Sampling time and conversion speed configurable
- Support wake-up in wait mode
- 26 analog input channels (including 1 test channel), each of which can be decided whether to support ADC function by configuration byte.





Figure 0.1 Schematic diagram of ADC module structure





Figure 0.2 ADC Architecture Block Diagram

#### **Channel Selection and Pin Control**

The analog inputs have a total of 25 ADC channels.

The pin control register (ADC\_IO\_SEL) is used to enable/disable the ADC control function of the analog input pins.

The ADC channel address selection register (ADC\_ADDR) is used to control the selection of the current scan channel.

| Channel            |
|--------------------|
| IO input channel   |
| Vref input channel |
|                    |

Table 0.3 Channel Selection

#### ADC Operating Clock Frequency Division Control



The ADC clock source is PLL\_48MHz, and the frequency division clock selection is specified by the ADCK[1:0] bits, as follows:

| ADCK | adc_clk Frequency |
|------|-------------------|
| 0    | 3MHZ              |
| 1    | 2MHZ              |
| 2    | 1.5MHZ            |
| 3    | 1MHZ              |

Table 0.4 ADC Operating Clock Frequency Division

# 9.2 ADC Registers

### 9.2.1 Module Switch Control Register (PD\_ANA)

XRAM\_SFR Address: 0x2024

| Bit No.             | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|---------------------|---|---|---|---|---|---|---|------------|
| Symbol              | - | - | - | - | - | - | - | PD_ADC     |
| Read/Write          | - | - | - | - | - | - | - | Read/Write |
| Po Initial<br>Value | - | - | - | - | - | - | - | 1          |

| Bit | No. | Symbol | Description                           |
|-----|-----|--------|---------------------------------------|
| 7   | '~1 |        | Reserved                              |
|     |     |        | Analog ADC Operating Control Register |
|     | 0   | PD_ADC | PD_ADC=0 ADC module works normally    |
|     |     |        | PD_ADC=1 ADC module does not work     |

### 9.2.2 ADC Scan Control Register (ADC\_CH\_CFG)

Address: 0x97

| Bit No.    | 7 | 6           | 5          | 4 | 3      | 2          | 1 | 0         |
|------------|---|-------------|------------|---|--------|------------|---|-----------|
| Symbol     | - | ADC_TRIG_EN |            | A | DC_ADD | R          |   | ADC_START |
| Read/Write | - | Read/Write  | Read/Write |   |        | Read/Write |   |           |



### BS9000AMxx

| - [ |            |   |   |   |   |
|-----|------------|---|---|---|---|
|     | Po Initial |   |   |   |   |
|     |            | _ | 0 | 0 | 0 |
|     | Value      | _ | 0 | 0 | 0 |
|     | value      |   |   |   |   |

| Bit No. | Symbol      | Description                                                        |
|---------|-------------|--------------------------------------------------------------------|
|         |             | ADC Trigger Type Selection                                         |
| 6       | ADC_TRIG_EN | 1: Hardware Trigger (PWM0_TRGO)                                    |
|         |             | 0: Software Trigger                                                |
|         |             | ADC channel address selection register.                            |
|         |             | 00000: corresponding to ADC0                                       |
|         |             | 00001: corresponding to ADC1                                       |
| 5~1     | ADC_ADDR    |                                                                    |
|         |             | 11000: corresponding to ADC24                                      |
|         |             | 11001: corresponding to ADC25_VREF                                 |
|         |             | All other values reserved.                                         |
|         |             | ADC scan to start register.                                        |
|         |             | 0: ADC module does not scan.                                       |
|         |             | 1: ADC module starts scanning                                      |
|         |             | ADC_START set from 0 to 1, ADC start scanning, after scanning      |
|         |             | once, ADC_START hardware automatically set to 0, the               |
|         |             | corresponding ADC interrupt flag sets to 1, ADC interrupt flag bit |
|         |             | needs to clear to 0 by software.                                   |
|         |             | Note: ADC_START is not allowed to be configured during             |
| 0       | ADC_START   | scanning.                                                          |
| 0       | //20_0///// | Note:                                                              |
|         |             | ADC_START writes 1 to start the scan.After the scan ,the           |
|         |             | hardware will be set to 0 automatically.To start the next          |
|         |             | scan,the software will be set to 1 again.If ADC_START =            |
|         |             | 0is set during the scan,the scan will stop immediately, the        |
|         |             | module internal related signal is reset. Operation must            |
|         |             | follow the configuration: ADC_START = 1, interrupt                 |
|         |             | detected, configure ADC_START = 0. ADC_START is not                |
|         |             | allowed to be configured during the scan.                          |

# 9.2.3 ADC Scan Result Register Low 8 bits (ADC\_RDATAL)

Address: 0x99

| Bit No.          | 7                 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|-------------------|---|---|---|---|---|---|---|
| Symbol           | ADC_RAWDATAL<7:0> |   |   |   |   |   |   |   |
| Read/Write       | Read              |   |   |   |   |   |   |   |
| Po Initial Value | 0                 |   |   |   |   |   |   |   |



| Bit No. | Symbol            | Description                         |
|---------|-------------------|-------------------------------------|
| 7~0     | ADC_RAWDATAL[7:0] | ADC Scan Result Register Low 8 bits |

# 9.2.4 ADC Scan Result Register High 4 bits (ADC\_RDATAH)

Address: 0x9A

| Bit No.             | 7 | 6 | 5 | 4 | 3                  | 2 | 1 | 0 |  |  |
|---------------------|---|---|---|---|--------------------|---|---|---|--|--|
| Symbol              | - | - | - | - | ADC_RAWDATAH[11:8] |   |   |   |  |  |
| Read/Write          | - | - | - | - | Read               |   |   |   |  |  |
| Po Initial<br>Value | - | - | - | - | 0                  |   |   |   |  |  |

| Bit No. | Symbol             | Description                          |
|---------|--------------------|--------------------------------------|
| 3~0     | ADC_RAWDATAH[11:8] | ADC Scan Result Register High 4 bits |

### 9.2.5 ADC Sampling Time Configuration Register (ADC\_SPT)

XRAM\_SFR Address: 0x2053

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|------------------|---|------------|---|---|---|---|---|---|--|--|
| Symbol           |   | ADC_SPT    |   |   |   |   |   |   |  |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |  |
| Po Initial Value |   |            |   | ( | ) |   |   |   |  |  |

| Bit No. | Symbol Description |                                                      |  |  |
|---------|--------------------|------------------------------------------------------|--|--|
| 7~0     | ADC SPT            | ADC sampling time configuration register (0~255)     |  |  |
| 7~0     | ADC_SPT            | sampling time: sample_Timer = (ADC_SPT+1)*4*Tadc_clk |  |  |

### 9.2.6 ADC Sampling Timing Control Register 2 (ADC\_ANA\_CFG2)

| Bit No.    | 7           | 6        | 5        | 4                  |
|------------|-------------|----------|----------|--------------------|
| Symbol     | -           | -        | -        | ADCVREF_SELVCC_SEL |
| Read/Write | -           | -        | -        | Read/Write         |
| Po Initial |             |          |          | 0                  |
| Value      | -           | -        | -        | 0                  |
| Bit No.    | 3           | 2        | 1        | 0                  |
| Symbol     | ADCVREF_SEL | VREF_IN_ | CTRL_SEL |                    |

# BS9000AMxx

| Read/Write          | Read/Write | Read/Write | Read/Write |
|---------------------|------------|------------|------------|
| Po Initial<br>Value | 0          | 0          | 1          |

| Bit No. | Symbol             | Description                                                |  |  |  |  |  |
|---------|--------------------|------------------------------------------------------------|--|--|--|--|--|
| 4       | ADCVREF SELVCC SEL | 0: Output VCC                                              |  |  |  |  |  |
| 4       | ADOVREF_SELVOO_SEL | 1: Output 2.048V or 4.096V reference voltage               |  |  |  |  |  |
| 3       |                    | 0: ADCVREF output 2.048V                                   |  |  |  |  |  |
| 3       | ADCVREF_SEL        | 1: ADCVREF output 4.096V                                   |  |  |  |  |  |
|         |                    | Input to ADC25 internal channel reference voltage          |  |  |  |  |  |
|         |                    | selection                                                  |  |  |  |  |  |
| 2~1     | VREF_IN_ADC_SEL    | 00: 1.375; 01: 2.200; 10: 3.143; 11: 4.125                 |  |  |  |  |  |
|         |                    | The ADC25 internal channel input voltage calibration value |  |  |  |  |  |
|         |                    | needs to be read during use                                |  |  |  |  |  |
|         |                    | ADC comparator offset erase selected signal                |  |  |  |  |  |
| 0       | CTRL_SEL           | 0: Offset erased after the sampling                        |  |  |  |  |  |
|         |                    | 1: All switches are disconnected together                  |  |  |  |  |  |

# 9.2.7 ADC Sampling Timing Control Register 1 (ADC\_ANA\_CFG1)

XRAM\_SFR Address: 0x2055

| Bit No.             | 7 | 6 | 5 | 4          | 3 | 2 | 1 | 0 |
|---------------------|---|---|---|------------|---|---|---|---|
| Symbol              | - |   |   | ADC_I_SEL  |   |   |   |   |
| Read/Write          | - |   |   | Read/Write |   |   |   |   |
| Po Initial<br>Value | 0 | 1 | 1 | 1          | 1 | 1 | 1 | 1 |

| Bit No. | Symbol    | Description                                                             |  |  |  |  |  |  |
|---------|-----------|-------------------------------------------------------------------------|--|--|--|--|--|--|
| 6~2     | ADCWNUM   | Distance conversion interval time selection after sampling is completed |  |  |  |  |  |  |
|         |           | 3+ADCWNUM(ADC_CLK)                                                      |  |  |  |  |  |  |
|         |           | ADC bias current size selection register                                |  |  |  |  |  |  |
|         |           | ADC_I_SEL<0> : comparator bias current size selection signal, 0 for     |  |  |  |  |  |  |
| 1~0     | ADC_I_SEL | 1uA, 1 for 2uA.                                                         |  |  |  |  |  |  |
|         |           | ADC_I_SEL<1> : Op-amp bias current size selection signal, 0 is 1uA,     |  |  |  |  |  |  |
|         |           | 1 is 2uA.                                                               |  |  |  |  |  |  |

# 9.2.8 ADC Clock Control Register (ADCCKC)



| Bit No.             | 7            | 6          | 5      | 4          | 3        | 2 | 1 | 0          |  |
|---------------------|--------------|------------|--------|------------|----------|---|---|------------|--|
| Symbol              | FILTER_R_SEL | SAMBG      | SAMDEL |            | SAMDEL - |   | - | ADCK       |  |
| Read/Write          | Read/Write   | Read/Write | Read/W | Read/Write |          | - |   | Read/Write |  |
| Po Initial<br>Value | 0            | 0          | 0      |            | -        |   |   | 0          |  |

| Bit No. | Symbol       | Description                                                          |  |  |  |  |  |
|---------|--------------|----------------------------------------------------------------------|--|--|--|--|--|
| 7       | FILTER R SEL | Input signal filter selection.                                       |  |  |  |  |  |
| 1       |              | 0: No filter. 1: Adds 10K resistance filter. The default value is 0. |  |  |  |  |  |
|         |              | Sampling timing and compare timing interval selection:               |  |  |  |  |  |
| 6       | SAMBG        | 0: Interval 0;                                                       |  |  |  |  |  |
|         |              | 1: Interval 1 (ADC_CLK)                                              |  |  |  |  |  |
| 5~4     | SAMDEL       | Sampling delay time selection                                        |  |  |  |  |  |
| 5~4     | SAWDEL       | 0:0; 1:2; 2:4; 3:8 (ADC_CLK)                                         |  |  |  |  |  |
| 3~2     |              | Reserved                                                             |  |  |  |  |  |
|         |              | ADC_CLK frequency division selection.                                |  |  |  |  |  |
|         |              | 0: 3 MHz.                                                            |  |  |  |  |  |
| 1~0     | ADCK         | 1: 2 MHz.                                                            |  |  |  |  |  |
|         |              | 2: 1.5 MHz.                                                          |  |  |  |  |  |
|         |              | 3: 1 MHz.                                                            |  |  |  |  |  |

# 9.2.9 ADC Pin Control register 1 (ADC\_IO\_SEL1)

| Bit No.    | 7 | 6                | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|------------|---|------------------|---|---|---|---|---|---|--|--|--|
| Symbol     |   | ADC_IO_SEL1[7:0] |   |   |   |   |   |   |  |  |  |
| Read/Write |   | Read/Write       |   |   |   |   |   |   |  |  |  |
| Po Initial |   |                  |   |   |   |   |   |   |  |  |  |
| Value      |   |                  |   | ( | J |   |   |   |  |  |  |

| Bit No. | Symbol       | Description                                                                                                                                                                                                                          |
|---------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7~0     | SEL_ADC[7:0] | ADC Function Selection<br>1: Select the ADC function.<br>0: ADC function is not selected.<br>00000001=ADC00; 00000010=ADC01.<br>00000100=ADC02; 00001000=ADC03.<br>00010000=ADC04; 00100000=ADC05.<br>01000000=ADC06; 10000000=ADC07 |



When the ADC IO is selected, it is automatically set as input.

### 9.2.10 ADC Pin Control register 2 (ADC\_IO\_SEL2)

XRAM\_SFR Address: 0x2041

| Bit No.          | 7                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|------------------|---|---|---|---|---|---|---|
| Symbol           | ADC_IO_SEL2[7:0] |   |   |   |   |   |   |   |
| Read/Write       | Read/Write       |   |   |   |   |   |   |   |
| Po Initial Value | 0                |   |   |   |   |   |   |   |

| Bit No. | Symbol            | Description                               |
|---------|-------------------|-------------------------------------------|
|         |                   | Disable ADC control of analog input pins. |
|         |                   | 1: ADC function selected.                 |
|         | 7~0 SEL_ADC[15:8] | 0: ADC function not selected.             |
| 7~0     |                   | 00000001=ADC08; 00000010=ADC09.           |
|         |                   | 00000100=ADC10; 00001000=ADC11.           |
|         |                   | 00010000=ADC12; 00100000=ADC13.           |
|         |                   | 0100000=ADC14; 1000000=ADC15              |

When the ADC IO is selected, it is automatically set as input.

### 9.2.11 ADC Pin Control register 3 (ADC\_IO\_SEL3)

| Bit No.          | 7                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|------------------|---|---|---|---|---|---|---|
| Symbol           | ADC_IO_SEL3[7:0] |   |   |   |   |   |   |   |
| Read/Write       | Read/Write       |   |   |   |   |   |   |   |
| Po Initial Value | 0                |   |   |   |   |   |   |   |

| Bit No. | Symbol             | Description                               |
|---------|--------------------|-------------------------------------------|
|         |                    | Disable ADC control of analog input pins. |
|         |                    | 1: ADC function selected.                 |
|         |                    | 0: ADC function not selected.             |
| 7~0     | 7~0 SEL_ADC[23:16] | 00000001=ADC16; 00000010=ADC17.           |
|         |                    | 00000100=ADC18; 00001000=ADC19.           |
|         |                    | 00010000=ADC20; 00100000=ADC21.           |
|         |                    | 0100000=ADC22; 1000000=ADC23              |



When the ADC IO is selected, it is automatically set as input.

# 9.2.12 ADC Pin Control Register 4 (ADC\_IO\_SEL4)

#### XRAM\_SFR Address: 0x2043

| Bit No.             | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0           |
|---------------------|---|---|---|---|---|---|---|-------------|
| Symbol              | - | - | - | - | - | - | - | ADC_IO_SEL4 |
| Read/Write          | - | - | - | - | - | - | - | Read/Write  |
| Po Initial<br>Value | - | - | - | - | - | - | - | 0           |

| Bit No. | Symbol                                   | Description                   |
|---------|------------------------------------------|-------------------------------|
|         | Disable ADC control of analog input pins |                               |
|         | 1: ADC function selected.                |                               |
| 0       | SEL_ADC[24]                              | 0: ADC function not selected. |
|         | 01=ADC24                                 |                               |

When the ADC IO is selected, it is automatically set as input.

# **9.3 ADC Configuration Procedures**

Configuration must follow the procedures: ADC\_START = 1, interrupt detected, configure ADC\_START = 0. ADC\_START is not allowed to be configured during the scan.







Table 12.3.2 gives ADC detection time as follows:

| Formula                                                          | Description                                     |  |  |  |
|------------------------------------------------------------------|-------------------------------------------------|--|--|--|
| $T_{AD} = T_{ADC\_SPT} + T_{W1} + T_{W2}$                        | ADC conversion time                             |  |  |  |
| T <sub>ADC_SPT</sub> (µs) = 4*(ADC_SPT+1) *T <sub>adc_clk</sub>  | ADC sampling time                               |  |  |  |
|                                                                  | The period interval between sampling completion |  |  |  |
| Tw1=(ADCWNUM+3+SAMDEL)*Tadc_clk                                  | and conversion time.                            |  |  |  |
| T <sub>W2</sub> =13*T <sub>adc_clk</sub> +5*T <sub>clk_12M</sub> | Fixed time                                      |  |  |  |

 Table 12.3.2
 ADC Detection Time Expression

#### Note:

- 1) Sequence timing requirements: (ADCWNUM+3)\* Tadc\_clk >4\*Tadc\_clk.
  - Voltage setup time after ADC incoming signal adds RC filter >= 2\*(ADC sampling conversion time).
  - ADCWNUM: The period interval between sampling completion and conversion time (ADCWNUM =2~31).
  - > ADCK: ADC\_CLK frequency division selection = 0: 3MHz; 1: 2MHz; 2: 1.5MHz; 3: 1MHz.



- > ADC\_SPT: ADC sampling time configuration register (ADC\_SPT=0~255).
- > ADCCKV: ADC analog input clock for comparator offset erase.
- > SAMDEL: Sampling delay time selection (SAMDEL = 0:0; 1:2; 2:4; 3:8).
- 2) ADC conversion time: T= sample\_time+ time2+ time3+ time4
  - sample\_time= (ADC\_SPT+1)\*4\*Tadc\_clk
  - time2=(ADCWNUM+3+SAMDEL)\* Tadc\_clk(SAMDEL=0:0;1:2;2:4;3:8)
  - time3=13\*Tadc\_clk
  - time4=5\*Tclk\_12M
- 3) When the supply voltage fluctuates or drops, the VCC can be back-calculated by ADCINNER\_Data/VREF\_IN\_ADC\_SEL = 4096/VCC, and the Vin can be back-calculated by the Vin\_Data/Vin = 4096/VCC.
  - > ADCINNER\_Data: ADC internal channel data.
  - > Vin\_Data: ADC input channel data.
  - > Vin: ADC input channel voltage.
  - > VREF\_IN\_ADC\_SEL: The chip calibration value needs to be read.
  - Vin = (Vin\_Data/ADCINNER\_Data)\*VREF\_IN\_ADC\_SEL, VREF\_IN\_ADC\_SEL needs to read the chip calibration value, first obtain the internal channel data, then obtain the input voltage data Vin\_Data. The interval between these two times to obtain data should be as short as possible.
- 4) Condition for ADC entering into the interrupt: the configuration sequence is ADC\_IO\_SEL enable -> ADC interrupt enable -> ADC\_ADDR (address must correspond to ADC\_IO\_SEL) -> ADC\_START, and note the initialization configuration timing for use by the applications. For application of ADC and IO function multiplexing, it is necessary to notice the switching timing, if ADC\_IO\_SEL enable is off or the address does not correspond to ADC\_IO\_SEL can not turn on ADC scan, it must follow the configuration order: ADC\_IO\_SEL enable -> ADC interrupt enable -> ADC\_ADDR (address must correspond to ADC\_IO\_SEL) -> ADC\_START in order to turn on ADC scan.
- 5) When the pin is configured as ADC function, the pin needs to be configured for IO input mode and other multiplexing functions are off, such as pull-up resistors, etc.

# 10 TouchKey

# 10.1 Introduction

BS9000AMxx supports 25 Sensor channels and CSD in parallel, and scans up to 25 channels at a time, which can wake up the system with any key. Any channel can be flexibly configured with registers, including detection rate, detection accuracy, pull-up current value. Detection is carried out in a point scan mode, i.e. the software only gives one scan channel address and its corresponding pull-up current value configuration at a time, and transmits an interrupt after the scan is completed.

CSD features:

- With three modes of CSD charge and discharge clock available
  - Fixed frequency division of the system clock from 6M to 369k
  - PRS 1.5M normal distribution
  - PRS 1.5M Uniform distribution
- CSD counting clock with 24M, 12M, 6M, 4M selectable
- Counting bit width available from 9 bits to16 bits
- Support asynchronous scan mode only
- Support Wake-up in Wait mode
- Supports 25 Sensor channels

The BS9000AMxx implements a wide range of functional applications through a series of registers. The relationship between related values of capacitance detection and SFR values is as follows.

- The size of the count value is proportional to RESO, Rb resistor, PULL\_I\_SELA\_H and inversely proportional to VTH\_SEL. It is proportional to the charging and discharging frequency set in PRS\_DIV when fully charging and discharging are ensured.
- The variations in channel touch is proportional to RESO and Rb and inversely proportional to VTH\_SEL. When fully charging and discharging are ensured, it is proportional to the charging and discharging frequency set through PRS\_DIV and the variations in touch.
- The signal-to-noise ratio of touch detection is proportional to VTH\_SEL, PULL\_I\_SELA\_L, and inversely proportional to CSD\_DS. In case of incomplete charging and discharging, it is inversely proportional to the frequency of charging and discharging set in PRS\_DIV and the signal-to-noise ratio.
- The time for individual key detection is related to RESO, CSD\_DS.



### Note:

The parameters should be configured in such a way that the keys are fully charged and discharged.



Figure 0.1 CSD Structure Block Diagram

# 10.2 TouchKey Register

### **10.2.1** Module Switch Control Register (PD\_ANA)

XRAM\_SFR Address: 0x2024

| Bit No.    | 7 | 6 | 5 | 4 |   | 3 | 2          | 0 |
|------------|---|---|---|---|---|---|------------|---|
| Symbol     | - | - | - | - | - | - | PD_CSD     | - |
| Read/Write | - | - | - | - | - | - | Read/Write | - |
| Po Initial | - | - | - | - | - | - | 1          | - |



|       |  |  |  | 20000 | •/ |
|-------|--|--|--|-------|----|
|       |  |  |  |       |    |
| Value |  |  |  |       |    |
| Value |  |  |  |       |    |
|       |  |  |  |       |    |

| Bit No. | Symbol | Description                        |  |
|---------|--------|------------------------------------|--|
| 7~2     | -      | Reserved.                          |  |
|         |        | Analog CSD control register.       |  |
| 1       | PD_CSD | PD_CSD=0 CSD module works normally |  |
|         |        | PD_CSD=1 CSD module does not work  |  |
| 0       | -      | Reserved.                          |  |

## **10.2.2 CSD Start Scanning Register (CSD\_START)**

Address: 0x92

| Bit No.    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|------------|---|---|---|---|---|---|---|------------|
| Symbol     | - | - | - | - | - | - | - | -          |
| Read/Write | - | - | - | - | - | - | - | Read/Write |
| Po Initial |   |   |   |   |   |   |   | 0          |
| Value      | - | - | - | - | - | - | - | U          |

| Bit No. | Symbol | Description                                                             |
|---------|--------|-------------------------------------------------------------------------|
|         |        | 1: CSD scan starts.                                                     |
|         |        | 0: CSD scan stops.                                                      |
|         |        | CSD_START writes 1 to start scanning, after scanning once, the          |
|         |        | hardware automatically sets to 0. If you want to begin the next scan,   |
|         |        | you need to set 1 again via software; if CSD_START=0 during             |
| 0       |        | scanning, the scan will stop immediately and the related signal         |
|         |        | inside the module will be reset.                                        |
|         |        | <b>Note:</b> Must be configured for use in accordance with the process: |
|         |        | CSD_START=1, interrupt detected, and configure                          |
|         |        | CSD_START=0. CSD_START is not allowed to be configured                  |
|         |        | during scanning                                                         |

CSD scan is turned on by software control (in register CSD\_START), pulls up by software to turn on the scan, the hardware automatically clears after the scan is finished. To begin the next scan requires to pull up the enable again by software.

If CSD\_START =0 is set during scanning, this scan stops and the internal related signals in the module are reset, i.e. to stop CSD scanning at any time, only configuring CSD\_START = 0 via software is required.

Note: configuration for use has to follow the procedure: CSD\_START = 1, interrupt detected, the configure CSD\_START = 0. CSD\_START is not allowed to be configured during scanning.



# 10.2.3 Touch Channel Control Register (SNS\_CH\_CFG)

Address: 0x93

| Bit No.          | 7 | 6             | 5           | 4        | 3          | 2 | 1 | 0 |
|------------------|---|---------------|-------------|----------|------------|---|---|---|
| Symbol           | - | PULL_I_SELA_H | PARALLEL_EN | CSD_ADDR |            |   |   |   |
| Read/Write       | - | Read/Write    | Read/Write  |          | Read/Write |   |   |   |
| Po Initial Value | - | 1             | 0           |          |            | 0 |   |   |

| Bit No. | Symbol        | Description                                                     |  |  |  |
|---------|---------------|-----------------------------------------------------------------|--|--|--|
| 6       | PULL_I_SELA_H | Configure the highest bit for CSD pull-up current source        |  |  |  |
|         |               | Note:Pull-up current source high bit. Default value: 0x01.      |  |  |  |
| 5       |               | SNS channels in parallel enable register                        |  |  |  |
|         | PARALLEL_EN   | 1: Multi-channel parallel connection                            |  |  |  |
|         |               | 0: Single channel                                               |  |  |  |
| 4~0     | CSD_ADDR      | Address of the detection channel, corresponding to channel from |  |  |  |
|         |               | 0 to 24.                                                        |  |  |  |

### 10.2.4 CSD Pull-up Current Source Selection Register (PULL\_I\_SELA\_L)

Address: 0x94

| Bit No.          | 7 | 6               | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|---|-----------------|---|---|---|---|---|---|
| Symbol           |   | PULL_I_SEL<7:0> |   |   |   |   |   |   |
| Read/Write       |   | Read/Write      |   |   |   |   |   |   |
| Po Initial Value |   |                 |   | ( | ) |   |   |   |

| Bit No. | Symbol          | Description                                              |
|---------|-----------------|----------------------------------------------------------|
| 7~0     | PULL_I_SEL<7:0> | Select switch for CSD pull-up current source size.       |
|         |                 | The default value is 0.                                  |
|         |                 | Note:Pull-up current source low 8 bits.                  |
|         |                 | Current source size =                                    |
|         |                 | 255.5-0.5*{PULL_I_SELA_H, PULL_I_SELA}, the smaller      |
|         |                 | the current source, the smaller the count value. Default |
|         |                 | value is 0x00.                                           |

## 10.2.5 CSD Count Value Low 8 bits (CSD\_RAWDATAL)

Address: 0x95

| Bit No. | 7 | 6 | 5 | 4       | 3          | 2 | 1 | 0 |
|---------|---|---|---|---------|------------|---|---|---|
| Symbol  |   |   |   | CSD_RAW | DATAL[7:0] |   |   |   |



| Read/Write       | Read |
|------------------|------|
| Po Initial Value | 0    |

| Bit No. | Symbol            | Description                 |
|---------|-------------------|-----------------------------|
| 7~0     | CSD_RAWDATAL[7:0] | CSD count value low 8 bits. |

# 10.2.6 CSD Count Value High 8 bits (CSD\_RAWDATAH)

Address: 0x96

| Bit No.          | 7 | 6                 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|---|-------------------|---|---|---|---|---|---|
| Symbol           |   | CSD_RAWDATAH[7:0] |   |   |   |   |   |   |
| Read/Write       |   | Read              |   |   |   |   |   |   |
| Po Initial Value |   | 0                 |   |   |   |   |   |   |

| Bit No. | Symbol            | Description                  |
|---------|-------------------|------------------------------|
| 7~0     | CSD_RAWDATAH[7:0] | CSD count value high 8 bits. |

## 10.2.7 SNS Channel Selection Register 1 (SNS\_IO\_SEL1)

XRAM\_SFR Address: 0x203C

| Bit No.          | 7 | 6                 | 5 | 4    | 3      | 2 | 1 | 0 |
|------------------|---|-------------------|---|------|--------|---|---|---|
| Symbol           |   | SNS_IO_SEL1 [7:0] |   |      |        |   |   |   |
| Read/Write       |   |                   |   | Read | /Write |   |   |   |
| Po Initial Value |   |                   |   | (    | )      |   |   |   |

| Bit No. | Symbol           | Description                     |
|---------|------------------|---------------------------------|
|         |                  | SENSOR IO selection enable bit. |
|         |                  | 1: SENSOR selected.             |
|         |                  | 0: SENSOR not selected.         |
| 7~0     | SNS_IO_SEL1[7:0] | 0000001=SNS00; 00000010=SNS01.  |
|         |                  | 00000100=SNS02; 00001000=SNS03. |
|         |                  | 00010000=SNS04; 00100000=SNS05. |
|         |                  | 0100000=SNS06; 1000000=SNS07    |

For SENSOR IO selection, set IO as Input automatically.



## 10.2.8 SNS Channel Selection Register 2 (SNS\_IO\_SEL2)

XRAM\_SFR Address: 0x203D

| Bit No.          | 7 | 6                 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|---|-------------------|---|---|---|---|---|---|
| Symbol           |   | SNS_IO_SEL2 [7:0] |   |   |   |   |   |   |
| Read/Write       |   | Read/Write        |   |   |   |   |   |   |
| Po Initial Value |   |                   |   | ( | ) |   |   |   |

| Bit No. | Symbol           | Description                     |
|---------|------------------|---------------------------------|
|         |                  | SENSOR IO Selection enable bit. |
|         |                  | 00000001=SNS08; 00000010=SNS09. |
| 7~0     | SNS_IO_SEL2[7:0] | 00000100=SNS10; 00001000=SNS11. |
|         |                  | 00010000=SNS12; 00100000=SNS13. |
|         |                  | 0100000=SNS14; 1000000=SNS15    |

For SENSOR IO selection, set IO as Input automatically.

### 10.2.9 SNS Channel Selection Register 3 (SNS\_IO\_SEL3)

| Bit No.          | 7 | 6                 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|---|-------------------|---|---|---|---|---|---|
| Symbol           |   | SNS_IO_SEL3 [7:0] |   |   |   |   |   |   |
| Read/Write       |   | Read/Write        |   |   |   |   |   |   |
| Po Initial Value |   | 0                 |   |   |   |   |   |   |

XRAM\_SFR Address: 0x203E

| Bit No. | Symbol            | Description                     |
|---------|-------------------|---------------------------------|
|         |                   | 1: SENSOR is selected.          |
|         |                   | 0: SENSOR is not selected.      |
| 7~0     |                   | 00000001=SNS16; 00000010=SNS17. |
| 7~0     | SNS_IO_SEL3 [7:0] | 00000100=SNS18; 00001000=SNS19. |
|         |                   | 00010000=SNS20; 00100000=SNS21. |
|         |                   | 0100000=SNS22; 10000000=SNS23   |

For SENSOR IO selection, set IO as Input automatically.



## 10.2.10 SNS Channel Selection Register 4 (SNS\_IO\_SEL4)

XRAM\_SFR Address: 0x203F

| Bit No.          | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0              |
|------------------|---|---|---|---|---|---|---|----------------|
| Symbol           | - | - | - | - | - | - | - | SNS_IO_SEL4[0] |
| Read/Write       | - | - | - | - | - | - | - | Read/Write     |
| Po Initial Value | - |   |   |   |   |   |   | 0              |

| Bit No. | Symbol         | Description                     |
|---------|----------------|---------------------------------|
|         |                | SENSOR IO selection enable bit. |
| 0       | SNS_IO_SEL4[0] | 1: SENSOR and SNS24 selected.   |
|         |                | 0: SENSOR not selected.         |

For SENSOR IO selection, set IO as Input automatically.

The above Sensor IO selection does not affect the Sensor enable for scanning and is only used to control the Sensor enable for IO. Also, when connected in parallel, all selected Sensor IO will transmit scan timing.

## 10.2.11 TouchKey Scan Configuration Register 1 (SNS\_SCAN\_CFG1)

XRAM\_SFR Address: 0x2050

| Bit No.          | 7 | 6          | 5                | 4 | 3 | 2 | 1 | 0 |  |  |
|------------------|---|------------|------------------|---|---|---|---|---|--|--|
| Symbol           | - | SW_PRE_OFF | PRS_DIV          |   |   |   |   |   |  |  |
| Read/Write       | - | Read/Write | Write Read/Write |   |   |   |   |   |  |  |
| Po Initial Value | - | 0          |                  |   |   | 0 |   |   |  |  |

| Bit No. | Symbol       | Description                                                           |
|---------|--------------|-----------------------------------------------------------------------|
|         | 6 SW_PRE_OFF | Front-end charge/discharge clock switch control.                      |
| 6       |              | 1: disable sw_clk.                                                    |
|         |              | 0: enable sw_clk.                                                     |
|         |              | Front-end charge/discharge clock frequency selection register.        |
|         |              | 0~61: for fixed frequency: F=F48m/2/(PRS_DIV+4) (6M~369k)             |
| 5.0     |              | 62: highest frequency of 3M, lowest frequency of 1M, center frequency |
| 5~0     | PRS_DIV      | of 1.5M, normal distribution                                          |
|         |              | 63: highest frequency of 3M, lowest frequency of 1M, center frequency |
|         |              | of 1.5M, uniform distribution                                         |

# 10.2.12 TouchKey Scan Configuration Register 2 (SNS\_SCAN\_CFG2)

XRAM\_SFR Address: 0x2051



| Bit No.             | 7     | 6                                | 5 | 4          |  |  |
|---------------------|-------|----------------------------------|---|------------|--|--|
| Symbol              | -     | RESO                             |   |            |  |  |
| Read/Write          | -     | Read/Write                       |   |            |  |  |
| Po Initial<br>Value | -     | 1 1 1                            |   |            |  |  |
| Bit No.             | 3     | 2 1 0                            |   |            |  |  |
| Symbol              | CSD   | _DS PRE_CHRG_SEL NIT_DISCHRG_SEL |   |            |  |  |
| Read/Write          | Read/ | Read/Write                       |   | Read/Write |  |  |
| Po Initial<br>Value | 0     |                                  | 0 | 0          |  |  |

| Bit No. | Symbol          | Description                                              |
|---------|-----------------|----------------------------------------------------------|
|         |                 | Counter bit selection register.                          |
|         |                 | 000 : 9 bits; 001 : 10 bits.                             |
|         |                 | 010 : 11 bits; 011 : 12 bits.                            |
|         |                 | 100 : 13 bits; 101 : 14 bits.                            |
|         |                 | 110 : 15 bits; 111 : 16 bits.                            |
| 6~4     | RESO            | Note: 0~7 TouchKey capacitance scan resolution, and      |
|         |                 | the number of counter bits equals to (RESO + 9) bits.    |
|         |                 | The larger the TouchKey capacitance scan resolution,     |
|         |                 | the larger the drop in Raw Data variations, while the    |
|         |                 | noise introduced will also increase, otherwise the       |
|         |                 | opposite.                                                |
|         |                 | Count clock frequency selection register.                |
|         |                 | 00:24M; 01:12M.                                          |
|         |                 | 10: 6M; 11: 4M; Default as 0                             |
|         |                 | Note: Detection speed 0: 24M, 1: 12M, 2: 6M, 3: 4M.      |
| 3~2     | CSD_DS          | The smaller the detection speed, the slower the time to  |
|         |                 | sample Raw data, otherwise the opposite. It is           |
|         |                 | recommended that setting the fastest 24M as the          |
|         |                 | default, and the detection speed is at least 2 times the |
|         |                 | PRS clock.                                               |
|         |                 | Precharge time selection.                                |
| 1       | PRE_CHRG_SEL    | 0: 20us                                                  |
|         |                 | 1: 40us                                                  |
|         |                 | Pre-discharge time selection.                            |
| 0       | NIT_DISCHRG_SEL | 0: 2us                                                   |
|         |                 | 1: 10us                                                  |



## 10.2.13 TouchKey Scan Configuration Register (SNS\_ANA\_CFG)

XRAM\_SFR Address: 0x2052

| Bit No.             | 7 | 6 | 5 | 4          | 3 | 2 | 1          | 0 |
|---------------------|---|---|---|------------|---|---|------------|---|
| Symbol              | - | - |   | RB_SEL     |   |   | VTH_SEL    |   |
| Read/Write          | - | - |   | Read/Write |   |   | Read/Write | 9 |
| Po Initial<br>Value | - | - | 1 | 0          | 1 | 1 | 0          | 1 |

| Bit No. | Symbol  | Description                                                       |
|---------|---------|-------------------------------------------------------------------|
|         |         | Rb resistor size selection                                        |
|         |         | 0: 20k; 1: 40k.                                                   |
|         |         | 2: 60k; 3: 80k; 4-7: 100k                                         |
|         |         | When using, you need to read the Rb80k calibration value from the |
|         |         | chip FLASH: CBYTE[0x41CD]k/80k, to calculate the normalized       |
| 5~3     | RB_SEL  | sensitivity proportionally.                                       |
|         |         | Note:                                                             |
|         |         | Rb resistance selection: 010: 60k, 011: 80k, others: 100k.        |
|         |         | The larger the resistance, the greater the variations in Raw      |
|         |         | data, while the noise introduced will also increase, otherwise    |
|         |         | the opposite.                                                     |
|         |         | VTH voltage selection signal                                      |
|         |         | 000: 1.505V, 001: 2.133V, 010: 2.508V.                            |
|         |         | 011: 2.859V, 100: 3.177V, 101: 3.487V.                            |
| 0.0     |         | 110: 3.864V, 111: 4.205V                                          |
| 2~0     | VTH_SEL | Note:                                                             |
|         |         | 1~7, the smaller the reference voltage, the greater the           |
|         |         | variations in Raw Data, while the noise introduced will also      |
|         |         | increase, otherwise the opposite.                                 |

# **10.3 TouchKey Configuration Process**

The TouchKey scan is query or interrupt mode, first, configure the TouchKey parameters; then, turn on the TouchKey scan; finally, obtain and save the TouchKey data at the TouchKey interrupt, and the software algorithm carries out the manipulation of the data and determines touchkeys output.





Figure 0.2 TouchKey Scan Configuration Process

The sensitivity parameters are configured to obtain a set of parameters with a better signal-tonoise ratio, thus improving the accuracy of keys pressing judgments.

### Note:

- 1) Raw data is the real-time raw count value of the capacitive TouchKey counter.
- 2) The application requires to check the data via a debugging software and compare the parameters to get a set of parameters with good signal-to-noise ratio.
- 3) The relation between chip supply voltage and reference voltage: VCC VTH > 0.5V.

# Semiconductor

# 11 IIC

IIC is for the exchange of data between chips. The host turns on the communication and decides the direction of data transfer, and the operating rate is also determined by the host. Its functions and features are as follows.

- Two serial IOs: serial data line (SDA) and serial clock line (SCL)
- Compliant with PHILIPS Standard Communication Protocol
- Data Transfer Rate: 100Kbps, 400Kbps
- IIC Slave supporting 7-bit addressing
- With clock low level stretching
- Wake up the core via IIC interrupt in low power mode
- Detecting write conflicts and BUF overflow exceptions
- With the function of caching host write data and preloading the host to read data
- Interrupt wake-up mechanism to wake up the CPU when the CPU is configured to enter wait mode.

The IIC master-slave connection diagram is shown below.



Figure 0.1 IIC Master/Slave Connection

### Supports 7-bit Addressing

Only 7-bit addressing is supported, it is not compatible with 10-bit addressing. The slave address is configured by CPU.

Address is equivalent to an ID for the device. According to the IIC protocol, the host sends the slave address code after the S signal, and the slave compares it with the contents of the slave address after receiving the address code to verify its identity. Only when the addresses match can communication take place.



**Note:** After correctly addressing the slave address, a read/write data operation must follow, otherwise the communication will be affected.

#### Data Transfer Rate

Fast communication 400Kbps in IIC communication mode and standard communication rate 100Kbps are supported. The communication rate ranges from 50Kbps to 500kbps.

#### **Exception Communication**

If any exception occurs during communication, the cause can be determined by the bus status. In the case of write conflict and BUF overflow exceptions, it can be judged by querying the value of register IICSTAT.

### Stretch clock low level

IIC is based on the interrupt service subroutine to complete the communication. Each byte received by IIC will generate an interrupt signal to inform the MCU to process the data accordingly, so that the data can be transmitted or received. When the interrupt service subroutine takes too long to process the data normally, it can be configured through the registers to pull down the clock line and stretch the low time to restore the normal communication. For the specific way to stretch the clock low level, refer to the register IICCON description and IIC sequence timing description.

### Wakeup from interrupt mechanism

When the CPU is configured to enter sleep mode, it starts IIC communication and after sending an address to match with the slave address, the slave responds with an ACK to generate an IIC interrupt, which will be used to wake up the system.

**Note:** When configuring the slave to pull down clock line, it wakes up in IDEL mode, the internal SCLEN signal pull-down clock line function is at the falling edge of the ninth clock; if the host supports the pull-down clock line function or the host waits 1ms after the ninth clock falling to send next IIC rising edge, the first byte of the wakeup communication is normal.

## **11.1** Communication Sequence

The BS9000AMxx uses a hardware slave. When the host Reads and Writes data, the slave receives the address and then generates an interrupt to send a valid acknowledge signal if that address matches. The interrupt will be generated after the eighth clock of the host written data, however the interrupt signal will not be generated when the host sends a stop signal. The following four read and write sequences shows the conditions with F\_sys\_clk clock. In sleep mode, the IIC\_START signal maintains low until the start signal of the next communication arrives. See IIC communication sequence diagram below.



### 11.1.1 IIC Host Write Sequence



The IIC host write sequence is shown in the following diagram.

Table 11 .2 IIC write without pulling down the clock line

As shown above is a schematic of the host write operation without pulling down the clock line, from which you can see how the IIC bus changes and how some internal signals change.

The IIC bus changes in accordance with the protocol requirements of the IIC, and the start signal as well as the transmission of the message are in accordance with the protocol requirements. First the host sends the start signal IIC\_START, and the slave detects the IIC\_START signal and then sets the IIC\_START status bit, as shown by the dashed line a in Figure 11.2.

Then the host sends the address byte and the read/write flag bit, the slave automatically compares with its own address after receiving the address byte, and if it matches, it sets IIC\_BF after the falling edge of the 8th clock, as shown in dashed line b.

The interrupt signal INT\_IIC is generated after the falling edge of the 9th clock, as shown in dashed line c. The MCU needs to read the IICBUF during the execution of the interrupt subroutine, even if this data is useless; the operation of reading the IICBUF causes an indirect clear of STAT\_BF.

Then the host continues to send the message, after the falling edge of the 8th clock of the 2nd byte IIC\_BF is also set, and the IIC\_AD flag bit will also be set, marking the current received byte is data, as shown in the dashed line d. The stop signal has no effect on the IIC\_AD flag bit, that is, the stop signal IIC\_STOP is detected, the IIC\_AD flag bit will not be cleared; The same interrupt will be generated after the falling edge of the 9th clock, and the interrupt subroutine needs to do the same operation.

If the host wants to send more than one byte, it can continue to send. The above diagram only

Semiconductor

## BS9000AMxx

illustrates the case where the host sends one data. Finally, the host sends a stop signal IIC\_STOP after sending all the data, which marks the end of communication and releases the IIC bus to the idle state.

### 11.1.2 IIC Host Write Pull-down Sequence

The IIC host write pull-down sequence are shown in the following diagram.



Table 11 .3 Host write pull-down clock line diagram

As shown above is a schematic of pulling down the clock line during a host write operation, from which you can see how the IIC bus changes and how some internal signals change.

The IIC bus changes in accordance with the protocol requirements of the IIC, and the start signal as well as the transmission of the telegrams are in accordance with the protocol requirements. First the host sends the start signal IIC\_START, and the slave detects the IIC\_START signal and then sets the IIC\_START status bit, as shown by the dashed line a in Figure 11.2.

Then the host sends the address byte and the read/write flag bit, the slave automatically compares with its own address after receiving the address byte, and if it matches, it sets IIC\_BF after the falling edge of the 8th clock, as shown in dashed line b. After the falling edge of the 9th clock, the interrupt signal INT\_IIC is generated, as shown in the dashed line c.

After the falling edge of the 9th clock SCLEN is automatically cleared by hardware, this period is used for slave processing or reading data, even if this data is not used, the operation of reading IICBUF will cause the IIC\_BF to be cleared indirectly, as shown in dashed line d. Then the software sets SCLEN to release the clock line, as shown in dashed line e.

Then the host will continue to send synchronous clock after detecting the release of SCL from the



slave. After the falling edge of the 8th clock of the 2nd byte, IIC\_BF will be set as well, and the IIC\_AD flag bit will be set at the same time, marking the current received byte as data, as shown in the dashed line f. The stop signal has no effect on the IIC\_AD flag bit that the stop signal IIC\_STOP is detected. IIC\_AD flag bit will not be cleared; the same interrupt will be generated after the falling edge of the 9th clock.

If the host wants to send more than one byte, it can continue to send, and the schematic illustrates the case where the host sends only one data. Note that when the host sends the last data, it does not enable the pull-down clock line function. Finally, the host sends a stop signal IIC\_STOP after sending all the data, marking the end of communication and releasing the IIC bus into the idle state.

## 11.1.3 IIC Host Read Sequence



The IIC host read sequence is shown in the following diagram.

Table 11 .4 IIC Host Read without Pulling Down Low Clock Line Diagram

As shown in the figure above, it is the sequence diagram of the master reading the slave clock line pulled down. From the diagram, you can know how the bus changes, and how some internal signals of the circuit change.

The host sends the IIC\_START signal to mark the start of communication, as shown in dashed line a. The internal circuitry detects the IIC\_START signal sequence and sets the status flag bit IIC\_START.

The host sends the address byte after the IIC\_START signal and IIC\_RW = 1, indicating that the host reads the slave. The status bit IIC\_RW is set after the falling edge of the eighth clock in case of address matches, as shown in dashed line b. IIC\_RW is not set if the address does not match.

An interrupt signal is generated after the falling edge of the ninth clock, as shown in dashed line c. And the data in IICBUFFER is ballasted into IICBUF, IIC\_BF is set, as shown in dashed line d, and





the highest bit is sent to the bus. After 8 clock's, a byte of data is sent and the IIC\_BF flag bit is cleared; also the address data flag bit is set to indicate the current byte of data sent. As shown in dashed line e.

An interrupt is generated after the falling edge of the 9th clock. If the host needs to continue reading the slave, the host replies with a valid acknowledge bit ACK and continues the communication; if the data the host needs has been read, the host replies with an invalid acknowledge bit NACK and then sends the stop signal IIC\_STOP to terminate the communication. In the schematic diagram, the host responds NACK after reading just one data, and then sends the IIC\_STOP signal to terminate the communication.

The read/write flag bit IIC\_RW is cleared by hardware when NACK is detected, as shown by dashed line f.

If the host sends NACK, the slave SCLEN is not automatically pulled down, which should be noted in the application.

When the IIC\_STOP signal is detected, the status bit IIC\_STOP is set and IIC\_START is cleared to zero, as shown in dashed line g.

### 11.1.4 IIC Host Read Pull-down Sequence



The IIC host read pull-down sequence is shown in the following diagram.

Table 11 .5 IIC host reads out pull-down clock line diagram

As shown in the figure above, it is the sequence diagram of the master reading out the slave clock line pulled down. From the diagram, you can know how the bus changes, and how some internal signals of the circuit change.

The host sends the IIC\_START signal to mark the start of communication, as shown in dashed line a. The internal circuitry detects the IIC\_START signal timing and sets the status flag bit IIC\_START.



The host sends the address byte after the IIC\_START signal and IIC\_RW = 1, indicating that the host reads the slave. The status bit IIC\_RW is set after the falling edge of the eighth clock in case of address matches, as shown in dashed line b. IIC\_RW is not set if the address does not match.

An interrupt signal is generated after the falling edge of the ninth clock, as shown in dashed line c. SCLEN is also automatically pulled down by hardware after the falling edge of the 9th clock. This period is used for slave processing or preparing data, and then the prepared data is written to the IICBUF, and then SCLEN is set by software to release the clock line. As shown in dashed line d, after writing data into the IICBUF, IIC\_BF is set to mark that this IICBUF is full. As shown in dashed line e, the software sets SCLEN and releases the clock line.

Then the host, after detecting the release of SCL from the slave, will continue to send synchronous clocks to read out the data from the slave. After the falling edge of the 8th clock, a byte of data is sent and the IIC\_BF flag bit is cleared; at the same time, the address data flag bit is also set to indicate the current byte of data sent. As shown in dashed line f.

An interrupt is generated after the falling edge of the 9th clock. If the host needs to continue reading the slave, it responds with a valid response bit ACK and continues the communication; if the data the host needs has been read, it responds with an invalid response NACK and then sends the stop signal IIC\_STOP to terminate the communication. In the schematic diagram, the host responds NACK after reading just one data, and then sends the IIC\_STOP signal, which terminates the communication.

The read/write flag bit IIC\_RW is cleared by hardware when NACK is detected, as shown in dashed line g.

When the IIC\_STOP signal is detected, the status bit IIC\_STOP is set and IIC\_START is cleared to zero, as shown in dashed line h.

## 11.1.5 IIC Host Write Data

The IIC host writes data is shown in the following figure.







### 11.1.6 IIC Host Read Data

The IIC host reads out the data as shown in the following figure.



Table 11 .7 IIC host reads out data

The slave gives the ACK signal on the falling edge of the eighth clock, and generates the IIC interrupt after the falling edge of the ninth clock. It is recommended that the host delay 60µs to 300µs after sending the falling edge of the ninth clock to reserve the slave IIC interrupt service data preparation time (if the slave IIC interrupt service processing time is around 100us, it is recommended to delay > 200us), and then send clock signal.

Note: For IIC communication >= 100K, the recommended system clock is 6MHz.

# 11.2 IIC Registers

## 11.2.1 IIC Address Register (IICADD)

Address: 0xF7

| Bit No.    | 7           | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|-------------|---|---|---|---|---|---|---|
| Symbol     | IICADD[7:1] |   |   |   |   |   | - |   |
| Read/Write | Read/Write  |   |   |   |   | - |   |   |
| Po Initial |             |   |   | 0 |   |   |   |   |
| Value      |             |   |   | 0 |   |   |   | - |

| Bit No. | Symbol      | Description          |
|---------|-------------|----------------------|
| 7~1     | IICADD[7:1] | IIC Address Register |

# 11.2.2 IIC Status Register (IICSTAT)

| Address: 0x | F8 |
|-------------|----|
|-------------|----|

| Bit No.    | 7         | 6        | 5          | 4          |
|------------|-----------|----------|------------|------------|
| Symbol     | IIC_START | IIC_STOP | IIC_RW     | IIC_AD     |
| Read/Write | Read      | Read     | Read       | Read       |
| Po Initial | 0         | 1        | 0          | 0          |
| Value      | 0         | I        |            |            |
| Bit No.    | 3         | 2        | 1          | 0          |
| Symbol     | IIC_BF    | IIC_ACK  | IIC_WCOL   | IIC_RECOV  |
| Read/Write | Read      | Read     | Read/Write | Read/Write |
| Po Initial | 0         | 1        | 0          | 0          |
| Value      |           | I        | 0          | U          |

| Bit No. | Symbol    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7       | IIC_START | <ul> <li>Start signal status bit.</li> <li>1 = Indicates that the start bit is detected.</li> <li>0 = Indicates no start bit detected</li> <li>Note: IIC_START will be set when the start signal is detected, indicating that the bus is busy.</li> </ul>                                                                                                                                                                                                                                                                                                                                                          |
| 6       | IIC_STOP  | Stop signal flag bit.<br>1 = Indicates that it is in stop state.<br>0 = Indicates that no stop bit is detected<br><b>Note:</b> IIC_STOP is set when the device is in stop state, indicating<br>that the bus is idle, and is cleared by hardware when the start<br>signal is detected, indicating the start of communication.                                                                                                                                                                                                                                                                                       |
| 5       | IIC_RW    | Read/Write flag bit: records the Read/Write information obtained<br>from the address byte after the recent address match<br>1 = Indicates a read operation.<br>0 = Indicates a write operation.<br><b>Note:</b> This flag bit records the read and write information bits<br>obtained from the address byte after address matching.<br>IIC_RW=1 means the host reads the slave operation, IIC_RW=0<br>means the host writes the slave operation. The start signal, stop<br>signal, and non-answer signal (NACK) all clear IIC_RW. The<br>change of this status bit occurs on the falling edge of the 9th<br>clock. |
| 4       | IIC_AD    | Address data flag bit<br>1 = Indicates that the most recently received or sent byte is data.<br>0 = Indicates that the most recently received or sent byte is the<br>address.                                                                                                                                                                                                                                                                                                                                                                                                                                      |



|   |         | <b>Note:</b> It marks the current received or sent byte is address or  |
|---|---------|------------------------------------------------------------------------|
|   |         | data. The start signal, stop signal, and non-valid acknowledge         |
|   |         | signal have no effect on this status bit. The change of this status    |
|   |         | bit occurs at the falling edge of the 8th clock.                       |
|   |         | IICBUF full flag bit.                                                  |
|   |         | When receiving in IIC bus mode,                                        |
|   |         | 1: Indicates that the reception was successful and the buffer is       |
|   |         | full.                                                                  |
|   |         | 0: Means the reception is not completed and the buffer is still        |
|   |         | empty                                                                  |
|   |         | When sending in IIC bus mode:                                          |
|   |         | 1: Indicates that data transmission is in progress (excluding the      |
|   |         | answer and stop bits) and the buffer is still full;                    |
|   |         | 0: Indicates that data transmission has been completed                 |
|   |         | (excluding the answer and stop bits) and the buffer is empty.          |
|   |         | Note: It marks that the transceiver buffer is currently full or        |
|   |         | empty. IIC_BF=0 means the buffer is not receiving data and the         |
|   |         | buffer is empty; IIC_BF=1 means the buffer is receiving data and       |
|   |         | the buffer is full. This status bit can only be set and cleared        |
|   |         | indirectly, and cannot be operated directly.                           |
| 3 | IIC_BF  | If the address matches and IIC_RW=0, IIC_BF is set after the           |
|   | —       | falling edge of the 8th clock, signaling that the IICBUF received      |
|   |         | data. The IICBUF should be read out during the execution of the        |
|   |         | interrupt routine, and the operation of reading the IICBUF will        |
|   |         | indirectly clear the BF flag bit. If the IICBUF is not read and the    |
|   |         | host continues to send data, a receive overflow will occur and         |
|   |         | although the slave still receives the data sent by the host and        |
|   |         | ballasts it to the IICBUF, it will still send a NACK signal giving an  |
|   |         | invalid answer.                                                        |
|   |         | If the address matches and IIC_RW=1, the IIC_BF flag bit will          |
|   |         | not be set after the slave receives the address byte; IIC_RW=1         |
|   |         | means the host reads out the slave operation and the slave             |
|   |         |                                                                        |
|   |         | needs to write the data to IICBUF, the slave operation of writing      |
|   |         | IICBUF will set IIC_BF, then the software sets SCLEN and               |
|   |         | releases the clock line; the host will then send the synchronous       |
|   |         | clock. After the 8th clock, IIC_BF is cleared by hardware after        |
|   |         | the data in IICBUF is sent out.                                        |
|   |         | Answer flag bit                                                        |
| 2 | IIC_ACK | 1: Indicates an invalid answer signal.                                 |
|   |         | 0: Indicates a valid answer signal.                                    |
|   |         | <b>Note:</b> Regardless of whether the host is reading or writing, the |





|   |            | slave will sample the data line at the rising edge of the 9th clock          |
|---|------------|------------------------------------------------------------------------------|
|   |            | to record the acknowledge information. The acknowledge bit is                |
|   |            | divided into valid acknowledge bit ACK and non-valid                         |
|   |            | acknowledge bit NACK, that is to say, if the rising edge of the              |
|   |            | 9th clock samples data "0", it means valid acknowledge ACK,                  |
|   |            | and IIC_ACK is cleared, if it samples data "1", IIC_ACK is set, it           |
|   |            | means non-valid acknowledge ACK. IIC_ACK is set, indicating                  |
|   |            | non-acknowledge. After the non-acknowledge signal, the host                  |
|   |            | will send a stop signal to announce the end of                               |
|   |            | communication.The start signal will clear this status bit.                   |
|   |            | Write conflict flag bit                                                      |
|   |            | 1: Indicates that the IIC is sending the current data when new               |
|   |            | data is trying to write to the transmit buffer; the new data cannot          |
|   |            | be written to the buffer.                                                    |
|   |            | 0: No write conflict occurred.                                               |
|   |            | Note:IICBUF can only be written by CPU if IIC RW=1, and                      |
| 1 | 1 IIC_WCOL | RD_SCL_EN=1, SCLEN=0. Any other attempt to write the                         |
|   |            | IICBUF is prohibited. If a write operation occurs without meeting            |
|   |            | the above conditions, the data will not be written to the IICBUF,            |
|   |            | and the write conflict flag bit IIC WCOL is set, indicating that a           |
|   |            | write conflict has occurred, and this flag bit needs to be cleared           |
|   |            | by software.                                                                 |
|   |            | Receive overflow flag bit                                                    |
|   |            | 1: Indicates that new data is received while the previous data               |
|   |            | received by the IIC has not been taken away, and the new data                |
|   |            | cannot be received by the buffer.                                            |
|   |            | 0: Indicates that no receive overflow has occurred.                          |
|   |            | <b>Note:</b> If the IICBUF is full, that is, if there is data in the IICBUF, |
| 0 | IIC_RECOV  | and the IIC has received new data, a receive overflow will occur             |
| - |            | and IIC RECOV will be set, while the data in the IICBUF will not             |
|   |            | be updated and the newly received data will be lost. This status             |
|   |            | bit also needs to be cleared by software, otherwise it should                |
|   |            | affect the communication process later. This situation will only             |
|   |            | occur when IIC_RW=0, BF=1, and the CPU does not read the                     |
|   |            | IICBUF.                                                                      |
|   |            |                                                                              |

# 11.2.3 IIC Transmit/Receive Data Register (IICBUF)

Address: 0xF9

| Bit No. 7 6 5 | 4 3 | 2 | 1 0 |
|---------------|-----|---|-----|
|---------------|-----|---|-----|

# Semiconductor

# BS9000AMxx

| Symbol           | IICBUF     |
|------------------|------------|
| Read/Write       | Read/Write |
| Po Initial Value | 0          |

| Bit No. | Symbol | Description                      |
|---------|--------|----------------------------------|
| 7~0     | IICBUF | IIC transmit/receive data buffer |

The specific application process is as follows.

In transmit state, after ballasting the data into the IICBUF, the data is sent out sequentially shifted under the synchronization clock of the host, with the high bit in front. 8 clocks later, a byte is sent out. In receive state, the data is written to the BUF after 8 clocks have passed in the host, and an interrupt is generated after the 9th clock to tell the CPU to read out the data in the IICBUF.

The operation of writing data to IICBUF is conditional, only when RD\_SCL\_EN=1 and IIC\_RW=1 and SCLEN=0 can write data to IICBUF; otherwise the operation of writing IICBUF is prohibited. In other words, if the condition is not satisfied, the operation of writing IICBUF cannot be successful, the data cannot be written, the data of IICBUF will not change, and it will also cause write conflict.

For example: IICBUF already has data 55h, in the case of write IICBUF conditions are not met but still wanting to write data 0x00 to IICBUF, the result is that the data in IICBUF is still 0x55, while the write conflict flag bit IIC\_WCOL is set, informing the user that the operation is abnormal.

When RD\_SCL\_EN=0, the data to be sent by the slave is the value of the ballasted IICBUFFER register when the interrupt signal is generated.

# 11.2.4 IIC Status Register (IICCON)

| Bit No.    | 7          | 6          | 5          | 4          |
|------------|------------|------------|------------|------------|
| Symbol     | -          | -          | IIC_RST    | RD_SCL_EN  |
| Read/Write | -          | -          | Read/Write | Read/Write |
| Po Initial | _          | _          | 0          | 1          |
| Value      | -          | -          | 0          | I          |
| Bit No.    | 3          | 2          | 1          | 0          |
| Symbol     | WR_SCL_EN  | SCLEN      | SR         | IIC_EN     |
| Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial | 0          | 0          | 0          | 0          |
| Value      | 0          | 0          | 0          | 0          |

Address: 0xFA

| Bit No. | Symbol  | Description                  |  |
|---------|---------|------------------------------|--|
| 7~6     |         | Reserved bit.                |  |
|         |         | IIC module reset signal      |  |
| 5       | IIC_RST | 1: IIC module is reset.      |  |
|         |         | 0: IIC module works normally |  |



|   |           | <b>Note:</b> configuration 1 to reset the IIC module. The IIC_RST is a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |           | global reset. Therefore, write the IIC_RST bit to 0 before                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|   |           | operating other register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|   |           | Host reads pull-down clock line control bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|   |           | 1: Enables the host read pull-down clock line function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|   |           | 0: Disable the host read pull-down clock line function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|   |           | Note:RD_SCL_EN is the read pull-down line control bit, which                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|   |           | enables the interrupt pull-down clock line function when it is 1,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|   |           | and disable the interrupt pull-down clock line function when it is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|   |           | 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|   |           | When RD_SCL_EN=1, SCLEN is automatically pulled down by                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|   |           | hardware when the slave receives an address byte or finishes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|   |           | sending a byte and the host sends an ACK, forcing the host into                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|   |           | Wait state. To release the IIC clock, the slave needs to do the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|   |           | following two operations: first write the data to be sent to the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4 | RD_SCL_EN | IICBUF, and then set SCLEN by software. The purpose of this                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|   |           | design is to ensure that the data to be sent has been written to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|   |           | the IICBUF before pulling up SCL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|   |           | When RD_SCL_EN=0, when the slave receives the address byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|   |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|   |           | or finishes sending a byte and the host sends ACK, the slave will                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|   |           | immediately ballast the data prepared in the IICBUFFER register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|   |           | to the transmit buffer register and then send it to the data line.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|   |           | Therefore, to ensure the correct data is transmitted each time,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|   |           | the IICBUFFER in the interrupt service routine prepares the next                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|   |           | data to be sent, and the data received by the host are the data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|   |           | processed in the last interrupt, and the first received data is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|   |           | prepared in the initialization.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|   |           | Host write pull-down clock line control bit,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|   |           | 1: Enables the write pull-down clock line function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|   |           | 0: Disables the write pull-down clock line.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|   |           | Note:WR_SCL_EN is the write pull-down line control bit, which                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|   |           | enables the interrupt pull-down clock line function when it is 1,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|   |           | and does not enable the interrupt pull-down clock line function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2 |           | when it is 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3 |           | With IIC_RW=0, the decision to pull down the clock line can be                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|   |           | made based on the host's communication rate and the time to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|   |           | process the interrupt, i.e., configure the WR SCL EN bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|   |           | When the CPU can handle the interrupt and exit the interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|   |           | within 8 IIC clocks, WR_SCL_EN=0 does not enable the function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|   |           | of pulling down the clock line, then the hardware will not                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|   |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3 | WR_SCL_EN | <ul> <li>prepared in the initialization.</li> <li>Host write pull-down clock line control bit,</li> <li>1: Enables the write pull-down clock line function.</li> <li>0: Disables the write pull-down clock line.</li> <li>Note:WR_SCL_EN is the write pull-down line control bit, which enables the interrupt pull-down clock line function when it is 1, and does not enable the interrupt pull-down clock line function when it is 0.</li> <li>With IIC_RW=0, the decision to pull down the clock line can be made based on the host's communication rate and the time to process the interrupt, i.e., configure the WR_SCL_EN bit.</li> <li>When the CPU can handle the interrupt and exit the interrupt within 8 IIC clocks, WR_SCL_EN=0 does not enable the function</li> </ul> |



|   |        | When the CPU can not handle the interrupt and exit within 8 IIC clocks, WR_SCL_EN=1 enables the function of pulling down the clock line, then the hardware automatically pulls down the clock line when the interrupt occurs, forcing the host to enter Wai state, and the software sets SCLEN when the data written to the IICBUF is read out by the CPU.                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|---|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 2 | SCLEN  | <ul> <li>IIC clock enable bit.</li> <li>1: The clock is working properly.</li> <li>0: Pull down the clock line.</li> <li>Note:Although the slave cannot generate the communication clock, the slave can stretch the low voltage time of cloca according to the protocol. SCLEN=0, clock line is locked at low voltage, SCLEN=1 means release the clock line. Stretching the clock low voltage assumes that IIC_EN=1, otherwise the interm circuit will have no effect on the IIC bus. SCLEN is often used stretch the low voltage time to put the host into Wait state so the the slave has enough time to process the data.</li> </ul>                                                                                                                                   |  |  |  |
| 1 | SR     | <ul> <li>IIC slew rate control bit.</li> <li>1: Slew rate control is disabled to adapt standard speed mode (100K).</li> <li>0: Slew rate control is enabled for fast speed mode (400K).</li> <li>Note:SR=1 means slew rate control is off, the IO is adapted to 100Kbps communication.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| 0 | IIC_EN | <ul> <li>IIC operating enable bit</li> <li>1: Normal operation of the IIC.</li> <li>0: IIC does not work.</li> <li>Note:IICCON register is used for controlling the communication operation.</li> <li>Note: When it is necessary to pull down the clock line, i.e.</li> <li>WR_SCL_EN/RD_SCL_EN=1, before sending and receiving the last Byte data, the software should turn off the function of pulling down the clock line, i.e.</li> <li>WR_SCL_EN/RD_SCL_EN=0. After finishing sending and receiving the last Byte data, the software should turn on the function of writing to pull down the clock line. This operation can be adjusted according to whether the host is software or hardware, the processing time of interrupt handler is self-adjusted.</li> </ul> |  |  |  |



# 11.2.5 IIC Transmit/Receive Buffer Register (IICBUFFER)

Address: 0xFB

| Bit No.          | 7         | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|-----------|------------|---|---|---|---|---|---|
| Symbol           | IICBUFFER |            |   |   |   |   |   |   |
| Read/Write       |           | Read/Write |   |   |   |   |   |   |
| Po Initial Value |           | 0          |   |   |   |   |   |   |

| Bit No. | Symbol    | Description                                                                                                                          |
|---------|-----------|--------------------------------------------------------------------------------------------------------------------------------------|
| 7~0     | IICBUFFER | IIC transmit/receive data cache register; in the case of RD_SCL_EN is 0, when the host reads out data, the data in IICBUFFER is sent |
|         |           | to the slave transmit cache register in 2 clocks after the interrupt is                                                              |
|         |           | generated as the data sent by the slave. Therefore, the IICBUFFER                                                                    |
|         |           | interrupt data is prepared before the interrupt is generated.                                                                        |

# 11.2.6 IIC IO Configuration Register (IIC\_IO\_SEL)

| XRAM | SFR Address: 0x2049 |
|------|---------------------|
|      |                     |

| Bit No.             | 7            | 6            | 5             | 4             |
|---------------------|--------------|--------------|---------------|---------------|
| Symbol              | -            | -            | -             | -             |
| Read/Write          | -            | -            | -             | -             |
| Po Initial<br>Value | -            | -            | -             | -             |
| Bit No.             | 3            | 2            | 1             | 0             |
| Symbol              | IIC_AFIL_SEL | IIC_DFIL_SEL | IICSDA_IO_SEL | IICSCL_IO_SEL |
| Read/Write          | Read/Write   | Read/Write   | Read/Write    | Read/Write    |
| Po Initial<br>Value | 1            | 0            | 0             | 0             |

| Bit No. | Symbol        | Description                             |  |  |
|---------|---------------|-----------------------------------------|--|--|
|         |               | IIC IO analog filter selection enable.  |  |  |
| 3       | IIC_AFIL_SEL  | 1: Selects the analog filter function.  |  |  |
|         |               | 0: No analog filter function selected   |  |  |
|         |               | IIC IO digital filter selection enable  |  |  |
| 2       | IIC_DFIL_SEL  | 1: Selects the digital filter function. |  |  |
|         |               | 0: No digital filter function selected  |  |  |
|         |               | IIC_SDA IO Selection.                   |  |  |
| 1       | IICSDA_IO_SEL | 0: PA1                                  |  |  |
|         |               | 1: PB6                                  |  |  |



|   |               | IIC_SCL IO Selection. |
|---|---------------|-----------------------|
| 0 | IICSCL_IO_SEL | 0: PA2                |
|   |               | 1: PB7                |



# **11.3** IIC Configuration Procedure



Figure 11.8 shows the IIC configuration flow chart.

Table 0 .2 IIC Configuration

**Note**: IIC bus pull-up resistance is within 4.7k~10k, for ground filter capacitor it is recommended 10pF to 100pF near the pin.

# 12 SPI

SPI is a serial, synchronous, full-\half-duplex communication bus. The communication clock is a frequency division of the system clock. Under the 12M system clock frequency, the maximum frequency of the host supports 4M and the maximum frequency of the slave supports 2M. The communication mode has normal mode and high-speed mode. Clock idle level is available in four communication modes. The Duty Cycle of SPI clock is 50% (with 10% deviation allowed).

SPI normal mode: MCU writes into SPI transmit buffer SPID through interrupt (when SPI is enabled, it immediately generates a transmit empty interrupt) or polling, and the data is automatically loaded into the shift register and sent to SDO synchronously via SCLK; at the same time, the data is received from SDI and loaded into SPI receive buffer, and the receive data can be read from SPID when an accept full interrupt is generated.

SPI high-speed mode: The MCU writes transmit data (up to 2K) to SRAM in advance, and during communication, SPI reads out the data to be sent directly from SRAM without interrupt or polling; meanwhile, every time a byte of data (8Bits) is received, it is immediately written to the corresponding address in SRAM. When communication is completed, the SPI generates both the transmit empty flag and the receive full flag, and sends an interrupt.

The maximum operating frequency of the SPI host and slave modes is the bus clock divided by the baud rate of 2. The four modes are configured via SFR.

- CPOL: Select the clock idle state level. 0: clock idle state is low, 1: clock idle state is high.
- CPHA: Selects the data time for each cycle. 0: Data sampling at the first jump edge (rising or falling edge) of the clock. 1: Data sampling at the second jump edge (rising or falling edge) of the clock.

**Mode 0** (CPOL=0, CPHA=0): clock idle level is low and the host and slave are sampling data on the rising edge.

**Mode 1** (CPOL=0, CPHA=1): clock idle level is low, the host and slave are sampling data on the falling edge.

**Mode 2** (CPOL=1, CPHA=0): clock idle level is high, the host and slave sample at data on falling edge.

**Mode 3** (CPOL=1, CPHA=1): clock idle level is high, the host and slave are sampling data at rising edge.





Table 12 .1 SPI operating mode sequence diagram

### **Descriptions:**

SI: Slave sampling data;
SO: Slave transmitting data;
MI: Host sampling data;
MO:Host transmitting data.
The minimum time required for SPI\_CS to become high is 1 spi\_clk clock cycle.

# 12.1 Functions

- Host communication function: configured as host via internal registers, select the corresponding off-chip slave for each 8bit data serial exchange, send interrupt to MCU when data transmission and receive is completed, MCU reads out data before the next byte of data transmission is completed, otherwise the current data overflows.
- 2) **Slave communication function:** configured as a slave via internal registers, waiting to be selected for 8bit (per time) data serial exchange with the host.
- 3) **Disable the system clock F\_sys\_clk, interrupt to wake up the CPU:** After turning off the core clock, the slave receives a full interrupt to wake up the core.

# 12.2 Communication Sequence

There are three flag bits, two interrupt mask bits, and an interrupt vector associated with the SPI system. The SPI interrupt enable bit (RX\_IE) allows interrupts to occur from the SPI receiver full flag (SPRF). SPI transmit interrupt enable bit (TX\_IE) allows interrupts to occur from the SPI transmit buffer empty flag (SPTEF). When a flag bit is set and the associated interrupt enable bit is set, a



hardware interrupt request is sent to the CPU. If the interrupt enable bit is cleared, software can poll the associated flag bit without an interrupt occurring. the SPI interrupt service routine (ISR) should check the flag bit to determine the event that caused the interrupt. The service routine should also clear the flag bits before returning from the ISR (usually near the start point of the ISR).

If there is new data in the Tx buffer, the host will send continuously, and ss\_n\_out cannot be pulled Up in the middle.

# 12.3 SPI Registers

## 12.3.1 SPI Configuration Register 1 (SPI\_CFG1)

Address: 0xFC

| Bit No.             | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
|---------------------|----------|----------|----------|----------|----------|----------|----------|----------|
| Symbol              | RX_IE    | SPI_EN   | TX_IE    | MSTR     | CPOL     | CPHA     | LSBFE    | CS_N     |
| Read/Wri            | Read/Wri | Read/Wri | Read/Wri | Read/Wri | Read/Wri | Read/Wri | Read/Wri | Read/Wri |
| te                  | te       | te       | te       | te       | te       | te       | te       | te       |
| Po Initial<br>Value | 0        | 0        | 0        | 1        | 0        | 1        | 0        | 1        |

| Bit No. | Symbol | Description                                                   |
|---------|--------|---------------------------------------------------------------|
|         |        | Receive Enable - This is the SPI Receive Buffer Full (SPRF)   |
| 7       | RX_IE  | interrupt enable                                              |
| /       |        | 1: Interrupt enabled                                          |
|         |        | 0: Interrupt disabled (using polling)                         |
|         |        | SPI Enable                                                    |
| 6       | SPI_EN | 1: Module enabled                                             |
|         |        | 0: Module disabled                                            |
|         |        | Transmit Enable - This is the SPI Receive Buffer Full (SPTEF) |
| 5       | TX_IE  | interrupt enable                                              |
| 5       |        | 1: Interrupt enabled                                          |
|         |        | 0: Interrupt disabled (using polling)                         |
|         |        | Host/Slave Mode Selection                                     |
| 4       | MSTR   | 1: Host mode                                                  |
|         |        | 0: Slave mode                                                 |
|         |        | SCLK active voltage selection                                 |
| 3       | CPOL   | 1: Active low                                                 |
|         |        | 0: High level active                                          |
| 2       | СРНА   | SCLK phase selection.                                         |
| 2       | CPHA   | 1: transmit data on the first active clock edge               |



|   |       | 0: samples data at the first active clock edge         |  |  |  |
|---|-------|--------------------------------------------------------|--|--|--|
|   |       | LSB-first shifting (shifter direction)                 |  |  |  |
| 1 | LSBFE | 1: SPI serial data transfer starts at the lowest bit   |  |  |  |
|   |       | 0: SPI serial data transfer starts at the highest bit  |  |  |  |
|   |       | The chip select signal control, CS is high by default. |  |  |  |
| 0 | CS_N  | 0: Pull down CS                                        |  |  |  |
|   |       | 1: Pull up CS                                          |  |  |  |

### Note 1:

In master mode, CPOL and CPHA must be configured before pulling down the chip select CS (the corresponding GPIO of CS must be configured before configuring the CS), otherwise SCLK\_OUT has burrs.

### Note 2:

In slave mode, after the chip select is pulled low, SPI\_EN cannot be turned off, otherwise when SPI\_EN is turned on again, there is a burr in the internally generated SCLK when the chip select becomes low again.

## 12.3.2 SPI Configuration Register 2 (SPI\_CFG2)

Address: 0xFD

| Bit No.          | 7            | 6          | 5            | 4           |  |  |  |
|------------------|--------------|------------|--------------|-------------|--|--|--|
| Symbol           | -            | FEEDBACK   | HSPEED_START | HALF_DUPLEX |  |  |  |
| Read/Write       | -            | Read/Write | Read/Write   | Read/Write  |  |  |  |
| Po Initial Value | -            | 0          | 0            | 1           |  |  |  |
| Bit No.          | 3            | 2          | 1            | 0           |  |  |  |
| Symbol           | BIDIR_SELECT | SPR        |              |             |  |  |  |
| Read/Write       | Read/Write   | Read/Write |              |             |  |  |  |
| Po Initial Value | 1            | 0          |              |             |  |  |  |

| Bit No. | Symbol       | Description                                                              |
|---------|--------------|--------------------------------------------------------------------------|
|         |              | Transmit the received data to the master/slave                           |
|         |              | 1: Send the received data to the master\slave (the first byte of data    |
| 6       |              | sent is 0xff, the second is the first data received from the master, the |
| 6       | FEEDBACK     | later data sent are the previous data sent by the master. (Note: This    |
|         |              | function is only used in the mode of CPHA=0)                             |
|         |              | 0:Transmit the data written by MCU to the master/slave                   |
|         |              | High-speed SPI communication mode enabled, work done, hardware           |
| F       | HSPEED_START | automatically pulls down                                                 |
| 5       |              | 1: High-speed SPI communication mode enabled                             |
|         |              | 0: High-speed SPI communication mode disabled                            |



|     |                | (In high-speed SPI mode, the chip select signal cannot be pulled up,    |
|-----|----------------|-------------------------------------------------------------------------|
|     |                | whether in slave or master mode, which will result in loss of data sent |
|     |                | by the SPI)                                                             |
|     |                | Half-duplex mode selection                                              |
| 4   | HALF_DUPLEX    | 1: Select half-duplex mode                                              |
|     |                | 0: Select full-duplex mode                                              |
|     | 3 BIDIR_SELECT | Half-duplex mode, transmit and receive direction selection              |
| 3   |                | 1: Transmit                                                             |
|     |                | 0: Receive                                                              |
|     |                | SPI baud rate factor: maximum communication frequency is 2M             |
| 2~0 | SPR            | 0: F_sys_clk/2, 1: F_sys_clk/4, 2: F_sys_clk/6                          |
| 2~0 |                | 3: f_sys_clk/8, 4: f_sys_clk/10, 5: f_sys_clk/12                        |
|     |                | 6: F_sys_clk/14, 7: F_sys_clk/16                                        |

# 12.3.3 SPI Status Register (SPI\_STATE)

Address: 0xFE

| Bit No.          | 7 | 6 | 5 | 4 | 3 | 2          | 1           | 0          |
|------------------|---|---|---|---|---|------------|-------------|------------|
| Symbol           | - | - | - | - | - | SPRF       | OVERFLOW_RX | SPTEF      |
| Read/Write       | - | - | - | - | - | Read/Write | Read/Write  | Read/Write |
| Po Initial Value | - | - | - | - | - | 0          | 0           | 1          |

| Bit No. | Symbol      | Description                                                               |
|---------|-------------|---------------------------------------------------------------------------|
|         |             | Read buffer full flag, software write 0 to clear.                         |
| 2       | SPRF        | 0: No data available in the receive data buffer                           |
|         |             | 1: Data in the receive data buffer                                        |
|         |             | In the normal communication mode, when the read is not timely             |
|         |             | resulting in receive overflow, OVERFLOW_RX=1, this signal does            |
|         |             | not generate interrupt, only flag.                                        |
| 1       | OVERFLOW_RX | Invalid in high-speed SPI communication mode (when the number of          |
|         |             | received data is equal to the configured {SPI_NUM_H,SPI_NUM_L},           |
|         |             | it will end the operation and SPRF will be set, generating a full         |
|         |             | interrupt).                                                               |
|         |             | The transmit buffer empty flag, and hardware automatically clears by      |
|         |             | writing into the SPID. In SPI idle state, the first data written to the   |
| 0       | SPTEF       | SPID will be stored directly into the shift register, and the second data |
|         |             | written will be loaded into the transmit buffer, and SPTEF will be        |
|         |             | automatically pulled down.                                                |



## 12.3.4 SPI Data Register (SPI\_SPID)

Address: 0xFF

| Bit No.    | 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------|------------|---|---|---|---|---|---|---|--|
| Symbol     |            | - |   |   |   |   |   |   |  |
| Read/Write | Read/Write |   |   |   |   |   |   |   |  |
| Po Initial | 0          |   |   |   |   |   |   |   |  |
| Value      |            |   |   |   |   |   |   |   |  |

| Bit No. | Symbol | Description                                                              |
|---------|--------|--------------------------------------------------------------------------|
|         |        | Reading out the SPID register returns the data read from the receive     |
|         |        | data buffer rx_reg. When writing this register, the data will be written |
|         |        | into the transmit data buffer tx_reg.                                    |
|         |        | Data should not be written to the transmit data buffer unless the SPI    |
|         |        | Transmit Buffer Empty Flag (SPTEF) is set, indicating that there is      |
| 7~0     |        | some space in the transmit buffer to queue new transmit bytes.           |
|         |        | Data can be read out from the SPID at any time after the SPRF is set     |
|         |        | and before another transmission is completed. Failure to read data       |
|         |        | from the receive data buffer before the end of a new transmission        |
|         |        | results in a receive overflow, the OVERFLOW_RX flag is set, and the      |
|         |        | newly transmitted data is lost.                                          |

When SPI\_EN=0, this register cannot be written into.

Directly reading out the SPID register will return the data in current receive data buffer, when read the SPI\_STATE status register first to determine SPRF=1, and then read the SPID, only then can clear the SPRF flag and correctly read out the data in receive data buffer.

The SPI\_STATE status register is read out first to determine SPTEF=1 (transmit buffer empty flag) before the SPID register (transmit data buffer) can be written. When the SPI is configured as master, writing data to the transmit data buffer will initiate an SPI transfer.

### 12.3.5 SPI Transmit Buffer Start Address Register (SPI\_TX\_START\_ADDR)

XRAM\_SFR Address: 0x2057

| Bit No.    | 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|------------|------------|---|---|---|---|---|---|---|--|--|
| Symbol     |            | - |   |   |   |   |   |   |  |  |
| Read/Write | Read/Write |   |   |   |   |   |   |   |  |  |
| Po Initial |            | 0 |   |   |   |   |   |   |  |  |
| Value      |            | 0 |   |   |   |   |   |   |  |  |



| Bit No. | Symbol | Description                                                          |
|---------|--------|----------------------------------------------------------------------|
| 7~0     |        | In SPI high-speed mode, the first address of the transmit data cache |
|         |        | SPI_TX_START_ADDR*8                                                  |

### 12.3.6 SPI Receive Buffer Start Address Register (SPI\_RX\_START\_ADDR)

XRAM\_SFR Address: 0x2058

| Bit No.    | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|---|------------|---|---|---|---|---|---|
| Symbol     |   |            |   |   | - |   |   |   |
| Read/Write |   | Read/Write |   |   |   |   |   |   |
| Po Initial |   |            |   |   | 0 |   |   |   |
| Value      |   |            |   |   | 0 |   |   |   |

| Bit No. | Symbol | Description                                                         |
|---------|--------|---------------------------------------------------------------------|
| 7~0     |        | In SPI high-speed mode, the first address of the receive data cache |
|         |        | SPI_RX_START_ADDR*8                                                 |

### 12.3.7 SPI Data Buffer Address Number Low 8-bit Register (SPI\_NUM\_L)

XRAM\_SFR Address: 0x2059

| Bit No.    | 7 | 6          | 5 | 4 | 3        | 2 | 1 | 0 |
|------------|---|------------|---|---|----------|---|---|---|
| Symbol     |   |            |   |   | -        |   |   |   |
| Read/Write |   | Read/Write |   |   |          |   |   |   |
| Po Initial |   |            |   |   | <b>`</b> |   |   |   |
| Value      |   |            |   | ( | J        |   |   |   |

|   | Bit No. | Symbol | Description                                                     |
|---|---------|--------|-----------------------------------------------------------------|
| ſ | 7~0     |        | In SPI high-speed mode, the number of data cache addresses, low |
|   |         |        | 8 bits                                                          |

### 12.3.8 SPI Data Buffer Address Number High 3-bit Register (SPI\_NUM\_H)

XRAM\_SFR Address: 0x205A

| Bit No.    | 7 | 6 | 5 | 4 | 3 | 2 | 1          | 0 |
|------------|---|---|---|---|---|---|------------|---|
| Symbol     | - | - | - | - | - |   |            |   |
| Read/Write | - | - | - | - | - |   | Read/Write | ) |



| Po Initial | - | - | - | - | - | 0 |
|------------|---|---|---|---|---|---|
| Value      |   |   |   |   |   |   |

| Bit No. | Symbol | Description                                                   |
|---------|--------|---------------------------------------------------------------|
| 2~0     |        | Number of data cache addresses in SPI high-speed mode, high 3 |
|         |        | bits                                                          |

### 12.3.9 SPI Host Mode Receiver Clock Selection Register (SPI\_MCLK\_MOD)

XRAM\_SFR Address: 0x205B

| Bit No.    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|------------|---|---|---|---|---|---|---|------------|
| Symbol     | - | - | - | - | - | - | - | -          |
| Read/Write | - | - | - | - | - | - | - | Read/Write |
| Po Initial | - | - | - | - | - | - | - | 0          |
| Value      |   |   |   |   |   |   |   |            |

| Bit No. | Symbol | Description                                     |
|---------|--------|-------------------------------------------------|
|         |        | SPI Master Mode Receiver Clock Select Register  |
| 0       | -      | 1: Selects the master output as receiving clock |
|         |        | 0: Selects PAD input for receiving clock        |

## 12.3.10 SPI IO High Speed Mode Enable Register (SPI\_SPEED\_EN)

XRAM\_SFR Address: 0x205F

| Bit No.          | 7             | 6             | 5             | 4             |
|------------------|---------------|---------------|---------------|---------------|
| Symbol           | -             | -             | HSPEED_EN_PC4 | HSPEED_EN_PC3 |
| Read/Write       | -             | -             | Read/Write    | Read/Write    |
| Po Initial Value | -             | -             | 0             | 0             |
| Bit No.          | 3             | 2             | 1             | 0             |
| Symbol           | HSPEED_EN_PC2 | HSPEED_EN_PA3 | HSPEED_EN_PA2 | HSPEED_EN_PA1 |
| Read/Write       | Read/Write    | Read/Write    | Read/Write    | Read/Write    |
| Po Initial Value | 0             | 0             | 0             | 0             |

| Bit No. | Symbol          | Description                                            |  |  |  |  |  |
|---------|-----------------|--------------------------------------------------------|--|--|--|--|--|
|         | 5 HSPEED_EN_PC4 | SPI communication IO PC4 configured as high-speed mode |  |  |  |  |  |
| Б       |                 | enable.                                                |  |  |  |  |  |
| 5       |                 | 1: High-speed mode.                                    |  |  |  |  |  |
|         |                 | 0: Normal mode                                         |  |  |  |  |  |



|   |               | SPI communication IO PC3 configured as high-speed mode    |
|---|---------------|-----------------------------------------------------------|
| 4 | HSPEED EN PC3 | enable.                                                   |
| 4 | HSPEED_EN_PC3 | 1: High-speed mode.                                       |
|   |               | 0: Normal mode                                            |
|   |               | SPI communication IO PC2 configured as high-speed enable. |
| 3 | HSPEED_EN_PC2 | 1: High-speed mode.                                       |
|   |               | 0: Normal mode                                            |
|   |               | SPI communication IO PA3 configured as high-speed enable. |
| 2 | HSPEED_EN_PA3 | 1: High-speed mode.                                       |
|   |               | 0: Normal mode                                            |
|   |               | SPI communication IO PA2 configured as high-speed enable. |
| 1 | HSPEED_EN_PA2 | 1: High-speed mode.                                       |
|   |               | 0: Normal mode                                            |
|   |               | SPI communication IO PA1 configured as high-speed enable. |
| 0 | HSPEED_EN_PA1 | 1: High-speed mode.                                       |
|   |               | 0: Normal mode                                            |

# 12.3.11 SPI IO Selection Register (SPI\_IO\_SEL)

XRAM\_SFR Address: 0x2044

| Bit No.          | 7           | 6           | 5          | 4          |
|------------------|-------------|-------------|------------|------------|
| Symbol           | -           | -           | -          | -          |
| Read/Write       | -           | -           | -          | -          |
| Po Initial Value | -           | -           | -          | -          |
| Bit No.          | 3           | 2           | 1          | 0          |
| Symbol           | MISO_IO_SEL | MOSI_IO_SEL | SCK_IO_SEL | CS_IO_SEL  |
| Read/Write       | Read/Write  | Read/Write  | Read/Write | Read/Write |
| Po Initial Value | 0           | 0           | 0          | 0          |

| Bit No. | Symbol      | Description        |
|---------|-------------|--------------------|
|         |             | MISO IO Selection. |
| 3       | MISO_IO_SEL | 0: PA2             |
|         |             | 1: PC3             |
| 2       |             | MOSI IO Selection. |
|         | MOSI_IO_SEL | 0: PA1             |
|         |             | 1: PC4             |
| 1       |             | SCK IO Selection.  |
|         | SCK_IO_SEL  | 0: PA3             |
|         |             | 1: PC2             |
| 0       | CS_IO_SEL   | CS IO Selection.   |



|  | 0: PD0 |
|--|--------|
|  | 1: PC5 |

### Note:

By default, the chip select CS is high. In master mode, the corresponding GPIO must be configured before configuring the CS.

# 12.4 SPI Configuration Procedure



Figure 0.3 SPI Master/Slave Operation Flow Chart

Note:

1. Configure CPOL and CPHA when chip select CS is high, otherwise SCLK has glitches (Applied for both master and slave).

2. In slave mode, after the chip select is pulled down, SPI\_EN cannot be turned off, otherwise there is a glitch in the internally generated SCLK when the chip select becomes low again when SPI\_EN is turned on again. That is, SPI\_EN cannot be turned off while SPI is selected.

Semiconductor

- 3. In slave mode, if the chip select is always 0, if you want to switch CPOL/CPHA/LSBFE in the middle, the slave can switch only after the master pulls up the chip select.
- 4. In high speed mode, HSPEED\_START will be automatically pulled down after work is done, at this time, the master cannot send SCLK again, otherwise it will generate an unsteady state.
- 5. In high-speed mode, if an odd number of data is sent in each frame, the chip select signal CS needs to be pulled high once between each frame.
- 6. The chip select signal CS must be pulled high once before switching from normal mode to high-speed mode.



# 13 UART

There is one UART module in the BS9000AMxx, supporting up to 5 IOs mapping, which can only correspond to one group of mappings at the same time. UART module IO features:

- Support full-duplex, half-duplex serial communication
- With independent double buffer receiver, single buffer transmitter
- Programmable baud rate (10-bit analog-to-digital frequency divider)
- Interrupt-driven or poll operation.
  - Transmit completed
  - Receive full
  - > Receive overflow, parity error, frame error
- Support hardware parity generation and check
- Programmable 8-bit or 9-bit character length
- STOP bit 1 bit or 2 bits selectable
- Supports multi-processor mode
- Support TXD/RXD separate enable

## 13.1 Description

### 13.1.1 Baud Rate Generation

Baud rate generation modulo bandrate={UART\_CON2.UART\_BDH[1:0],UART\_BDL}.

Baud rate calculation formula: when bandrate=0, no baud rate clock is generated, when bandrate=1~1023, SCI baud rate= BUSCLK/(16xbandrate). BUSCLK can select 24Mhz system clock or external oscillator.

Each time the baud rate register is configured the internal counter is cleared to regenerate the baud rate signal. Communication requires the transmitter and receiver to use the same baud rate. Allowable baud rate deviation range for communication:  $\pm$ 5%.

### 13.1.2 Functions of Emitter

Transmitting data process: write the UART\_BUF to enable the transmitting, the transmit interrupt is set after the stop bit is sent, the software clears the interrupt flag and waits for the next writing. The idle state of the transmitter output pin (TxD) defaults to the logic high state. The whole transmit process must be performed when the module is enabled (UART\_CON1.UART\_ENABLE=1) and the



transmitter is enabled (UART\_CON1.TRANS\_ENABLE=1).

By writing data into the data register (UART\_BUF), it will store the data directly to the transmit data buffer and turn on the transmitting process. During the subsequent complete transmit process, writing to the data register UART\_BUF and T8 is not allowed until the transmit completion stop bit is set and the transmit interrupt flag is set, then the UART\_BUF can be written again to restart a new transmit.

The central component of a serial transmitter is a transmit shift register with a size of 10/11/12 bits (depending on the setting in the DATA\_MODE control bit). Assuming DATA\_MODE=0, the normal 8-bit data mode is selected. In 8-bit data mode, there are 1 start bit, 8 data bits and 1 to 2 stop bits in the shift register.

Transmit and receive are in little endian mode (LSB first).

When the transmitter is not enabled, the TXD IO is released and the corresponding PAD can be used for other functions.

### 13.1.3 Functions of Receiver

The receiver is enabled by setting the RECEIVE\_ENABLE bit in the UART\_CON1. Note that the whole receive process must be performed when the module is enabled, i.e. UART\_CON1.UART\_ENABLE=1.

When the receiver is not enabled, the RXD IO is released and the corresponding PAD can be used for other functions.

Receive data process: receive data at any time when receive enable is active, set the receive interrupt after receive stop bit, and software will clear the interrupt flag.

The current received data will have a detection mechanism, which can detect 3 kinds of errors: receive overflow, frame error, parity error, all of which need software to clear the flags. It is recommended to read out the status flag after detecting the receive interrupt, read out the data UART\_BUF, and finally clear all the receive data status flags (UART\_STATE[3:0]).

The data character consists of the start bit of logic 0, 8 (or 9) data bits (LSB-first), and the stop bit of logic 1 (1 bit). After receiving the stop bit into the receive shifter, if the receive data register is not yet full (RX\_FULL\_IF=0), the data character is transferred to the receive data register, setting the receive data register full (RX\_FULL\_IF=1) status flag. If RX\_FULL\_IF is already set at this time with the receive data register full, the overflow (RX\_OVERFLOW\_IF) status flag is set and new data is lost. Because the receiver is double buffered, the program has a full character time for reading after setting RX\_FULL\_IF and before reading the data from the receive data buffer to avoid receiver overflow.

When the program detects that the receive data register is full (RX\_FULL\_IF=1), it obtains the data from the receive data register by reading UART\_BUF.

### 13.1.4 Receiver Sampling Method

The receiver uses a 16x baud rate clock for sampling. The receiver searches for falling edges on the RxD serial data input pins by extracting logic level samples at 16x baud rate. The falling edge is



defined as a logic 0 sample after 3 consecutive logic 1 samples. 16x baud rate clock is used to divide the bit times into 16 segments, labeled from RT1 to RT16.

Then the receiver samples each bit time of RT8, RT9 and RT10, including the start and stop bits, to determine the logic level of that bit. The logic level is the logic level of the majority of samples extracted during the bit time. When the falling edge is positioned, the logic level is 0 to ensure that this is the true start bit and not the noise. If at least two of these three samples are 0, the receiver assumes it is synchronized with the receiver character and begins shifting to receive the following data, and if the above conditions are not met then exits the state machine to return to wait for falling edge state.

The falling edge detection logic constantly looks for falling edges, and if an edge is detected, the sample clock resynchronizes the bit time. This improves receiver reliability when there is noise or a mismatch of baud rates.

### 13.1.5 Multi-processor Mode

Multiprocessor mode works in 9-bit mode only, the receive interrupt is set when the received UART\_R8 bit = 1, otherwise it is not set. The effect of this mechanism is to eliminate the software overhead of processing unimportant message characters using hardware detection, allowing the receiver to ignore characters in messages used for different receivers.

In this application system, all receivers estimate the address character (bit 9 = 1) of each message, and once it is determined that the message is intended for a different receiver, subsequent data characters (bit 9 = 0) are not received.

Configuration process: configure receive enable, configure multiprocessor mode, receive address data (bit 9 = 1), receive and generate interrupt, used to confirm whether the address matches. If matching then configure to disable multiprocessor mode, all subsequent data (bit 9 = 0) can be received and generate an interrupt until the next received address data. If addresses do not match, then enable multiprocessor mode, all subsequent data are not be received until the next address data, and so on in a cyclic application.

Hardware response: transmit data, enabled by writing the UART\_BUF value, set the transmit interrupt flag after the stop bit is sent, software clears the interrupt flag, and wait for the next write. Receive data is received at any time when receive enable is active, receive interrupt is set after receive stop bit, and software clears the interrupt flag. The currently received data will have a detection mechanism that detects three types of errors: receive overflow, frame error, and parity check error, all of which require software to clear the flags. It is recommended to read out the status flag after detecting the receive interrupt, and clear all the receive status flags UART\_STATE[0:3]. **Note:** The mapping synchronization output function is not supported.



# 13.2 UART Register

# 13.2.1 UART Control Register 1 (UART\_CON1)

Address: 0xBE

| Bit No.             | 7           | 6            | 5              | 4          |
|---------------------|-------------|--------------|----------------|------------|
| Symbol              | UART_ENABLE | TRANS_ENABLE | RECEIVE_ENABLE | MULTI_MODE |
| Read/Write          | Read/Write  | Read/Write   | Read/Write     | Read/Write |
| Po Initial<br>Value | 0           | 0            | 0              | 0          |
| Bit No.             | 3           | 2            | 1              | 0          |
| Symbol              | STOP_MODE   | DATA_MODE    | PARITY_EN      | PARITY_SEL |
| Read/Write          | Read/Write  | Read/Write   | Read/Write     | Read/Write |
| Po Initial          | 0           | 0            | 0              | 0          |
| Value               |             |              |                |            |

| Bit No. | Symbol         | Description                                                      |  |  |  |  |
|---------|----------------|------------------------------------------------------------------|--|--|--|--|
|         |                | Module enable.                                                   |  |  |  |  |
| 7       | UART_ENABLE    | 1: Enabled                                                       |  |  |  |  |
|         |                | 0: Disabled                                                      |  |  |  |  |
|         |                | Transmitter enable.                                              |  |  |  |  |
| 6       | TRANS_ENABLE   | 1: Enabled                                                       |  |  |  |  |
|         |                | 0: Disabled                                                      |  |  |  |  |
|         |                | Receiver enable.                                                 |  |  |  |  |
| 5       | RECEIVE_ENABLE | 1: Enabled                                                       |  |  |  |  |
|         |                | 0: Disabled                                                      |  |  |  |  |
|         |                | Multi-processor mode for multi-slave system where hardware       |  |  |  |  |
| 4       | MULTI_MODE     | automatically masks invalid information.                         |  |  |  |  |
| 4       |                | 1: Enabled                                                       |  |  |  |  |
|         |                | 0: Disabled                                                      |  |  |  |  |
|         |                | STOP bit size selection.                                         |  |  |  |  |
| 3       | STOP_MODE      | 1: 2 bits                                                        |  |  |  |  |
|         |                | 0: 1 bit                                                         |  |  |  |  |
| 2       | DATA MODE      | Data mode selection, unified control of transmitter and receiver |  |  |  |  |
| 2       | DATA_MODE      | 1: 9-bit mode 0: 8-bit mode                                      |  |  |  |  |
| 1       | PARITY_EN      | Parity check enable                                              |  |  |  |  |
|         | FANIT_EN       | 1: Parity check enabled; 0: Parity check not enabled             |  |  |  |  |
| 0       | PARITY_SEL     | Parity check selection                                           |  |  |  |  |
| 0       | FARIT_SEL      | 1: Odd check; 0: Even check                                      |  |  |  |  |



# 13.2.2 UART Control Register 2 (UART\_CON2)

Address: 0xBF

| Bit No.    | 7           | 6          | 5          | 4 |  |
|------------|-------------|------------|------------|---|--|
| Symbol     | -           | -          | -          |   |  |
| Read/Write | -           | -          | -          |   |  |
| Po Initial |             |            |            |   |  |
| Value      | -           | -          | -          |   |  |
| Bit No.    | 3           | 2          | 1          | 0 |  |
| Symbol     | TX_EMPTY_IE | RX_FULL_IE | UART_BDH   |   |  |
| Read/Write | Read/Write  | Read/Write | Read/Write |   |  |
| Po Initial | 1           | 1          | 0          |   |  |
| Value      | I           | I          |            | 0 |  |

| Bit No. | Symbol       | Description                                   |  |  |  |
|---------|--------------|-----------------------------------------------|--|--|--|
|         |              | Transmit interrupt enable                     |  |  |  |
| 3       | TX_FINISH_IE | 1: Enabled                                    |  |  |  |
|         |              | 0: Disabled ( for polling mode)               |  |  |  |
|         |              | Receive interrupt enable.                     |  |  |  |
| 2       | RX_FULL_IE   | 1: Enabled                                    |  |  |  |
|         |              | 0: Disabled ( for polling mode)               |  |  |  |
| 1~0     | UART_BDH     | Baud rate modulo divisor register high 2 bits |  |  |  |

## 13.2.3 UART Status Flag Register (UART\_STATE)

Address: 0xC0

| Bit No.             | 7          | 6              | 5            | 4             |
|---------------------|------------|----------------|--------------|---------------|
| Symbol              | -          | UART_R8        | UART_T8      | TX_FINISH_IF  |
| Read/Write          | -          | Read           | Read/Write   | Read/Write    |
| Po Initial<br>Value | -          | 0              | 0            | 0             |
| Bit No.             | 3          | 2              | 1            | 0             |
| Symbol              | RX_FULL_IF | RX_OVERFLOW_IF | FRAME_ERR_IF | PARITY_ERR_IF |
| Read/Write          | Read/Write | Read/Write     | Read/Write   | Read/Write    |
| Po Initial          | 0          | 0              | 0            | 0             |
| Value               |            |                |              |               |

| Bit No. | Symbol  | Description                             |
|---------|---------|-----------------------------------------|
| 6       | UART_R8 | The 9th data of the receiver, read-only |



| 5 | UART_T8        | The 9th data of the transmitter, read-only when parity is enabled       |
|---|----------------|-------------------------------------------------------------------------|
|   |                | Transmit interrupt flag.                                                |
| 4 |                | 1: Transmit is finished.                                                |
| 4 | TX_FINISH_IF   | 0: Transmit is finished, software writes 0 to clear, while writing 1 is |
|   |                | invalid                                                                 |
|   |                | Receive interrupt flag.                                                 |
| 3 |                | 1: Receiving cache is full                                              |
| 5 | RX_FULL_IF     | 0: Receive cache is empty, software writes 0 to clear, while writing    |
|   |                | 1 is invalid                                                            |
|   | RX_OVERFLOW_IF | Receive overflow flag.                                                  |
| 2 |                | 1: Receive overflow (new data lost)                                     |
|   |                | 0: No overflow, software writes 0 to clear, while writing 1 is invalid  |
|   |                | Frame error flag.                                                       |
| 1 | FRAME_ERR_IF   | 1: Frame error detected                                                 |
| 1 |                | 0: No frame error detected, software writes 0 to clear, while writing   |
|   |                | 1 is invalid                                                            |
|   |                | Parity error flag.                                                      |
| 0 | PARITY_ERR_IF  | 1: Receiver parity error                                                |
|   |                | 0: Parity check is correct, software writes 0 to clear, while writing 1 |
|   |                | is invalid                                                              |

#### **Description:**

8-bit mode: parity enable is invalid.

**9-bit mode**: When the parity bit is enabled, the 9th bit is the calculated parity bit; when it is disabled, the ninth bit is the T8 written into.

## 13.2.4 UART Data Register (UART\_BUF)

Address: 0xC1

| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------------|---|------------|---|---|---|---|---|---|--|
| Symbol           |   | -          |   |   |   |   |   |   |  |
| Read/Write       |   | Read/Write |   |   |   |   |   |   |  |
| Po Initial Value |   | FF         |   |   |   |   |   |   |  |

| Bit No. | Symbol | Description                                                                     |
|---------|--------|---------------------------------------------------------------------------------|
|         |        | Data register.                                                                  |
| 7~0     |        | Read returns the contents of the read-only receive data buffer, write goes into |
|         |        | the write-only transmit data buffer                                             |



# 13.2.5 UART Baud Rate Control Register (UART\_BDL)

Address: 0xC2

| Bit No.          | 7 | 6             | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|------------------|---|---------------|---|---|---|---|---|---|--|--|
| Symbol           |   | UART_BDL[7:0] |   |   |   |   |   |   |  |  |
| Read/Write       |   | Read/Write    |   |   |   |   |   |   |  |  |
| Po Initial Value |   | 0             |   |   |   |   |   |   |  |  |

| Bit | t No.      | Symbol                                                           | Description                                   |
|-----|------------|------------------------------------------------------------------|-----------------------------------------------|
|     |            | Baud rate control register                                       |                                               |
|     |            |                                                                  | baud rate modulo divisor register low 8 bits, |
| 7   | <b>~</b> 0 | UART_BDL[7:0]                                                    | bandrate={UART_BDH[1:0], UART_BDL}.           |
|     |            | When bandrate =0, no baud rate clock is generated, when bandrate |                                               |
|     |            |                                                                  | =1~1023, baud rate = BUSCLK/(16x bandrate)    |

## 13.2.6 UART Clock Selection Register (UART\_CLK\_SEL)

XRAM\_SFR Address: 0x205C

| Bit No.          | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|------------------|---|---|---|---|---|---|---|------------|
| Symbol           | - | - | - | - | - | - | - | -          |
| Read/Write       | - | - | - | - | - | - | - | Read/Write |
| Po Initial Value |   |   |   |   |   |   |   | 0          |

| Bit No. | Symbol | Description                   |  |  |  |
|---------|--------|-------------------------------|--|--|--|
|         |        | UART clock selection register |  |  |  |
| 0       |        | 0: Selects 24Mhz clock        |  |  |  |
|         |        | 1: Selects clk_xtal           |  |  |  |

### 13.2.7 UART IO Selection Register (UART\_IO\_SEL)

XRAM\_SFR Address: 0x2045

| Bit No.          | 7 | 6 | 5            | 4 | 3 | 2            | 1          | 0 |
|------------------|---|---|--------------|---|---|--------------|------------|---|
| Symbol           | - | - | UART_RXD_SEL |   |   | UART_TXD_SEL |            |   |
| Read/Write       | - | - | Read/Write   |   |   |              | Read/Write | e |
| Po Initial Value | - | - | 0            |   |   | 0            |            |   |

| Bit No. | Symbol | Description |
|---------|--------|-------------|
|         |        | ·           |



| 5~3 | UART_RXD_SEL | UART_RXD IO selection.                 |
|-----|--------------|----------------------------------------|
|     |              | 0: PA2; 1: PB1; 2: PB5; 3: PB7; 4: PC1 |
| 2~0 | UART_TXD_SEL | UART_TXD IO selection                  |
|     |              | 0: PA1; 1: PB2; 2: PB4; 3: PB6; 4: PC0 |

## **13.3 UART Configuration Procedure**



Table 13 .1 UART initialization configuration Flow Chart

#### **Recommended application process:**

- 1. Configure module enable, receive enable, mode selection: UART\_CON1.
- 2. Configure baud rate and turn on interrupt enable: UART\_BDL, UART\_CON2.
- 3. Write into UART\_BUF to start transmitting data and clearing the interrupt flag TX\_FINISH\_IF when a transmit interrupt is detected.

4. When the receive interrupt is detected, first read the receive status UART\_STATE, then read UART\_STATE.UART\_R8 and UART\_BUF, and finally clear the receive status flag (UART\_STAT[3:0] = 0), when a receive process is finished, and wait for the next receive interrupt.

5. If configure interrupt is disabled, the program executes the UART, and also has to read the status flag first, then read out UART\_STATE.UART\_R8 and UART\_BUF, and finally clear



the status flag.

6. Interrupt flag bit clear operation, in full-duplex operation, clear flag bit operation needs to write 0 for valid interrupt bits and 1 for other interrupt bits (write 1 is invalid operation), otherwise, it is easy to operate by mistake. For example, when the transmit interrupt is valid, you need to write UART\_STATE = 0x0F; (i.e. configure UART\_STATE[0:3] = 0x0F, UART\_STATE.UART\_R8 write invalid, UART\_STATE.UART\_T8 need to configure valid transmit data when it is in 9-bit mode and without parity check).

7. **8-bit mode**: parity enable is invalid.

8. **9-bit mode**: When the parity bit is enabled, the parity bit calculated by the ninth bit is not enabled, the ninth bit is written into UART\_STATE.UART\_T8. It only has transmit interrupt and receive interrupt, the error flag only marks the current data error detection, and only the corresponding bit is cleared by writing 0, no error interrupt, the transmit interrupt is set to 1 after the stop bit is sent and the software clears to 0. The receive interrupt is set to 1 after the stop bit is received, and the software clears to 0.



# 14 SCI

## 14.1 Introduction

The SCI module supports UART and LIN2.1 protocols.

### 14.1.1 UART Mode

- Support full-duplex/half-duplex serial communication
- Dual buffered transmitter and receiver with independent enable
- Programmable baud rate (13-bit analog-digital frequency divider)
- Interrupt-driven or polling operation.
  - > Transmit data register empty, transmitting completed
  - Receive data register is full
  - > Receive overflows, parity errors, frame errors and noise errors
  - Idle receiver detection
  - > Active edge detection on the receive pin
- Support LIN synchronization interval segment detection
- Support hardware parity generation and checking
- Programmable 8-bit or 9-bit character length
- Programmable 1-bit or 2-bit STOP bit length
- Wake up receiver by idle line or address flag
- 13-bit abort character generation / 11-bit abort character detection optional
- Transmitter output polarity and receiver input polarity selectable
- Support baud rate adaptive function
- Support edge wake-up in wait mode and sleep mode

### 14.1.2 LIN Frame Mode

- Support Master and slave node transmission
- As master node, it supports automatic frame-header transmit, frame response transmit and receive
- As slave node, it supports automatic frame-header receive, frame response transmit and receive
- Support frame data storage, including PID, DATA, CHECKSUM
- Support classical checksum, enhanced checksum
- Support timeout detection
- Support Error detection
- Support baud rate detection



# 14.2 Baud Rate Generation

Baud rate generation modulo bandrate = {SCI\_BDH[4:0], SCI\_BDL}.

Baud rate calculation formula: when bandrate = 0, no baud rate clock is generated, when bandrate = 1 to 8191, SCI baud rate = BUSCLK/(16xbandrate). BUSCLK is SCI working clock, optional PLL\_24MHZ clock or crystal clock XTAL.

Each time the baud rate register is configured, the internal counter is cleared to regenerate the baud rate signal.

Communication requires the transmitter and receiver to use the same baud rate.

Baud rate deviation range for communication can be 8/11\*16=4.5%.

The system supports automatic baud rate matching, in LIN protocol, the synchronization segment character is 0x55. The baud rate detection is measured from the falling edge of the received START bit until the falling edge of the 8th data bit, 8 bits in total, and the bandrate will be updated automatically after the communication is finished, and can be read out through the register SCI\_BDH/SCI\_BDL. Note here that receiving the synchronization segment and automatically matching the baud rates is performed simultaneously with the receive function, and the receive full interrupt will be issued after the character is received. The maximum deviation before baud rate matching is not allowed to exceed 40%, otherwise the calibration fails.

## 14.3 Emitter Function

The idle state of the emitter output pin (TxD) defaults to the logic high state  $(SCI_C3.TXD_INV = 0$  after reset). If  $SCI_C3.TXD_INV = 1$ , the emitter output is inverted.

The transmitter can send three types of characters: leading character, abort character, and data character. Writing 0 to SCI\_C2.TRANS\_ENABLE bit and then to 1 will make the leading character in the queue. Writing 1 to SCI\_C2.BREAK\_TRANS\_START bit and then to 0 will make the abort character in the queue, write data register SCI\_D will queue a data character.

The transmitter is enabled by setting the TRANS\_ENABLE bit in SCI\_C2. This queues the leading character, which is a complete character frame of the idle state, and controls the transmit of 12-bit or 11-bit or 10-bit idle characters (logic high) according to SCI\_C1.DATA\_MODE and SCI\_C1.STOP\_MODE. During normal applications where idle characters need to be sent, the program waits for the transmit null to be valid before setting it up to show that the last character of the message has moved to the transmit shifter and then writes 0 and 1 to the TRANS\_ENABLE bit in that order. After that, as soon as the shifter is available, the operation queues the idle characters in the shifter (including the three characters) are not completed when TRANS\_ENABLE=0.

By writing data to the SCI data register (SCI\_D), the program stores data to the transmit data buffer that will queue a data character. The central component of the SCI transmitter is a transmit shift register of length 10 or 11 or 12 bits (depending on the setting in the SCI\_C1. DATA\_MODE and SCI\_C1. STOP\_MODE control bits). Assuming SCI\_C1.DATA\_MODE=0, the normal 8-bit data mode



is selected. In 8-bit data mode, there are 1 start bit, 8 data bits and 1 to 2 stop bits in the shift register. When the transmit shift register is available for a new SCI character, the value waiting in the transmit data register is transferred to the shift register while the transmit data register empty status flag (TX\_EMPTY\_IF) is set, indicating that another character can be written to the transmit data buffer of SCI\_D.

An abort character is queued by writing a 1 followed by a 0 to the SCI C2.BREAK TRANS START bit. The abort character is the full character time of logic 0 (10-bit time, including the start and stop 13-bit time bits). Longer abort characters of can be enabled bv settina SCI\_S2.BREAK\_TRANS\_SIZE=1. Similarly, both SCI\_C1.DATA MODE and SCI C1.STOP MODE can choose to increase one bit time. In general, the program waits for the transmit empty to be valid before setting it to show that the last character of the message has moved to the transmit shifter, and then writes 1 and 0 to the BREAK TRANS START bits in order. The operation then queues the abort characters to be sent as soon as the shifter is available. If SCI C2.BREAK TRANS START is still 1 when an abort character already in the queue enters the shifter, additional abort characters will enter the queue.

If there are no new characters (including three types of characters) waiting in the transmit data buffer after stopping the shift out of the TxD pin, the transmitter sets the transmit finish flag and enters idle mode with TxD in high state waiting for more characters to be sent.

Note: The transmit data empty interrupt conditions include: configure the transmitter enable from 0 to 1 to turn on an empty interrupt. Also, enable an empty interrupt when transmitting the FIFO to the shift register. Turning off the transmitter enable during transmission will stop transmission after the current character is sent and will clear the previously queued characters.

The generation condition for a Transmit Finish Interrupt : enable a finish interrupt after all the queued characters are sent.

## 14.4 **Receiver Function**

The receiver is enabled by setting the RECEIVE\_ENABLE bit in SCI\_C2. The receiver input is inverted by setting SCI\_C3.RXD\_INV=1.

Receive characters include three types: data characters, abort characters, and idle characters.

The data character consists of the start bit of logic 0, 8 or 9 data bits (LSB first), and the stop bit of logic 1. After receiving the stop bit to the receive shifter, if the receive data register is not yet full (SCI\_S1.RX\_FULL\_IF=0), the data character is transferred to the receive data register, setting the receive data register full (SCI\_S1.RX\_FULL\_IF=1) status flag. If the SCI\_S1.RX\_FULL\_IF at which the receive data register is full is already set at this time, the overflow (SCI\_S1.RX\_OVERFLOW\_IF) status flag is set and the new data is lost. Because the SCI receiver is double buffered, the program has a full character time after setting SCI\_S1.RX\_FULL\_IF and before reading out the data from the receive data buffer to avoid receiver overflow.

When the program detects that the receive data register is full (SCI\_S1.RX\_FULL\_IF=1), it gets the data from the receive data register by reading SCI\_D.

The abort character is counted from the 0 character of START until the STOP bit detects a 0 character,



and the SCI S2.BREAK CHECK EN bit selects whether to enable 11-bit abort character detection, clearing the count once a rising edge is detected on the pin during the process. Enough 0 characters are detected (11 or 12 or 13 bits), set the abort character detection flag (SCI S2.BREAK CHECK IF).

Idle character is selected according to SCI\_C3.IDLE\_SEL bit starting from the idle character bit count after the stop/start bit, and is detected only after the receiver has been active for a period of time (received full valid set once). Once a 0 character is detected the count is cleared and enough 1 characters (10/11/12 bits) are detected to set the idle character detection flag (SCI\_S1.IDLE\_IF). Note: When abort character detection is enabled, only abort characters are detected and data receive is not considered, which is for LIN protocol flow control; when abort character detection is disabled, only data is received and abort character detection is ignored.

### 14.4.1 Receiver Sampling Method

The SCI receiver uses a 16x baud rate clock for sampling. The receiver searches for falling edges on the RxD serial data input pins by extracting logic level samples at 16x baud rate. The falling edge is defined as logic 0 sample after three consecutive logic 1 sampling. The 16x baud rate clock is used to divide the bit times into 16 segments, labeled from RT1 to RT16. When the falling edge is located, three more samples are extracted from RT3, RT5, and RT7 to ensure that this is the actual start bit and not just noise. If at least two of the three samples are 0, the receiver assumes it is synchronized with the receiver characters and starts shifting to receive the following data. If the above conditions are not met, then exit the state machine to return to wait for falling edge state.

The receiver then samples each bit time of RT8, RT9 and RT10, including the start and stop bits, to determine the logic level of the bit. The logic level is the logic level of the majority of the samples extracted during the bit time. Among the start bits, if at least 2 of the samples on RT3, RT5, and RT7 are 0, then that bit is assumed to be 0, even if one or all of the samples extracted on RT8, RT9, and RT10 are 1. If any sample in any bit time of the character frame (8 samples from RT3 to RT10 for the start bit and 3 samples RT8 to RT10 for the other bits) fails to match the the logical level of that bit, the noise error flag (SCI\_S1.NOISE\_ERR\_IF) is set for all received characters when they are transmitted to the receive data buffer.

The falling edge detection logic constantly looks for falling edges, and if an edge is detected, the sample clock resynchronizes the bit time. This improves receiver reliability when there is noise or a mismatch of baud rates.

### 14.4.2 Receiver Wakeup from Sleep

Receiver wakeup from sleep is a hardware mechanism that uses hardware detection to eliminate the software overhead of handling unimportant message characters, allowing the SCI receiver to ignore characters in messages used for different SCI receivers.

In such applications, all receivers estimate the first character of each message, and as soon as they determine that the message is intended for a different receiver, they write logic 1 to the receiver wakeup (SCI\_C2.RWU) control bit in SCI\_C2. When the SCI\_C2.RWU bit is set, the receiver-related status flags setting is not allowed (when the SCI\_C3.RWU\_IDLESEL bit is set, the idle bit IDLE is



Semiconductor

set and an interrupt is generated).

In receiver sleep state (software sets the SCI\_C2.RWU bit to enter sleep), the wake-up method can be selected via the SCI\_C3.WAKE\_SEL bit (i.e. hardware automatically clears the SCI\_C2.RWU bit), including idle character wake-up and address flag wake-up.

Idle character detection is described above, and SCI\_C2.RWU is automatically cleared once the receiver detects a full idle character. After wake-up, the receiver sets the corresponding status flag upon the next character received.

Address flag wakeup is when the receiver detects a logic 1 in the highest bits of the received characters (8th bit in SCI\_C1.DATA\_MODE=0 mode; 9th bit R8 in SCI\_C2.DATA\_MODE=1 mode), SCI\_C2.RWU is automatically cleared.

After woken up, the receiver status flags and interrupts in the current character can be set.

# 14.5 Pin Connection Mode

When SCI\_C1.CYCLE\_MODE = 1, the SCI\_C1.SINGLE\_TXD bit selects either cyclic mode (SCI\_C1.SINGLE\_TXD= 0) or single line mode (SCI\_C1.SINGLE\_TXD= 1).

#### Cyclic mode

Cyclic mode is independent of external system connections and is sometimes used to check software to help isolate system problems. In this mode, the transmitter output is interconnected to the receiver input and the SCI does not use the RxD pin.

#### Single line mode

In single line mode, the SCI\_C3.TXD\_DIRECT bit controls the direction of the serial data on the TxD pin. When SCI\_C3.TXD\_DIRECT= 0, the TxD pin is an input to the SCI receiver, connecting to the receiver input, and when SCI\_C3.TXD\_DIRECT= 1, the TxD pin is an output driven by the transmitter.

### 14.6 Low power Wake-up

This module can be configured to enable the receive edge interrupt function to wake up the system in low power mode.

If the SCI module is configured to enable (SCI\_C1.SCI\_ENABLE=1), the receiver (SCI\_C2.RECEIVE\_ENABLE=1) and the RX edge interrupt (SCI\_S2.RX\_EDGE\_IE=1) when the system enters sleep or wait mode, it will wake up the system when the receive IO is low .

## 14.7 Frame Mode

### 14.7.1 Frame Format





Table 14 .1 Frame Format

The master node sends the BREAK character according to the following table when the LIN\_CMD.TX\_HEADER command is valid (note that DATA\_MODE here is fixed at 0 in frame mode). TX\_HEADER\_BREAK\_ERROR is set when a bus "1" is detected at this stage.

When SCI\_S2.BREAK\_CHECK\_EN is set, the slave node will decide to detect 11 or 12 bit "0" as BREAK character according to STOP\_MODE, and set SCI\_S2.BREAK\_CHECK\_IF at the same time.

| BREAK_TRANS_SIZE | DATA_MODE | STOP_MODE | Length       |
|------------------|-----------|-----------|--------------|
| 0                | 0         | 0         | 10 bit times |
| 0                | 0         | 1         | 11 bit times |
| 0                | 1         | 0         | 11 bit times |
| 0                | 1         | 1         | 12 bit times |
| 1                | 0         | 0         | 13 bit times |
| 1                | 0         | 1         | 14 bit times |
| 1                | 1         | 0         | 14 bit times |
| 1                | 1         | 1         | 15 bit times |

| Table 14 .2 | Different Frame Lengths |
|-------------|-------------------------|
|-------------|-------------------------|

#### 14.7.1.1 BREAK Delimiter Segment

The master node determines the length of the BREAK interval character to be sent with 2 to 5 bytes selectable, according to LIN\_CTL0.BREAK\_DELIMITER\_LEN. At this stage, if the bus is detected as "0", then set the bit LIN\_STATUS.TX\_HEADER\_BREAK\_DELIMITER\_ERROR.



#### 14.7.1.2 SYNC Segment

The master node is fixed to transmit 0x55.

The slave node will be valid at LIN\_CMD. RX\_HEADER command, after detecting BREAK, fixed to receive 0x55, data is not stored, calculate the time from START falling edge to the falling edge of BIT7 (total 8 bits length), recorded in register LIN\_SYNC\_COUNTER, if there is no deviation, it should be 8\*16=128. The deviation of 0.5% is allowed at the transmitter IO and 14% at the receiver IO as defined in the frame protocol, and the deviation range allowed for the synchronization segment is [106, 152] according to this calculation. If the deviation does not exceed this range, the slave node will automatically match the baud rates and continue the communication, and if the deviation exceeds this range, the interrupt flag LIN\_INTR1.RX\_HEADER\_SYNC\_ERROR will be set and the communication will be stopped.

#### 14.7.1.3 PID Segment

The master node automatically computes the high 2 bits based on the configured 6-bit ID. LIN\_INTR2.TX\_HEADER\_DONE is set after the frame header is sent. If there is no LIN\_CMD.TX\_RESPONSE or LIN\_CMD.RX\_RESPONSE command at this time, LIN\_CMD.TX\_HEADER will be cleared automatically.

 $bit6:P0 = ID0 \oplus ID1 \oplus ID2 \oplus ID4$ 

bit7:P1 = ~ (ID1  $\oplus$  ID3  $\oplus$  ID4  $\oplus$  ID5)

The slave node will check automatically after the receive is finished and set LIN\_INTR1.RX\_HEADER\_PARITY\_ERROR for errors and LIN\_INTR2.RX\_HEADER\_DONE is set when the receive is finished.

#### 14.7.1.4 DATA Segment

This stage does not distinguish between master and slave nodes, instead it is distinguished by instruction. From the LIN\_DATA\_IDX register, it reads out how many bytes have been transferred. LIN\_CMD. TX\_RESPONSE is the transmit response, the data sent (TX\_DATA/TX\_CHECKSUM) and the number of data (LIN\_CTL0.DATA\_NR) are configured before the command is enabled. LIN\_CMD.RX\_RESPONSE is the receive response. The number of data received (LIN\_CTL0.DATA\_NR) and the checksum type (LIN\_CTL0.CHECKSUM\_ENHANCED) have to be configured before the STOP bit of the first data is issued, otherwise there may be a conflict. In general, for the master node, the number of data and the checksum type of the response are configured before the frame transmission starts. Slave nodes need to decide these based on the received PIDs.

#### 14.7.1.5 CHECKSUM Segment

Transmit Response Node will transmit checksum bytes at the same time, and the data is stored in



Semiconductor

the transmit cache, which is obtained by the software based on the calculation.

The receive response node receives both checksum bytes and automatically checks the data. The checksum can be divided into an enhanced checksum with PID and a classical checksum without PID. If the checksum fails, the error flag LIN\_INTR2.RX\_RESPONSE\_CHECKSUM\_ERROR is set.

The checksum method is to add each byte of the checksum object in rounded binary (subtract 255 whenever the result is greater than or equal to 256), and invert the final sum bit by bit, and use the result as the checksum to be sent. The receiver conducts the same rounded binary addition to the received data according to the checksum type, the final sum is not inverted, and the sum is added to the received checksum. If the result is 0xFF, the checksum is correct, which ensures the correctness of data transmission to some extent.

#### 14.7.1.6 TIMEOUT Handling

Three modes of timeout detection.

- 1) Full Frame Mode
- 2) Frame header mode
- 3) Frame Response Mode



Table 14 .3 Frame timeout mode

According to register LIN\_CTL0.FRAME\_TIMEOUT\_SEL, three timing methods can be selected. When the frame communication time exceeds the value configured in register LIN\_FRAME\_TIMEOUT, the error flag LIN\_INTR1.TIMEOUT is set.

| FRAME_TIMEOUT_SEL | RAME_TIMEOUT_SEL         Timeout selection |                                                | Timer STOP                            |  |
|-------------------|--------------------------------------------|------------------------------------------------|---------------------------------------|--|
| 0                 | 0 Timerout disabled                        |                                                | None                                  |  |
| 1                 | Frame mode                                 | Falling edge of<br>START bit in BREAK<br>field | Checksum field STOP bit<br>OR timeout |  |



| 2 | Frame header mode      | Falling edge of<br>START bit in BREAK<br>field | PID field STOP bit OR<br>timeout      |
|---|------------------------|------------------------------------------------|---------------------------------------|
| 3 | Frame response<br>mode | End of STOP bit                                | Checksum field STOP bit<br>OR timeout |

Table 14 .4 Frame Timeout Timing Methods

### 14.7.2 LIN Communication

The LIN protocol supports three types of information transfer.

- 1) Master response: the master node sends the frame header and sends a response. This type is used to observe and control slave nodes.
- 2) Slave response: the master node sends the frame header, the slave node sends a response, and the master node receives the response. This type is used to observe the state of the slave node.
- 3) Slave to slave: the master node sends the frame header, one slave node sends a response, and the other slave node receives the response.

To support these different message types, the manipulation of LIN master or slave operation modes is done indirectly by command sequences.

**LIN\_CMD.TX\_HEADER**: The master node sends a full frame header with this command, including the interval segment, the synchronization segment and the PID field.

**LIN\_CMD.RX\_HEADER**: The slave node receives the frame header with this command. After the slave node receives the frame header, the finish flag (LIN\_INTR2.RX\_HEADER\_DONE) is set and then the slave node application can decide the following actions based on the received PID field.

- > Receive a response (LIN\_CMD.RX\_RESPONSE).
- Transmit a response (LIN\_CMD. TX\_RESPONSE).
- > Ignore a response, close the channel and re-enable the next frame

**LIN\_CMD.TX\_RESPONSE:** The master or slave node uses this command to transmit a response, the hardware sends the data field and the auto-generated checksum.

**LIN\_CMD.RX\_RESPONSE:** The master or slave node uses this command to receive a response, and the hardware receive data field stored in the cache to verify the checksum.

| Magaza turaa    | Command Sequence in register LIN_CMD |           |             |             |  |  |  |
|-----------------|--------------------------------------|-----------|-------------|-------------|--|--|--|
| Massage types   | TX_HEADER                            | RX_HEADER | TX_RESPONSE | RX_RESPONSE |  |  |  |
| Master Response | 1                                    | 0         | 1           | 0           |  |  |  |
| Slave Response  | 1                                    | 0         | 0           | 1           |  |  |  |
| Slave-to-Slave  | 1                                    | 0         | 0           | 0           |  |  |  |

#### LIN Master Node Command Sequence



| Response(transmitting |  |  |
|-----------------------|--|--|
| node)                 |  |  |

Table 14 .5 LIN master node command sequence

For the master node, the order of these commands is set at the beginning of the frame. To enter the relevant interrupt handling function only once, the Master node needs to enable an interrupt source LIN\_INTR2.(TX\_HEADER\_DONE,TX\_RESPONSE\_DONE).

#### LIN Slave Node Command Sequence

| Magaza tupog          | Command Sequence in register LIN_CMD |           |             |             |  |  |  |
|-----------------------|--------------------------------------|-----------|-------------|-------------|--|--|--|
| Massage types         | TX_HEADER                            | RX_HEADER | TX_RESPONSE | RX_RESPONSE |  |  |  |
| Master Response       | 0                                    | 1         | 0           | 1           |  |  |  |
| Slave Response        | 0                                    | 1         | 1           | 1           |  |  |  |
| Slave-to-Slave        |                                      |           |             |             |  |  |  |
| Response(transmitting | 0                                    | 1         | 1           | 1           |  |  |  |
| node)                 |                                      |           |             |             |  |  |  |
| Slave-to-Slave        |                                      |           |             |             |  |  |  |
| Response(receiving    | 0                                    | 1         | 0           | 1           |  |  |  |
| node)                 |                                      |           |             |             |  |  |  |
| Ignore Response 0     |                                      | 1         | 0           | 0           |  |  |  |

Table 14 .6 LIN slave node command sequence

For slave nodes, RX\_HEADER and RX\_RESPONSE are to be set before detecting the interval segment, which can avoid losing the interval segment and the data field (because it is not sure what state the bus is currently in.) When both TX\_RESPONSE and RX\_RESPONSE are set, priority is given to TX\_RESPONSE.

The slave node always sets two commands LIN\_CMD. RX\_HEADER and LIN\_CMD. RX RESPONSE, and the received frame header PID field will specify the slave node:

- Receive a response
- > Transmit a response
- > Abort transmission and ignore a response

By setting both LIN\_CMD. RX\_HEADER and LIN\_CMD. RX\_RESPONSE, the slave node responds first to the receive in order to avoid the loss of data fields in the response.

When a message is successfully transmitted, the command is cleared and re-enabled for the next transmission. On detection of an error, the transmit command is cleared, but the receive command is not cleared. This behavior is important for slave nodes in practical applications where interval segments occur during the receiving.

LIN\_CMD.TX\_RESPONSE and LIN\_CMD.RX\_RESPONSE can be enabled at the same time and the command order is handled according to the following priority.

- Highest priority: LIN\_CMD.TX\_RESPONSE command
- Second priority: LIN\_CMD. RX\_RESPONSE command



Lowest priority: no response without these two commands

### 14.7.3 LIN Software Flow Chart

Figure 14.7 shows the master node communication software flow chart.



Table 14 .7 Master node communication software Flow Chart

Figure 14.8 shows the flow chart of the slave node communication software.





Table 14 .8 Slave Node Communication Software Flow Chart



# 14.8 Frame Mode State Machine



Table 14 .9 Frame mode operating state machine

Descriptions of each state machine.

- ➢ IDLE: Wait state.
- Transmit BREAK: Transmits the BREAK character (13 bits), including the BREAK interval (configurable).
- > Transmit SYNC: Transmits synchronization character, 0x55.
- Transmit PID: Transmits PID character, 1 byte (two parity bits are calculated automatically).
- > Transmit DATA: Transmits data character, 1~8 bytes (configurable).
- > Transmit CHECKSUM: Transmits checksum character, 1 byte.



- Receive SYNC: Receives synchronous segment, baud rate auto-matching, data is not stored.
- > Receive PID: Receives PID character, 1 byte.
- Receive DATA: Receives data characters, 1~8 bytes (configurable).
- > Receive CHECKSUM: Receives checksum character, 1 byte.

## 14.9 Instructions for interrupt handling

There are two interrupt groups based on the working mode:

- > UART mode: There are send/receive interrupts.
  - Send interrupts include TX\_EMPTY, TX\_FINISH.
  - Receive interrupts include RX\_FULL, IDLE, BREAK\_CHEK, and RX\_EDGE.
  - Error flags RX\_OVERFLOW, NOISE\_ERR, FRAME\_ERR, PARITY\_ERR do not trigger the interrupt.
- LIN mode: There are BREAK\_CHEK, RX\_EDGE and LIN communication interrupt.LIN communication interrupts include normal interrupts and error interrupts.

■ Normal interrupt: TX\_HEADER\_DONE, TX\_RESPONSE\_DONE,

#### RX\_HEADER\_DONE,

- RX\_RESPONSE\_DONE, RX\_HEADER\_SYNC\_DONE.
- Error interrupt: TIMEOUT, TX\_HEADER\_BIT\_ERROR, TX\_RESPONSE\_BIT\_ERROR, RX\_HEADER\_FRAME\_ERROR, RX\_HEADER\_SYNC\_ERROR, RX\_HEADER\_PARITY\_ERROR, RX\_RESPONSE\_FRAME\_ERROR, RX\_RESPONSE\_CHECKSUM\_ERROR.

#### Note:

Note 1: In the same set of interrupts, enabled interrupts are processed by OR operation, so when multiple interrupts are enabled at the same time, once one interrupt is set, the interrupt handler function will not be entered again without being cleared.

Note 2: some of LIN error interrupt will abort the current frame transmission immediately , after the error normal send/receive interrupt will not occcur after the error occurred, including: TX\_HEADER\_BIT\_ERROR (configurable), TX\_RESPONSE\_BIT\_ERROR (configurable), PX\_HEADER\_ERAME\_ERROR PX\_HEADER\_SYNC\_ERROR

RX\_HEADER\_FRAME\_ERROR, RX\_HEADER\_SYNC\_ERROR,

RX\_RESPONSE\_FRAME\_ERROR; Some errors occur at points that lag behind normal receive interrupts, including: RX\_HEADER\_PARITY\_ERROR (receiving the frame header is complete and will abort the subsequent response transmission of the current frame),

RX\_RESPONSE\_CHEGKSUM\_ERROR (receiving the frame response is complete), it is recommended to handle this error in receive interrupts.

Note 3: TIMEOUT interrupt will not stop frame transmission. The interrupt handling should restart SCI, and the steps are as follows:

Clear the error flag bit (LIN\_INTR1.TIMEOUT) after entering the TIMEOUT interrupt, clear the frame command (Clear LIN\_CMD to 0), and disable the enablement module (Clear SCI\_C1.SCI\_ENABLE 0); To transfer the next frame, enable the module (Clear SCI\_C1.SCI\_ENABLE 0);

Semiconductor



0), reconfigure all frame related configuration registers (LIN\_FRAME\_TIMEOUT, LIN\_CTL1, LIN\_CTL0, LIN\_INTR1\_IE, LIN\_INTR2\_IE), Finally, configure LIN\_CMD to enable communication.

## 14.10 SCI Registers

LIN\_FRAME\_TIMEOUT, LIN\_CTL1, LIN\_CTL0, LIN\_INTR1\_IE and LIN\_INTR2\_IE registers can be modified the configuration after enabling, but they cannot be configured continuously. If continuous configuration is required, it is recommended that the interval be more than 10 system clocks.

### 14.10.1 SCI Clock Selection Register (SCI\_CLK\_SEL)

XRAM\_SFR Address: 0x205D

| Bit No.          | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|------------------|---|---|---|---|---|---|---|------------|
| Symbol           |   |   |   | - |   |   |   | -          |
| Read/Write       |   |   |   | - |   |   |   | Read/Write |
| Po Initial Value |   |   |   | - |   |   |   | 0          |

| Bit No. | Symbol | Description                |
|---------|--------|----------------------------|
|         |        | SCI Clock Select Register  |
| 0       |        | 0: Selects PLL_24Mhz clock |
|         |        | 1: Selects clk_xtal        |

This register is used to select the module clock source, on which the baud rate generator is also based.

This register is also valid in LIN frame mode.

### 14.10.2 Baud Rate Control High 5-bit Register (SCI\_BDH)

XRAM\_SFR Address: 0x2070

| Bit No.    | 7 | 6 | 5 | 4          | 3 | 2 | 1 | 0 |
|------------|---|---|---|------------|---|---|---|---|
| Symbol     | - |   |   | -          |   |   |   |   |
| Read/Write | - |   |   | Read/Write |   |   |   |   |
| Po Initial |   |   |   |            |   | 0 |   |   |
| Value      |   | - |   |            |   | 0 |   |   |

| Bit No. | Symbol                                                 | Description                 |  |
|---------|--------------------------------------------------------|-----------------------------|--|
| 4~0     |                                                        | Baud rate control register. |  |
|         | bit[4:0]:Baud rate modulo divisor register high 5 bits |                             |  |



## 14.10.3 Baud Rate Control Low 8-bit Register(SCI\_BDL)

XRAM\_SFR Address: 0x2071

| Bit No.    | 7                                       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|-----------------------------------------|---|---|---|---|---|---|---|
| Symbol     | - · · · · · · · · · · · · · · · · · · · |   |   |   |   |   |   |   |
| Read/Write | Read/Write                              |   |   |   |   |   |   |   |
| Po Initial | 0                                       |   |   |   |   |   |   |   |
| Value      |                                         |   |   |   |   |   |   |   |

| Bit No. | Symbol | Description                                    |  |
|---------|--------|------------------------------------------------|--|
| 7~0     |        | Baud rate control register.                    |  |
|         |        | Baud rate modulus divisor register low 8 bits. |  |

bandrate={SCI\_BDH[4:0],SCI\_BDL}, no baud rate clock is generated when bandrate=0. When bandrate=1~8191, SCI baud rate= BUSCLK/(16xbandrate).

This register is also valid in LIN frame mode.

### 14.10.4 Control Register 1 (SCI\_C1)

Address: 0xB5

| Bit No.          | 7          | 6          | 5             | 4          |
|------------------|------------|------------|---------------|------------|
| Symbol           | CYCLE_MODE | STOP_MODE  | SINGLE_TXD    | DATA_MODE  |
| Read/Write       | Read/Write | Read/Write | Read/Write    | Read/Write |
| Po Initial Value | 0          | 0          | 0             | 0          |
| Bit No.          | 3          | 2          | 1             | 0          |
| Symbol           | PARITY_EN  | PARITY_SEL | RATE_MATCH_EN | SCI_ENABLE |
| Read/Write       | Read/Write | Read/Write | Read/Write    | Read/Write |
| Po Initial Value | 0          | 0          | 0             | 0          |

| Bit No. | Symbol      | Description                                                  |  |
|---------|-------------|--------------------------------------------------------------|--|
|         |             | Cycle mode enable.                                           |  |
| 7       | CYCLE_MODE  | 1: Cyclic mode or single line mode, txd connected to rxd     |  |
|         |             | 0: Normal two-line mode                                      |  |
|         |             | Stop digit selection.                                        |  |
| 6       | 6 STOP_MODE | 1: 2bits.                                                    |  |
|         |             | 0: 1bit.                                                     |  |
| F       |             | Single line mode enable.                                     |  |
| 5       | SINGLE_TXD  | 1: Single line mode selected at CYCLE_MODE =1, txd pin valid |  |



|   |               | 0: Internal cycle mode, txd pin invalid                            |  |  |
|---|---------------|--------------------------------------------------------------------|--|--|
|   |               | Transfer data mode selection.                                      |  |  |
| 4 | DATA_MODE     | 1: 9-bit mode (the 9th bit is the parity bit)                      |  |  |
|   |               | 0: 8-bit mode                                                      |  |  |
|   |               | Parity check enable.                                               |  |  |
| 3 | PARITY_EN     | 1: Parity check enabled.                                           |  |  |
|   |               | 0: Parity disabled                                                 |  |  |
|   |               | Parity check selection.                                            |  |  |
| 2 | PARITY_SEL    | 1: Odd check.                                                      |  |  |
|   |               | 0: Even check                                                      |  |  |
|   |               | Synchronization segment (0x55) baud rate auto-match enable.        |  |  |
| 1 | RATE_MATCH_EN | 1: Adaptive baud rate update.                                      |  |  |
|   |               | 0: Fixed configuration baud rate                                   |  |  |
|   |               | Module operating clock gate enable.                                |  |  |
| 0 | SCI_ENABLE    | 1; enable is valid, turn on the module working clock               |  |  |
|   |               | 0: Turn off the module working clock and reset the function module |  |  |

The SINGLE\_TXD bit is meaningful when CYCLE\_MODE = 1 and is used to select whether the txd pin is active or not.

STOP\_MODE: STOP bit selection, it is valid for both transmitter and receiver.

| Symbol    | Description                                               |
|-----------|-----------------------------------------------------------|
|           | Transmission data mode selection, it is valid for both    |
|           | transmitter and receiver.                                 |
|           | For 1:9-bit mode, start + 8 data bits (LSB first sent)    |
| DATA_MODE | + 9th data bit + stop, the 9th bit is normally used as    |
|           | a parity bit.                                             |
|           | For 0:8-bit mode, start + 8 data bits (LSB first sent)    |
|           | + stop.                                                   |
|           |                                                           |
|           | Parity check enable bit, which is used for receiver       |
|           | parity check enable and transmitter parity check          |
|           | generation enable, applicable in 8-bit/9-bit mode. In     |
|           | 8-bit mode transmitter sends the 8th bit for the first 7  |
|           | bits of parity check generation, the receiver checks      |
| PARITY_EN | the first 7 bits to get the value compared with the 8th   |
|           | bit; in 9-bit mode transmitter sends the T8 for the 8-    |
|           | bit data calculation to generate the bit, the receiver    |
|           | checks the first 8 bits to get the value compared with    |
|           | the 8th bit. The receiver checks the first 8 bits of data |
|           | to get the value compared with R8.                        |

Semiconductor



| PARITY_SEL                                      | Parity selection. Parity indicates that the total number of 1's in the data character (including parity bits) is odd. Even indicates that the total number of 1's in the data character (including parity bits) is even.                                                                                                                                                                                                |
|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RATE_MATCH_EN:                                  | Synchronization segment baud rate auto-match only<br>applies to 8-bit data 0x55, that is, the next<br>communication must be 0x55, it will automatically<br>update the bandrate after the communication is<br>finished, and can be read out through register<br>SCI_BDH/SCI_BDL, can only synchronize once<br>upon enabled; if need to synchronize again, need to<br>pull the enable bit down once and pull it up again. |
| SCI_ENABLE                                      | To use all the functions of SCI, first configure to<br>enable the module with SCI_ENABLE=1 to turn on<br>the operating clock. In the case of turning off the<br>module enable, the module can only perform<br>write/read registers.                                                                                                                                                                                     |
| CYCLE_MODE/ STOP_MODE<br>/SINGLE_TXD/SCI_ENABLE | CYCLE_MODE/STOP_MODE<br>SINGLE_TXD/SCI_ENABLE<br>registers are also valid in LIN frame mode.                                                                                                                                                                                                                                                                                                                            |

# 14.10.5 Control Register 2 (SCI\_C2)

Address: 0xB6

| Bit No.             | 7            | 6              | 5          | 4                 |
|---------------------|--------------|----------------|------------|-------------------|
| Symbol              | TX_EMPTY_IE  | TX_FINISH_IE   | RX_FULL_IE | IDLE_IE           |
| Read/Write          | Read/Write   | Read/Write     | Read/Write | Read/Write        |
| Po Initial<br>Value | 0            | 0              | 0          | 0                 |
| Bit No.             | 3            | 2              | 1          | 0                 |
| Symbol              | TRANS_ENABLE | RECEIVE_ENABLE | RWU        | BREAK_TRANS_START |
| Read/Write          | Read/Write   | Read/Write     | Read/Write | Read/Write        |
| Po Initial<br>Value | 0            | 0              | 0          | 0                 |

| Bit No. | Symbol      | Description                             |
|---------|-------------|-----------------------------------------|
| 7       | TX_EMPTY_IE | Transmit buffer empty interrupt enable. |



|   |                       | 1: Interrupt enabled.                                       |
|---|-----------------------|-------------------------------------------------------------|
|   |                       | 0: Interrupt disabled                                       |
|   |                       | Transmit finish interrupt enable.                           |
| 6 | TX_FINISH_IE          | 1: Interrupt enabled.                                       |
|   |                       | 0: Interrupt disabled                                       |
|   |                       | Receive full interrupt enable.                              |
| 5 | RX_FULL_IE            | 1: Interrupt enabled.                                       |
|   |                       | 0: Interrupt disabled                                       |
|   |                       | Idle line interrupt enable.                                 |
| 4 | IDLE_IE               | 1: Interrupt enabled.                                       |
|   |                       | 0: Interrupt disabled                                       |
|   |                       | Transmitter enable bit.                                     |
| 3 | TRANS_ENABLE          | 1: The transmitter is turned on.                            |
|   |                       | 0: Transmitter is off                                       |
|   |                       | Receiver enable.                                            |
| 2 | RECEIVE_ENABLE        | 1: The receiver is turned on.                               |
|   |                       | 0: Receiver is off                                          |
|   |                       | Receiver wake-up control.                                   |
| 1 | RWU                   | 1: The receiver is in standby mode, waiting for the wake-up |
| 1 |                       | condition.                                                  |
|   |                       | 0: Receiver operates normally.                              |
|   | BREAK_TRANS_ST<br>ART | Transmit interval segment, write 1 and 0 to this bit        |
| 0 |                       | successively, i.e. a interval segment is scheduled in the   |
|   |                       | transmit data stream.                                       |

The interrupt enable register, which is set 1 to enable interrupt generation and set to 0 to disable interrupt generation, but does not affect the interrupt flag set in the following register, used for polling mode.

| Symbol         | Description                                            |
|----------------|--------------------------------------------------------|
|                | Transmitter enable. This bit must be set to 1 in order |
| TRANS_ENABLE   | to use the SCI transmitter. An idle character can be   |
|                | queued by clearing 0 to this bit and then setting 1.   |
|                |                                                        |
| RECEIVE_ENABLE | Receiver enable. To use SCI receiver, this bit must    |
|                | be set to 1.                                           |
|                |                                                        |
|                | RWU receiver wake-up control. This bit writes a 1      |
|                | to put the SCI receiver to sleep state and wait the    |
|                | selected wake-up condition to be detected by           |
|                | hardware automatically. The wake-up condition can      |
| RWU            | be either an idle line between messages or a logic     |
|                | 1 in the highest data bit in a character. Application  |



|                                 | software sets RWU or software clears it. General        |
|---------------------------------|---------------------------------------------------------|
|                                 | application hardware wake-up automatically clears       |
|                                 | RWU.                                                    |
|                                 | Transmit interval segment control, write 1 and 0 to     |
| BREAK_TRANS_START               | this bit successively, i.e., a interval is scheduled in |
|                                 | the transmit data stream, and a set of abort            |
|                                 | characters is sent once the shifter is available.       |
|                                 | TRANS_ENABLE/RECEIVE_ENABLE/RWU                         |
| TRANS_ENABLE/RECEIVE_ENABLE/RWU | registers are also valid in LIN frame mode.             |
|                                 |                                                         |

# 14.10.6 Control Register 3 (SCI\_C3)

Address: 0xB9

| Bit No.          | 7          | 6           | 5          | 4          |
|------------------|------------|-------------|------------|------------|
| Symbol           | R8         | Т8          | TXD_DIRECT | TXD_INV    |
| Read/Write       | Read       | Read/Write  | Read/Write | Read/Write |
| Po Initial Value | 0          | 0           | 0          | 0          |
| Bit No.          | 3          | 2           | 1          | 0          |
| Symbol           | RXD_INV    | RWU_IDLESEL | IDLE_SEL   | WAKE_SEL   |
| Read/Write       | Read/Write | Read/Write  | Read/Write | Read/Write |
| Po Initial Value | 0          | 0           | 0          | 0          |

| Bit No. | Symbol      | Description                                                       |
|---------|-------------|-------------------------------------------------------------------|
| 7       | R8          | The 9th data of the receiver. Read only.                          |
| 6       | Т8          | The 9th data of the transmitter                                   |
|         |             | txd pin direction selection in Single line mode.                  |
| 5       | TXD_DIRECT  | 1: TxD pin is output in single line mode                          |
|         |             | 0: TxD pin is input in single line mode                           |
|         |             | Invert the data at the txd.                                       |
| 4       | TXD_INV     | 1: The transmit data is reversed.                                 |
|         |             | 0: the transmit data is not reversed                              |
|         |             | Invert the data at the rxd.                                       |
| 3       | RXD_INV     | 1: The received data is reversed.                                 |
|         |             | 0: Received data not reversed                                     |
|         |             | Receive wake-up from Idle detection.                              |
| 2       | RWU_IDLESEL | 1: Set the IDLE bit when an idle character is detected during the |
|         |             | receive standby state (RWU=1).                                    |



|   |          | 0: No IDLE bit is set when an idle character is detected during the     |
|---|----------|-------------------------------------------------------------------------|
|   |          | receive standby state (RWU=1)                                           |
|   |          | Idle line type selection.                                               |
|   |          | 1: Idle character bit count starts after the stop bit                   |
| 1 | IDLE_SEL | 0: Idle character bit count starts after the start bit, counting 10-bit |
|   |          | times (if DATA_MODE = 1 or STOP_MODE = 1, add 1 bit time,               |
|   |          | respectively)                                                           |
|   |          | Receiver wake-up method selection.                                      |
| 0 | WAKE_SEL | 1: Address flag wake-up.                                                |
|   |          | 0: Idle line wake-up                                                    |

| Symbol         | Description                                              |
|----------------|----------------------------------------------------------|
|                | The 9th data bit of the receiver, when configured        |
|                | for 9-bit data, R8 can be regarded as the 9th            |
|                | received data to the left of the MSB of the data         |
| R8             | register, R8 needs to be read out before reading         |
|                | the data register, because reading the data register     |
|                | can complete the automatic receive full flag             |
|                | clearing, allowing R8 and SCI_D to be overwritten        |
|                | by new data.                                             |
|                | The 9th data of the transmitter. When SCI is             |
|                | configured for 9-bit data, T8 can be considered the      |
|                | 9th transmit data bit to the left of the MSB that        |
|                | buffers the data in the data register. T8 should be      |
|                | written before the data register is written (if it needs |
| 70             | to be modified from its previous value). If T8 does      |
| Т8             | not need to be modified from its new value (e.g.         |
|                | when it is used to generate a flag or parity), it does   |
|                | not need to be written before each write to the data     |
|                | register. When parity enable is configured, this bit     |
|                | is used as a parity bit and is automatically             |
|                | generated by hardware, not a written value.              |
|                | The TXD_DIRECT bit is meaningful when                    |
| The TXD_DIRECT | CYCLE_MODE = 1 and SINGLE_TXD = 1, and is                |
|                | used to select the txd pin direction.                    |
|                | Invert the data at the txd, it will invert all output    |
|                | signals.                                                 |
|                | The interrupt enable register, which is set to 1 to      |
| TXD_INV        | enable interrupt generation and is set to 0 to           |



|                                       | disable interrupt generation, but does not affect the       |
|---------------------------------------|-------------------------------------------------------------|
|                                       | interrupt flag set in the following register, used for      |
|                                       | polling mode.                                               |
| RXD_INV                               | Invert the data at the rxd IO, it will invert all the input |
|                                       | signals.                                                    |
|                                       | Receive wakeup from idle detection, used to                 |
| RWU_IDLESEL                           | control whether the IDLE state and interrupts are           |
|                                       | set during receiver standby.                                |
|                                       | TXD_DIRECT/TXD_INV/RXD_INV/RWU_IDLESE                       |
| TXD_DIRECT/TXD_INV/RXD_INV/RWU_IDLESE | L/IDLE_SEL/WAKE_SEL registers are also valid in             |
| L/IDLE_SEL/WAKE_SEL                   | LIN frame mode.                                             |

# 14.10.7 Sync Segment Control Register (SCI\_S2)

Address: 0xBA

| Bit No.          | 7              | 6          | 5               | 4              |
|------------------|----------------|------------|-----------------|----------------|
| Symbol           | BREAK CHECK IF | RX_EDGE_IF | RX ACTIVE FLAG  | RXDATA0_FRAME_ |
| Symbol           | BREAK_CHECK_II |            |                 | CHECK          |
| Read/Write       | Read/Write     | Read/Write | Read            | Read/Write     |
| Po Initial Value | 0              | 0          | 0               | 0              |
| Bit No.          | 3              | 2          | 1               | 0              |
| Symbol           | BREAK_CHECK_IE | RX_EDGE_IE | BREAK_TRANS_SIZ | BREAK_CHECK_EN |
|                  |                |            | Е               |                |
| Read/Write       | Read/Write     | Read/Write | Read/Write      | Read/Write     |
| Po Initial Value | 0              | 0          | 0               | 0              |

| Bit No. | Symbol         | Description                                                          |
|---------|----------------|----------------------------------------------------------------------|
|         |                | Interval segment detection interrupt flag.                           |
| 7       |                | 1: The interval segment is detected.                                 |
| 1       | BREAK_CHECK_IF | 0: No interval segment is detected, the bit is cleared by writing 1  |
|         |                | and invalid by writing 0                                             |
|         | 6 RX_EDGE_IF   | RxD pin active edge interrupt flag.                                  |
|         |                | 1: Active edge occurs on the receive pin.                            |
| 0       |                | 0: No active edge on the receive pin, this bit is cleared by writing |
|         |                | 1, invalid by writing 0                                              |
|         |                | Receiver activity flag, read-only.                                   |
| 5       | RX_ACTIVE_FLAG | 1: Receiver active                                                   |
|         |                | 0: Receiver idle                                                     |



|   | RXDATA0_FRAME_  | Interval detection enable bit, configuring delayed transmit interrupt |
|---|-----------------|-----------------------------------------------------------------------|
|   |                 | when 0x00 character is detected and STOP=0 while interval             |
| 4 |                 | detection interrupt is disabled                                       |
|   | CHECK           | 1: Transmit interrupt received and frame error interrupt delayed.     |
|   |                 | 0: Ignore this byte data reception                                    |
|   |                 | Interval segment detection interrupt enable.                          |
| 3 | BREAK_CHECK_IE  | 1: Interrupt enabled                                                  |
|   |                 | 0: Interrupt disabled                                                 |
|   | 2 RX_EDGE_IE    | RxD pin active edge interrupt enable.                                 |
| 2 |                 | 1: Interrupt enabled                                                  |
|   |                 | 0: Interrupt disabled                                                 |
|   |                 | The length of the interval segment generation bit.                    |
|   | BREAK_TRANS_SIZ | 1: transmit with 13-bit times length (1 bit more if DATA_MODE = 1     |
| 1 | E               | or STOP_MODE = 1, respectively)                                       |
|   | L               | 0: transmit with 10-bit times length (if DATA_MODE = 1 or             |
|   |                 | STOP_MODE = 1, add 1 bit time respectively)                           |
|   | BREAK_CHECK_EN  | Interval detection enable.                                            |
| 0 |                 | 1: Detect at 11-bit time length (if DATA_MODE = 1 or                  |
| U |                 | STOP_MODE = 1, add 1 bit time, respectively)                          |
|   |                 | 0: Not detected                                                       |

| Symbol         | Description                                             |
|----------------|---------------------------------------------------------|
|                | Interval segment detection interrupt flag, which is set |
|                | when BREAK_CHECK_EN=1 and the LIN abort                 |
|                | character is detectedThe characters of bit 11           |
| BREAK_CHECK_IF | /12/13 are detected as 0.                               |
|                | To clear this flag: The software writes 1 to this       |
|                | register bit directly.                                  |
|                | Active edge interrupt flag on RxD pin, which is set     |
|                | when there is an active edge on the RxD pin (falling    |
| RX_EDGE_IF     | if RXD_INV = 0, rising if RXD_INV = 1).                 |
|                | To clear this flag: The software writes a 1 to this     |
|                | register bit directly.                                  |
|                | Receiver activity flag that is set when the SCI         |
|                | receiver detects the start of a valid start bit and     |
| RX_ACTIVE_FLAG | cleared when the receiver detects an idle line. This    |
|                | status flag can be used to tell the MCU if it is        |
|                | currently receiving SCI characters. This bit is read-   |
|                | only.                                                   |
|                | Interval segment detection enable bit. When 0x00        |
|                | character is detected and STOP=0 and interval           |

Semiconductor

## BS9000AMxx

|                     | segment detection interrupt is failed, configure        |
|---------------------|---------------------------------------------------------|
|                     | delayed transmit interrupt. 1 means delayed             |
| RXDATA0_FRAME_CHECK | transmit receive interrupt and frame error interrupt    |
|                     | while 0 means to ignore this data reception. When       |
|                     | 10 consecutive "0" bits are received and the 11th       |
|                     | bit of the interval detection is "1", the frame error   |
|                     | flag is allowed to delay the transmission of this       |
|                     | data.                                                   |
|                     | interval segment detection interrupt enable, used to    |
| BREAK_CHECK_IE      | control the generation of interrupt signal.             |
|                     |                                                         |
|                     | RxD pin active edge interrupt enable, used to control   |
| RX_EDGE_IE          | the generation of interrupt signal.                     |
|                     |                                                         |
|                     | The size of the interval generation bits, used to       |
| BREAK_TRANS_SIZE    | select whether to send a 13-bit interval.               |
|                     |                                                         |
|                     | Interval segment detection circuit enable. When this    |
|                     | bit is set, if the STOP bit after the detection of 0x00 |
| BREAK_CHECK_EN      | characters still detects 0 characters, then it will     |
|                     | prevent the frame error and receive data register full  |
|                     | flag is set and continue to detect the next 0           |
|                     | characters.                                             |

| BREAK_TRANS_SIZE | DATA_MODE | STOP_MODE | Character length |
|------------------|-----------|-----------|------------------|
| 0                | 0         | 0         | 10 bit times     |
| 0                | 0         | 1         | 11 bit times     |
| 0                | 1         | 0         | 11 bit times     |
| 0                | 1         | 1         | 12 bit times     |
| 1                | 0         | 0         | 13 bit times     |
| 1                | 0         | 1         | 14 bit times     |
| 1                | 1         | 0         | 14 bit times     |
| 1                | 1         | 1         | 15 bit times     |

Table 14 .10Interval segment lengths

#### Note:

If normal data is detected after enabling interval segment detection, it will be received normally, including frame error and receive full will be set normally. Once 0x00 character is detected and



STOP=0, the interval segment will be detected first, and if the next bit is still 0, it will be determined as interval segment. If the next bit detects a rising edge, you can choose whether to delay transmitting the receive interrupt and frame error interrupt via the register RXDATA0\_FRAME\_CHECK. If this bit is not enabled, all data is received normally and frame error and receive full are set normally.

This register is also valid in LIN frame mode, where after BREAK\_CHECK\_EN is set, it will always detect the BREAK segment.

### 14.10.8 Interrupt Status Flag Register (SCI\_S1)

Address: 0xBB

| Bit No.          | 7              | 6            | 5            | 4             |
|------------------|----------------|--------------|--------------|---------------|
| Symbol           | TX_EMPTY_IF    | TX_FINISH_IF | RX_FULL_IF   | IDLE_IF       |
| Read/Write       | Read           | Read         | Read         | Read          |
| Po Initial Value | 0              | 0            | 0            | 0             |
| Bit No.          | 3              | 2            | 1            | 0             |
| Symbol           | RX_OVERFLOW_IF | NOISE_ERR_IF | FRAME_ERR_IF | PARITY_ERR_IF |
| Read/Write       | Read           | Read         | Read         | Read          |
| Po Initial Value | 0              | 0            | 0            | 0             |

| Bit No. | Symbol         | Description                                          |
|---------|----------------|------------------------------------------------------|
|         |                | Transmit a cache empty interrupt flag.               |
| 7       | TX_EMPTY_IF    | 1: Transmit cache is empty,                          |
|         |                | 0: Transmit cache is full, read-only                 |
|         |                | Transmit the finish interrupt flag.                  |
| 6       | TX_FINISH_IF   | 1: Transmit is completed and the transmitter is idle |
|         |                | 0: Transmitter is working, read only                 |
|         |                | Receive a full interrupt flag.                       |
| 5       | RX_FULL_IF     | 1: The receive cache is full.                        |
|         |                | 0: The receive cache is empty, read-only             |
|         |                | idle line interrupt flag.                            |
| 4       | IDLE_IF        | 1: Idle line detected.                               |
|         |                | 0: No idle line detected, read-only                  |
|         |                | Receive the overflow interrupt flag.                 |
| 3       | RX_OVERFLOW_IF | 1: Received overflow (new data lost).                |
|         |                | 0: No overflow, read-only                            |
|         |                | noise interrupt flag.                                |
| 2       | NOISE_ERR_IF   | 1: Noise detected.                                   |
|         |                | 0: No noise detected, read-only                      |



|   |               | frame error interrupt flag.           |
|---|---------------|---------------------------------------|
| 1 | FRAME_ERR_IF  | 1: Frame error detected               |
|   |               | 0: No frame error detected, read-only |
|   |               | Parity error interrupt flag.          |
| 0 | PARITY_ERR_IF | 1: Receiver parity error              |
|   |               | 0: Parity correct, read-only          |

| Symbol       | Description                                              |
|--------------|----------------------------------------------------------|
|              | The transmit buffer empty interrupt flag, which is set   |
|              | when the transmit data value is transferred from the     |
|              | transmit data buffer (tx_buffer) to the transmit shifter |
| TX_EMPTY_IF  | to make space in the buffer for the new character.       |
|              | The interrupt flag can be cleared by writing to the SCI  |
|              | data register (SCI_D) and writing to the                 |
|              | corresponding clear register CLK_TX_EMPTY_IF.            |
|              | Transmit finished interrupt flag, which is set when the  |
|              | transmitter has finished sending all data, idle          |
|              | characters and abort characters, and it is in the idle   |
|              | state.                                                   |
|              | The methods to clear this interrupt flag are: writing to |
| TX_FINISH_IF | SCI data register (SCI_D) to send new data; queuing      |
|              | idle characters by changing TRANS_ENABLE from            |
|              | 0 to 1; queuing abort characters by writing              |
|              | BREAK_TRANS_START to 1 and then clearing it to           |
|              | 0, and writing the corresponding clear register          |
|              | CLK_TX_FINISH_IF.                                        |
|              | Receive full interrupt flag, which is set when the       |
|              | character is transferred from the receive shifter to the |
| RX_FULL_IF   | receive data register (SCI_D).                           |
|              | The interrupt flag can be cleared by reading out the     |
|              | SCI data register and writing the corresponding clear    |
|              | register CLK_RX_FULL_IF.                                 |
|              | Idle line interrupt flag that is set IDLE after a period |
|              | of activity when the SCI receive line has been idle for  |
|              | a full character time. When IDLE_SEL=0, the              |
|              | receiver starts counting idle bit times after the start  |
|              | bit. Therefore, if the receive characters are all 1s,    |
|              | these bit times and the stop bit times count into the    |





|                | full character time that the receiver uses to detect the                       |
|----------------|--------------------------------------------------------------------------------|
|                | required logical high state (10/11/12 bit times,                               |
|                | depending on the DATA_MODE and STOP_MODE                                       |
|                | control bits) for an idle line. When IDLE_SEL=1, the                           |
| IDLE_IF        | receiver does not start counting the idle bit time until                       |
|                | after the stop bit. Therefore, the stop bit and any                            |
|                | logical high state bit time at the end of the previous                         |
|                | character will not count into the full character time of                       |
|                | the logical high state that the receiver uses to detect                        |
|                | an idle line.                                                                  |
|                | The interrupt flag is cleared by reading the SCI data                          |
|                | register and writing the corresponding clear register                          |
|                | CLK_IDLE_IF. After clearing this flag, it will not be set                      |
|                | again until a new character is received and                                    |
|                | RX FULL IF has been set.                                                       |
|                | Receive overflow interrupt flag, which is set when a                           |
|                | new serial character is received to be transferred to                          |
|                | the receive data register and the original received                            |
|                | character has not been read from SCI_D. In this                                |
| RX_OVERFLOW_IF | case, the new character is lost (all associated error                          |
|                | flags are lost).                                                               |
|                | The interrupt flag can be cleared by reading the SCI                           |
|                |                                                                                |
|                | data register and writing the corresponding clear register CLK RX OVERFLOW IF. |
|                |                                                                                |
|                | Noise interrupt flag, which is set when the receiver                           |
|                | samples 16 samples per bit, if the samples are                                 |
| NOISE_ERR_IF   | inconsistent then it is flagged (8 samples from RT3                            |
|                | to RT10 for the start bit, 3 samples from RT8 to RT10                          |
|                | for the other bits, including the stop bit).                                   |
|                | The interrupt flag can be cleared by reading out the                           |
|                | SCI data register and writing the corresponding clear                          |
|                | register CLK_NOISE_ERR_IF.                                                     |
|                | Frame error interrupt flag, which is set when the                              |
|                | receiver detects a logic 0 when it should be a stop                            |
| FRAME_ERR_IF   | bit, and the receive full interrupt flag is also set.                          |
|                | The interrupt flag can be cleared by reading out the                           |
|                | SCI data register and writing the corresponding clear                          |
|                | register CLK_FRAME_ERR_IF.                                                     |
|                | Parity error interrupt flag, which is set when parity is                       |
|                | enabled (PARITY_EN=1) and the parity bit in the                                |
|                |                                                                                |



| PARITY_ERR_IF | received character does not match the expected      |
|---------------|-----------------------------------------------------|
|               | parity value.                                       |
|               | To clear this interrupt flag, read out the SCI data |
|               | register and write the corresponding clear register |
|               | CLK_PARITY_ERR_IF.                                  |

The above three error interrupt flags only record the error of the data currently deposited in the data register, and the data update status is automatically updated. This register is not valid in LIN frame mode.

### 14.10.9 SCI Data Register (SCI\_D)

Address: 0xBC

| Bit No.          | 7  | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------------|----|------------|---|---|---|---|---|---|--|
| Symbol           |    | -          |   |   |   |   |   |   |  |
| Read/Write       |    | Read/Write |   |   |   |   |   |   |  |
| Po Initial Value | FF |            |   |   |   |   |   |   |  |

| Bit No. | Symbol | Description                                                             |
|---------|--------|-------------------------------------------------------------------------|
|         |        | SCI Data Register                                                       |
| 7~0     |        | Read returns the contents of the read-only receiving data buffer, write |
|         |        | goes to the write-only transmitting data buffer.                        |

One set of addresses corresponds to two sets of cache registers. Reads return the contents of the read-only receiving data buffer and write goes to the write-only transmitting data buffer. This register is not valid in LIN frame mode

### 14.10.10 SCI Interrupt Clear Register (SCI\_INT\_CLR)

Address: 0xBD

| Bit No.    | 7               | 6     | 5              | 4           |  |
|------------|-----------------|-------|----------------|-------------|--|
| Symbol     | CLK_TX_EMPTY_IF |       | CLK_RX_FULL_IF | CLK_IDLE_IF |  |
| Read/Writ  | Write           | Write | Write          | Write       |  |
| е          |                 |       |                |             |  |
| Po Initial | 0               | 0     | 0              | 0           |  |
| Value      |                 |       |                |             |  |
| Bit No.    | 3               | 2     | 1              | 0           |  |



| Symbol     | CLK_RX_OVERFLOW | CLK_NOISE_ERR_ | CLK_FRAME_ERR_ | CLK_PARITY_ERR_ |
|------------|-----------------|----------------|----------------|-----------------|
|            | _IF             | IF             | IF             | IF              |
| Read/Writ  | Write           | Write          | Write          | Write           |
| е          |                 |                |                |                 |
| Po Initial | 0               | 0              | 0              | 0               |
| Value      |                 |                |                |                 |

| Bit No. | Symbol                 | Description                                                                                                                          |
|---------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 7       | CLK_TX_EMPTY_IF        | Transmit buffer empty interrupt clear bit.<br>Writing 1 to this bit clears the corresponding interrupt, while write 0<br>is invalid. |
| 6       | CLK_TX_FINISH_IF       | Transmit finish interrupt clear bit.<br>Writing 1 to this bit clears the corresponding interrupt, while write 0<br>is invalid.       |
| 5       | CLK_RX_FULL_IF         | Receive full interrupt clear bit.<br>Writing 1 to this bit clears the corresponding interrupt, while write 0<br>is invalid.          |
| 4       | CLK_IDLE_IF            | Idle line interrupt clear bit.<br>Writing 1 to this bit clears the corresponding interrupt, while write 0<br>is invalid.             |
| 3       | CLK_RX_OVERFLO<br>W_IF | Receive overflow interrupt clear bit.<br>Writing 1 to this bit clears the corresponding interrupt, while write 0<br>is invalid.      |
| 2       | CLK_NOISE_ERR_IF       | Noise interrupt clear bit.<br>Writing 1 to this bit clears the corresponding interrupt, while write 0 is invalid.                    |
| 1       | CLK_FRAME_ERR_I<br>F   | Frame error interrupt clear bit.<br>Writing 1 to this bit clears the corresponding interrupt, while write 0<br>is invalid.           |
| 0       | CLK_PARITY_ERR_I<br>F  | Parity error interrupt clear bit.<br>Writing 1 to this bit clears the corresponding interrupt, while write 0<br>is invalid.          |

This register can only be written, not read. Write 1 to corresponding bit to clear the corresponding interrupt flag, while writing 0 is invalid. This register is only used as a backup and does not need to be configured for general applications.

This register is not valid in LIN frame mode.

#### 14.10.11 LIN Frame Timeout Configuration Register (LIN\_FRAME\_TIMEOUT)



| Bit No.          | 7 | 6                 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|---|-------------------|---|---|---|---|---|---|
| Symbol           |   | LIN_FRAME_TIMEOUT |   |   |   |   |   |   |
| Read/Write       |   | Read/Write        |   |   |   |   |   |   |
| Po Initial Value | 0 | 0 0 0 0 0 0 0 0   |   |   |   |   |   |   |

| Bit No. | Symbol | Description                                                                                                                                          |
|---------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7~0     |        | Frame timeout configuration. It requires to select the corresponding configuration according to the frame timeout mode and the number of data fields |

This register is used for frame timeout comparison, and the corresponding configuration is selected according to the mode of frame timeout and the number of data fields. The minimum is 34\*1.4, and the maximum 124\*1.4.

### 14.10.12 LIN Configuration Register 1 (LIN\_CTL1)

| Bit No.    | 7 | 6 | 5 | 4 | 3 | 2 | 1                | 0          |
|------------|---|---|---|---|---|---|------------------|------------|
| Symbol     | - | - | - | - | - | - | BIT_ERROR_IGNORE | FRAME_MODE |
| Read/Write | - | - | - | - | - | - | Read/Write       | Read/Write |
| Po Initial | - | - | - | - | - | - | 0                | 0          |
| Value      |   |   |   |   |   |   |                  |            |

| Bit No. | Symbol         | Description                                         |
|---------|----------------|-----------------------------------------------------|
| 1       | BIT_ERROR_IGNO | Transmission mode selection upon bit error.         |
| I       | RE             | 0: Terminate transmission, 1: Continue transmission |
| 0       |                | LIN frame mode enable.                              |
| 0       | FRAME_MODE     | 0: Disabled, 1: Enabled                             |

| Symbol           | Description                                    |
|------------------|------------------------------------------------|
|                  | Selects whether the transmission needs to be   |
| BIT_ERROR_IGNORE | terminated after a bit error is detected.      |
|                  | LIN frame mode enable selection. When enabled, |
|                  | UART mode is automatically disabled, only      |
| FRAME_MODE       | communicating according to the frame command   |
|                  | format in order.                               |



### 14.10.13 LIN Configuration Register 0 (LIN\_CTL0)

| Bit No.          | 7                 | 6          | 5                   | 4 |
|------------------|-------------------|------------|---------------------|---|
| Symbol           | FRAME_TIMEOUT_SEL |            | BREAK_DELIMITER_LEN |   |
| Read/Write       | Read/Wri          | te         | Read/Write          |   |
| Po Initial Value | 0                 |            | (                   | ) |
| Bit No.          | 3                 | 2          | 1                   | 0 |
| Symbol           | CHECKSUM_ENHANCED |            | DATA_NR             |   |
| Read/Write       | Read/Write        | Read/Write |                     |   |
| Po Initial Value | 0                 |            | 0                   |   |

| Bit No. | Symbol       | Description                                                            |
|---------|--------------|------------------------------------------------------------------------|
|         | FRAME_TIMEO  | Mode selection for frame timeout                                       |
| 7~6     | UT SEL       | 0: Frame timeout not enabled; 1: Frame timing.                         |
|         | UT_SEE       | 2: Frame header timing; 3: Frame response timing                       |
| 5~4     | BREAK_DELIMI | Interval configuration of Frame synchronization interval segment.      |
| 5-4     | TER_LEN      | 0~3: 2~5 interval bits                                                 |
|         |              | Checksum mode selection. Standard checksum does not contain PID,       |
|         |              | enhanced checksum contains PID, the protocol specifies that the        |
| 3       | CHECKSUM_E   | standard checksum (ID=0x3c/0x3d) is fixed for diagnostic frames. Here  |
| 5       | NHANCED      | the hardware determines it automatically, independent of this register |
|         |              | configuration.                                                         |
|         |              | 0: Standard checksum; 1: Enhanced checksum                             |
|         |              | LIN frame data segment length, 0~7: 1 to 8 bytes                       |
| 2~0     | DATA_NR      | The number of data that needs to be transmitted and received uniformly |
|         |              | by the application side before transmission starts.                    |

| Symbol              | Description                                           |  |
|---------------------|-------------------------------------------------------|--|
| FRAME_TIMEOUT_SEL   | Select the timing mode for the frame timeout.         |  |
|                     | Select the number of interval bits for the frame      |  |
| BREAK_DELIMITER_LEN | synchronization interval. 0~3: 2~5 interval bits, the |  |
|                     | default is 2 interval bits.                           |  |
|                     | Checksum mode selection, standard checksum            |  |
|                     | does not contain PID, enhanced checksum contains      |  |
|                     | PID, the protocol specifies that the standard         |  |
|                     | checksum (ID=0x3c/0x3d) is fixed for diagnostic       |  |
|                     | frames. Here the hardware automatically               |  |
| CHECKSUM_ENHANCED   | determines, independent of this register              |  |
|                     | configuration. 0: standard checksum; 1: enhanced      |  |



### 14.10.14 LIN Transfer Command Register (LIN\_LIN\_CMD)

| XRAM | SFR Address: 0x2083 |
|------|---------------------|
|      |                     |

| Bit No.    | 7           | 6          | 5           | 4          |
|------------|-------------|------------|-------------|------------|
| Symbol     |             | -          |             |            |
| Read/Write |             | -          |             |            |
| Po Initial |             | -          |             |            |
| Value      |             |            |             |            |
| Bit No.    | 3           | 2          | 1           | 0          |
| Symbol     | RX_RESPONSE | RX_HEADER  | TX_RESPONSE | TX_HEADER  |
| Read/Write | Read/Write  | Read/Write | Read/Write  | Read/Write |
| Po Initial | 0           | 0          | 0           | 0          |
| Value      |             |            |             |            |

| Bit No. | Symbol      | Description            |
|---------|-------------|------------------------|
| 3       | RX_RESPONSE | Receive frame response |
| 2       | RX_HEADER   | Receive frame header   |
| 1       | TX_RESPONSE | Sending frame response |
| 0       | TX_HEADER   | Sending frame header   |

| Symbol | Description                                        |
|--------|----------------------------------------------------|
|        | Software configures 1 to start receiving response, |
|        | after the STOP bit of the checksum is received to  |



| RX_RESPONSE | determine the response reception is complete, any       |
|-------------|---------------------------------------------------------|
|             | valid transmission is completed (one complete frame     |
|             | configuration) will have hardware to clear, if there is |
|             | an error not cleared.                                   |
|             | Software configures 1 to start receiving frame          |
|             | headers, determines frame header reception              |
|             | completion after the STOP bit of the PID is received,   |
|             | any valid transmission completion (one complete         |
|             | frame configuration) will have hardware to clear, if    |
|             | there is an error it is not cleared. Usually, the slave |
|             | node has to set two instructions RX_HEADER and          |
|             | <br>RX_RESPONSE, because the master node is             |
|             | expected to transmit the response to the slave node.    |
| RX_HEADER   | After receiving the PID, the slave node can set         |
|             | TX_RESPONSE, which has a higher priority.               |
|             | BREAK is always in detection, with or without a         |
|             | receive frame header command, and after BREAK is        |
|             | detected (BREAK_CHECK_IF), the hardware                 |
|             | checks the receive frame header command before          |
|             | entering the synchronization segment, and when the      |
|             | command is 0, the software has at least 11 bits to      |
|             | reset the receive frame header command before the       |
|             | next BREAK (BREAK_CHECK_IF). This way,                  |
|             | BREAK is not lost.                                      |
|             | Software configures 1 to start transmitting response,   |
|             | determine transmission completion after the STOP        |
|             | bit of the transmit checksum is completed, any valid    |
| TX_RESPONSE | transmission completion (one complete frame             |
|             | configuration) will have hardware to clear. If there is |
|             | an error, it will immediately clear to zero.            |
|             | Software configures 1 to start sending frame            |
|             | headers, determine transmission completion after        |
|             | sending STOP bit of PID, any valid transmission         |
| TX_HEADER   | completion (one complete frame configuration) will      |
|             | be hardware cleared, if there is an error, it will      |
|             | immediately clear to 0.                                 |



# 14.10.15 LIN Synchronization Section Baud Rate Count Period Register (LIN\_SYNC\_CO UNTER)

XRAM\_SFR Address: 0x2084

| Bit No.          | 7 | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|---|------|---|---|---|---|---|---|
| Symbol           |   | -    |   |   |   |   |   |   |
| Read/Write       |   | Read |   |   |   |   |   |   |
| Po Initial Value |   | 0    |   |   |   |   |   |   |

| Bit No. | Symbol | Description                                                                                                                          |
|---------|--------|--------------------------------------------------------------------------------------------------------------------------------------|
|         |        | Read-only, used to record the baud rate counting period of the synchronous segment, if there is no deviation, it should be 8*16=128. |
| 7~0     |        | The deviation allowed in the frame protocol is 0.5% at the transmitter                                                               |
|         |        | side and 14% at the receiver side, and the deviation allowed in the                                                                  |
|         |        | synchronous segment is within [106, 152] according to this calculation.                                                              |

### 14.10.16 LIN Status Register (LIN\_STATUS)

| Bit No.    | 7                                   | 6                     | 5          | 4        |
|------------|-------------------------------------|-----------------------|------------|----------|
| Symbol     | TX_HEADER_BREAK<br>_DELIMITER_ERROR | TX_HEADER_BREAK_ERROR | RX_DONE    | TX_DONE  |
| Read/Write | Read                                | Read                  | Read       | Read     |
| Po Initial | 0                                   | 0                     | 0          | 0        |
| Value      |                                     |                       |            |          |
| Bit No.    | 3                                   | 2                     | 1          | 0        |
| Symbol     | RX_BUSY                             | TX_BUSY               | RX_DATA0_F | HEADER_R |
|            |                                     |                       | RAME_ERRO  | ESPONSE  |
|            |                                     |                       | R          |          |
| Read/Write | Read                                | Read                  | Read       | Read     |
| Po Initial | 0                                   | 0                     | 0          | 0        |
| Value      |                                     |                       |            |          |

| Bit No. | Symbol                                  | Description                                                                                                                             |
|---------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 7       | TX_HEADER_BRE<br>AK_DELIMITER_E<br>RROR | A "0" is detected when the host sends the break delimiter of the frame header and is cleared when the current instruction is completed. |
| 6       | TX_HEADER_BRE                           | A "1" is detected when the host sends the BREAK of the frame header                                                                     |



|   | AK ERROR                 | and is cleared when the current instruction is completed.                                     |
|---|--------------------------|-----------------------------------------------------------------------------------------------|
|   |                          | Receive done bit, set after received the instruction and cleared to 0                         |
|   |                          | upon a new command.                                                                           |
| 5 | RX_DONE                  | - RX_HEADER, RX_RESPONSE.                                                                     |
|   |                          | - TX_HEADER, RX_RESPONSE.                                                                     |
|   |                          | Transmit done bit, set after transmit the instruction and cleared to 0                        |
|   |                          | upon a new command.                                                                           |
| 4 | TX_DONE                  | - TX HEADER.                                                                                  |
| - | IX_DONE                  | - TX_HEADER, TX_RESPONSE.                                                                     |
|   |                          | - RX_HEADER, TX_RESPONSE.                                                                     |
|   |                          | Receiver in busy state, set at the beginning of the receive frame                             |
| 3 | RX_BUSY                  | header and frame response, cleared when the current command is                                |
| 5 | 3 102_0001               | completed or there is an error.                                                               |
|   |                          | Transmitter busy state, set at the beginning of the transmitting frame                        |
| 2 | 2 TX_BUSY                | header and frame response, cleared at the end of the current                                  |
| 2 | 17_0001                  | command or if there is an error.                                                              |
|   |                          | The frame error flag for the first data in the frame response, which is                       |
|   |                          | set when the first data received is 0x00 and the STOP bit detects 0                           |
|   | RX_DATA0_FRAM<br>E_ERROR | (only after receiving the frame header command), it will clear when the                       |
|   |                          | falling edge of the START bit of the synchronization segment of the                           |
|   |                          | BREAK segment is finished receiving. This bit, together with the                              |
|   |                          | receive response frame error interrupt flag, distinguishes whether                            |
| 1 |                          | there is no response or an error response or a correct response is                            |
|   |                          | received. This flag does not abort the message transmission. When it                          |
|   |                          | is set, the description is that this frame does not response and needs                        |
|   |                          | no handling.RX RESPONSE FRAME ERROR is set, Description is                                    |
|   |                          |                                                                                               |
|   |                          | an error and needs to be processed, Description is a correct response<br>when neither is set. |
|   |                          | The frame header response status, set at the beginning of the frame                           |
|   |                          | response and cleared at the end of the frame response. To be                                  |
| 0 | HEADER_RESPO             | combined with TX_BUSY=1 or RX_BUSY=1.                                                         |
|   | NSE                      | 0: Frame header transmission in progress.                                                     |
|   |                          |                                                                                               |
|   |                          | 1: Frame response in transmission.                                                            |

# 14.10.17 LIN Data Field Count Value Register (LIN\_DATA\_IDX)

| Bit No.    | 7 | 6 | 5 | 4 | 3 | 2  | 1  | 0 |
|------------|---|---|---|---|---|----|----|---|
| Symbol     | - | - | - | - |   | -  | -  |   |
| Read/Write | - | - | - | - |   | Re | ad |   |



| Po Initial Value | - | - | - | - | 0 |
|------------------|---|---|---|---|---|

| Bit No. | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                       |
|---------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3~0     |        | Description<br>Data field count value, which is cleared to 0 at the beginning of the<br>transmit/receive frame header, indicating which byte number of data<br>currently being transmitted.<br>0: No bytes transferred.<br>1: 1 byte Transferred.<br><br>7: 1~7 bytes transferred.<br>8: 1~8 bytes transferred.<br>9: 1~8 bytes and checksum bytes transferred.<br>10~15: Unused. |



### 14.10.18 LIN Interrupt Status Register 1 (LIN\_INTR1)

| Bit No.    | 7               | 6                     | 5          | 4          |
|------------|-----------------|-----------------------|------------|------------|
|            | RX RESPONSE CHE | RX_RESPONSE_FRAME_ERR | RX_HEADER_ | RX_HEADE   |
| Symbol     | CKSUM ERROR     | OR                    | PARITY_ERR | R_SYNC_E   |
|            |                 | OR                    | OR         | RROR       |
| Read/Write | Read/Write      | Read/Write            | Read/Write | Read/Write |
| Po Initial | 0               | 0                     | 0          | 0          |
| Value      |                 |                       |            |            |
| Bit No.    | 3               | 2                     | 1          | 0          |
| Symbol     | RX_HEADER_FRAME | TX_RESPONSE_BIT_ERROR | TX_HEADER_ | TIMEOUT    |
|            | _ERROR          |                       | BIT_ERROR  |            |
| Read/Write | Read/Write      | Read/Write            | Read/Write | Read/Write |
| Po Initial | 0               | 0                     | 0          | 0          |
| Value      |                 |                       |            |            |

| Bit No. | Symbol                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7       | RX_RESPONSE_C<br>HECKSUM_ERRO<br>R | Hardware sets the software to write 1 to clear, while writing 0 has no<br>effect.<br>Receive response checksum error, which will be reset when the<br>calculated checksum does not match the received one.<br>Ongoing info transmission is aborted and the transmit command is set<br>to 0.                                                                                                                                              |
| 6       | RX_RESPONSE_F<br>RAME_ERROR        | Hardware sets the software to write 1 to clear, while writing 0 has no effect.<br>Receive response frame error, which will be reset when there is abnormal data in the received START/STOP. If a 0 is received, this bit is not used to determine the stop bit for the first data after the RX_HEADER command,and instead the RX_DATA0_FRAME_ERROR is used.<br>Ongoing info transmission is aborted and the transmit command is set to 0 |
| 5       | RX_HEADER_PAR<br>ITY_ERROR         | Hardware sets the software to write 1 to clear, while writing 0 has no effect.<br>Receive frame header PID checksum error, which is performed automatically in LIN frame mode, independent of the parity enable bit in uart mode. Ongoing info transmission is aborted and the transmit command is set to 0                                                                                                                              |
| 4       | RX_HEADER_SYN<br>C_ERROR           | Hardware sets the software to write 1 to clear, while writing 0 has no effect.                                                                                                                                                                                                                                                                                                                                                           |



|   |                | Receive frame header synchronous segment error, set if the syncing           |
|---|----------------|------------------------------------------------------------------------------|
|   |                | segment is not received within the specified time (SYNC_COUNTER =            |
|   |                | [106, 152]). The ongoing info transmission is aborted and the transmit       |
|   |                | command is set to 0                                                          |
|   |                | Hardware sets the software to write 1 to clear, while writing 0 has no       |
|   |                | effect.                                                                      |
| 3 | RX_HEADER_FRA  | Receive frame header frame error, which is set when there is abnormal        |
| 5 | ME_ERROR       | data in the received START/STOP.                                             |
|   |                | Ongoing info transmission is aborted and the transmit command is set         |
|   |                | to 0                                                                         |
|   |                | Hardware sets the software to write 1 to clear, while writing 0 has no       |
|   |                | effect.                                                                      |
|   |                | Send response bit error, set when the levels of transmit line and receive    |
|   |                | line do not match. It is used to transmit all positions of the response data |
| 2 | TX_RESPONSE_B  | byte and checksum (START,DATA,STOP).                                         |
|   | IT_ERROR       | When the bit error ignore function (BIT_ERROR_IGNORE=1) is                   |
|   |                | configured, this error does not cause the info transmission to be            |
|   |                | aborted, otherwise the ongoing info transmission is aborted and the          |
|   |                | send command is set to 0                                                     |
|   |                | Hardware sets the software to write 1 to clear, while writing 0 has no       |
|   |                | effect.                                                                      |
|   |                | Transmit frame header bit error, set when transmit line and receive line     |
|   |                | levels do not match. It is used to send all positions of the interval        |
| 1 | TX_HEADER_BIT_ | segment, sync byte and PID of the frame header (START,DATA,STOP).            |
|   | ERROR          | When the bit error ignore function (BIT_ERROR_IGNORE=1) is                   |
|   |                | configured, this error does not cause the info transmission to be            |
|   |                | aborted, otherwise the ongoing info transmission is aborted and the          |
|   |                | send command is set to 0.                                                    |
|   |                | Hardware sets the software to write 1 to clear, while writing 0 has no       |
|   |                | effect.                                                                      |
| 0 | TIMEOUT        | Timeout error, three configuration timeout calculation methods, set after    |
|   |                | timeout.                                                                     |
|   |                |                                                                              |

### 14.10.19 LIN Interrupt Status Register 2 (LIN\_INTR2)

| Bit No.    | 7 | 6          | 5 | 4           |
|------------|---|------------|---|-------------|
| Symbol     |   |            |   | RX_HEADER_S |
| Symbol     |   | -          |   | YNC_DONE    |
| Read/Write |   | Read/Write |   |             |



| Po Initial |               | -              |                | 0           |
|------------|---------------|----------------|----------------|-------------|
| Value      |               |                |                |             |
| Bit No.    | 3             | 2              | 1              | 0           |
| Symbol     | RX_RESPONSE_D | RX_HEADER_DONE | TX_RESPONSE_DO | TX_HEADER_D |
|            | ONE           |                | NE             | ONE         |
| Read/Write | Read/Write    | Read/Write     | Read/Write     | Read/Write  |
| Po Initial | 0             | 0              | 0              | 0           |
| Value      |               |                |                |             |

| Bit No. | Symbol             | Description                                                                    |
|---------|--------------------|--------------------------------------------------------------------------------|
| 4       | RX_HEADER_SYNC     | Hardware sets the software to write 1 to clear, while writing 0 has no effect. |
| 4       | _DONE              | The synchronous segment of Frame received header completion                    |
|         |                    | flag. Set after receiving the STOP bit.                                        |
|         |                    | Hardware set software to write 1 to clear, while writing 0 has no              |
| 3       | RX_RESPONSE_D      | effect.                                                                        |
| 5       | ONE                | Receive frame response completion flag. This bit can only be set if            |
|         |                    | no receive response error is triggered                                         |
|         |                    | Hardware sets software to write 1 clear, while writing 0 has no effect.        |
| 2       | RX_HEADER_DON<br>E | Receive frame header completion flag. Set after the full frame                 |
|         |                    | header has been received.                                                      |
| 1       | TX_RESPONSE_DO     | Hardware sets software to write 1 clear, while writing 0 has no effect.        |
|         | NE                 | Transmit frame response completion flag.                                       |
| 0       |                    | Hardware sets software to write 1 clear, while writing 0 has no effect.        |
| 0       | TX_HEADER_DONE     | Transmit frame header completion flag.                                         |

### 14.10.20 LIN Interrupt Enable Register 1 (LIN\_INTR1\_IE)

| Bit No.          | 7             | 6                  | 5             | 4          |
|------------------|---------------|--------------------|---------------|------------|
|                  | RX_RESPONSE_C | Т                  | RX HEADER PA  | RX_HEADE   |
| Symbol           | HECKSUM_ERROR | RX_RESPONSE_FRAME_ | RITY ERROR IE | R_SYNC_E   |
|                  | _IE           | ERROR_IE           | KITT_EKKOK_IE | RROR_IE    |
| Read/Write       | Read/Write    | Read/Write         | Read/Write    | Read/Write |
| Po Initial Value | 0             | 0                  | 0             | 0          |
| Bit No.          | 3             | 2                  | 1             | 0          |
| Symbol           | RX_HEADER_FRA | TX_RESPONSE_BIT_ER | TX_HEADER_BIT | TIMEOUT_I  |
|                  | ME_ERROR_IE   | ROR_IE             | _ERROR_IE     | E          |
| Read/Write       | Read/Write    | Read/Write         | Read/Write    | Read/Write |
| Po Initial Value | 0             | 0                  | 0             | 0          |



| Bit No. | Symbol           | Description                                                  |
|---------|------------------|--------------------------------------------------------------|
|         | RX RESPONSE CHE  | Receive response checksum error interrupt enable.            |
| 7       | CKSUM_ERROR_IE   | 1: Interrupt enabled.                                        |
|         |                  | 0: Interrupt disabled.                                       |
|         | RX RESPONSE FRA  | Response frame received error interrupt enable.              |
| 6       | ME ERROR IE      | 1: Interrupt enabled.                                        |
|         |                  | 0: Interrupt disabled.                                       |
|         | RX_HEADER_PARITY | Receive header PID error interrupt enable.                   |
| 5       | _ERROR_IE        | 1: Interrupt enabled.                                        |
|         |                  | 0: Interrupt disabled.                                       |
|         |                  | Synchronous segment error interrupt of Frame received header |
| 4       | RX_HEADER_SYNC_  | enable.                                                      |
| 4       | ERROR_IE         | 1: Interrupt enabled.                                        |
|         |                  | 0: Interrupt disabled.                                       |
|         | RX HEADER FRAME  | Frame received header error interrupt enable.                |
| 3       |                  | 1: Interrupt enabled.                                        |
|         |                  | 0: Interrupt disabled.                                       |
|         | TX RESPONSE BIT  | Transmit response bit error interrupt enable.                |
| 2       |                  | 1: Interrupt enabled.                                        |
|         | ERROR_IE         | 0: Interrupt disabled.                                       |
|         | TX HEADER BIT ER | Transmit frame header bit error interrupt enable.            |
| 1       | ROR_IE           | 1: Interrupt enabled.                                        |
|         | KOK_IE           | 0: Interrupt disabled.                                       |
|         |                  | Timeout error interrupt enable.                              |
| 0       | TIMEOUT_IE       | 1: Interrupt enabled.                                        |
|         |                  | 0: Interrupt disabled.                                       |

### 14.10.21 LIN Interrupt Enable Register 2 (LIN\_INTR2\_IE)

| Bit No.    | 7              | 6                 | 5         | 4        |  |  |  |  |
|------------|----------------|-------------------|-----------|----------|--|--|--|--|
|            |                |                   |           | RX_HEADE |  |  |  |  |
| Symbol     | mbol -         |                   |           |          |  |  |  |  |
|            |                |                   |           | ONE_IE   |  |  |  |  |
| Read/Write |                | Read/Write        |           |          |  |  |  |  |
| Po Initial |                | -                 |           | 0        |  |  |  |  |
| Value      |                |                   |           |          |  |  |  |  |
| Bit No.    | 3              | 2                 | 1         | 0        |  |  |  |  |
| Symbol     | RX_RESPONSE_DO | RX_HEADER_DONE_IE | TX_RESPON | TX_HEADE |  |  |  |  |



|            | NE_IE      |            | SE_DONE_IE | R_DONE_IE  |
|------------|------------|------------|------------|------------|
| Read/Write | Read/Write | Read/Write | Read/Write | Read/Write |
| Po Initial | 0          | 0          | 0          | 0          |
| Value      |            |            |            |            |

| Bit No. | Symbol                | Description                                              |
|---------|-----------------------|----------------------------------------------------------|
|         | RX HEADER SYNC        | Frame received header to synchronously interrupt enable. |
| 4       | DONE IE               | 1: Interrupt enabled.                                    |
|         | DONE_IE               | 0: Interrupt disabled.                                   |
|         | RX_RESPONSE_DO        | Response received to interrupt enable.                   |
| 3       |                       | 1: Interrupt enabled.                                    |
|         | NE_IE                 | 0: Interrupt disabled.                                   |
|         | RX_HEADER_DONE_       | Frame Received header to interrupt enable.               |
| 2       |                       | 1: Interrupt enabled.                                    |
|         | IE                    | 0: Interrupt disabled.                                   |
|         | TY RESPONSE DON       | Frame response transmitted to interrupt enable.          |
| 1       | TX_RESPONSE_DON       | 1: Interrupt enabled.                                    |
|         | E_IE                  | 0: Interrupt disabled.                                   |
|         |                       | Frame transmitted header to interrupt enable.            |
| 0       | TX_HEADER_DONE_<br>IE | 1: Interrupt enabled.                                    |
|         | IC                    | 0: Interrupt disabled.                                   |

### 14.10.22 LIN Transmit Register Description

When configuring the transmit data register, it needs to be done before configuring the transmit command, and no further configuration is allowed during transmission.

#### 14.10.22.1 LIN Transmit PID Register (LIN\_TX\_PID)

| XRAM | SFR | Address: | 0x2090 |
|------|-----|----------|--------|
|      |     |          |        |

| Bit No.          | 7 | 6 | 5          | 4 | 3 | 2 | 1 | 0 |
|------------------|---|---|------------|---|---|---|---|---|
| Symbol           | - | - | -          |   |   |   |   |   |
| Read/Write       | - | - | Read/Write |   |   |   |   |   |
| Po Initial Value | - | - | 0          |   |   |   |   |   |

| Bit No. | Symbol | Description                                                                         |
|---------|--------|-------------------------------------------------------------------------------------|
|         |        | Store PIDs transmitted in LIN frame mode                                            |
| 5~0     |        | When transmitting, It is calculated automatically according to the written bit 0 to |
|         |        | 5 as follows:                                                                       |



| bit6:P0 = ID0⊕ ID1⊕ ID2⊕ ID4     |
|----------------------------------|
| bit7:P1 = ~ (ID1⊕ ID3⊕ ID4⊕ ID5) |

#### 14.10.22.2 LIN Transmit Data Register (LIN\_TX\_DATA)

XRAM\_SFR Address: 0x2091~0x2098

| Bit No.          | 7 | 6            | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|------------------|---|--------------|---|---|---|---|---|---|--|--|--|
| Symbol           |   | LIN_TX_DATAx |   |   |   |   |   |   |  |  |  |
| Read/Write       |   | Read/Write   |   |   |   |   |   |   |  |  |  |
| Po Initial Value |   | 0            |   |   |   |   |   |   |  |  |  |

#### LIN\_TX\_DATAx, where x: 1~8

| Bit No. | Symbol       | Description                                                     |  |  |  |  |
|---------|--------------|-----------------------------------------------------------------|--|--|--|--|
| 7~0     | LIN_TX_DATAx | Stores the transmitted data field and byte X in LIN frame mode, |  |  |  |  |
|         |              | where x ranges from 1 to 8.                                     |  |  |  |  |

#### 14.10.22.3 LIN Transmit Checksum Register (LIN\_TX\_ CHECKSUM)

XRAM\_SFR Address: 0x2099

| Bit No.          | 7               | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------------|-----------------|------------|---|---|---|---|---|---|--|
| Symbol           | LIN_TX_CHECKSUM |            |   |   |   |   |   |   |  |
| Read/Write       |                 | Read/Write |   |   |   |   |   |   |  |
| Po Initial Value |                 | 0          |   |   |   |   |   |   |  |

| Bit No. | Symbol              | Description                                      |
|---------|---------------------|--------------------------------------------------|
| 7~0     | LIN_TX_CHECKSU<br>M | Store the transmitted checksum in LIN frame mode |

#### 14.10.23 LIN Receive Register Description

Received data is not lost after the SCI module is disabled.

#### 14.10.23.1 LIN Receive PID Register (LIN\_RX\_PID)



| Bit No.          | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|------------------|---|------------|---|---|---|---|---|---|--|--|
| Symbol           |   | LIN_RX_PID |   |   |   |   |   |   |  |  |
| Read/Write       |   | Read       |   |   |   |   |   |   |  |  |
| Po Initial Value |   | 0          |   |   |   |   |   |   |  |  |

| Bit No. | Symbol     | Description                              |
|---------|------------|------------------------------------------|
| 7~0     | LIN_RX_PID | Store the received PID in LIN frame mode |

#### 14.10.23.2 LIN Receive Data Register (LIN\_RX\_DATA)

XRAM\_SFR Address: 0x20A1~0x20A8

| Bit No.          | 7 | 6            | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|------------------|---|--------------|---|---|---|---|---|---|--|--|--|
| Symbol           |   | LIN_RX_DATAx |   |   |   |   |   |   |  |  |  |
| Read/Write       |   | Read         |   |   |   |   |   |   |  |  |  |
| Po Initial Value |   | 0            |   |   |   |   |   |   |  |  |  |

LIN\_RX\_DATAx, where x: 1 to 8.

| Bit No. | Symbol       | Description                                                          |
|---------|--------------|----------------------------------------------------------------------|
| 7~0     | LIN_RX_DATAx | Stores the received data field and byte x in LIN frame mode, where x |
|         |              | ranges from 1 to 8.                                                  |

#### 14.10.23.3 LIN Receive Checksum Register (LIN\_RX\_CHECKSUM)

| Bit No.          | 7 | 6               | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|------------------|---|-----------------|---|---|---|---|---|---|--|--|--|
| Symbol           |   | LIN_RX_CHECKSUM |   |   |   |   |   |   |  |  |  |
| Read/Write       |   | Read            |   |   |   |   |   |   |  |  |  |
| Po Initial Value | 0 |                 |   |   |   |   |   |   |  |  |  |

| Bit No. | Symbol          | Description                                   |
|---------|-----------------|-----------------------------------------------|
| 7~0     | LIN_RX_CHECKSUM | Store the received checksum in LIN frame mode |



# 15 **Programming and Debugging**

FLASH uses a two-wire serial command Programming method. In addition to the power and ground, 2 IOs are used for the Programming clock line (PGC) and data line (PGD).

### **15.1 SWE Circuit Connection**

Two-wire Programming and single-wire debugging. During the emulation debugging, you need to connect one wire of SWE. In the SWE debugging mode, the IO function of the SWE is masked, it is recommended not to configure other functions of the SWE debugging IO port to avoid affecting the SWE debugging function.



Table 15 .1 SWE circuit connection reference diagram

### 15.2 Capacitive TouchKey Data Assisted Programming &

### debugging

Connect the four wires of chip PGC (PGC1/PGC2), PGD (PGD1/PGD2), VCC and VSS, and when you enter the Programming interface, select the corresponding model of chip, open the compiled HEX file, click on the one-click write FLASH and wait for the Programming to complete.

When you enter the debugging interface, first burn the HEX file with debugging data sending mode, and click Start Debug to view the button data.

**Note:** Refer to the Capacitive button Programming/debugging guide for specific operation descriptions.







Table 0.1 BS9000AMxx Programming Wiring Diagram

| The low of the second | otive MCU-V1.0.0.0<br>Program Debug |                                                                                                                | × |
|-----------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------------|---|
|                       | Trofram Debd&                       |                                                                                                                |   |
|                       | Program                             | Messages                                                                                                       |   |
| (BYD)                 | open file                           | 无USB设备!                                                                                                        |   |
| 比亚迪半导体                | Download                            |                                                                                                                |   |
| IN LOW OF             | Read Flash                          |                                                                                                                |   |
| 接线说明                  | Write EEPROM                        |                                                                                                                |   |
| 通信方式                  | Read EEPROM                         |                                                                                                                |   |
| ● USB通信               | Read Configs                        |                                                                                                                |   |
| anguage select        | Power                               |                                                                                                                |   |
| English 🗸 🗸           | 37                                  |                                                                                                                |   |
| hip select            | 57                                  |                                                                                                                |   |
| BS9000AMXX 🗸          | Power off                           |                                                                                                                |   |
|                       | Others                              |                                                                                                                |   |
| hip type              | Clear                               |                                                                                                                |   |
| BS9000AM20-QB: 🗸      |                                     |                                                                                                                |   |
| urning select         | Erase EEPRO                         |                                                                                                                |   |
| Burning Alone 🧹       | Reset                               |                                                                                                                |   |
|                       | Encrypt                             | Operation Messages Write Buf Write EEPROM Read EEPROM                                                          |   |
|                       | Unlock                              | An address of the second s |   |
|                       | MP                                  |                                                                                                                |   |
|                       | Create *. tk                        |                                                                                                                |   |
|                       |                                     |                                                                                                                |   |
|                       |                                     |                                                                                                                | > |

Table 15 .3 Programming Interface



# 16 CPU Instructional System

### **16.1** Instruction Code

The instructions of BS9000AMxx are divided into 1-byte instruction, 2-byte instructions and 3-byte instructions.

**1-byte instruction**: 1-byte instruction consists of an 8-bit binary code. There is only instruction opcode in the instruction, no instruction operand or instruction operand is implied in the instruction opcode. There are 49 instructions in this category.

**2-byte instructions**: 2-byte instructions consist of two bytes, one for the opcode and the other for the operand (or the address of the operand), which are stored sequentially in program memory. There are 46 instructions in this class.

**3-byte instructions**: 3-byte instructions consist of a one-byte instruction opcode and a two-byte operand (or the address of the operand). There are 16 instructions in this class.

### **16.2** Instruction Set

In order to describe the instructions more clearer and easier, some Symbols are used in the instructions, of which meanings are as follows.

| addr 11      | Low 11-bit address                                                   |
|--------------|----------------------------------------------------------------------|
| addr 16      | 16-bit address                                                       |
| direct       | Direct addressable, 8-bit internal data and address (including SFRs) |
| bit          | Bit Address                                                          |
| #data        | 8-bit immediate number                                               |
| #data16      | 16-bit immediate number                                              |
| rel          | 8-bit relative displacement with Symbol                              |
| n            | digit 0 to 7                                                         |
| Rn           | R0 to R7 working registers of current register set                   |
| i            | Digit 0, 1                                                           |
| Ri           | Working registers R0, R1                                             |
| @            | Register indirect addressing                                         |
| <i>←</i>     | Data transfer direction                                              |
| ^            | Logic "with"                                                         |
| V            | Logic "or"                                                           |
| $\oplus$     | Logic "Xor"                                                          |
| $\checkmark$ | Has an effect on the flag bits                                       |
| ×            | No effect on flag bits                                               |



#### Table 16 .1 CPU Instruction Symbol

The table 16.2 shows assembly instructions, function of each instruction, the number of bytes occupied, the instruction execution cycle, and the effect on the corresponding flag bits that provided for use.

|                  |                  |                          | Ef           | fect or   | n flag l | oits   | Number       | Number      |
|------------------|------------------|--------------------------|--------------|-----------|----------|--------|--------------|-------------|
| Mnemor           | nic sign         | Function                 | Р            | ov        | AC       | CY     | of bytes     | of cycles   |
|                  | Rn               | A←(Rn)                   | $\checkmark$ | ×         | ×        | ×      | 1            | 1           |
|                  | direct           | A←(direct)               | $\checkmark$ | ×         | ×        | ×      | 2            | 1           |
| MOV A            | @Ri              | A←((Ri))                 | $\checkmark$ | ×         | ×        | ×      | 1            | 1           |
|                  | #data            | A←data                   | $\checkmark$ | ×         | ×        | ×      | 2            | 1           |
|                  | A                | Rn←(A)                   | ×            | ×         | ×        | ×      | 1            | 1           |
| MOV Rn           | direct           | Rn←(direct)              | ×            | ×         | ×        | ×      | 2            | 2           |
|                  | #data            | Rn←data                  | ×            | ×         | ×        | ×      | 2            | 1           |
|                  | A                | direct1←(A)              | ×            | ×         | ×        | ×      | 2            | 1           |
| MOV direct1      | Rn               | direct1←(Rn)             | ×            | ×         | ×        | ×      | 2            | 2           |
|                  | direct2          | direct1←(direct2)        | ×            | ×         | ×        | ×      | 3            | 2           |
| MOV ( alian at   | @Ri              | direct←((Ri))            | ×            | ×         | ×        | ×      | 2            | 2           |
| MOV direct       | #data            | direct←data              | ×            | ×         | ×        | ×      | 3            | 2           |
|                  | A                | (Ri)←(A)                 | ×            | ×         | ×        | ×      | 1            | 1           |
| MOV @Ri          | direct           | (Ri)←(direct)            | ×            | ×         | ×        | ×      | 2            | 2           |
|                  | #data            | (Ri)←data                | ×            | ×         | ×        | ×      | 2            | 1           |
| 16-bit data trar | nsfer instructio | n                        |              | ·         |          |        |              |             |
| mnomonio oigi    |                  | Function                 | Effe         | ct on fla | ag bits  | Number | Number       |             |
| mnemonic sigr    | 1                | Function                 | Р            | OV        | AC       | CY     | of bytes     | of cycles   |
| MOV DPTR,#c      | lata16           | DPTR←data16              |              | ×         | ×        | ×      | 3            | 2           |
| External data t  | ransfer and ta   | ble lookup instructions  |              |           |          |        |              |             |
| mnomonio oigi    |                  | Function                 | Effe         | ct on fla | ag bits  |        | Number       | Number      |
| mnemonic sigr    | 1                | FUNCTION                 | Р            | OV        | AC       | CY     | of bytes     | of cycles   |
| MOVX @DP         | TR,A             | (DPTR)←(A)               | ×            | ×         | ×        | ×      | 1            | 2           |
| MOVC A,          | @A+DPTR          | A←((A)+(DPTR))           | $\checkmark$ | ×         | ×        | ×      | 1            | 2           |
| WOVCA,           | @A+PC            | A←((A)+(PC))             | $\checkmark$ | ×         | ×        | ×      | 1            | 2           |
| MOVX A, @DPTR    |                  | A←(DPTR)                 | $\checkmark$ | ×         | ×        | ×      | 1            | 2           |
| Note: The num    | ber of cycles a  | nd the number of bytes o | of the MO    | VX inst   | ruction  | can be | e configured | via registe |
| CKCON<2:0>.      |                  |                          |              |           |          |        |              |             |
| Exchange Inst    | ructions         |                          |              |           |          |        |              |             |
| mnomonio cia     |                  | Eurotion                 | Effe         | ct on fla | ag bits  |        | Number       | Number      |
| mnemonic sign    |                  | Function                 | Р            | OV        | AC       | CY     | of bytes     | of cycles   |



|                |                |                                                                               |              |                     |              |              | 2000     |           |
|----------------|----------------|-------------------------------------------------------------------------------|--------------|---------------------|--------------|--------------|----------|-----------|
|                | Rn             | (Rn)←(A)                                                                      |              | ×                   | ×            | ×            | 1        | 2         |
| XCH A,         | direct         | (A)←(direct)                                                                  | $\checkmark$ | ×                   | ×            | ×            | 2        | 1         |
|                | @Ri            | (A)←((Ri))                                                                    | ×            | ×                   | ×            | ×            | 1        | 1         |
| XCHD A,@Ri     |                | (A)3~0~((Ri))3~0                                                              | $\checkmark$ | ×                   | ×            | ×            | 1        | 1         |
| SWAP A         |                | (A)7-4~(A)3-0                                                                 | $\checkmark$ | ×                   | ×            | ×            | 1        | 1         |
| Arithmetic ope | eration instru | ction                                                                         |              |                     |              |              |          |           |
| manania aia    | 2              | Function                                                                      | Effec        | Effect on flag bits |              |              | Number   | Number    |
| mnemonic sign  |                | FUNCTION                                                                      | Р            | OV                  | AC           | CY           | of bytes | of cycles |
|                | Rn             | A←(A)+(Rn)                                                                    | $\checkmark$ | $\checkmark$        | $\checkmark$ |              | 1        | 1         |
|                | direct         | A←(A)+(direct)                                                                | $\checkmark$ | $\checkmark$        | $\checkmark$ | $\checkmark$ | 2        | 1         |
| ADD A,         | @Ri            | A←(A)+((Ri))                                                                  | $\checkmark$ | $\checkmark$        | $\checkmark$ |              | 1        | 1         |
|                | #data          | A←(A)+data                                                                    | $\checkmark$ | $\checkmark$        | $\checkmark$ | $\checkmark$ | 2        | 1         |
|                | Rn             | A←(A)+(Rn)+(C)                                                                | $\checkmark$ | $\checkmark$        | $\checkmark$ | $\checkmark$ | 1        | 1         |
|                | direct         | A←(A)+(direct) +(C)                                                           | $\checkmark$ | $\checkmark$        | $\checkmark$ |              | 2        | 1         |
| ADDC A,        | @Ri            | A←(A)+((Ri)) +(C)                                                             | $\checkmark$ | $\checkmark$        | $\checkmark$ | $\checkmark$ | 1        | 1         |
|                | #data          | A←(A)+data+(C)                                                                | $\checkmark$ | $\checkmark$        | $\checkmark$ | $\checkmark$ | 2        | 1         |
|                | А              | A←(A)+1                                                                       | $\checkmark$ | ×                   | ×            | ×            | 1        | 1         |
|                | Rn             | Rn←(Rn)+1                                                                     | ×            | ×                   | ×            | ×            | 1        | 1         |
| INC            | direct         | direct←(direct)+1                                                             | ×            | ×                   | ×            | ×            | 2        | 1         |
|                | @Ri            | (Ri)←((Ri))+1                                                                 | ×            | ×                   | ×            | ×            | 1        | 1         |
|                | DPTR           | DPTR←((DPTR))+1                                                               | ×            | ×                   | ×            | ×            | 1        | 2         |
| DAA            |                | BCD code adjustment                                                           | $\checkmark$ | ×                   | $\checkmark$ |              | 1        | 1         |
|                | Rn             | A←(A)-(Rn)-(C)                                                                | $\checkmark$ | ×                   | ×            | ×            | 1        | 1         |
|                | direct         | A←(A)-(direct)-(C)                                                            | $\checkmark$ | $\checkmark$        | $\checkmark$ |              | 2        | 1         |
| SUBB A         | @Ri            | (A)←(A)-((Ri))-(C)                                                            | $\checkmark$ | $\checkmark$        | $\checkmark$ |              | 1        | 1         |
|                | #data          | A←(A)-data-(C)                                                                | $\checkmark$ | $\checkmark$        | $\checkmark$ |              | 2        | 1         |
|                | А              | A←(A)-1                                                                       | $\checkmark$ | ×                   | ×            | ×            | 1        | 1         |
|                | Rn             | Rn←(Rn)-1                                                                     | ×            | ×                   | ×            | ×            | 1        | 1         |
| DEC            | direct         | direct←(direct)-1                                                             | ×            | ×                   | ×            | ×            | 2        | 1         |
|                | @Ri            | (Ri)←((Ri))-1                                                                 | ×            | ×                   | ×            | ×            | 1        | 1         |
|                | -              | BA←(A)*(B),after                                                              |              |                     |              |              |          |           |
| MUL AB         |                | performing<br>multiplication, the low                                         |              |                     | ×            | 0            | 1        | 4         |
|                |                | byte of the result is<br>stored in A and the high<br>byte is stored in B      |              |                     |              |              |          |           |
| DIV AB         |                | A←(A)/(B)<br>B←remainder                                                      | $\checkmark$ |                     | ×            | 0            | 1        | 4         |
|                |                | is used, the adjustment rule i<br>on A $\leftarrow$ A+06H; if the high 4 bits |              |                     |              |              |          |           |

# Semiconductor



| Logical operat  | tion instruction | _                                                                           | -                   |                     |         |              |          |           |
|-----------------|------------------|-----------------------------------------------------------------------------|---------------------|---------------------|---------|--------------|----------|-----------|
| mnemonic sig    | n                | Function                                                                    | Effec               | t on fla            | ag bits |              | Number   | Number    |
|                 | 11               |                                                                             | Р                   | OV                  | AC      | CY           | of bytes | of cycles |
| CLR A           |                  | A←00H                                                                       | $\checkmark$        | ×                   | ×       | ×            | 1        | 1         |
| CPL A           |                  | A←(Ā)                                                                       | $\checkmark$        | ×                   | ×       | ×            | 1        | 1         |
|                 | Rn               | A←(A)^ (Rn)                                                                 | $\checkmark$        | ×                   | ×       | ×            | 1        | 1         |
| ANL A,          | direct           | A←(A)∧ (direct)                                                             | $\checkmark$        | ×                   | ×       | ×            | 2        | 1         |
| ANL A,          | @Ri              | A←(A)^ ((Ri))                                                               | $\checkmark$        | ×                   | ×       | ×            | 1        | 1         |
|                 | #data            | A←(A)∧ data                                                                 | $\checkmark$        | ×                   | ×       | ×            | 2        | 1         |
| ANIL direct     | A                | direct←(A)∧ (direct)                                                        | ×                   | ×                   | ×       | ×            | 2        | 1         |
| ANL direct,     | #data            | direct←(direct)∧ data                                                       | ×                   | ×                   | ×       | ×            | 3        | 2         |
|                 | Rn               | A←(A)∨ (Rn)                                                                 | $\checkmark$        | ×                   | ×       | ×            | 1        | 1         |
|                 | direct           | A←(A)∨ (direct)                                                             | $\checkmark$        | ×                   | ×       | ×            | 2        | 1         |
| ORL A,          | @Ri              | A←(A)∨ ((Ri))                                                               | $\checkmark$        | ×                   | ×       | ×            | 1        | 1         |
|                 | #data            | A←(A)∨ data                                                                 | $\checkmark$        | ×                   | ×       | ×            | 2        | 1         |
| ORL direct,     | А                | direct←(direct)∨ (A)                                                        | ×                   | ×                   | ×       | ×            | 2        | 1         |
|                 | #data            | direct←(direct)∨ data                                                       | ×                   | ×                   | ×       | ×            | 3        | 2         |
|                 | Rn               | A←(A)⊕ (Rn)                                                                 | $\checkmark$        | ×                   | ×       | ×            | 1        | 1         |
|                 | direct           | A←(A)⊕ (direct)                                                             | $\checkmark$        | ×                   | ×       | ×            | 2        | 1         |
| XRL A,          | @Ri              | A←(A)⊕ ((Ri))                                                               | $\checkmark$        | ×                   | ×       | ×            | 1        | 1         |
|                 | #data            | A←(A)⊕ data                                                                 | $\checkmark$        | ×                   | ×       | ×            | 2        | 1         |
| VDL direct      | A                | direct←(direct)⊕ (A)                                                        | ×                   | ×                   | ×       | ×            | 2        | 1         |
| XRL direct,     | #data            | direct←(direct)⊕ data                                                       | ×                   | ×                   | ×       | ×            | 3        | 2         |
| Loop and shift  | t instructions   |                                                                             |                     |                     |         |              |          |           |
| momonio aig     |                  | Function                                                                    | Effect on flag bits |                     |         |              | Number   | Number    |
| mnemonic sig    | 11               | FUNCTION                                                                    | Р                   | OV                  | AC      | CY           | of bytes | of cycles |
| RL A            |                  | The content in A is shifted each bit to the left                            | ×                   | ×                   | ×       | ×            | 1        | 1         |
| RLC A           |                  | The contents of A are<br>shifted each bit to the left<br>with a Carry flag  | $\checkmark$        | ×                   | ×       | $\checkmark$ | 1        | 1         |
| RR A            |                  | The content in A is<br>shifted each bit to the<br>right                     | ×                   | ×                   | ×       | ×            | 1        | 1         |
| RRC A           |                  | The contents of A are<br>shifted each bit to the<br>right with a carry flag | $\checkmark$        | ×                   | ×       | $\checkmark$ | 1        | 1         |
| Call, Return ir | nstructions      |                                                                             |                     |                     |         |              |          |           |
| mnemonic sig    | n                | Function                                                                    | Effec               | Effect on flag bits |         |              | Number   | Number    |
| mnemonic sign   |                  |                                                                             | Р                   | OV                  | AC      | CY           | of bytes | of cycles |



| LCALL     | addr16        | (PC)←(PC)+3,(SP)←(P<br>C),<br>(PC), addr16                                                                 | ×          | ×        | ×             | ×  | 3                  | 2                   |
|-----------|---------------|------------------------------------------------------------------------------------------------------------|------------|----------|---------------|----|--------------------|---------------------|
| ACALL a   | addr11        | (PC)←addr16<br>(PC)←(PC)+2,(SP)←(P<br>C),<br>(PC10~0)←addr11                                               | ×          | ×        | ×             | ×  | 2                  | 2                   |
| RET       |               | (PC)←((SP))                                                                                                | ×          | ×        | ×             | ×  | 1                  | 2                   |
| RETI      |               | (PC)←((SP)) return from<br>interrupt                                                                       | ×          | ×        | ×             | ×  | 1                  | 2                   |
| Transfer  | instructions  |                                                                                                            |            |          |               |    |                    |                     |
| mnemon    | ic sign       | Function                                                                                                   | Effec<br>P | t on fla | ag bits<br>AC | CY | Number<br>of bytes | Number<br>of cycles |
| LJMP      | addr16        | PC←addr15~0                                                                                                | ×          | ×        | ×             | ×  | 3                  | 2                   |
| AJMP      | addr11        | PC10~0←addr10~0                                                                                            | ×          | ×        | ×             | ×  | 2                  | 2                   |
| SJMP      | rel           | PC←(PC)+rel                                                                                                | ×          | ×        | ×             | ×  | 2                  | 2                   |
| JMP       | @A+DPTR       | PC←(A)+(DPTR)                                                                                              | ×          | ×        | ×             | ×  | 1                  | 2                   |
| JZ        | rel           | PC←(PC)+2,<br>If (A)=0,PC←(PC)+rel                                                                         | ×          | ×        | ×             | ×  | 2                  | 2                   |
| JNZ       | rel           | PC←(PC)+2,<br>If (A)≠0,PC←(PC)+rel                                                                         | ×          | ×        | ×             | ×  | 2                  | 2                   |
| JC        | rel           | PC←(PC)+2,<br>If(CY)=1,PC←(PC)+rel                                                                         | ×          | ×        | ×             | ×  | 2                  | 2                   |
| JNC rel   |               | PC←(PC)+2,<br>If(CY)=0,PC←(PC)+rel                                                                         | ×          | ×        | ×             | ×  | 2                  | 2                   |
| JB        | bit,rel       | PC←(PC)+3,<br>If (bit)=1,PC←(PC)+rel                                                                       | ×          | ×        | ×             | ×  | 3                  | 2                   |
| JNB bit,r | el            | PC←(PC)+3,<br>If (bit)=0,PC←(PC)+rel                                                                       | ×          | ×        | ×             | ×  | 3                  | 2                   |
| JBC bit,r | el            | $PC \leftarrow (PC)+3,$<br>If (bit)=1, then bit $\leftarrow 0,$<br>$PC \leftarrow (PC)+rel$                | ×          | ×        | ×             | ×  | 3                  | 2                   |
|           | A, direct,rel | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                       | ×          | ×        | ×             | ×  | 3                  | 2                   |
| CJNE      | A,#data,rel   | PC $\leftarrow$ (PC)+3,<br>If (A) $\neq$ data, then<br>PC(PC)+rel<br>If (A)<(data), then CY $\leftarrow$ 1 | ×          | ×        | ×             | ×  | 3                  | 2                   |
|           | Rn,#data,rel  | PC←(PC)+3,<br>If (Rn) ≠data,                                                                               | ×          | ×        | ×             | ×  | 3                  | 2                   |



|            |                      |                                                                                                |                     |          |         |              | <b>D30</b> |           |
|------------|----------------------|------------------------------------------------------------------------------------------------|---------------------|----------|---------|--------------|------------|-----------|
|            |                      | PC←(PC)+rel                                                                                    |                     |          |         |              |            |           |
|            |                      | If (Rn)<(data), then                                                                           |                     |          |         |              |            |           |
|            |                      | CY←1                                                                                           |                     |          |         |              |            |           |
|            |                      | $PC \leftarrow (PC)+3,  if((Ri))$                                                              |                     |          |         |              |            |           |
|            |                      | ≠data, then                                                                                    |                     |          |         |              |            |           |
|            | @Ri,#data,rel        | PC←(PC)+rel.                                                                                   | ×                   | ×        | ×       | ×            | 3          | 2         |
|            |                      | If ((Ri))<(data), then                                                                         |                     |          |         |              |            |           |
|            |                      | CY←1                                                                                           |                     |          |         |              |            |           |
|            |                      | PC←(PC)+2,Rn←(Rn)-                                                                             |                     |          |         |              |            |           |
|            | Rn,rel               | 1,                                                                                             | ×                   | ×        | ×       | ×            | 2          | 2         |
|            | ,                    | If (Rn) ≠0, then                                                                               |                     |          |         |              |            |           |
| DJNZ       |                      | PC←(PC)+rel                                                                                    |                     |          |         |              |            |           |
|            |                      | PC←(PC)+3,                                                                                     |                     |          |         |              | 3          |           |
|            | direct,rel           | (direct)←(direct)-1.                                                                           | ×                   | ×        | ×       | ×            |            | 2         |
|            |                      | If (direct) ≠0,                                                                                |                     |          |         |              |            | -         |
|            |                      | then PC←(PC)+rel                                                                               |                     |          |         |              |            |           |
| Stack, em  | pty operation instru | uctions                                                                                        |                     |          |         |              | 1          |           |
| mnemonic   | : sian               | Function                                                                                       | Effect on flag bits |          | Number  | Number       |            |           |
|            | g                    |                                                                                                | Р                   | OV       | AC      | CY           | of bytes   | of cycles |
| PUSH o     | direct               | SP←(SP)+1,(SP)←(dire                                                                           | ×                   | ×        | ×       | ×            | 2          | 2         |
|            |                      | ct)                                                                                            |                     |          |         |              | -          |           |
| POP o      | direct               | direct←(SP),SP←(SP)-                                                                           | ×                   | ×        | ×       | ×            | 2          | 2         |
|            |                      | 1                                                                                              |                     |          |         |              | -          | -         |
| NOP        |                      | No Operation Performed                                                                         | ×                   | ×        | ×       | ×            | 1          | 1         |
| Bit manipu | ulation instructions | I                                                                                              |                     |          |         |              | 1          |           |
| mnemonic   | sian                 | Function                                                                                       | Effec               | t on fla | ag bits |              | Number     | Number    |
|            |                      |                                                                                                | Р                   | OV       | AC      | CY           | of bytes   | of cycles |
| MOV        | C,bit                | CY←bit                                                                                         | ×                   | ×        | ×       | $\checkmark$ | 2          | 1         |
|            | bit,C                | bit—CY                                                                                         | ×                   | ×        | ×       | ×            | 2          | 1         |
| CLR        | С                    | CY←0                                                                                           | ×                   | ×        | ×       | $\checkmark$ | 1          | 1         |
| ULK        | bit                  | bit←0                                                                                          | ×                   | ×        | ×       | ×            | 2          | 1         |
| OFTO       | С                    | CY←1                                                                                           | ×                   | ×        | ×       | $\checkmark$ | 1          | 1         |
| SETB       | bit                  | bit←1                                                                                          | ×                   | ×        | ×       | ×            | 2          | 1         |
|            | 0                    |                                                                                                |                     |          |         |              | 1          | 1         |
|            |                      | CY←( <del>CY</del> )                                                                           | ×                   | ×        | ×       | N            |            | I         |
|            | 1.14                 |                                                                                                |                     |          |         |              |            | 4         |
|            | DIT                  | bit←( bit )                                                                                    | ×                   | ×        | ×       | ×            | 1          | 1         |
|            | C,bit                | C←(C)∧ (bit)                                                                                   | ×                   | ×        | ×       | $\checkmark$ | 2          | 2         |
| ANL        |                      |                                                                                                |                     |          |         | .1           |            | 0         |
|            | C ,/bit              | C←(C)∧ ( bit )                                                                                 | ×                   | ×        | ×       | N            | 2          | 2         |
| ORL        | C,bit                | C←(C)∨ (bit)                                                                                   | ×                   | ×        | ×       | $\checkmark$ | 2          | 2         |
|            | C ,/bit              | bit $\leftarrow$ (bit)<br>C $\leftarrow$ (C) $\land$ (bit)<br>C $\leftarrow$ (C) $\land$ (bit) | ×                   | ×        | ×       | $\checkmark$ | 2          | 2         |



|                  | C,/bit                                                                                                                                                                  | C←(C)∨ ( bit ) | ×    | ×                                                                                      | × | $\checkmark$ | 2 | 2 |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------|----------------------------------------------------------------------------------------|---|--------------|---|---|
| Pseudo Instructi | Pseudo Instructions                                                                                                                                                     |                |      |                                                                                        |   |              |   |   |
| mnemonic sign    | Format                                                                                                                                                                  |                | Desc | Description                                                                            |   |              |   |   |
| ORG              | [Label:] ORG addr16                                                                                                                                                     |                | Spec | Specify the starting address of the label                                              |   |              |   |   |
| EQU              | Label EQU Value or label                                                                                                                                                |                |      | Assign a value to the label                                                            |   |              |   |   |
| DB               | [Label:] DB item or item list                                                                                                                                           |                |      | Used to define a byte content of a cell or batch of cells in memory                    |   |              |   |   |
| DW               | [Label:] DW item or item list                                                                                                                                           |                |      | Used to define the contents of a 16-bit word consisting of two or more cells of memory |   |              |   |   |
| DS               | [Label:] DS Expression                                                                                                                                                  |                |      | Specify to leave a number of storage cells starting from the label                     |   |              |   |   |
| BIT              | label BIT ac                                                                                                                                                            | ldress         | Assi | Assigning bit addresses to label                                                       |   |              |   |   |
| END              | END is placed at the end of the assembly language program to tell the assembler that<br>the source program has come to an end.The source program that does not end with |                |      |                                                                                        |   |              |   |   |
|                  | END will enter a dead loop                                                                                                                                              |                |      |                                                                                        |   |              |   |   |

Table 0 .1 CPU Instruction Set

#### **CPU-related Registers**

| SFR Register |               |     |             |                                |  |
|--------------|---------------|-----|-------------|--------------------------------|--|
| Address      | Register Name | R/W | Reset Value | Description                    |  |
| 0x81         | SP            | RW  | 0x07        | Stack pointer                  |  |
| 0x82         | DPL           | RW  | 0x00        | Data Pointer Low 8 bit         |  |
| 0x83         | DPH           | RW  | 0x00        | Data Pointer High 8 bit        |  |
| 0x87         | PCON          | RW  | 0x00        | Low power mode select register |  |
| 0xE0         | ACC           | RW  | 0x00        | Accumulator                    |  |
| 0xF0         | В             | RW  | 0x00        | B Register                     |  |

Table 16.3 CPU SFR Register



# 17 Application Circuit For Reference



Note: The above circuit is designed for reference only.



# 18 Package Information

### 18.1 QFN20



Figure 18.1 QFN20 Packaging Information Diagram





### 18.2 TSSOP28



A1+

-(L1)-



|    | (UNITS OF MEASURE=MILLIMETER) |         |      |      |  |  |  |  |
|----|-------------------------------|---------|------|------|--|--|--|--|
|    | SYMBOL                        | MIN     | NOM  | MAX  |  |  |  |  |
|    | A                             | ()      |      | 1.20 |  |  |  |  |
|    | A1                            | 0.05    | 10.0 | 0.15 |  |  |  |  |
| 12 | A2                            | 0.90    | 1.00 | 1.05 |  |  |  |  |
|    | A3                            | 0.34    | 0.44 | 0.54 |  |  |  |  |
|    | b                             | 0.20    |      | 0.29 |  |  |  |  |
|    | b1                            | 0.19    | 0.22 | 0.25 |  |  |  |  |
|    | С                             | 0.13    |      | 0.18 |  |  |  |  |
|    | c1                            | 0.12    | 0.13 | 0.14 |  |  |  |  |
|    | D                             | 9.60    | 9.70 | 9.80 |  |  |  |  |
|    | E                             | 6.20    | 6.40 | 6.60 |  |  |  |  |
|    | E1                            | 4.30    | 4.40 | 4.50 |  |  |  |  |
|    | e                             | 0.55    | 0.65 | 0.75 |  |  |  |  |
|    | L                             | 0.45    | 0.60 | 0.75 |  |  |  |  |
|    | L1                            | 1.00REF |      |      |  |  |  |  |
|    | L2                            | 0.25BSC |      |      |  |  |  |  |
|    | R                             | 0.09    | -    |      |  |  |  |  |
|    | R1                            | 0.09    | -    |      |  |  |  |  |
|    | S                             | 0.20    | -    |      |  |  |  |  |
|    | 0                             | 0.      | -    | 8.   |  |  |  |  |
|    | 0 1                           | 10*     | 12"  | 14"  |  |  |  |  |
|    | θ 2                           | 10*     | 12*  | 14'  |  |  |  |  |
|    | 03                            | 10" 12" |      | 14*  |  |  |  |  |
|    | 04                            | 10*     | 12*  | 14*  |  |  |  |  |

COMMON DIMENSIONS

Figure 18.2 TSSOP28 Package

SECTION C-C



# **19** Ordering Information

| Package Type | Tempera          | Packing            |                |
|--------------|------------------|--------------------|----------------|
| S: SOP       |                  | A:-40°C to +150°C  | B: Tape & Reel |
| A: SSOP      | Automotive-      | B: -40°C to +125°C | L: Tube        |
| T: TSSOP     | grade            | C: -40°C to +105°C | T: Tray        |
| M: MSSOP     |                  | D: -40°C to +85°C  | -              |
| L: LQFP      |                  | K: -40°C to +85°C  | -              |
| Q: QFN       | Industrial-grade | J: -40°C to +105°C | -              |
| B: BGA       |                  | L: -40°C to +125°C | -              |
| D: DIP       | Concurrent grade | P: -25°C to +70°C  | -              |
| -            | Consumer-grade   | Q: 0°C to +70°C    | -              |

See a schematic diagram below.





# 20 Revision History

| Date       | Description     | Complied by | REV  |
|------------|-----------------|-------------|------|
| 2022-05-30 | Initial release | Liu Hong    | V1.0 |
|            |                 |             |      |
|            |                 |             |      |
|            |                 |             |      |
|            |                 |             |      |
|            |                 |             |      |
|            |                 |             |      |
|            |                 |             |      |

### 21 Disclaimer

BYD Semiconductor makes no representations or warranties with respect to the accuracy or completeness of the contents of this document and reserves the right to make changes to specifications and products descriptions at any time without notice. BYD Semiconductor does not make any commitment to update the information contained herein. Please contact BYD FAE or authorized agents to obtain new version of this document.

BYD Semiconductor will do its best to guarantee the high quality and stability of products. Nevertheless, damages may be caused to components or devices due to its intrinsic electrical and physical susceptibility, which may result in breakdown or failure. It is the user's liability to design a safe and stable system environment following the safety requirements when using BYD products. Users can take measures to avoid the possible accidents, fire and public injuries by the removal of the extra devices, failure and fire prevention. When using the product, users need to follow the operation steps specified in the latest specification.

The product of BYD Semiconductor contained herein is designed for electrically generic application, such as computer, PC, office equipments and measurement instruments, industrial machines and home applicances. However, the products are not suitable for use in a particular devices that require ultra-high stability and quality, which may result in personal injury or death. BYD semiconductor products are not designed for use in nuclear facilities, airplanes or aerospace devices, transportation, traffic signal, combustion control equipment and medical or life-saving devices or system. BYD Semiconductor disclaims any and all liability including loss and damage arising from use in above-mentioned applications.