



ASR6601

# Reference Manual

Version 1.3.0

Issue Date 2022-08-11

Copyright © 2022 ASR

## About This Document

This document provides detailed and complete information on the IoT LPWAN SoC-ASR6601 for application developers.

## Intended Readers

This document is mainly for engineers who use this chip to develop their own platform and products, for instance:

- Hardware Development Engineer
- Software Engineer
- Technical Support Engineer

## Included Chip Models

The product models corresponding to this document are as follows.

| Model      | Flash  | SRAM  | Processor                           | Package          | Frequency     |
|------------|--------|-------|-------------------------------------|------------------|---------------|
| ASR6601SE  | 256 KB | 64 KB | 32-bit 48 MHz<br>Arm China STAR-MC1 | QFN68,<br>8*8 mm | 150 ~ 960 MHz |
| ASR6601CB  | 128 KB | 16 KB | 32-bit 48 MHz<br>Arm China STAR-MC1 | QFN48,<br>6*6 mm | 150 ~ 960 MHz |
| ASR6601SER | 256 KB | 64 KB | 32-bit 48 MHz<br>Arm China STAR-MC1 | QFN68,<br>8*8 mm | 150 ~ 960 MHz |
| ASR6601CBR | 128 KB | 16 KB | 32-bit 48 MHz<br>Arm China STAR-MC1 | QFN48,<br>6*6 mm | 150 ~ 960 MHz |

## Copyright Notice

© 2022 ASR Microelectronics Co., Ltd. All rights reserved. No part of this document can be reproduced, transmitted, transcribed, stored, or translated into any language in any form or by any means without the written permission of ASR Microelectronics Co., Ltd.

## Trademark Statement



ASR and ASR Microelectronics Co., Ltd. are trademarks of ASR Microelectronics Co., Ltd.

Other trade names, trademarks, and registered trademarks mentioned in this document are the property of their respective owners and are hereby declared.

## Disclaimer

ASR does not give any warranty of any kind and may make improvements and/or changes in this document or in the product described in this document at any time.

This document is only used as a guide, and no contents in the document constitute any form of warranty. Information in this document is subject to change without notice.

All liability, including liability for infringement of any proprietary rights caused by using the information in this document, is disclaimed.

## ASR Microelectronics Co., Ltd.

**Address:** 9F, Building 10, No. 399 Keyuan Road, Zhangjiang High-tech Park, Pudong New Area, Shanghai, 201203, China

**Homepage:** <http://www.asrmicro.com/>

## Revision History

| Date    | Version | Release Notes                                                                                                                                                                                                                                                                                                |
|---------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2022.08 | V1.2.0  | First Release.                                                                                                                                                                                                                                                                                               |
| 2022.08 | V1.3.0  | <ul style="list-style-type: none"><li>● Updated some descriptions of the bits in Sections <a href="#">7.5.3</a>, <a href="#">8.3.3</a>, <a href="#">8.3.4</a>, <a href="#">8.3.7</a>, <a href="#">8.3.12</a> and <a href="#">8.3.13</a>.</li><li>● Updated <a href="#">Figure 8-1: Clock Tree</a>.</li></ul> |

# Table of Contents

---

|                                                  |          |
|--------------------------------------------------|----------|
| <b>1. Overview .....</b>                         | <b>1</b> |
| <b>2. ASR6601 Introduction .....</b>             | <b>2</b> |
| 1.1 General.....                                 | 2        |
| 1.2 Key Features .....                           | 2        |
| <b>3. ASR6601 Functions .....</b>                | <b>4</b> |
| 3.1 ASR6601 SoC Diagram.....                     | 4        |
| <b>4. Power Management Unit .....</b>            | <b>5</b> |
| 4.1 Power Supply .....                           | 5        |
| 4.2 Power Supply Architecture .....              | 6        |
| <b>5. Access Control.....</b>                    | <b>7</b> |
| 5.1 Simple Configuration .....                   | 7        |
| 5.1.1 Recoverable Security Configuration .....   | 7        |
| 5.1.2 Unrecoverable Security Configuration ..... | 7        |
| 5.2 Access Control .....                         | 8        |
| 5.2.1 Debug Level Rules .....                    | 8        |
| 5.2.2 Secure and Non-Secure Operation .....      | 8        |
| <b>6. Operation Mode.....</b>                    | <b>9</b> |
| 6.1 Run .....                                    | 12       |
| 6.1.1 Enter and Exit .....                       | 12       |
| 6.1.2 Wakeup Source .....                        | 12       |
| 6.2 LpRun .....                                  | 12       |
| 6.2.1 Enter and Exit .....                       | 12       |
| 6.2.2 Wakeup Source .....                        | 12       |
| 6.3 Sleep.....                                   | 13       |
| 6.3.1 Enter and Exit .....                       | 13       |
| 6.3.2 Wakeup Source .....                        | 13       |
| 6.4 LpSleep.....                                 | 13       |
| 6.4.1 Enter and Exit .....                       | 13       |
| 6.4.2 Wakeup Source .....                        | 13       |
| 6.5 Stop0 .....                                  | 14       |
| 6.5.1 Enter and Exit .....                       | 14       |
| 6.5.2 Wakeup Source .....                        | 14       |
| 6.6 Stop1 .....                                  | 15       |
| 6.6.1 Enter and Exit .....                       | 15       |
| 6.6.2 Wakeup Source .....                        | 15       |
| 6.7 Stop2 .....                                  | 15       |
| 6.7.1 Enter and Exit .....                       | 15       |

|           |                                           |           |
|-----------|-------------------------------------------|-----------|
| 6.7.2     | Wakeup Source .....                       | 16        |
| 6.8       | Stop3 .....                               | 16        |
| 6.8.1     | Enter and Exit .....                      | 16        |
| 6.8.2     | Wakeup Source .....                       | 16        |
| 6.9       | Standby.....                              | 17        |
| 6.9.1     | Enter and Exit .....                      | 17        |
| 6.9.2     | Wakeup Source .....                       | 17        |
| <b>7.</b> | <b>System Configuration .....</b>         | <b>18</b> |
| 7.1       | System Architecture .....                 | 18        |
| 7.1.1     | Arm China STAR-MC1 Processor.....         | 19        |
| 7.1.2     | DMAC0 .....                               | 19        |
| 7.1.3     | DMAC1 .....                               | 19        |
| 7.1.4     | Master.....                               | 19        |
| 7.2       | Memory Mapping.....                       | 20        |
| 7.2.1     | AHB0 SFR .....                            | 21        |
| 7.2.2     | AHB1 SFR .....                            | 21        |
| 7.2.3     | APB0 SFR .....                            | 21        |
| 7.2.4     | APB1 SFR .....                            | 22        |
| 7.3       | SRAM .....                                | 23        |
| 7.4       | Boot Mode .....                           | 23        |
| 7.5       | SYSCFG Registers.....                     | 24        |
| 7.5.1     | SYSCFG_CR0 .....                          | 25        |
| 7.5.2     | SYSCFG_CR1 .....                          | 25        |
| 7.5.3     | SYSCFG_CR2 .....                          | 26        |
| 7.5.4     | SYSCFG_CR3.....                           | 29        |
| 7.5.5     | SYSCFG_CR4 .....                          | 30        |
| 7.5.6     | SYSCFG_CR5.....                           | 30        |
| 7.5.7     | SYSCFG_CR6.....                           | 30        |
| 7.5.8     | SYSCFG_CR7 .....                          | 32        |
| 7.5.9     | SYSCFG_CR8 .....                          | 33        |
| 7.5.10    | SYSCFG_CR9 .....                          | 33        |
| 7.5.11    | SYSCFG_CR10.....                          | 34        |
| 7.6       | DMA Request MUX .....                     | 35        |
| <b>8.</b> | <b>Reset and Clock Control (RCC).....</b> | <b>37</b> |
| 8.1       | Reset .....                               | 37        |
| 8.1.1     | External Reset .....                      | 37        |
| 8.1.2     | Power-on Reset .....                      | 37        |
| 8.1.3     | System Reset .....                        | 37        |
| 8.1.4     | Low-power Reset.....                      | 37        |
| 8.2       | Clock.....                                | 38        |
| 8.2.1     | SYS_CLK.....                              | 39        |
| 8.2.2     | Clocks for the Modules .....              | 39        |

|            |                                                   |           |
|------------|---------------------------------------------------|-----------|
| 8.2.3      | Clock-out Capability.....                         | 40        |
| 8.3        | RCC Registers.....                                | 40        |
| 8.3.1      | RCC_CR0.....                                      | 41        |
| 8.3.2      | RCC_CR1.....                                      | 43        |
| 8.3.3      | RCC_CR2.....                                      | 45        |
| 8.3.4      | RCC_CGR0.....                                     | 47        |
| 8.3.5      | RCC_CGR1 .....                                    | 50        |
| 8.3.6      | RCC_CGR2 .....                                    | 51        |
| 8.3.7      | RCC_RST0.....                                     | 52        |
| 8.3.8      | RCC_RST1 .....                                    | 55        |
| 8.3.9      | RCC_RST_SR.....                                   | 56        |
| 8.3.10     | RCC_RST_CR.....                                   | 57        |
| 8.3.11     | RCC_SR .....                                      | 58        |
| 8.3.12     | RCC_SR1 .....                                     | 59        |
| 8.3.13     | RCC_CR3.....                                      | 61        |
| <b>9.</b>  | <b>Interrupts .....</b>                           | <b>62</b> |
| 9.1        | Main Features.....                                | 62        |
| 9.2        | SysTick .....                                     | 62        |
| 9.3        | Interrupt Vector Table.....                       | 62        |
| <b>10.</b> | <b>Embedded Flash.....</b>                        | <b>64</b> |
| 10.1       | Introduction .....                                | 64        |
| 10.2       | Main Features.....                                | 64        |
| 10.3       | Functional Description .....                      | 64        |
| 10.3.1     | Flash Info Area Division.....                     | 64        |
| 10.3.2     | EFC_CR Protection .....                           | 65        |
| 10.3.3     | Read Access Latency .....                         | 65        |
| 10.3.4     | Acceleration for Accessing the Flash Memory ..... | 66        |
| 10.3.5     | Instruction Prefetch.....                         | 66        |
| 10.3.6     | Flash Program Operation .....                     | 66        |
| 10.3.7     | Flash Erase Operation.....                        | 67        |
| 10.4       | Flash Option Bytes .....                          | 68        |
| 10.4.1     | Flash Option0 .....                               | 68        |
| 10.4.2     | Flash Option1 .....                               | 70        |
| 10.5       | Embedded Flash Registers .....                    | 71        |
| 10.5.1     | EFC_CR .....                                      | 72        |
| 10.5.2     | EFC_INT_EN .....                                  | 74        |
| 10.5.3     | EFC_SR.....                                       | 75        |
| 10.5.4     | EFC_PROG_DATA0 .....                              | 76        |
| 10.5.5     | EFC_PROG_DATA1 .....                              | 77        |
| 10.5.6     | EFC_TIMING_CFG .....                              | 77        |
| 10.5.7     | EFC_PROTECT_SEQ.....                              | 78        |
| 10.5.8     | SERIAL_NUM_LOW.....                               | 78        |
| 10.5.9     | SERIAL_NUM_HIGH.....                              | 78        |

|                                         |                                          |            |
|-----------------------------------------|------------------------------------------|------------|
| 10.5.10                                 | OPTION_CSR_BYTES.....                    | 79         |
| 10.5.11                                 | OPTION_EXE_ONLY_BYT...ES.....            | 80         |
| 10.5.12                                 | OPTION_WR_PROTECT_BYT...ES.....          | 80         |
| 10.5.13                                 | OPTION_SECURE_BYT...ES0.....             | 81         |
| 10.5.14                                 | OPTION_SECURE_BYT...ES1.....             | 82         |
| <b>11. GPIO.....</b>                    |                                          | <b>83</b>  |
| 11.1                                    | Introduction .....                       | 83         |
| 11.2                                    | Output Configuration .....               | 83         |
| 11.3                                    | Input Configuration .....                | 83         |
| 11.4                                    | Output Drive Strength.....               | 84         |
| 11.5                                    | GPIO Interrupts .....                    | 84         |
| 11.6                                    | Wakeup from Sleep/Stop0~2 Mode .....     | 84         |
| 11.7                                    | Wakeup from Stop3 Mode.....              | 84         |
| 11.8                                    | Alternate Function Configuration.....    | 84         |
| 11.9                                    | Clock Reset .....                        | 85         |
| 11.10                                   | Power Domain .....                       | 85         |
| 11.11                                   | Low-power Mode Operation and Wakeup..... | 85         |
| 11.12                                   | SWD IO.....                              | 85         |
| 11.13                                   | BOOT0 Control.....                       | 86         |
| 11.14                                   | GPIO Registers .....                     | 86         |
| 11.14.1                                 | GPIOx_OER (x=A, B, C, D).....            | 87         |
| 11.14.2                                 | GPIOx_OTYPER (x=A, B, C, D).....         | 87         |
| 11.14.3                                 | GPIOx_IER (x=A, B, C, D).....            | 87         |
| 11.14.4                                 | GPIOx_PER (x=A, B, C, D).....            | 88         |
| 11.14.5                                 | GPIOx_PSR (x=A, B, C, D).....            | 88         |
| 11.14.6                                 | GPIOx_IDR (x=A, B, C, D).....            | 88         |
| 11.14.7                                 | GPIOx_ODR (x=A, B, C, D).....            | 89         |
| 11.14.8                                 | GPIOx_BRR (x=A, B, C, D).....            | 89         |
| 11.14.9                                 | GPIOx_BSRR (x=A, B, C, D).....           | 89         |
| 11.14.10                                | GPIOx_DSR (x=A, B, C, D).....            | 90         |
| 11.14.11                                | GPIOx_INT_CR (x=A, B, C, D).....         | 90         |
| 11.14.12                                | GPIOx_FR (x=A, B, C, D).....             | 90         |
| 11.14.13                                | GPIOx_WU_EN (x=A, B, C, D).....          | 91         |
| 11.14.14                                | GPIOx_WU_LVL (x=A, B, C, D).....         | 91         |
| 11.14.15                                | GPIOx_AFRL (x=A, B, C, D).....           | 91         |
| 11.14.16                                | GPIOx_AFRH (x=A, B, C).....              | 94         |
| 11.14.17                                | GPIOD_AFRH .....                         | 96         |
| 11.14.18                                | GPIOA_STOP3_WU_CR .....                  | 98         |
| 11.14.19                                | GPIOx_STOP3_WU_CR (x=B, C) .....         | 99         |
| 11.14.20                                | GPIOD_STOP3_WU_CR .....                  | 101        |
| <b>12. LoRa Controller (LoRaC).....</b> |                                          | <b>102</b> |
| 12.1                                    | Introduction .....                       | 102        |

|            |                                   |            |
|------------|-----------------------------------|------------|
| 12.2       | Main Features.....                | 102        |
| 12.3       | Functional Description.....       | 102        |
| 12.3.1     | Internal SPI Interface .....      | 102        |
| 12.3.2     | Timing Sequence of Power-on ..... | 103        |
| 12.3.3     | Interrupts.....                   | 103        |
| 12.4       | LoRaC Registers .....             | 104        |
| 12.4.1     | SSP_CR0 .....                     | 105        |
| 12.4.2     | SSP_CR1 .....                     | 106        |
| 12.4.3     | SSP_DR .....                      | 106        |
| 12.4.4     | SSP_SR.....                       | 107        |
| 12.4.5     | SSP_CPSR.....                     | 107        |
| 12.4.6     | SSP_IMSC.....                     | 108        |
| 12.4.7     | SSP_RIS.....                      | 108        |
| 12.4.8     | SSP_MIS .....                     | 109        |
| 12.4.9     | SSP_ICR .....                     | 109        |
| 12.4.10    | SSP_DMCR .....                    | 109        |
| 12.4.11    | LORAC_CR0 .....                   | 110        |
| 12.4.12    | LORAC_CR1 .....                   | 110        |
| 12.4.13    | LORAC_SR .....                    | 111        |
| 12.4.14    | LORAC_NSS_CR.....                 | 112        |
| 12.4.15    | LORAC_SCK_CR.....                 | 112        |
| 12.4.16    | LORAC_MOSI_CR .....               | 112        |
| 12.4.17    | LORAC_MISO_SR .....               | 113        |
| <b>13.</b> | <b>UART.....</b>                  | <b>114</b> |
| 13.1       | Introduction.....                 | 114        |
| 13.2       | Clock Reset .....                 | 114        |
| 13.3       | Reference Clock .....             | 115        |
| 13.4       | Baud Rate Generator .....         | 115        |
| 13.5       | FIFO.....                         | 115        |
| 13.6       | UART Operation .....              | 116        |
| 13.6.1     | Baud Rate Divisor.....            | 116        |
| 13.6.2     | Data Transmission.....            | 116        |
| 13.6.3     | Data Reception .....              | 117        |
| 13.7       | IrDA SIR Operation.....           | 117        |
| 13.7.1     | Low-Power Divisor.....            | 117        |
| 13.7.2     | IrDA SIR Transmit Encoder .....   | 118        |
| 13.7.3     | IrDA SIR Receive Decoder .....    | 118        |
| 13.8       | UART Character Frame.....         | 118        |
| 13.9       | IrDA Data Modulation .....        | 119        |
| 13.10      | Hardware Flow Control.....        | 119        |
| 13.11      | Interrupts.....                   | 119        |
| 13.12      | DMA.....                          | 119        |

|            |                                    |            |
|------------|------------------------------------|------------|
| 13.13      | UART Registers.....                | 120        |
| 13.13.1    | UARTx_DR (x=0, 1, 2, 3).....       | 121        |
| 13.13.2    | UARTx_RSR_ECR (x=0, 1, 2, 3) ..... | 122        |
| 13.13.3    | UARTx_FR (x=0, 1, 2, 3) .....      | 123        |
| 13.13.4    | UARTx_ILPR (x=0, 1, 2, 3).....     | 124        |
| 13.13.5    | UARTx_IBRD (x=0, 1, 2, 3) .....    | 124        |
| 13.13.6    | UARTx_FBRD (x=0, 1, 2, 3) .....    | 124        |
| 13.13.7    | UARTx_LCR_H (x=0, 1, 2, 3) .....   | 125        |
| 13.13.8    | UARTx_CR (x=0, 1, 2, 3).....       | 126        |
| 13.13.9    | UARTx_IFLS (x=0, 1, 2, 3) .....    | 127        |
| 13.13.10   | UARTx_IMSC (x=0, 1, 2, 3).....     | 127        |
| 13.13.11   | UARTx_RIS (x=0, 1, 2, 3).....      | 128        |
| 13.13.12   | UARTx_MIS (x=0, 1, 2, 3) .....     | 129        |
| 13.13.13   | UARTx_ICR (x=0, 1, 2, 3) .....     | 129        |
| 13.13.14   | UARTx_DMACR (x=0, 1, 2, 3) .....   | 130        |
| 13.13.15   | UARTx_ID[8] (x=0, 1, 2, 3) .....   | 131        |
| <b>14.</b> | <b>SSP .....</b>                   | <b>134</b> |
| 14.1       | Introduction .....                 | 134        |
| 14.2       | Main Features.....                 | 134        |
| 14.3       | Functional Description.....        | 134        |
| 14.3.1     | Basic Information .....            | 134        |
| 14.3.2     | Clock Division .....               | 135        |
| 14.3.3     | Data Format.....                   | 136        |
| 14.3.4     | DMA Transaction .....              | 136        |
| 14.3.5     | SSP Interrupts .....               | 137        |
| 14.4       | SSP Registers .....                | 137        |
| 14.4.1     | SSP_CR0 .....                      | 138        |
| 14.4.2     | SSP_CR1 .....                      | 139        |
| 14.4.3     | SSP_DR .....                       | 139        |
| 14.4.4     | SSP_SR .....                       | 140        |
| 14.4.5     | SSP_CPSR.....                      | 140        |
| 14.4.6     | SSP_IMSC.....                      | 141        |
| 14.4.7     | SSP_RIS.....                       | 141        |
| 14.4.8     | SSP_MIS .....                      | 142        |
| 14.4.9     | SSP_ICR .....                      | 142        |
| 14.4.10    | SSP_DMACR .....                    | 142        |
| <b>15.</b> | <b>I2C .....</b>                   | <b>144</b> |
| 15.1       | Introduction .....                 | 144        |
| 15.2       | Start and Stop Conditions.....     | 145        |
| 15.3       | Data Transmission Sequence .....   | 146        |
| 15.4       | Data and Addressing .....          | 147        |
| 15.5       | Acknowledge .....                  | 148        |
| 15.6       | Arbitration .....                  | 148        |

|            |                                     |            |
|------------|-------------------------------------|------------|
| 15.7       | I2C Master Mode .....               | 149        |
| 15.8       | FIFO Mode.....                      | 151        |
| 15.9       | I2C Slave Mode .....                | 153        |
| 15.10      | I2C Clock Reset.....                | 154        |
| 15.11      | I2C Interrupts.....                 | 154        |
| 15.12      | DMA Requests .....                  | 154        |
| 15.13      | I2C Registers.....                  | 155        |
| 15.13.1    | I2Cx_CR (x=0, 1, 2).....            | 156        |
| 15.13.2    | I2Cx_SR (x=0, 1, 2) .....           | 159        |
| 15.13.3    | I2Cx_SAR (x=0, 1, 2).....           | 160        |
| 15.13.4    | I2Cx_DBR (x=0, 1, 2) .....          | 161        |
| 15.13.5    | I2Cx_LCR (x=0, 1, 2).....           | 161        |
| 15.13.6    | I2Cx_WCR (x=0, 1, 2) .....          | 161        |
| 15.13.7    | I2Cx_RST_CYCL (x=0, 1, 2) .....     | 162        |
| 15.13.8    | I2Cx_BMR (x=0, 1, 2) .....          | 162        |
| 15.13.9    | I2Cx_WFIFO0 (x=0, 1, 2) .....       | 162        |
| 15.13.10   | I2Cx_WFIFO_WPTR (x=0, 1, 2).....    | 163        |
| 15.13.11   | I2Cx_WFIFO_RPTR (x=0, 1, 2) .....   | 163        |
| 15.13.12   | I2Cx_RFIFO (x=0, 1, 2) .....        | 163        |
| 15.13.13   | I2Cx_RFIFO_WPTR (x=0, 1, 2).....    | 164        |
| 15.13.14   | I2Cx_RFIFO_RPTR (x=0, 1, 2) .....   | 164        |
| 15.13.15   | I2Cx_WFIFO_STATUS (x=0, 1, 2) ..... | 164        |
| 15.13.16   | I2Cx_RFIFO_STATUS (x=0, 1, 2).....  | 165        |
| <b>16.</b> | <b>ADC .....</b>                    | <b>166</b> |
| 16.1       | Introduction.....                   | 166        |
| 16.2       | ADC Input Mode .....                | 166        |
| 16.3       | Sampling Channels .....             | 167        |
| 16.4       | Trigger Source.....                 | 167        |
| 16.5       | Low-power Operation .....           | 168        |
| 16.6       | ADC Overrun .....                   | 168        |
| 16.7       | Conversion Modes.....               | 168        |
| 16.8       | Voltage Reference.....              | 169        |
| 16.9       | Data Buffer .....                   | 169        |
| 16.10      | DMA Request .....                   | 170        |
| 16.11      | Interrupts.....                     | 170        |
| 16.12      | Wakeup.....                         | 170        |
| 16.13      | ADC Clock and Reset.....            | 170        |
| 16.14      | ADC Registers.....                  | 170        |
| 16.14.1    | ADC_CR .....                        | 171        |
| 16.14.2    | ADC_CFGR .....                      | 172        |
| 16.14.3    | ADC_SEQR0 .....                     | 174        |
| 16.14.4    | ADC_SEQR1 .....                     | 175        |

|            |                                                      |            |
|------------|------------------------------------------------------|------------|
| 16.14.5    | ADC_DIFFSEL .....                                    | 177        |
| 16.14.6    | ADC_ISR .....                                        | 178        |
| 16.14.7    | ADC_IER .....                                        | 179        |
| 16.14.8    | ADC_DR .....                                         | 179        |
| <b>17.</b> | <b>RTC .....</b>                                     | <b>180</b> |
| 17.1       | Introduction .....                                   | 180        |
| 17.2       | Main Features .....                                  | 180        |
| 17.3       | Interface Clock .....                                | 180        |
| 17.4       | Calendar .....                                       | 181        |
| 17.4.1     | Reading the Calendar .....                           | 181        |
| 17.4.2     | Setting the Calendar .....                           | 181        |
| 17.5       | RTC PPM Calibration .....                            | 182        |
| 17.6       | Wake-up from Low-power Mode .....                    | 182        |
| 17.7       | Tamper/Wakeup IO Detection .....                     | 183        |
| 17.7.1     | Tamper/Wakeup Initialization and Configuration ..... | 183        |
| 17.7.2     | Erase Operation on Retention SRAM .....              | 184        |
| 17.8       | Periodic Counter .....                               | 184        |
| 17.9       | RTC Alarms .....                                     | 184        |
| 17.10      | Internal Signal Output through IO .....              | 185        |
| 17.11      | RTC Interrupts .....                                 | 186        |
| 17.12      | RTC Registers .....                                  | 187        |
| 17.12.1    | RTC_CR .....                                         | 188        |
| 17.12.2    | RTC_ALARM0 .....                                     | 191        |
| 17.12.3    | RTC_ALARM1 .....                                     | 192        |
| 17.12.4    | RTC_PPMADJUST .....                                  | 193        |
| 17.12.5    | RTC_CALENDAR .....                                   | 193        |
| 17.12.6    | RTC_CALENDAR_H .....                                 | 194        |
| 17.12.7    | RTC_CYC_MAX_VALUE .....                              | 194        |
| 17.12.8    | RTC_SR .....                                         | 195        |
| 17.12.9    | RTC_ASYNCDATA .....                                  | 196        |
| 17.12.10   | RTC_ASYNCDATA_H .....                                | 196        |
| 17.12.11   | RTC_CR1 .....                                        | 197        |
| 17.12.12   | RTC_SR1 .....                                        | 198        |
| 17.12.13   | RTC_CR2 .....                                        | 199        |
| 17.12.14   | RTC_SUB_SECOND .....                                 | 200        |
| 17.12.15   | RTC_CYC_CNT_VALUE .....                              | 200        |
| 17.12.16   | RTC_ALARM0_SUB .....                                 | 201        |
| 17.12.17   | RTC_ALARM1_SUB .....                                 | 201        |
| 17.12.18   | RTC_CALENDAR_R .....                                 | 202        |
| 17.12.19   | RTC_CALENDAR_R_H .....                               | 202        |
| <b>18.</b> | <b>LPUART .....</b>                                  | <b>203</b> |
| 18.1       | Introduction .....                                   | 203        |

|            |                                          |            |
|------------|------------------------------------------|------------|
| 18.2       | Main Features.....                       | 203        |
| 18.3       | Functional Description.....              | 203        |
| 18.3.1     | Data Format.....                         | 203        |
| 18.3.2     | Baud Rate Generation.....                | 204        |
| 18.3.3     | CTS/RTS Flow Control.....                | 204        |
| 18.3.4     | DMA Transaction.....                     | 205        |
| 18.3.5     | LPUART Interrupt Signals .....           | 206        |
| 18.3.6     | CPU Wakeup from Low-power Mode.....      | 206        |
| 18.4       | LPUART Registers .....                   | 206        |
| 18.4.1     | LPUART_CRO .....                         | 207        |
| 18.4.2     | LPUART_CR1 .....                         | 208        |
| 18.4.3     | LPUART_SR0.....                          | 210        |
| 18.4.4     | LPUART_SR1.....                          | 211        |
| 18.4.5     | LPUART_DATA.....                         | 212        |
| <b>19.</b> | <b>DMA.....</b>                          | <b>213</b> |
| 19.1       | Introduction .....                       | 213        |
| 19.2       | Main Features.....                       | 213        |
| 19.3       | Transfer Data Length Configuration ..... | 213        |
| 19.4       | Data Transfer Method.....                | 214        |
| 19.5       | LLI.....                                 | 216        |
| 19.6       | Auto-reloading .....                     | 216        |
| 19.7       | Interrupt .....                          | 217        |
| 19.8       | DMA-related Register Description.....    | 218        |
| 19.8.1     | DMA_SARx.....                            | 219        |
| 19.8.2     | DMA_DARx .....                           | 219        |
| 19.8.3     | DMA_LLPx.....                            | 219        |
| 19.8.4     | DMA_CTLx .....                           | 220        |
| 19.8.5     | DMA_CFGx .....                           | 222        |
| 19.8.6     | DMA_StatusTfr .....                      | 224        |
| 19.8.7     | DMA_StatusBlock .....                    | 224        |
| 19.8.8     | DMA_StatusSrcTran.....                   | 225        |
| 19.8.9     | DMA_StatusDstTran.....                   | 225        |
| 19.8.10    | DMA_StatusErr .....                      | 226        |
| 19.8.11    | DMA_MaskTfr.....                         | 226        |
| 19.8.12    | DMA_MaskBlock .....                      | 227        |
| 19.8.13    | DMA_MaskSrcTran .....                    | 228        |
| 19.8.14    | DMA_MaskDstTran .....                    | 229        |
| 19.8.15    | DMA_MaskErr .....                        | 230        |
| 19.8.16    | DMA_ClearTfr.....                        | 231        |
| 19.8.17    | DMA_ClearBlock .....                     | 232        |
| 19.8.18    | DMA_ClearSrcTran .....                   | 232        |
| 19.8.19    | DMA_ClearDstTran .....                   | 233        |
| 19.8.20    | DMA_ClearErr .....                       | 234        |

|            |                                            |            |
|------------|--------------------------------------------|------------|
| 19.8.21    | DMA_DmaCfgReg .....                        | 234        |
| 19.8.22    | DMA_ChEnReg .....                          | 234        |
| <b>20.</b> | <b>GPTIMER .....</b>                       | <b>236</b> |
| 20.1       | Introduction .....                         | 236        |
| 20.2       | Main Features .....                        | 236        |
| 20.3       | Counter .....                              | 238        |
| 20.3.1     | Counting Clock Selection .....             | 238        |
| 20.3.2     | Auto Reload .....                          | 239        |
| 20.3.3     | Upcounting Mode .....                      | 239        |
| 20.3.4     | Downcounting Mode .....                    | 240        |
| 20.3.5     | Center-aligned Mode .....                  | 240        |
| 20.4       | Prescaler .....                            | 241        |
| 20.5       | Sampling Clock .....                       | 241        |
| 20.6       | Channel .....                              | 242        |
| 20.6.1     | Input Capture .....                        | 243        |
| 20.6.2     | Output Compare .....                       | 243        |
| 20.7       | Trigger Input Channel .....                | 246        |
| 20.8       | Update Event Management .....              | 247        |
| 20.9       | Coding Mode Control .....                  | 248        |
| 20.10      | Slave Mode Control .....                   | 249        |
| 20.11      | Slave Mode Control .....                   | 250        |
| 20.12      | Outout Control .....                       | 251        |
| 20.13      | Channel Remapping .....                    | 251        |
| 20.14      | Debug Mode Control .....                   | 251        |
| 20.15      | DMA Control .....                          | 251        |
| 20.16      | Interrupt .....                            | 252        |
| 20.17      | GPTIMER Related Register Description ..... | 253        |
| 20.17.1    | GPTIM_CR1 .....                            | 254        |
| 20.17.2    | GPTIM_CR2 .....                            | 255        |
| 20.17.3    | GPTIM_SMCR .....                           | 256        |
| 20.17.4    | GPTIM_DIER .....                           | 257        |
| 20.17.5    | GPTIM_SR .....                             | 259        |
| 20.17.6    | GPTIM_EGR .....                            | 260        |
| 20.17.7    | GPTIM_CCMR1 .....                          | 261        |
| 20.17.8    | GPTIM_CCMR2 .....                          | 264        |
| 20.17.9    | GPTIM_CCER .....                           | 267        |
| 20.17.10   | GPTIM_CNT .....                            | 270        |
| 20.17.11   | GPTIM_PSC .....                            | 270        |
| 20.17.12   | GPTIM_ARR .....                            | 270        |
| 20.17.13   | GPTIM_CCR0 .....                           | 270        |
| 20.17.14   | GPTIM_CCR1 .....                           | 271        |
| 20.17.15   | GPTIM_CCR2 .....                           | 271        |

|            |                                       |            |
|------------|---------------------------------------|------------|
| 20.17.16   | GPTIM_CCR3 .....                      | 271        |
| 20.17.17   | GPTIM_DCR .....                       | 271        |
| 20.17.18   | GPTIM_DMAR.....                       | 273        |
| 20.17.19   | GPTIM_OR.....                         | 273        |
| <b>21.</b> | <b>I2S .....</b>                      | <b>278</b> |
| 21.1       | Main Features.....                    | 278        |
| 21.2       | Data Reception and Transmission ..... | 279        |
| 21.2.1     | Pin Connections.....                  | 279        |
| 21.2.2     | Transmission waveform.....            | 279        |
| 21.3       | Clock Configuration .....             | 280        |
| 21.4       | Software DMA .....                    | 280        |
| 21.5       | Interrupt .....                       | 281        |
| 21.6       | I2S Register.....                     | 282        |
| 21.6.1     | IER.....                              | 282        |
| 21.6.2     | IRER .....                            | 283        |
| 21.6.3     | ITER.....                             | 283        |
| 21.6.4     | CER .....                             | 283        |
| 21.6.5     | CCR .....                             | 284        |
| 21.6.6     | RXFFR .....                           | 285        |
| 21.6.7     | TXFFR .....                           | 285        |
| 21.6.8     | LRBR_LTHR.....                        | 285        |
| 21.6.9     | RRBR_RTHR.....                        | 286        |
| 21.6.10    | RER .....                             | 286        |
| 21.6.11    | TER.....                              | 286        |
| 21.6.12    | RCR .....                             | 287        |
| 21.6.13    | TCR.....                              | 287        |
| 21.6.14    | ISR .....                             | 288        |
| 21.6.15    | IMR .....                             | 288        |
| 21.6.16    | ROR .....                             | 289        |
| 21.6.17    | TOR .....                             | 289        |
| 21.6.18    | RFCR .....                            | 290        |
| 21.6.19    | TFCR .....                            | 290        |
| 21.6.20    | RFF .....                             | 291        |
| 21.6.21    | TFF .....                             | 291        |
| 21.6.22    | RXDMA.....                            | 292        |
| 21.6.23    | RRXDMA .....                          | 292        |
| 21.6.24    | TXDMA .....                           | 292        |
| 21.6.25    | RTXDMA.....                           | 293        |
| 21.6.26    | I2S_COMP_PARAM_2.....                 | 293        |
| 21.6.27    | I2S_COMP_PARAM_1.....                 | 294        |
| 21.6.28    | I2S_COMP_VERSION .....                | 296        |
| 21.6.29    | I2S_COMP_TYPE .....                   | 296        |
| <b>22.</b> | <b>LCD .....</b>                      | <b>297</b> |

|          |                                               |     |
|----------|-----------------------------------------------|-----|
| 22.1     | Main Features.....                            | 297 |
| 22.2     | COM and SEG.....                              | 297 |
| 22.3     | Bias and Duty .....                           | 299 |
| 22.4     | High and Low Current Switching Control .....  | 299 |
| 22.5     | Blink Control .....                           | 299 |
| 22.6     | Frequency Division and Prescale Control ..... | 299 |
| 22.7     | Dead Control .....                            | 299 |
| 22.8     | LCD Drive Mode .....                          | 300 |
| 22.9     | LCD Screen Software Control Process .....     | 300 |
| 22.10    | Interrupt .....                               | 302 |
| 22.11    | LCD Register .....                            | 303 |
| 22.11.1  | CR0.....                                      | 303 |
| 22.11.2  | CR1.....                                      | 304 |
| 22.11.3  | DR0.....                                      | 306 |
| 22.11.4  | DR1.....                                      | 306 |
| 22.11.5  | DR2.....                                      | 306 |
| 22.11.6  | DR3.....                                      | 307 |
| 22.11.7  | DR4.....                                      | 307 |
| 22.11.8  | DR5.....                                      | 308 |
| 22.11.9  | DR6.....                                      | 308 |
| 22.11.10 | DR7.....                                      | 308 |
| 22.11.11 | SR.....                                       | 309 |
| 22.11.12 | CR2.....                                      | 309 |

# List of Tables

---

|                                                                                 |     |
|---------------------------------------------------------------------------------|-----|
| Table 6-1 Modules Working Status in Various Operation Modes .....               | 9   |
| Table 7-1 Master Bus Access Scope .....                                         | 19  |
| Table 7-2 Memory Mapping .....                                                  | 20  |
| Table 7-3 AHB0 SFR Internal Address Mapping .....                               | 21  |
| Table 7-4 AHB1 SFR Internal Address Mapping .....                               | 21  |
| Table 7-5 APB0 SFR Internal Address Mapping.....                                | 21  |
| Table 7-6 APB1 SFR Internal Address Mapping.....                                | 22  |
| Table 7-7 ASR6601 Boot Mode Configuration.....                                  | 23  |
| Table 7-8 SYSCFG Register Summary .....                                         | 24  |
| Table 7-9 DMA Request MUX.....                                                  | 35  |
| Table 8-1 RCC Register Summary .....                                            | 40  |
| Table 9-1 Interrupt Vector .....                                                | 62  |
| Table 10-1 Flash Info Area Division .....                                       | 64  |
| Table 10-2 Flash Option0 .....                                                  | 68  |
| Table 10-3 ASR6601 Boot Mode Configuration.....                                 | 69  |
| Table 10-4 Flash Option1 .....                                                  | 70  |
| Table 10-5 Embedded Flash Register Summary.....                                 | 71  |
| Table 11-1 GPIO Register Summary .....                                          | 86  |
| Table 12-1 LORAC Register Summary.....                                          | 104 |
| Table 13-1 Receive FIFO Bit Functions.....                                      | 115 |
| Table 13-2 UART Register Summary .....                                          | 120 |
| Table 14-1 SSP Register Summary .....                                           | 137 |
| Table 15-1 Start and Stop Conditions .....                                      | 145 |
| Table 15-2 Master Transactions .....                                            | 149 |
| Table 15-3 Slave Transaction .....                                              | 153 |
| Table 15-4 I2C Register Summary .....                                           | 155 |
| Table 16-1 ADC Sampling Channels .....                                          | 167 |
| Table 16-2 ADC Register Summary.....                                            | 170 |
| Table 17-1 RTC Wake-up Source .....                                             | 182 |
| Table 17-2 Bits to Enable Wake-up Signals .....                                 | 183 |
| Table 17-3 RTC Interrupts .....                                                 | 186 |
| Table 17-4 RTC Register Summary.....                                            | 187 |
| Table 18-1 LPUART Register Summary .....                                        | 206 |
| Table 20-1 GPTIMER Module Introduction.....                                     | 237 |
| Table 20-2 Input Channel Active Polarity Configuration .....                    | 242 |
| Table 20-3 Input Channel Mapping.....                                           | 242 |
| Table 20-4 Description of Output Waveform in Various Output Compare Modes ..... | 243 |
| Table 20-5 Coding Mode .....                                                    | 248 |
| Table 20-6 Internal Trigger Input Mapping for Each GPTIMER.....                 | 249 |
| Table 20-7 GPTIMER Interrupt Signals .....                                      | 252 |
| Table 20-8 GPTIMER Register List .....                                          | 253 |

# List of Figures

---

|                                                                           |     |
|---------------------------------------------------------------------------|-----|
| Figure 3-1 ASR6601 SoC Diagram .....                                      | 4   |
| Figure 4-1 ASR6601 Power Grid .....                                       | 5   |
| Figure 4-2 ASR6601 Power Supply Architecture.....                         | 6   |
| Figure 7-1 System Architecture Diagram.....                               | 18  |
| Figure 8-1 Clock Tree .....                                               | 38  |
| Figure 12-1 Timing Sequence of Power-on.....                              | 103 |
| Figure 13-1 UART Character Frame .....                                    | 118 |
| Figure 13-2 IrDA Data Modulation (3/16).....                              | 119 |
| Figure 14-1 Connection between a SSP Master and a SPI Slave .....         | 135 |
| Figure 14-2 Connection between a SPI Master and a SSP Slave .....         | 135 |
| Figure 14-3 The Formula to Calculate Clock Output in Master Mode .....    | 135 |
| Figure 15-1 I2C Block Diagram .....                                       | 144 |
| Figure 15-2 SDA and SCL Signals During Start and Stop Conditions .....    | 145 |
| Figure 15-3 FIFO Mode Block Diagram.....                                  | 151 |
| Figure 16-1 ADC Diagram .....                                             | 166 |
| Figure 18-1 LPUART Data Format .....                                      | 203 |
| Figure 18-2 Connection between Two LPUART Devices.....                    | 204 |
| Figure 20-1 GPTIMER Block Diagram .....                                   | 237 |
| Figure 20-2 External Clock Mode 1 Counting .....                          | 238 |
| Figure 20-3 External Clock Mode 2 Counting .....                          | 238 |
| Figure 20-4 Internal Trigger Signal for Clock Counting .....              | 239 |
| Figure 20-5 Upcounting .....                                              | 239 |
| Figure 20-6 Downcounting .....                                            | 240 |
| Figure 20-7 Center-aligned Counting .....                                 | 240 |
| Figure 20-8 Prescaler .....                                               | 241 |
| Figure 20-9 Input Capture .....                                           | 243 |
| Figure 20-10 Waveforms in Various Output Compare Modes.....               | 244 |
| Figure 20-11 Edge- aligned Counting PWM2 .....                            | 245 |
| Figure 20-12 Center- aligned Counting PWM2 .....                          | 245 |
| Figure 20-13 Single Pulse Output Waveform when Fast Mode Is Enabled ..... | 245 |
| Figure 20-14 External Trigger Signal Clearing Channel Output.....         | 246 |
| Figure 20-15 Counting Waveform in Coding Mode 1 .....                     | 248 |
| Figure 20-16 Reset Mode Waveform in Slave Mode.....                       | 249 |
| Figure 20-17 Gated Mode Waveform in Slave Mode .....                      | 249 |
| Figure 20-18 Trigger Mode Waveform in Slave Mode .....                    | 250 |

# 1.

# Overview

ASR6601 is a general LPWAN Wireless Communication SoC chip developed by ASR which supports LoRa modulation. The chip integrates Sub-1G RF transceiver, Arm China STAR-MC1 processor, embedded Flash memory and SRAM, as well as diverse analog modules. ASR6601 is designed for a wide variety of applications, such as smart meters, building automation, smart cities, agricultural sensors, safety and security sensors, supply chain and logistics, etc.

This manual provides detailed and complete information on the IoT LPWAN SoC-ASR6601 for application developers. Together with the API file in SDK, it helps developers solve various problems they may encounter during development. If any further support is needed, please contact us. We will keep this manual updated.

## 2.

# ASR6601 Introduction

### 1.1 General

ASR6601 is a general LPWAN Wireless Communication SoC, with integrated RF Transceiver, Modem and a 32-bit RISC MCU. The MCU uses Arm China STAR-MC1 Processor, with 48 MHz operation frequency. The RF Transceiver has continuous frequency coverage from 150 MHz to 960 MHz. The Modem supports LoRa modulation for LPWAN use cases and (G)FSK modulation for legacy use cases. The Modem also supports BPSK modulation in TX and (G)MSK modulation in TX and RX.

ASR6601 LPWAN SoC supports Run, LpRun, Sleep, LpSleep, Stop0, Stop1, Stop2, Stop3 and Standby modes. Each mode supports different functions with different working modules and power consumption. The user can choose the appropriate operation mode according to specific application scenarios. Among all the low-power modes, the Standby and Stop3 modes are commonly used. With a 3.3V power supply, the power consumption is down to 0.9 uA (without RF/MCU Retention, with RTC) in Standby mode and is down to 1.3 uA (with RF/MCU Retention and RTC for ASR6601CB/CBR) and 1.6 uA (with RF/MCU Retention and RTC for ASR6601SE/SER) in Stop3 mode. The LPWAN Wireless Communication Module designed with ASR6601 provides ultra-long range and ultra-low power communication for LPWAN applications.

ASR6601 can achieve a high sensitivity to -148 dBm and the maximum transmit power is up to +22 dBm. This makes the chip suitable to be used in long-range LPWAN with high efficiency. The total chip package is of very small size, QFN 6 mm x 6 mm/QFN 8 mm x 8 mm.

### 1.2 Key Features

- Small footprint: QFN48, 6 mm x 6 mm or QFN68, 8 mm x 8 mm
- Frequency Range: 150 MHz ~ 960 MHz
- Maximum Power +22 dBm constant RF output
- High sensitivity: -148 dBm
- Programmable bit rate up to 62.5 Kbps in LoRa modulation mode
- Programmable bit rate up to 300 Kbps in (G)FSK modulation mode
- Preamble detection
- Embedded memories (up to 256 KB of Flash memory and 64 KB of SRAM).
- Up to 42 configurable GPIOs: 3 x I2C, 1 x I2S, 4 x UART, 1 x LPUART, 1 x SWD, 3 x SPI, 1 x QSPI and 2 x WDG
- 4 x GPtimer, 2 x Basic Timer, 2 x LP timer and 1 x Sys Ticker

- 48 MHz Arm China STAR-MC1 Processor
- 4-channel DMA engine x 2
- Support 37 IRQ interrupts with configurable 0~7 priority levels for each IRQ interrupt
- Embedded 12-bit 1 Msps SAR ADC
- Embedded 12-bit DAC
- 32.768 KHz External Watch Crystal Oscillator
- 32 MHz External Crystal Oscillator for RF Transceiver
- 24 MHz External Crystal Oscillator for SoC (optional)
- Embedded internal 4 MHz RC oscillator
- Embedded internal High frequency (48 MHz) RC oscillator
- Embedded internal Low frequency (32.768 KHz) RC oscillator
- Embedded internal PLL to generate 48 MHz clock
- Embedded 3 x OPA
- Embedded 2 x Low Power Comparator
- Embedded LCD driver
- Embedded LD, TD, VD and FD
- Supports AES, DES, RSA, ECC, SHA and SM2/3/4

# 3.

# ASR6601 Functions

## 3.1 ASR6601 SoC Diagram



Figure 3-1 ASR6601 SoC Diagram

# 4.

# Power Management Unit

## 4.1 Power Supply

ASR6601 has several separated power supply pins. With these separated power supply pins, the interference from digital parts of SoC to RF blocks is reduced.

ASR6601 Power Grid is shown in Figure 4-1:



Figure 4-1 ASR6601 Power Grid

- **VDD\_IN:** The power supply for the PA in the RF transmitter.
- **VBAT\_RF:** The power supply for the RF TRX, excluding the PA.
- **VDCC\_RF:** The low-power supply for RF TRX, which must be connected to VREG pin of SoC through the PCB.
- **VBAT\_ESD0:** The power supply for digital IO.
- **VBAT\_ESD1:** The power supply for digital IO.
- **VBAT\_ESD2:** The power supply for digital IO.
- **VBAT\_ESD3:** The power supply for digital IO.
- **VBAT\_DCC:** The dedicated power supply for DCDC in analog circuit.
- **VBAT\_ESD\_RTC:** The power supply for IOs in RTC domain.
- **VBAT\_RTC:** The power supply for analog blocks in RTC domain.
- **VBAT\_ANA:** The power supply for analog blocks.

## 4.2 Power Supply Architecture

Internal power domains of the chip are mainly divided into *main* domain, *aon* domain and *aonr* domain. Please note that the power domains are divided according to functions, as shown in Figure 4-2.

1. **Main** domain contains most of the digital logic circuits of the SoC chip. In the frequently-used low-power modes (Standby and Stop3), the power supply of main domain will be turned off.
2. **Aon** (always on domain) means that the power supply for this domain is always available, even in low-power mode. Most blocks in aon domain keep running in all power modes.
3. **Aonr** (Always on and retention) domain contains the modules that need to keep running in Stop3 mode. These modules will be powered off in Standby mode. When aonr domain modules remain in the current state without power off, the system can quickly recover and continue to execute.



Figure 4-2 ASR6601 Power Supply Architecture

# 5.

# Access Control

## 5.1 Simple Configuration

### 5.1.1 Recoverable Security Configuration

- **Enable Security**

Configure FlashSecStart to 0 and FlashSecEnd to 0x3F in OPTION1 tab, and set the entire Flash\_main area as a secure area.

Consequently, the code in SWD (Serial Wire Debug) and non-secure area cannot read and write data into Flash\_main to guarantee security. Please note that code in non-secure SRAM area or non secure DMA will not be able to access Flash\_main.

- **Disable Security**

Configure FlashSecStart to 0x3F and FlashSecEnd to 0 in OPTION1 tab, and set the entire Flash\_main area as a non-secure area.

The above configurations will erase the entire Flash\_main area, and then the program can be re-downloaded.

### 5.1.2 Unrecoverable Security Configuration

Configure the DebugLevel to 2 in Option0 tab. This operation is irreversible, and the code must be correct and strong.

## 5.2 Access Control

Based on debug\_level rules, boot mode, exe-only access rules, write-protected area access rules, info area access rules, and secure areas access rules, the access rights of the four main interfaces (cpucode, cpuw, dmac0 and dmac1) are controlled.

### 5.2.1 Debug Level Rules

Debug\_level mainly affects cpu\_code (boot from SRAM and boot from bootloader), cpu\_sw, dmac0 and dmac1 access to sensitive areas. Sensitive areas include the flash\_main area, the OTP partition of flash\_info area, and the retention SRAM.

### 5.2.2 Secure and Non-Secure Operation

- **Secure Operation**

The operations initiated by the code in the secure area include:

- ◆ Operations initiated by DMAC0 configured as a secure area
- ◆ Operations initiated by flash\_main configured as a secure area (CPU\_Code)
- ◆ Operations initiated by system\_sram configured as a secure area (CPU\_Code)

- **Non-secure Operation**

The operations initiated by the code in the non-secure area include:

- ◆ Operations initiated by DMAC0 configured as a non-secure area
- ◆ Operations initiated by DMAC1
- ◆ Operations initiated by Debug Port (CPU\_SW)
- ◆ Operations initiated by Bootloader (CPU\_Code)
- ◆ Operations initiated by flash\_main configured as a non-secure area (CPU\_Code)
- ◆ Operations initiated by system\_sram configured as a non-secure area (CPU\_Code)

# 6.

# Operation Mode

ASR6601 LPWAN SoC supports Run, LpRun, Sleep, LpSleep, Stop0, Stop1, Stop2, Stop3 and Standby modes. Each mode supports different functions with different working modules and power consumption. The user can choose the appropriate operation mode according to specific application scenarios. All modes are described detailedly in the contents below.

In addition, please note the following points:

1. When entering a low-power mode, peripherals marked as "O" (excluding GPIO) are turned off by default. The functions used in low-power mode must be turned on before entering low-power mode.
2. When entering a low-power mode, developers need to configure below items to achieve specified power consumption:
  - (1) Configure unused GPIOs to ANALOG mode (high impedance)
  - (2) If the GPIOs are in input mode, users should configure them pull-up or pull-down
  - (3) In output mode, configure the connected peripherals pull-up or pull-down according to the output level.
3. Use RCO48M/2 to enter or exit a low-power mode. If you use a clock other than RCO48M/2 before entering a low-power mode, you need to switch to RCO48M/2. After exiting the low-power mode, you can switch to the previously used clock.
4. RCO32K/XO32K and some other analog functions can retain active in low-power modes. If needed, turn on these functions before entering a low-power mode by software.
5. Clocks other than RCO48M/RCO32K/XO32K and the remaining analog function modules must be turned off by the software before entering a low-power mode.

**Table 6-1 Modules Working Status in Various Operation Modes**

|         | Run | LpRun | Sleep | LpSleep | Stop0 | Stop1 | Stop2 | Stop3 | Standby | Stop0-2 Wakeup | Stop3 Wakeup | Standby Wakeup |
|---------|-----|-------|-------|---------|-------|-------|-------|-------|---------|----------------|--------------|----------------|
| cpu     | Y   | Y     | NA    | NA      | NA    | NA    | NA    | NA    | NA      |                |              |                |
| efc     | Y   | Y     | O     | O       | NA    | NA    | NA    | NA    | NA      |                |              |                |
| sysramc | Y   | Y     | O     | O       | NA    | NA    | NA    | NA    | NA      |                |              |                |
| retramc | Y   | Y     | O     | O       | NA    | NA    | NA    | NA    | NA      |                |              |                |
| i2s     | O   | O     | O     | O       | NA    | NA    | NA    | NA    | NA      |                |              |                |
| uart0   | O   | O     | O     | O       | NA    | NA    | NA    | NA    | NA      |                |              |                |
| uart1   | O   | O     | O     | O       | NA    | NA    | NA    | NA    | NA      |                |              |                |
| uart2   | O   | O     | O     | O       | NA    | NA    | NA    | NA    | NA      |                |              |                |
| uart3   | O   | O     | O     | O       | NA    | NA    | NA    | NA    | NA      |                |              |                |
| ssp0    | O   | O     | O     | O       | NA    | NA    | NA    | NA    | NA      |                |              |                |

|           | Run | LpRun | Sleep | LpSleep | Stop0 | Stop1 | Stop2 | Stop3                        | Standby                        | Standby Wakeup | Stop3 Wakeup | Stop0-2 Wakeup |
|-----------|-----|-------|-------|---------|-------|-------|-------|------------------------------|--------------------------------|----------------|--------------|----------------|
| ssp1      | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| ssp2      | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| qspi      | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| i2c0      | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| i2c1      | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| i2c2      | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| adcctrl   | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| dacctrl   | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| gptim0    | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| gptim1    | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| gptim2    | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| gptim3    | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| basictim0 | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| basictim1 | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| wwdg      | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| crc       | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| sec       | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| sac       | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| mpu       | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| dmac0     | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| dmac1     | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| syscfg    | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| afec      | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| lorac     | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| gpio      | O   | O     | O     | O       | NA    | NA    | NA    | GPIO0~55: Y3<br>GPIO56~63:Y4 | GPIO0~55: NA3<br>GPIO56~63: Y4 | Y              | Y            |                |
| rcc       | Y   | Y     | Y     | Y       | Y     | Y     | Y     | Y                            | Y                              |                |              |                |
| pwr       | Y   | Y     | Y     | Y       | Y     | Y     | Y     | Y                            | Y                              |                |              |                |
| lpuart    | O   | O     | O     | O       | O     | O     | O     | O (RX only)                  | O (RX only)                    | Y              | Y            | Y              |
| lcdctrl   | O   | O     | O     | O       | O     | O     | O     | O                            | O                              |                |              |                |
| lptim0    | O   | O     | O     | O       | O     | O     | O     | O                            | O                              | Y              | Y            | Y              |
| lptim1    | O   | O     | O     | O       | O     | O     | O     | O                            | O                              | Y              | Y            | Y              |
| iwdg      | O   | O     | O     | O       | O     | O     | O     | O                            | O                              | Y1             | Y            | Y              |
| rtc       | O   | O     | O     | O       | O     | O     | O     | O                            | O                              | Y              | Y            | Y              |
| ADC       | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| RCO48M    | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| XO24M     | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| PLL48M    | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| RNG       | O   | O     | O     | O       | NA    | NA    | NA    | NA                           | NA                             |                |              |                |
| DAC       | O   | O     | O     | O       | O3    | O3    | O3    | NA                           | NA                             |                |              |                |

|         | Run | LpRun | Sleep | LpSleep | Stop0 | Stop1 | Stop2 | Stop3 | Standby | Standby Wakeup | Stop3 Wakeup | Stop0-2 Wakeup |
|---------|-----|-------|-------|---------|-------|-------|-------|-------|---------|----------------|--------------|----------------|
| OPA     | O   | O     | O     | O       | O     | O     | O     | NA    | NA      |                |              |                |
| COMP    | O   | O     | O     | O       | O     | O     | O     | O     | O       | Y              | Y            | Y              |
| VD      | O   | O     | O     | O       | O     | O     | O     | O     | O       | Y              | Y            | Y              |
| RCO3.6M | O   | O     | O     | O       | O     | O     | O     | O     | O       |                |              |                |
| RCO32K  | O   | O     | O     | O       | O     | O     | O     | O     | O       |                |              |                |
| XO32K   | O   | O     | O     | O       | O     | O     | O     | O     | O       |                |              |                |
| LCD     | O   | O     | O     | O       | O     | O     | O     | O     | O       |                |              |                |
| BOR     | Y   | Y     | Y     | Y       | Y     | Y     | Y     | Y     | Y       | Y2             | Y2           | Y2             |
| FLASH   | Y   | Y     | Y     | Y       | SLM   | SLM   | SLM   | PDM   | PDM     |                |              |                |
| SRAM    | Y   | Y     | Y     | Y       | NA    | NA    | NA    | NA1   | NA2     |                |              |                |
| IO      | Y   | Y     | Y     | Y       | Y     | Y     | Y     | Y     | Y       |                |              |                |
| RF      | O   | O     | O     | O       | O     | O     | O     | O     | O       | Y              | Y            | Y              |

Notes and symbol annotations for the above table:

- **Stop0-2:** all GPIOs can be configured to wake up the CPU; all GPIOs retain the previous state in Stop0-2 mode.
- **Stop3:** 56 GPIOs in the main domain can be configured to wake up the CPU; all GPIOs retain the previous state in Stop3 mode.
- **Standby:** 8 GPIOs in the AON domain retain the previous state in Standby mode; 56 GPIOs in the main domain are used as analog functions (such as LCD, COMP) and cannot be used to wake up the CPU. The LPUART only supports RX in Standby/Stop3 mode.
- **Y:** Work normally
- **O:** Optional, configured by software
- **O3:** Data update is not supported, but the output retains current voltage level
- **Y1:** Generate system reset to wake up the system indirectly
- **Y2:** Generate BOR reset to wake up the system indirectly
- **Y3:** Retain the state before entering low-power mode, and can be used to wake up the CPU.
- **Y4:** MUX Function1 of GPIO56~63 is not available and the other alternate functions is available
- **NA1:** Retention and algorithm contents are kept. System content can be configured to be kept or not.
- **NA2:** Retention content is kept
- **NA3:** Analog Output Only

## 6.1 Run

### 6.1.1 Enter and Exit

**Run** mode is the default operation mode after power-on or system reset.

ASR6601 can enter Sleep, LpRun, Stop0, Stop1, Stop2, Stop3 or Standby mode from **Run** mode.

ASR6601 can return to **Run** mode from Sleep, LpRun, Stop0, Stop1, Stop2, Stop3 or Standby mode.

For detailed mode switching conditions, please refer to the descriptions of other operation modes.

### 6.1.2 Wakeup Source

N/A

## 6.2 LpRun

### 6.2.1 Enter and Exit

Enter **LpRun** mode from Run mode in the following way:

Turn off all high-speed clocks to make CPU run at 32K clock frequency. Then switch the working state of LDO by software.

LpRun config register is used to switch LDO working state:

- (1) Set bits[3:3] of the register (address 0x05) to 1, and the other bits remain unchanged.
- (2) Set bits[21:20] of the register (address 0x06) to 1, and the other bits remain unchanged.

Return to **Run** mode from LpRun mode in the following way:

Switch the working state of LDO by software. Then turn on the high-speed clock

LpRun config register is used to switch LDO working state:

- (1) Clear bits[21:20] of the register (address 0x06) to 0, and the other bits remain unchanged.
- (2) Clear bits[3:3] of the register (address 0x05) to 0, and the other bits remain unchanged.

### 6.2.2 Wakeup Source

N/A

## 6.3 Sleep

### 6.3.1 Enter and Exit

Enter **Sleep** mode from Run mode in the following way:

CPU executes WFI/WFE instruction SLEEPDEEP=0, or isr returns SLEEPONEXIT=1 and SLEEPDEEP=0.

Return to **Run** mode from Sleep mode in the following ways:

- If WFI instruction is used to enter Sleep mode, then the system is waked-up by interrupts.
- If WFE instruction is used to enter Sleep mode, then the system is waked-up by events.

**Notice:** Since there is no dedicated wake-up event signal, the interrupt signal is used to generate wake-up events by instruction SVONPEND=1 and turning off the corresponding NVIC.

### 6.3.2 Wakeup Source

Interrupt signal generated by each module

## 6.4 LpSleep

### 6.4.1 Enter and Exit

Enter **LpSleep** mode from LpRun mode in the following way:

CPU executes WFI/WFE instruction SLEEPDEEP=0, or isr returns SLEEPONEXIT=1 and SLEEPDEEP=0.

Return to **LpRun** mode from LpSleep mode in the following ways:

- If WFI instruction is used to enter LpSleep mode, then the system returns LpRun mode by interrupts.
- If WFE instruction is used to enter LpSleep mode, then the system returns LpRun mode by wake-up events.

**Notice:** Since there is no dedicated event wake-up signal, the interrupt signal is used to generate wake-up events by instruction SVONPEND=1 and turning off the corresponding NVIC.

### 6.4.2 Wakeup Source

Interrupt signal of each module

## 6.5 Stop0

### 6.5.1 Enter and Exit

Enter **Stop0** mode from Run mode in the following way:

Configure lp\_mode to 2'b00, then CPU executes WFI/WFE instruction SLEEPDEEP=1, or isr returns SLEEPONEXIT=1 and SLEEPDEEP=1.

Return to **Run** mode from Stop0 mode in the following ways:

- If WFI instruction is used to enter Stop0 mode, then the system is waked-up by interrupts.
- If WFE instruction is used to enter Stop0 mode, then the system is waked-up by events.

The pwr module manages the status of the wake-up sources and outputs the *pwr\_wakeup\_int* signal and the *pwr\_wakeup\_event* signal to wake up the CPU.

### 6.5.2 Wakeup Source

- GPIO00-GPIO63 can all be used to wake up the CPU, 4 IOs make up a group, and each group can select any of the 4 IOs for wake-up. A group generates a wake-up signal, and any of the IOs can wake up the CPU at high or low level. The wake-up sources other than GPIOs are listed below.
  - PVM Alarm
  - VD Alarm
  - TD Alarm
  - LD Alarm
  - Comparator
  - LPTIM0/1
  - FD\_32K Alarm
  - Wakeup/Tamper IO
  - RTC Alarm
  - RTC CYC Timer
  - LPUART RX Status
  - LORA BUSY
  - LORA IRQ

## 6.6 Stop1

### 6.6.1 Enter and Exit

Enter **Stop1** mode from Run mode in the following way:

Configure lp\_mode to 2'b01, then CPU executes WFI/WFE instruction SLEEPDEEP=1, or isr returns SLEEPONEXIT=1 and SLEEPDEEP=1.

Return to **Run** mode from Stop1 mode in the following ways:

- If WFI instruction is used to enter Stop1 mode, then the system is waked-up by interrupts.
- If WFE instruction is used to enter Stop1 mode, then the system is waked-up by events.

The pwr module manages the status of the wake-up sources and outputs the *pwr\_wakeup\_int* signal and the *pwr\_wakeup\_event* signal to wake up the CPU.

### 6.6.2 Wakeup Source

- GPIO00-GPIO63 can all be used to wake up the CPU, 4 IOs make up a group, and each group can select any of the 4 IOs for wake-up. A group generates a wake-up signal, and any of the IOs can wake up the CPU at high or low level. The wake-up sources other than GPIOs are listed below.
  - PVM Alarm
  - VD Alarm
  - TD Alarm
  - LD Alarm
  - Comparator
  - LPTIM0/1
  - FD\_32K Alarm
  - Wakeup/Tamper IO
  - RTC Alarm
  - RTC CYC Timer
  - LPUART RX Status
  - LORA BUSY
  - LORA IRQ

## 6.7 Stop2

### 6.7.1 Enter and Exit

Enter **Stop2** mode from Run mode in the following way:

Configure lp\_mode to 2'b10, then CPU executes WFI/WFE instruction SLEEPDEEP=1, or isr returns SLEEPONEXIT=1 and SLEEPDEEP=1.

Return to **Run** mode from Stop2 mode in the following ways:

- If WFI instruction is used to enter Stop2 mode, then the system is waked-up by interrupts.
- If WFE instruction is used to enter Stop2 mode, then the system is waked-up by events.

The pwr module manages the status of the wake-up sources, and outputs *pwr\_wakeup\_int* signal and *pwr\_wakeup\_event* signal to wake up the CPU.

## 6.7.2 Wakeup Source

- GPIO00-GPIO63 can all be used to wake up the CPU, 4 IOs make up a group, and each group can select any of the 4 IOs for wake-up. A group generates a wake-up signal, and any of the IOs can wake up the CPU at high or low level. The wake-up sources other than GPIOs are listed below.
- PVM Alarm
- VD Alarm
- TD Alarm
- LD Alarm
- Comparator
- LPTIM0/1
- FD\_32K Alarm
- Wakeup/Tamper IO
- RTC Alarm
- RTC CYC Timer
- LPUART RX Status
- LORA BUSY
- LORA IRQ

## 6.8 Stop3

### 6.8.1 Enter and Exit

Enter **Stop3** mode from Run mode in the following way:

Configure lp\_mode to 2'b11 and lp\_mode\_ext to 1'b1, then CPU executes WFI/WFE instruction SLEEPDEEP=1, or isr returns SLEEPONEXIT=1 and SLEEPDEEP=1.

The system returns to **Run** mode if a wake-up event occurred in Stop3 mode.

### 6.8.2 Wakeup Source

- GPIO00-GPIO55 can all be used to wake up the CPU, 4 IOs make up a group, and each group can select any of the 4 IOs for wake-up. A group generates a wake-up signal, and any of the IOs can wake up the CPU at high or low level. The wake-up sources other than GPIOs are listed below.
- PVM Alarm
- VD Alarm
- Comparator
- LPTIM0/1
- FD\_32K Alarm
- Wakeup/Tamper IO
- RTC Alarm
- RTC CYC Timer
- LPUART RX Status
- LORA BUSY
- LORA IRQ
- IWDG Timeout

## 6.9 Standby

### 6.9.1 Enter and Exit

Enter **Standby** mode from Run mode in the following way:

Configure lp\_mode to 2'b11 and lp\_mode\_ext to 1'b0, then CPU executes WFI/WFE instruction SLEEPDEEP=1, or isr returns SLEEPONEXIT=1 and SLEEPDEEP=1.

The system returns to **Run** mode if a wake-up event occurred in Standby mode.

**Notice:**

1. When the power supply is switched between DCDC and VBAT, the CPU will return to Run mode immediately after entering Standby mode without any wake-up event.
2. When dbg\_standby=1, the switch between DCDC and VBAT is disabled.

### 6.9.2 Wakeup Source

- PVM Alarm
- VD Alarm
- Comparator
- LPTIM0/1
- FD\_32K Alarm
- Wakeup/Tamper IO
- RTC Alarm
- RTC CYC Timer
- LPUART RX Status
- LORA BUSY
- LORA IRQ
- IWDG Timeout

# 7.

# System Configuration

## 7.1 System Architecture



Figure 7-1 System Architecture Diagram

### 7.1.1 Arm China STAR-MC1 Processor

Arm China STAR-MC1 Processor consists of three master buses, including i code AHB bus, dcode AHB bus and system AHB bus, which are used for program access, data access and register access.

### 7.1.2 DMAC0

DMAC0 has a master bus, which can assist the CPU to transfer data.

### 7.1.3 DMAC1

DMAC1 has a master bus, which can assist the CPU to transfer data.

### 7.1.4 Master

The addresses accessible by each master bus is shown in the table below.

*(1) Only accessible when boot from Bootloader.*

Table 7-1 Master Bus Access Scope

| Start Address | End Address | Description                    | Execut-able | i code Access    | dcode Access     | system Access | DMAC0 Access | DMAC1 Access |
|---------------|-------------|--------------------------------|-------------|------------------|------------------|---------------|--------------|--------------|
| 0xE0100000    | 0xFFFFFFFF  | Reserved                       |             |                  |                  |               |              |              |
| 0xE0000000    | 0xE00FFFFF  | Arm China STAR-MC1 peripherals |             |                  |                  |               |              |              |
| 0xA0000000    | 0xDFFFFFFF  | Reserved                       |             |                  |                  |               |              |              |
| 0x70000000    | 0x9FFFFFFF  | Reserved                       |             |                  |                  |               |              |              |
| 0x60000000    | 0x6FFFFFFF  | Qspi Flash Bank                | Y           |                  |                  | Y             | Y            | Y            |
| 0x50000000    | 0x5FFFFFFF  | Reserved                       |             |                  |                  |               |              |              |
| 0x40030000    | 0x4FFFFFFF  | AHB1 SFR                       |             |                  |                  | Y             | Y            | Y            |
| 0x40020000    | 0x4002FFFF  | AHB0 SFR                       |             |                  |                  | Y             | Y            | Y            |
| 0x40010000    | 0x4001FFFF  | APB1 SFR                       |             |                  |                  | Y             | Y            | Y            |
| 0x40000000    | 0x4000FFFF  | APB0 SFR                       |             |                  |                  | Y             | Y            | Y            |
| 0x30000400    | 0x3FFFFFFF  | Reserved                       |             |                  |                  |               |              |              |
| 0x30000000    | 0x300003FF  | Retention SRAM                 |             |                  |                  | Y             | Y            | Y            |
| 0x20010000    | 0x2FFFFFFF  | Reserved                       |             |                  |                  |               |              |              |
| 0x20000000    | 0x2000FFFF  | System SRAM                    | Y           |                  |                  | Y             | Y            | Y            |
| 0x18010000    | 0x1FFFFFFF  | Reserved                       |             |                  |                  |               |              |              |
| 0x18000000    | 0x1800FFFF  | System SRAM                    | Y           | Y                | Y                |               |              |              |
| 0x10004000    | 0x17FFFFFF  | Reserved                       |             |                  |                  |               |              |              |
| 0x10003000    | 0x10003FFF  | Option Bytes                   |             |                  | Y                |               |              |              |
| 0x10002000    | 0x10002FFF  | Factory Bytes                  |             |                  | Y                |               |              |              |
| 0x10001C00    | 0x10001FFF  | OTP                            |             |                  | Y                |               |              |              |
| 0x10000000    | 0x10001BFF  | BootLoader                     |             | Y <sup>(1)</sup> | Y <sup>(1)</sup> |               |              |              |
| 0x08040000    | 0x0FFFFFFF  | Reserved                       |             |                  |                  |               |              |              |

| Start Address | End Address | Description                                          | Execut-able | i code Access | dcode Access | system Access | DMAC0 Access | DMAC1 Access |
|---------------|-------------|------------------------------------------------------|-------------|---------------|--------------|---------------|--------------|--------------|
| 0x08000000    | 0x0803FFFF  | Flash Main                                           | Y           | Y             | Y            |               | Y            | Y            |
| 0x00040000    | 0x07FFFFFF  | Reserved                                             |             |               |              |               |              |              |
| 0x00000000    | 0x0003FFFF  | Flash Main/BootLoader/<br>System SRAM <sup>(1)</sup> | Y           | Y             | Y            |               |              |              |

## 7.2 Memory Mapping

The Memory Mapping table is shown below. The bytes are coded in memory in Little Endian format, i.e. the least significant byte is in the lowest address.

Table 7-2 Memory Mapping

| Category       | Start Address | End Address   | Description                                          | Size   |
|----------------|---------------|---------------|------------------------------------------------------|--------|
| SYSTEM         | 0xE0100000    | 0xFFFFFFFFFFF | Reserved                                             |        |
| PPB            | 0xE0000000    | 0xE00FFFFFF   | Arm China STAR-MC1 peripherals                       |        |
| EXT PERIPHERAL | 0xA0000000    | 0xDFFFFFFF    | Reserved                                             |        |
| EXT SRAM       | 0x70000000    | 0x9FFFFFFF    | Reserved                                             |        |
|                | 0x60000000    | 0x6FFFFFFF    | QSPI Flash Bank                                      | 256 MB |
| PERIPHERAL     | 0x50000000    | 0x5FFFFFFF    | Reserved                                             |        |
|                | 0x40030000    | 0x4FFFFFFF    | AHB1 SFR                                             |        |
|                | 0x40020000    | 0x4002FFFF    | AHB0 SFR                                             |        |
|                | 0x40010000    | 0x4001FFFF    | APB1 SFR                                             |        |
|                | 0x40000000    | 0x4000FFFF    | APB0 SFR                                             |        |
| SRAM           | 0x30000400    | 0x3FFFFFFF    | Reserved                                             |        |
|                | 0x30000000    | 0x300003FF    | Retention SRAM                                       | 1 KB   |
|                | 0x20010000    | 0x2FFFFFFF    | Reserved                                             |        |
|                | 0x20000000    | 0x2000FFFF    | System SRAM                                          | 64 KB  |
| CODE           | 0x18010000    | 0x1FFFFFFF    | Reserved                                             |        |
|                | 0x18000000    | 0x1800FFFF    | System SRAM                                          | 64 KB  |
|                | 0x10004000    | 0x17FFFFFF    | Reserved                                             |        |
|                | 0x10003000    | 0x10003FFF    | Option Bytes                                         | 4 KB   |
|                | 0x10002000    | 0x10002FFF    | Factory Bytes                                        | 4 KB   |
|                | 0x10001C00    | 0x10001FFF    | OTP                                                  | 1 KB   |
|                | 0x10000000    | 0x10001BFF    | BootLoader                                           | 7 KB   |
|                | 0x08040000    | 0x0FFFFFFF    | Reserved                                             |        |
|                | 0x08000000    | 0x0803FFFF    | Flash Main                                           | 256 KB |
|                | 0x00040000    | 0x07FFFFFF    | Reserved                                             |        |
|                | 0x00000000    | 0x0003FFFF    | Flash Main/BootLoader/<br>System SRAM <sup>(1)</sup> | 256 KB |

<sup>(1)</sup> The memory corresponding to address 0x00000000 is determined by the boot mode.

### 7.2.1 AHB0 SFR

See the table below for AHB0 SFR Internal Address Mapping.

**Table 7-3 AHB0 SFR Internal Address Mapping**

| Start Address | End Address | Description | Size |
|---------------|-------------|-------------|------|
| 0x40025000    | 0x4002FFFF  | Reserved    |      |
| 0x40024000    | 0x40024FFF  | DMAC1       | 4KB  |
| 0x40023000    | 0x40023FFF  | DMAC0       | 4KB  |
| 0x40022000    | 0x40022FFF  | CRC         | 4KB  |
| 0x40021000    | 0x40021FFF  | QSPI        | 4KB  |
| 0x40020000    | 0x40020FFF  | EFC         | 4KB  |

### 7.2.2 AHB1 SFR

See the table below for AHB1 SFR Internal Address Mapping.

**Table 7-4 AHB1 SFR Internal Address Mapping**

| Start Address | End Address | Description | Size                   |
|---------------|-------------|-------------|------------------------|
| 0x40034000    | 0x4003FFFF  | Reserved    |                        |
| 0x40033000    | 0x40033FFF  | RNGC        | 4KB                    |
| 0x40030000    | 0x40032FFF  | SAC         | 12KB <sup>(1)(2)</sup> |

<sup>(1)</sup> Low 8KB is ARAM space, and high 4KB is for registers.

<sup>(2)</sup> ARAM space can only be accessed in word.

### 7.2.3 APB0 SFR

See the table below for APB0 SFR Internal Address Mapping.

**Table 7-5 APB0 SFR Internal Address Mapping**

| Start Address | End Address | Description | Size |
|---------------|-------------|-------------|------|
| 0x4000f000    | 0x4000FFFF  | SEC         | 4KB  |
| 0x4000e000    | 0x4000EFFF  | RTC         | 4KB  |
| 0x4000d800    | 0x4000DFFF  | LPTIM1      | 2KB  |
| 0x4000d000    | 0x4000D7FF  | LPTIM0      | 2KB  |
| 0x4000c000    | 0x4000CFFF  | BASICTIM0   | 4KB  |
| 0x4000b000    | 0x4000BFFF  | GPTIM2      | 4KB  |
| 0x4000a000    | 0x4000AFFF  | GPTIM0      | 4KB  |
| 0x40009000    | 0x40009FFF  | LORAC       | 4KB  |
| 0x40008000    | 0x40008FFF  | AFEC        | 4KB  |
| 0x40007000    | 0x40007FFF  | I2C0        | 4KB  |
| 0x40006000    | 0x40006FFF  | SSP0        | 4KB  |

| Start Address | End Address | Description | Size |
|---------------|-------------|-------------|------|
| 0x40005000    | 0x40005FFF  | LPUART      | 4KB  |
| 0x40004000    | 0x40004FFF  | UART1       | 4KB  |
| 0x40003000    | 0x40003FFF  | UART0       | 4KB  |
| 0x40002000    | 0x40002FFF  | I2S         | 4KB  |
| 0x40001800    | 0x40001FFF  | PWR         | 2KB  |
| 0x40001000    | 0x400017FF  | SYSCFG      | 2KB  |
| 0x40000000    | 0x40000FFF  | RCC         | 4KB  |

#### 7.2.4 APB1 SFR

See the table below for APB1 SFR Internal Address Mapping.

Table 7-6 APB1 SFR Internal Address Mapping

| Start Address | End Address | Description | Size |
|---------------|-------------|-------------|------|
| 0x4001fc00    | 0x4001FFFF  | PortD       | 1KB  |
| 0x4001f800    | 0x4001FBFF  | PortC       | 1KB  |
| 0x4001f400    | 0x4001F7FF  | PortB       | 1KB  |
| 0x4001f000    | 0x4001F3FF  | PortA       | 1KB  |
| 0x4001e000    | 0x4001EFFF  | WWDG        | 4KB  |
| 0x4001d000    | 0x4001DFFF  | IWDG        | 4KB  |
| 0x4001c000    | 0x4001CFFF  | BASICTIM1   | 4KB  |
| 0x4001b000    | 0x4001BFFF  | GPTIM3      | 4KB  |
| 0x4001a000    | 0x4001AFFF  | GPTIM1      | 4KB  |
| 0x40019000    | 0x40019FFF  | DACCTRL     | 4KB  |
| 0x40018000    | 0x40018FFF  | LCDCTRL     | 4KB  |
| 0x40017000    | 0x40017FFF  | ADCCTRL     | 4KB  |
| 0x40016000    | 0x40016FFF  | Reserved    | 4KB  |
| 0x40015000    | 0x40015FFF  | I2C2        | 4KB  |
| 0x40014000    | 0x40014FFF  | I2C1        | 4KB  |
| 0x40013000    | 0x40013FFF  | SSP2        | 4KB  |
| 0x40012000    | 0x40012FFF  | SSP1        | 4KB  |
| 0x40011000    | 0x40011FFF  | UART3       | 4KB  |
| 0x40010000    | 0x40010FFF  | UART2       | 4KB  |

## 7.3 SRAM

The SRAM in ASR6601 includes system SRAM, retention SRAM and SAC SRAM. SAC SRAM only supports word access, and system SRAM and retention SRAM support word, halfword, and byte access.

## 7.4 Boot Mode

The boot mode can be configured by the levels of BOOT0 pin (GPIO02) and the data in the Flash.

Table 7-7 ASR6601 Boot Mode Configuration

| DEBUG_LEVEL | USE_FLASH_BOOT0 | FLASH_BOOT0 | BOOT0_PIN | FLASH_BOOT1 | MAIN_FLASH_EMPTY | Boot Config                |
|-------------|-----------------|-------------|-----------|-------------|------------------|----------------------------|
| 2           | X               | X           | X         | X           | X                | Boot from Flash Main       |
| <2          | 0               | X           | 0         | X           | 0                | Boot from Flash Main       |
| <2          | 0               | X           | 0         | X           | 1                | Boot from inner Bootloader |
| <2          | 0               | X           | 1         | 1           | X                | Boot from inner Bootloader |
| <2          | 0               | X           | 1         | 0           | X                | Boot from System SRAM      |
| <2          | 1               | 1           | X         | X           | 0                | Boot from Flash Main       |
| <2          | 1               | 1           | X         | X           | 1                | Boot from inner Bootloader |
| <2          | 1               | 0           | X         | 1           | X                | Boot from inner Bootloader |
| <2          | 1               | 0           | X         | 0           | X                | Boot from System SRAM      |

- DebugLevel, UseFlashBoot0, FlashBoot0 and FlashBoot1 is the information area of the Flash, they can be modified according to the application.  
MainFlashEmpty is determined by the data of address 0 in the Flash Main area. If the data in the address 0 of Flash Main area is 0xFFFFFFFF, the value of MainFlashEmpty is 1, otherwise the value of MainFlashEmpty is 0. BOOT0 pin is GPIO02 in the package.
- The boot mode is selected according to the configurations when the system is in these status: first powered up, exit the Standby mode or reset.

## 7.5 SYSCFG Registers

SYSCFG Base Address: 0x40001000

**Table 7-8 SYSCFG Register Summary**

| Register Name | Address Offset | Description                                    |
|---------------|----------------|------------------------------------------------|
| SYSCFG_CR0    | 0x000          | Control Register 0, DMA handshake              |
| SYSCFG_CR1    | 0x004          | Control Register 1, DMA handshake              |
| SYSCFG_CR2    | 0x008          | Control Register 2                             |
| SYSCFG_CR3    | 0x00C          | Control Register 3                             |
| SYSCFG_CR4    | 0x010          | Control Register 4                             |
| SYSCFG_CR5    | 0x014          | Control Register 5                             |
| SYSCFG_CR6    | 0x018          | Control Register 6, secure lock control        |
| SYSCFG_CR7    | 0x01C          | Control Register 7, secure lock control        |
| SYSCFG_CR8    | 0x020          | Control Register 8, QSPI memory encryption key |
| SYSCFG_CR9    | 0x024          | Control Register 9, QSPI REMAP                 |
| SYSCFG_CR10   | 0x028          | Control Register 10                            |

### 7.5.1 SYSCFG\_CR0

Address Offset: 0x000

Reset Value: 0x00000000

| 31-30    | 29-24                | 23-22    | 21-16                |
|----------|----------------------|----------|----------------------|
| RESERVED | DMAC0_HANDSHAKE0_SEL | RESERVED | DMAC0_HANDSHAKE1_SEL |
| r        | r/w                  | r        | r/w                  |
| 15-14    | 13-8                 | 7-6      | 5-0                  |
| RESERVED | DMAC0_HANDSHAKE2_SEL | RESERVED | DMAC0_HANDSHAKE3_SEL |
| r        | r                    | r        | r/w                  |

**Bits 31-30 RESERVED:** Must be kept, and can't be modified.

**Bits 29-24 DMAC0\_HANDSHAKE0\_SEL:** DMAC0 HANDSHAKE0 selection. For details, please refer to [Table7-9 DMA Request MUX](#).

**Bits 23-22 RESERVED:** Must be kept, and can't be modified.

**Bits 21-16 DMAC0\_HANDSHAKE1\_SEL:** DMAC0 HANDSHAKE1 selection. For details, please refer to [Table7-9 DMA Request MUX](#).

**Bits 15-14 RESERVED:** Must be kept, and cannot be modified.

**Bits 13-8 DMAC0\_HANDSHAKE2\_SEL:** DMAC0 HANDSHAKE2 selection. For details, please refer to [Table7-9 DMA Request MUX](#).

**Bits 7-6 RESERVED:** Must be kept, and cannot be modified.

**Bits 5-0 DMAC0\_HANDSHAKE3\_SEL:** DMAC0 HANDSHAKE3 selection. For details, please refer to [Table7-9 DMA Request MUX](#).

### 7.5.2 SYSCFG\_CR1

Address Offset: 0x004

Reset Value: 0x00000000

| 31-30    | 29-24                | 23-22    | 21-16                |
|----------|----------------------|----------|----------------------|
| RESERVED | DMAC1_HANDSHAKE0_SEL | RESERVED | DMAC1_HANDSHAKE1_SEL |
| r        | r/w                  | r        | r/w                  |
| 15-14    | 13-8                 | 7-6      | 5-0                  |
| RESERVED | DMAC1_HANDSHAKE2_SEL | RESERVED | DMAC1_HANDSHAKE3_SEL |
| r        | r                    | r        | r/w                  |

**Bits 31-30 RESERVED:** Must be kept, and cannot be modified.

**Bits 29-24 DMAC1\_HANDSHAKE0\_SEL:** DMAC1 HANDSHAKE0 selection. For details, please refer to [Table7-9 DMA Request MUX](#).

**Bits 23-22 RESERVED:** Must be kept, and cannot be modified.

**Bits 21-16 DMAC1\_HANDSHAKE1\_SEL:** DMAC1 HANDSHAKE1 selection. For details, please

refer to [Table7-9 DMA Request MUX](#).

**Bits 15-14 RESERVED:** Must be kept, and cannot be modified.

**Bits 13-8 DMAC1\_HANDSHAKE2\_SEL:** DMAC1 HANDSHAKE2 selection. For details, please refer to [Table7-9 DMA Request MUX](#).

**Bits 7-6 RESERVED:** Must be kept, and cannot be modified.

**Bits 5-0 DMAC1\_HANDSHAKE3\_SEL:** DMAC1 HANDSHAKE3 selection. For details, please refer to [Table7-9 DMA Request MUX](#).

### 7.5.3 SYSCFG\_CR2

Address Offset: 0x008

Reset Value: 0x00000000

| 31                          | 30                          | 29-28                          | 27                             |
|-----------------------------|-----------------------------|--------------------------------|--------------------------------|
| RESERVED                    | SYSCFG_HALTED_IPTI<br>M1_EN | RESERVED                       | SYSCFG_HALTED_LPT<br>IM0_EN    |
| r                           | r/w                         | r                              | r/w                            |
| 26                          | 25                          | 24                             | 23                             |
| SYSCFG_HALTED_IW<br>DG_EN   | SYSCFG_HALTED_WW<br>DG_EN   | SYSCFG_HALTED_GP<br>TIM0_EN    | SYSCFG_HALTED_GP<br>TIM1_EN    |
| r/w                         | r/w                         | r/w                            | r/w                            |
| 22                          | 21                          | 20                             | 19                             |
| SYSCFG_HALTED_GP<br>TIM2_EN | SYSCFG_HALTED_GP<br>TIM3_EN | SYSCFG_HALTED_BA<br>SICTIM0_EN | SYSCFG_HALTED_BA<br>SICTIM1_EN |
| r/w                         | r/w                         | r/w                            | r/w                            |
| 18                          | 17                          | 16-12                          |                                |
| QSPI_MEM_ENCRYPT<br>_EN     | QSPI_REMAP_ENABLE           |                                | RESERVED                       |
| r/w                         | r/w                         | r                              |                                |
| 11                          | 10                          | 9-8                            |                                |
| CPU_STCALIB_SKEW            | SYSCFG_DBG_SLEEP            |                                | RESERVED                       |
| r/w                         | r/w                         | r                              |                                |
| 7                           | 6                           | 5                              | 4                              |
| UART0_DMA_CLR_SEL           | UART1_DMA_CLR_SEL           | UART2_DMA_CLR_SEL              | UART3_DMA_CLR_SEL              |
| r/w                         | r/w                         | r/w                            | r/w                            |
| 3                           | 2                           | 1                              | 0                              |
| SSP0_DMA_CLR_SEL            | SSP1_DMA_CLR_SEL            | SSP2_DMA_CLR_SEL               | SSP_AFEC_DMA_CLR<br>_SEL       |
| r/w                         | r/w                         | r/w                            | r/w                            |

**Bit 31 RESERVED:** Must be kept, and cannot be modified.

**Bit 30 SYSCFG\_HALTED\_LPTIM1\_EN:** Whether the LPTIM1 counter is stopped when the core is halted

- 0: LPTIM1 counter continues to work normally when the core is halted
- 1: LPTIM1 counter is stopped when the core is halted

**Bit 29-28 RESERVED:** Must be kept, and cannot be modified.

**Bit 27 SYSCFG\_HALTED\_LPTIM0\_EN:** Whether the LPTIM0 counter is stopped when the core is halted

- 0: LPTIM0 counter continues to work normally when the core is halted
- 1: LPTIM0 counter is stopped when the core is halted

**Bit 26 SYSCFG\_HALTED\_IWDG\_EN:** Whether the independent watchdog counter is stopped when the core is halted

- 0: the independent watchdog counter continues to work normally when the core is halted
- 1: the independent watchdog counter is stopped when the core is halted

**Bit 25 SYSCFG\_HALTED\_WWDG\_EN:** Whether the window watchdog counter is stopped when the core is halted

- 0: The window watchdog counter continues to work normally when the core is halted
- 1: The window watchdog counter is stopped when the core is halted

**Bit 24 SYSCFG\_HALTED\_GPTIM0\_EN:** Whether the GPTIM0 counter is stopped when the core is halted

- 0: GPTIM0 counter continues to work normally when the core is halted
- 1: GPTIM0 counter is stopped when the core is halted

**Bit 23 SYSCFG\_HALTED\_GPTIM1\_EN:** Whether the GPTIM1 counter is stopped when the core is halted

- 0: GPTIM1 counter continues to work normally when the core is halted
- 1: GPTIM1 counter is stopped when the core is halted

**Bit 22 SYSCFG\_HALTED\_GPTIM2\_EN:** Whether the GPTIM2 counter is stopped when the core is halted

- 0: GPTIM2 counter continues to work normally when the core is halted
- 1: GPTIM2 counter is stopped when the core is halted

**Bit 21 SYSCFG\_HALTED\_GPTIM3\_EN:** Whether the GPTIM3 counter is stopped when the core is halted

- 0: GPTIM3 counter continues to work normally when the core is halted
- 1: GPTIM3 counter is stopped when the core is halted

**Bit 20 SYSCFG\_HALTED\_BASICTIM0\_EN:** Whether the BASICTIM0 counter is stopped when the core is halted

- 0: BASICTIM0 counter continues to work normally when the core is halted
- 1: BASICTIM0 counter is stopped when the core is halted

**Bit 19 SYSCFG\_HALTED\_BASICTIM1\_EN:** Whether the BASICTIM1 counter is stopped when the core is halted

- 0: BASICTIM1 counter continues to work normally when the core is halted
- 1: BASICTIM1 counter is stopped when the core is halted

**Bit 18 QSPI\_MEM\_ENCRYPT\_EN:** QSPI memory encryption enable

- 0: disabled
- 1: enabled

**Bit 17 QSPI\_REMAP\_ENABLE:** QSPI remap function enable

- 0: disabled
- 1: enabled

**Bit 16-12 RESERVED:** Must be kept, and cannot be modified.

**Bit 11 CPU\_STCALIB\_SKEW:** CPU SysTick skew configuration

- 0: no skew
- 1: skew exist

**Bit 10 SYSCFG\_DBG\_SLEEP:** Whether to allow a debug connection in Deepsleep mode

It is only used in debug mode and it will affect the Deepsleep mode.

- 0: not allowed
- 1: allowed

**Bit 9-8 RESERVED:** Must be kept, and cannot be modified.

**Bit 7 UART0\_DMA\_CLR\_SEL:** UART0 DMA\_CLR signal selection

It is recommended to set this bit to improve DMAC transfer efficiency. UART module uses the synchronized DMA\_CLR signal by default.

- 0: use the DMA\_CLR signal after 2 cycles
- 1: directly use the DMA\_CLR signal output by DMAC

**Bit 6 UART1\_DMA\_CLR\_SEL:** UART1 DMA\_CLR signal selection

It is recommended to set this bit to improve DMAC transfer efficiency. UART module uses the synchronized DMA\_CLR signal by default.

- 0: use the DMA\_CLR signal after 2 cycles
- 1: directly use the DMA\_CLR signal output by DMAC

**Bit 5 UART2\_DMA\_CLR\_SEL:** UART2 DMA\_CLR signal selection

It is recommended to set this bit to improve DMAC transfer efficiency. UART module uses the synchronized DMA\_CLR signal by default.

- 0: use the DMA\_CLR signal after 2 cycles
- 1: directly use the DMA\_CLR signal output by DMAC

**Bit 4 UART3\_DMA\_CLR\_SEL:** UART3 DMA\_CLR signal selection

It is recommended to set this bit to improve DMAC transfer efficiency. UART module uses the synchronized DMA\_CLR signal by default.

- 0: use the DMA\_CLR signal after 2 cycles
- 1: directly use the DMA\_CLR signal output by DMAC

**Bit 3 SSP0\_DMA\_CLR\_SEL:** SSP0 DMA\_CLR signal selection

It is recommended to set this bit to improve DMAC transfer efficiency. SSP module uses the synchronized DMA\_CLR signal by default.

- 0: use the DMA\_CLR signal after 2 cycles
- 1: directly use the DMA\_CLR signal output by DMAC

**Bit 2 SSP1\_DMA\_CLR\_SEL:** SSP1 DMA\_CLR signal selection

It is recommended to set this bit to improve DMAC transfer efficiency. SSP module uses the synchronized DMA\_CLR signal by default.

- 0: use the DMA\_CLR signal after 2 cycles
- 1: directly use the DMA\_CLR signal output by DMAC

**Bit 1 SSP2\_DMA\_CLR\_SEL:** SSP2 DMA\_CLR signal selection

It is recommended to set this bit to improve DMAC transfer efficiency. SSP module uses the synchronized DMA\_CLR signal by default.

- 0: use the DMA\_CLR signal after 2 cycles
- 1: directly use the DMA\_CLR signal output by DMAC

**Bit 0 SSP\_AFEC\_DMA\_CLR\_SEL:** SSP (for afec) DMA\_CLR signal selection

It is recommended to set this bit to improve DMAC transfer efficiency. SSP module uses the synchronized DMA\_CLR signal by default.

- 0: use the DMA\_CLR signal after 2 cycles
- 1: directly use the DMA\_CLR signal output by DMAC

## 7.5.4 SYSCFG-CR3

Address Offset: 0x00C

Reset Value: 0x00000000

This register is in the AON domain.

| 31-2     | 1               | 0                  |
|----------|-----------------|--------------------|
| RESERVED | SYSCFG_DBG_STOP | SYSCFG_DBG_STANDBY |
| r        | r/w             | r/w                |

**Bits 31-2 RESERVED:** MUST BE KEPT, AND CANNOT BE MODIFIED.

**Bit 1 SYSCFG\_DBG\_STOP:** Whether to allow a debug connection in Stop mode

It is only used in debug and it will affect the implementation of Stop mode.

- 0: not allowed
- 1: allowed

**Bit 0 SYSCFG\_DBG\_STANDBY:** Whether to allow a debug connection in Standby mode

It is only used in debug and it will affect the implementation of Standby mode.

- 0: not allowed
- 1: allowed

### 7.5.5 SYSCFG\_CR4

Address Offset: 0x010

Reset Value: 0x00000000

This register is in the AON domain.

| 31             | 30-0         |
|----------------|--------------|
| SYSCFG_CR4_REG | USER-DEFINED |
| r/w            | r/w          |

**Bit 31 SYSCFG\_CR4\_REG:** LPTIM1\_IN2 remapping enable

- 0: disabled, LPTIM1\_IN2 is determined by GPIO AFR
- 1: enabled, LPTIM1\_IN2 is derived from LPTIM0\_IN1

**Bits 30-0 USER-DEFINED:** These bits are user-defined and can be used to store a small amount of data by software.

### 7.5.6 SYSCFG\_CR5

Address Offset: 0x014

Reset Value: 0x00000000

This register is in the AON domain.

| 31-0           |
|----------------|
| SYSCFG_CR5_REG |
| r/w            |

**Bits 31-0 SYSCFG\_CR5\_REG:** These bits are user-defined and can be used to store a small amount of data by software.

### 7.5.7 SYSCFG\_CR6

Address Offset: 0x018

Reset Value: 0x00000000

| 31-16           | 15               | 14-5                        | 4                            |
|-----------------|------------------|-----------------------------|------------------------------|
| RESERVED        | RNGC_SECURE_LOCK | ANALOG_MAIN_SECU<br>RE_LOCK | RESERVED                     |
| r               | r/w              | r/w                         | r                            |
| 3               | 2                | 1                           | 0                            |
| SEC_SECURE_LOCK | SAC_SECURE_LOCK  | DMAC0_SLAVE_SECU<br>RE_LOCK | DMAC0_MASTER_SEC<br>URE_LOCK |
| r/w             | r/w              | r/w                         | r/w                          |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bit 15 RNGC\_SECURE\_LOCK:** RNGC security lock

- 0: no security lock
- 1: security lock enabled

**Bits 14-5 ANALOG\_MAIN\_SECURE\_LOCK:** Security lock for main domain configuration of AFEC

[5] Correspond to VD

- 0: no security lock
- 1: security lock enabled

[6] Correspond to TD

- 0: no security lock
- 1: security lock enabled

[7] Correspond to LD

- 0: no security lock
- 1: security lock enabled

[8] Correspond to FD24M

- 0: no security lock
- 1: security lock enabled

[9] Correspond to FD32M

- 0: no security lock
- 1: security lock enabled

[10] Correspond to RNG

- 0: no security lock
- 1: security lock enabled

[11] Correspond to TEST

- 0: no security lock
- 1: security lock enabled

[14:12]: Unused

- 0: no security lock
- 1: security lock enabled

**Bit 4 RESERVED:** Must be kept, and cannot be modified.**Bit 3 SEC\_SECURE\_LOCK:** SEC security lock

- 0: no security lock
- 1: security lock enabled

**Bit 2 SAC\_SECURE\_LOCK:** SAC security lock

- 0: no security lock
- 1: security lock enabled

**Bit 1 DMAC0\_SLAVE\_SECURE\_LOCK:** DMAC0 slave interface security lock

- 0: no security lock
- 1: security lock enabled

**Bit 0 DMAC0\_MASTER\_SECURE\_LOCK:** DMAC0 master interface security lock

- 0: no security lock
- 1: security lock enabled

## 7.5.8 SYSCFG\_CR7

Address Offset: 0x01C

Reset Value: 0x00000000

This register is in the AON domain.

| 31-15                   | 14-5                     | 4                        |                        |
|-------------------------|--------------------------|--------------------------|------------------------|
| RESERVED                | ANALOG_AON_SECURE_LOCK   | RTC_CALENDAR_SECURE_LOCK |                        |
| r                       | r/w                      | r/w                      |                        |
| 3                       | 2                        | 1                        | 0                      |
| RTC_WAKEUP2_SECURE_LOCK | RTC_WAKEUP1_SECU RE_LOCK | RTC_WAKEUP0_SECU RE_LOCK | RTC_TAMPER_SECURE_LOCK |
| r/w                     | r/w                      | r/w                      | r/w                    |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 14-5 ANALOG\_AON\_SECURE\_LOCK:** Security lock for AON domain configuration of AFEC

[5] Correspond to LPLDO

- 0: no security lock
- 1: security lock enabled

[6] Correspond to RCO3.6M

- 0: no security lock
- 1: security lock enabled

[7] Correspond to PWRSW

- 0: no security lock
- 1: security lock enabled

[8] Correspond to RCO32K

- 0: no security lock
- 1: security lock enabled

[9] Correspond to XO32K

- 0: no security lock
- 1: security lock enabled

[10] Correspond to LDO12

- 0: no security lock
- 1: security lock enabled

[11] Correspond to FD32K

- 0: no security lock
- 1: security lock enabled

[14:12] Unused

- 0: no security lock
- 1: security lock enabled

**Bit 4 RTC\_CALENDAR\_SECURE\_LOCK:** Calendar configuration security lock in RTC

- 0: no security lock

- 1: security lock enabled

**Bit 3 RTC\_WAKEUP2\_SECURE\_LOCK:** Wakeup2 configuration security lock in RTC

- 0: no security lock
- 1: security lock enabled

**Bit 2 RTC\_WAKEUP1\_SECURE\_LOCK:** Wakeup1 configuration security lock in RTC

- 0: no security lock
- 1: security lock enabled

**Bit 1 RTC\_WAKEUP0\_SECURE\_LOCK:** Wakeup0 configuration security lock in RTC

- 0: no security lock
- 1: security lock enabled

**Bit 0 RTC\_TAMPER\_SECURE\_LOCK:** Tamper configuration security lock in RTC

- 0: no security lock
- 1: security lock enabled

### 7.5.9 SYSCFG\_CR8

Address Offset: 0x020

Reset Value: 0x00000000

| 31-0                 |
|----------------------|
| QSPI_MEM_ENCRYPT_KEY |
| r/w                  |

**Bits 31-0 QSPI\_MEM\_ENCRYPT\_KEY:** Encryption key for QSPI memory

### 7.5.10 SYSCFG\_CR9

Address Offset: 0x024

Reset Value: 0x00000000

| 31-28    | 27-14               | 13-0                |
|----------|---------------------|---------------------|
| RESERVED | QSPI_REMAP_SRC_ADDR | QSPI_REMAP_DST_ADDR |
| r        | r/w                 | r/w                 |

**Bits 31-28 RESERVED:** Must be kept, and cannot be modified.

**Bits 27-14 QSPI\_REMAP\_SRC\_ADDR:** QSPI remap source address, aligned in 1KB

**Bits 13-0 QSPI\_REMAP\_DST\_ADDR:** QSPI remap destination address, aligned in 1KB

### 7.5.11 SYSCFG\_CR10

Address Offset: 0x028

Reset Value: 0x00000000

| 31-24    | 23         | 22        | 21-15      | 14           | 13-0            |
|----------|------------|-----------|------------|--------------|-----------------|
| RESERVED | I2S_WS_SEL | I2S_WS_EN | I2S_WS_LEN | I2S_MODE_SEL | QSPI_REMAP_SIZE |
| r        | r/w        | r/w       | r/w        | r/w          | r/w             |

**Bits 31-24 RESERVED:** Must be kept, and cannot be modified.

**Bit 23 I2S\_WS\_SEL:** I2S WS output delay enable

- 0: output delay disabled
- 1: output delay enabled

**Notice:** This bit can only be configured when the I2S acts as master interface. When enabled, the WS signal is output one cycle later than the data transmission.

**Bit 22 I2S\_WS\_EN:** I2S WS enable

- 0: disabled
- 1: enabled

**Notice:** This bit can only be configured when the I2S acts as master interface. When enabled, the WS signal is generated based on the I2S\_WS\_LEN configuration.

**Bits 21-15 I2S\_WS\_LEN:** I2S main interface resolution configuration

N: WS frequency=I2S interface clock frequency/[(N+1)\*2]

The I2S interface clock frequency is jointly determined by the I2S\_CLK\_DIV and I2S\_CLK\_SEL bits in the [RCC\\_CR3](#) and [RCC\\_CR2](#) registers.

**Bit 14 I2S\_MODE\_SEL:** I2S works in master or slave mode

- 0: slave mode
- 1: master mode

**Notice:** In addition to this register, it is also necessary to configure the I2S\_CLK\_DIV and I2S\_CLK\_SEL bits in the [RCC\\_CR3](#) and [RCC\\_CR2](#) registers, as well as the alternate functions of GPIOs.

**Bits 13-0 QSPI\_REMAP\_SIZE:** Address space for QSPI remapping, aligned in 1KB

## 7.6 DMA Request MUX

Table 7-9 DMA Request MUX

| No. | Source       |
|-----|--------------|
| 63  |              |
| 62  |              |
| 61  |              |
| 60  |              |
| 59  |              |
| 58  |              |
| 57  |              |
| 56  |              |
| 55  |              |
| 54  |              |
| 53  | basictim0_up |
| 52  | basictim1_up |
| 51  | gptim3_up    |
| 50  | gptim3_trg   |
| 49  | gptim3_ch0   |
| 48  | gptim3_ch1   |
| 47  | gptim2_up    |
| 46  | gptim2_trg   |
| 45  | gptim2_ch0   |
| 44  | gptim2_ch1   |
| 43  | gptim1_up    |
| 42  | gptim1_trg   |
| 41  | gptim1_ch0   |
| 40  | gptim1_ch1   |
| 39  | gptim1_ch2   |
| 38  | gptim1_ch3   |
| 37  | gptim0_up    |
| 36  | gptim0_trg   |
| 35  | gptim0_ch0   |
| 34  | gptim0_ch1   |
| 33  | gptim0_ch2   |
| 32  | gptim0_ch3   |
| 31  | uart0_rx     |
| 30  | uart0_tx     |
| 29  | uart1_rx     |
| 28  | uart1_tx     |
| 27  | uart2_rx     |
| 26  | uart2_tx     |

| No. | Source    |
|-----|-----------|
| 25  | uart3_rx  |
| 24  | uart3_tx  |
| 23  | lpuart_rx |
| 22  | lpuart_tx |
| 21  | ssp0_rx   |
| 20  | ssp0_tx   |
| 19  | ssp1_rx   |
| 18  | ssp1_tx   |
| 17  | ssp2_rx   |
| 16  | ssp2_tx   |
| 15  | i2c0_rx   |
| 14  | i2c0_tx   |
| 13  | i2c1_rx   |
| 12  | i2c1_tx   |
| 11  | i2c2_rx   |
| 10  | i2c2_tx   |
| 9   |           |
| 8   |           |
| 7   | adcctrl   |
| 6   | dacctrl   |
| 5   | lorac_rx  |
| 4   | lorac_tx  |
| 3   |           |
| 2   |           |
| 1   |           |
| 0   |           |

# 8. Reset and Clock Control (RCC)

## 8.1 Reset

There are four types of reset: external reset, power reset, system reset and low-power reset.

### 8.1.1 External Reset

The external reset is triggered by RSTN IO input (active at low level).

The external reset is used to reset all digital logic.

### 8.1.2 Power-on Reset

The power-on reset is generated by the BOR (Brownout reset) circuitry. The BOR circuitry monitors VBAT to ensure that the internal reset is released when the voltage is greater than 1.8V.

Power-on reset is used to reset all digital logic.

### 8.1.3 System Reset

System reset sources include IWDG Reset, WWDG Reset, Option Byte Load Reset, Software Reset, Sec Reset, Power-on Reset, and External Reset.

- IWDG Reset: generated by the IWDG module for exception recovery
- WWDG Reset: generated by the WWDG module for exception recovery
- Option Byte Load Reset: generated by the EFC module and used to start option byte reloading
- Software Reset: generated by the CPU
- Sec Reset: generated by the Sec module and used for system reset after security alarm

The system reset is used to reset most of the data logic in the Main domain excluding the Reset Source Status Register ([RCC\\_RST\\_SR](#)) which is used to record the latest system reset source.

### 8.1.4 Low-power Reset

The low-power reset is generated by the low-power state machine and is used to reset the logic of the main domain when the CPU exits Standby or Stop3 mode.

The low-power reset is used to reset all digital logic in the main domain.

## 8.2 Clock

Figure 8-1 shows the system clock structure.



Figure 8-1 Clock Tree

### 8.2.1 SYS\_CLK

RCO48M divided by 2, RCO32K, XO32K, PLL, XO24M, XO32M, RCO3.6M or RCO48M can be selected as the SYS\_CLK clock source. The default is RCO48M divided by 2.

- RCO48M (48MHz) is generated from the internal clock circuit.
- RCO32K (32kHz) is generated from the internal clock circuit.
- RCO3.6M (3.6MHz) is generated from the internal clock circuit.
- XO32K (32.768kHz) is generated from an external crystal oscillator.
- XO32M (32MHz) is generated from an external crystal oscillator.
- XO24M (24MHz) is generated from an external crystal oscillator.
- PLL is an internal clock circuit, RCO48M, XO32M, XO24M or RCO3.6M can be selected as PLL clock source, and the PLL clock output supports up to 48MHz

AHB bus clock HCLK is generated from SYS\_CLK divided by  $2^N$  (N ranges from 0 to 9).

The system includes two APB buses, the APB bus clock PCLK1 and PCLK2 are generated from HCLK divided by  $2^M$  (M ranges from 0 to 4). The clock division factor for the two APB buses can be configured independently.

### 8.2.2 Clocks for the Modules

The clocks for the modules consist of bus clocks and interface clocks.

The bus clock is generated by HCLK or PCLK gating and is used for modules to access bus.

In addition to a bus clock, some modules also have an independent interface clock, which is different from the bus clock, and is used to realize the function of the module.

The interface clock source for each module is selectable by software:

- LPTIM: PCLK0, RCO3.6M, XO32K, RCO32K, IO input clock
- LCDCTRL: XO32K, RCO32K, RCO3.6M
- LPUART: XO32K, RCO32K, RCO3.6M
- RTC: XO32K, RCO32K
- IWDG: XO32K, RCO32K
- UART: PCLK0/PCLK1, RCO3.6M, XO32K, XO24M
- ADCCTRL: PCLK1, SYS\_CLK, PLL, RCO48M
- I2S: PCLK0, XO24M, PLL, XO32M, IO input clock
- QSPI: HCLK, SYS\_CLK, PLL

ADCCTRL and I2S also support interface clock division, which is used to generate low-frequency interface clocks.

LPTIM, LCDCTRL, LPUART, RTC and IWDG in AON domain and those in Main domain can be enabled or disabled independently.

### 8.2.3 Clock-out Capability

The microcontroller clock output (MCO) capability allows the internal clock to be output by IO.

MCO clock source can be RCO32K, XO32K, RCO3.6M, XO24M, XO32M, RCO48M, PLL or SYS\_CLK.

The clock can be output with a frequency divided by software configuration.

## 8.3 RCC Registers

RCC Base Address: 0x40000000

Table 8-1 RCC Register Summary

| Register Name | Address Offset | Description                                          |
|---------------|----------------|------------------------------------------------------|
| RCC_CR0       | 0x000          | Control register 0                                   |
| RCC_CR1       | 0x004          | Control register 1, interface clock source selection |
| RCC_CR2       | 0x008          | Control register 2, interface clock source selection |
| RCC_CGR0      | 0x00C          | Module clock configure register 0                    |
| RCC_CGR1      | 0x010          | Module clock configure register 1                    |
| RCC_CGR2      | 0x014          | Module clock configure register 2                    |
| RCC_RST0      | 0x018          | Module reset control register 0                      |
| RCC_RST1      | 0x01C          | Module reset control register 1                      |
| RCC_RST_SR    | 0x020          | System reset source Status register                  |
| RCC_RST_CR    | 0x024          | System reset source control register                 |
| RCC_SR        | 0x028          | Status register, RCC_CGR2 configuration status       |
| RCC_SR1       | 0x02C          | Status register 1, module clock configuration status |
| RCC_CR3       | 0x030          | Control register 3, interface clock division         |

### 8.3.1 RCC\_CR0

Address Offset: 0x000

Reset Value: 0x00000000

| 31-26        | 25           | 24-22           | 21-19       | 18             |
|--------------|--------------|-----------------|-------------|----------------|
| RESERVED     | STCLKEN_SEL  | MCO_CLK_DIV_NUM | MCO_CLK_SEL | MCO_CLK_OUT_EN |
| r            | r/w          | r/w             | r/w         | r/w            |
| <b>17-15</b> | <b>14-12</b> | <b>11-8</b>     | <b>7-5</b>  | <b>4-0</b>     |
| PCLK1_DIV    | SYS_CLK_SEL  | HCLK_DIV        | PCLK0_DIV   | RESERVED       |
| r/w          | r/w          | r/w             | r/w         | r              |

**Bit 31-26 RESERVED:** Must be kept, and cannot be modified.

**Bit 25 STCLKEN\_SEL:** CPU SysTick clock source selection

- 0: XO32K
- 1: RCO32K

**Bits 24-22 MCO\_CLK\_DIV\_NUM:** MCO division factor

- <4: division factor is 1
- 4: division factor is 2
- 5: division factor is 4
- 6: division factor is 8
- 7: division factor is 16

**Notice:** Make sure to configure this bit when MCO\_CLK\_OUT\_EN=0. If the MCO\_CLK\_OUT\_EN bit is enabled, users must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure the MCO division factor.

**Bits 21-19 MCO\_CLK\_SEL:** MCO clock source selection

- 0: RCO32K
- 1: XO32K
- 2: RCO3.6M
- 3: XO24M
- 4: XO32M
- 5: RCO48M
- 6: PLL
- 7: SYS\_CLK

**Notice:** Make sure to configure this bit when MCO\_CLK\_OUT\_EN=0. If the MCO\_CLK\_OUT\_EN bit is enabled, users must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure the MCO clock source.

**Bits 18 MCO\_CLK\_OUT\_EN:** MCO output enable

- 0: disabled
- 1: enabled

**Bits 17-15 PCLK1\_DIV:** PCLK1 division factor

- 0: PCLK1 clock frequency = HCLK clock frequency
- 1: PCLK1 clock frequency = 1/2 HCLK clock frequency
- 2: PCLK1 clock frequency = 1/4 HCLK clock frequency
- 3: PCLK1 clock frequency = 1/8 HCLK clock frequency
- >3: PCLK1 clock frequency = 1/16 HCLK clock frequency

**Bits 14-12 SYS\_CLK\_SEL:** SYS\_CLK clock source selection

- 0: RCO48M divided by 2
- 1: RCO32K
- 2: XO32K
- 3: PLL
- 4: XO24M
- 5: XO32M
- 6: RCO3.6M
- 7: RCO48M

**Bits 11-8 HCLK\_DIV:** HCLK division factor

- 0: HCLK clock frequency = SYS\_CLK clock frequency
- 1: HCLK clock frequency = 1/2 SYS\_CLK clock frequency
- 2: HCLK clock frequency = 1/4 SYS\_CLK clock frequency
- 3: HCLK clock frequency = 1/8 SYS\_CLK clock frequency
- 4: HCLK clock frequency = 1/16 SYS\_CLK clock frequency
- 5: HCLK clock frequency = 1/32 SYS\_CLK clock frequency
- 6: HCLK clock frequency = 1/64 SYS\_CLK clock frequency
- 7: HCLK clock frequency = 1/128 SYS\_CLK clock frequency
- 8: HCLK clock frequency = 1/256 SYS\_CLK clock frequency
- >8: HCLK clock frequency = 1/512 SYS\_CLK clock frequency

**Bits 7-5 PCLK0\_DIV:** PCLK0 division factor

- 0: PCLK0 clock frequency = HCLK clock frequency
- 1: PCLK0 clock frequency = 1/2 HCLK clock frequency
- 2: PCLK0 clock frequency = 1/4 HCLK clock frequency
- 3: PCLK0 clock frequency = 1/8 HCLK clock frequency
- >3: PCLK0 clock frequency = 1/16 HCLK clock frequency

**Bits 4-0 RESERVED:** Must be kept, and cannot be modified.

### 8.3.2 RCC\_CR1

Address Offset: 0x0004

Reset Value: 0x00000000

This register is in AON power domain.

| 31-12          | 11                 | 10                 | 9-8            |              |
|----------------|--------------------|--------------------|----------------|--------------|
| RESERVED       | LPTIM1_EXT_CLK_SEL | LPTIM0_EXT_CLK_SEL | LPTIM1_CLK_SEL |              |
| r              | r/w                | r/w                | r/w            |              |
| 7-6            | 5-4                | 3-2                | 1              | 0            |
| LPTIM0_CLK_SEL | LCDCTRL_CLK_SEL    | LPUART_CLK_SEL     | RTC_CLK_SEL    | IWDG_CLK_SEL |
| r/w            | r/w                | r/w                | r/w            | r/w          |

**Bits 31-12 RESERVED:** Must be kept, and cannot be modified.

**Bit 11 LPTIM1\_EXT\_CLK\_SEL:** LPTIM1 interface clock source selection

- 0: decided by the LPTIM1\_CLK\_SEL bit
- 1: use external clock from IN1

**Notice:**

1. Make sure to configure this bit when LPTIM1\_CLK\_EN=0. If the LPTIM1\_CLK\_EN bit is enabled, the user must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure the LPTIM1 interface clock source.
2. This bit and the LPTIM1\_CLK\_SEL bit jointly determine the LPTIM1 interface clock source.

**Bit 10 LPTIM0\_EXT\_CLK\_SEL:** LPTIM0 interface clock source selection

- 0: decided by the LPTIM0\_CLK\_SEL bit
- 1: use external clock from IN1

**Notice:**

1. Make sure to configure this bit when LPTIM0\_CLK\_EN=0. If the LPTIM0\_CLK\_EN bit is enabled, the user must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure the LPTIM0 interface clock source.
2. This bit and the LPTIM0\_CLK\_SEL bit jointly determine the LPTIM0 interface clock source.

**Bits 9-8 LPTIM1\_CLK\_SEL:** LPTIM1 interface clock source selection

- 0: PCLK0
- 1: RCO3.6M
- 2: XO32K
- 3: RCO32K

**Notice:**

1. Make sure to configure this bit when LPTIM1\_CLK\_EN=0. If the LPTIM1\_CLK\_EN bit is enabled, the user must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure the LPTIM1 interface clock source.
2. This bit and the LPTIM1\_EXT\_CLK\_SEL bit jointly determine the LPTIM1 interface clock source.
3. To select PCLK0 as clock source, the LPTIM1\_INF\_CLK\_EN bit in the [RCC\\_CGR1](#) register must

have been enabled.

**Bits 7-6 LPTIM0\_CLK\_SEL:** LPTIM0 interface clock source selection

- 0: PCLK0
- 1: RCO3.6M
- 2: XO32K
- 3: RCO32K

**Notice:**

1. Make sure to configure this bit when *LPTIM0\_CLK\_EN*=0. If the *LPTIM0\_CLK\_EN* bit is enabled, the user must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure the LPTIM0 interface clock source.
2. This bit and the *LPTIM0\_EXT\_CLK\_SEL* bit jointly determine the LPTIM0 interface clock source.
3. To select PCLK0 as clock source, the *LPTIM0\_INF\_CLK\_EN* bit in the [RCC\\_CGR1](#) register must have been enabled.

**Bits 5-4 LCDCTRL\_CLK\_SEL:** LCDCTRL interface clock source selection

- 0: XO32K
- 1: RCO32K
- >1: RCO3.6M

**Bits 3-2 LPUART\_CLK\_SEL:** LPUART interface clock source selection

- 0: XO32K
- 1: RCO32K
- >1: RCO3.6M

**Bit 1 RTC\_CLK\_SEL:** RTC interface clock source selection

- 0: XO32K
- 1: RCO32K

**Bit 0 IWDG\_CLK\_SEL:** IWDG interface clock source selection

- 0: XO32K
- 1: RCO32K

### 8.3.3 RCC\_CR2

Address Offset: 0x008

Reset Value: 0x00000000

| 31-17         | 16-15         | 14-13           | 12-11         |              |
|---------------|---------------|-----------------|---------------|--------------|
| RESERVED      | UART0_CLK_SEL | UART1_CLK_SEL   | UART2_CLK_SEL |              |
| r             | r/w           | r/w             | r/w           |              |
| 10-9          | 8-7           | 6-5             | 4-2           | 1-0          |
| UART3_CLK_SEL | RESERVED      | ADCCTRL_CLK_SEL | I2S_CLK_SEL   | QSPI_CLK_SEL |
| r/w           | r             | r/w             | r/w           | r/w          |

**Bits 31-17 RESERVED:** Must be kept, and cannot be modified.

**Bits 16-15 UART0\_CLK\_SEL:** UART0 interface clock source selection

- 0: PCLK0
- 1: RCO3.6M
- 2: XO32K
- 3: XO24M

**Notice:** Make sure to configure this bit when `UART0_CLK_EN=0`. If the `UART0_CLK_EN` bit is enabled, the user must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure the UART0 interface clock source.

**Bits 14-13 UART1\_CLK\_SEL:** UART1 interface clock source selection

- 0: PCLK0
- 1: RCO3.6M
- 2: XO32K
- 3: XO24M

**Notice:** Make sure to configure this bit when `UART1_CLK_EN=0`. If the `UART1_CLK_EN` bit is enabled, the user must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure the UART1 interface clock source.

**Bits 12-11 UART2\_CLK\_SEL:** UART2 interface clock source selection

- 0: PCLK1
- 1: RCO3.6M
- 2: XO32K
- 3: XO24M

**Notice:** Make sure to configure this bit when `UART2_CLK_EN=0`. If the `UART2_CLK_EN` bit is enabled, the user must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure the UART2 interface clock source.

**Bits 10-9 UART3\_CLK\_SEL:** UART3 interface clock source selection

- 0: PCLK1
- 1: RCO3.6M
- 2: XO32K
- 3: XO24M

**Notice:** Make sure to configure this bit when *UART3\_CLK\_EN*=0. If the *UART3\_CLK\_EN* bit is enabled, the user must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure the *UART3* interface clock source.

**Bits 8-7 RESERVED:** Must be kept, and cannot be modified.

**Bits 6-5 ADCCTRL\_CLK\_SEL:** ADCCTRL interface clock source selection

- 0: PCLK1
- 1: SYS\_CLK
- 2: PLL
- 3: RCO48M

**Notice:** Make sure to configure this bit when *ADCCTRL\_CLK\_EN*=0. If the *ADCCTRL\_CLK\_EN* bit is enabled, the user must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure the *ADCCTRL* interface clock source.

**Bits 4-2 I2S\_CLK\_SEL:** I2S interface clock source selection

- 0: PCLK0
- 1: XO24M
- 2: PLL
- 3: XO32M
- >3: external IOM\_I2S\_CLK

**Notice:**

1. Make sure to configure this bit when *I2S\_CLK\_EN*=0. If the *I2S\_CLK\_EN* bit is enabled, the user must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure the *I2S* interface clock source.
2. When *I2S* acts as a slave, the clock source must be configured to external *IOM\_I2S\_CLK*; when *I2S* acts as a master, the clock source is selected according to functional requirements.

**Bits 1-0 QSPI\_CLK\_SEL:** QSPI interface clock source selection

- 0: HCLK
- 1: SYS\_CLK
- >1: PLL

**Notice:** Make sure to configure this bit when *QSPI\_CLK\_EN*=0. If the *QSPI\_CLK\_EN* bit is enabled, the user must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure the *QSPI* interface clock source.

### 8.3.4 RCC\_CGR0

Address Offset: 0x00C

Reset Value: 0x00000000

| <b>31</b>    | <b>30</b>     | <b>29</b>     | <b>28</b>     | <b>27</b>        | <b>26</b>        | <b>25</b>     | <b>24</b>      |
|--------------|---------------|---------------|---------------|------------------|------------------|---------------|----------------|
| PWR_CLK_EN   | DMAC0_C_LK_EN | DMAC1_C_LK_EN | CRC_CLK_EN    | BASICTIM0_CLK_EN | BASICTIM1_CLK_EN | IOM0_CLK_K_EN | IOM1_CLK_K_EN  |
| r/w          | r/w           | r/w           | r/w           | r/w              | r/w              | r/w           | r/w            |
| <b>23</b>    | <b>22</b>     | <b>21</b>     | <b>20</b>     | <b>19</b>        | <b>18</b>        | <b>17</b>     | <b>16</b>      |
| IOM2_CLK_EN  | IOM3_CL_K_EN  | SYSCFG_CLK_EN | UART0_C_LK_EN | UART1_CL_K_EN    | UART2_CL_K_EN    | UART3_C_LK_EN | LPUART_CLK_EN  |
| r/w          | r/w           | r/w           | r/w           | r/w              | r/w              | r/w           | r/w            |
| <b>15</b>    | <b>14</b>     | <b>13</b>     | <b>12</b>     | <b>11</b>        | <b>10</b>        | <b>9</b>      | <b>8</b>       |
| SSP0_CLK_EN  | SSP1_CL_K_EN  | SSP2_CL_K_EN  | I2C0_CLK_EN   | I2C1_CLK_EN      | I2C2_CLK_EN      | RESERVE_D     | ADCCTRL_CLK_EN |
| r/w          | r/w           | r/w           | r/w           | r/w              | r/w              | r             | r/w            |
| <b>7</b>     | <b>6</b>      | <b>5</b>      | <b>4</b>      | <b>3</b>         | <b>2</b>         | <b>1</b>      | <b>0</b>       |
| AFEC_CL_K_EN | LCDCTRL       | DACCTRL       | LORAC_C_LK_EN | GPTIM0_C_LK_EN   | GPTIM1_C_LK_EN   | GPTIM2_CLK_EN | GPTIM3_CLK_EN  |
| r/w          | r/w           | r/w           | r/w           | r/w              | r/w              | r/w           | r/w            |

**Bit 31 PWR\_CLK\_EN:** PWR clock enable

- 0: disabled
- 1: enabled

**Bit 30 DMAC0\_CLK\_EN:** DMAC0 clock enable

- 0: disabled
- 1: enabled

**Bit 29 DMAC1\_CLK\_EN:** DMAC1 clock enable

- 0: disabled
- 1: enabled

**Bit 28 CRC\_CLK\_EN:** CRC clock enable

- 0: disabled
- 1: enabled

**Bit 27 BASICTIM0\_CLK\_EN:** BASICTIM0 clock enable

- 0: disabled
- 1: enabled

**Bit 26 BASICTIM1\_CLK\_EN:** BASICTIM1 clock enable

- 0: disabled
- 1: enabled

**Bit 25 IOM0\_CLK\_EN:** IOM0 clock enable

- 0: disabled
- 1: enabled

**Bit 24 IOM1\_CLK\_EN:** IOM1 clock enable

- 0: disabled
- 1: enabled

**Bit 23 IOM2\_CLK\_EN:** IOM2 cLOCK ENABLE

- 0: disabled
- 1: enabled

**Bit 22 IOM3\_CLK\_EN:** IOM3 clock enable

- 0: disabled
- 1: enabled

**Bit 21 SYSCFG\_CLK\_EN:** SYSCFG clock enable

- 0: disabled
- 1: enabled

**Bit 20 UART0\_CLK\_EN:** UART0 clock enable

- 0: disabled
- 1: enabled

**Bit 19 UART1\_CLK\_EN:** UART1 clock enable

- 0: disabled
- 1: enabled

**Bit 18 UART2\_CLK\_EN:** UART2 clock enable

- 0: disabled
- 1: enabled

**Bit 17 UART3\_CLK\_EN:** UART3 clock enable

- 0: disabled
- 1: enabled

**Bit 16 LPUART\_CLK\_EN:** LPUART clock enable

- 0: disabled
- 1: enabled

**Bit 15 SSP0\_CLK\_EN:** SSP0 clock enable

- 0: disabled
- 1: enabled

**Bit 14 SSP1\_CLK\_EN:** SSP1 clock enable

- 0: disabled
- 1: enabled

**Bit 13 SSP2\_CLK\_EN:** SSP2 clock enable

- 0: disabled
- 1: enabled

**Bit 12 I2C0\_CLK\_EN:** I2C0 clock enable

- 0: disabled
- 1: enabled

**Bit 11 I2C1\_CLK\_EN:** I2C1 clock enable

- 0: disabled
- 1: enabled

**Bit 10 I2C2\_CLK\_EN:** I2C2 clock enable

- 0: disabled
- 1: enabled

**Bit 9 RESERVED:** Must be kept, and cannot be modified.**Bit 8 ADCCTRL\_CLK\_EN:** ADCCTRL clock enable

- 0: disabled
- 1: enabled

**Bit 7 AFEC\_CLK\_EN:** AFEC clock enable

- 0: disabled
- 1: enabled

**Bit 6 LCDCTRL\_CLK\_EN:** LCDCTRL clock enable

- 0: disabled
- 1: enabled

**Bit 5 DACCTRL\_CLK\_EN:** DACCTRL clock enable

- 0: disabled
- 1: enabled

**Bit 4 LORAC\_CLK\_EN:** LORAC clock enable

- 0: disabled
- 1: enabled

**Bit 3 GPTIM0\_CLK\_EN:** GPTIM0 clock enable

- 0: disabled
- 1: enabled

**Bit 2 GPTIM1\_CLK\_EN:** GPTIM1 clock enable

- 0: disabled
- 1: enabled

**Bit 1 GPTIM2\_CLK\_EN:** GPTIM2 clock enable

- 0: disabled
- 1: enabled

**Bit 0 GPTIM3\_CLK\_EN:** GPTIM3 clock enable

- 0: disabled
- 1: enabled

### 8.3.5 RCC\_CGR1

Address Offset: 0x010

Reset Value: 0x00000000

| 31-13           | 12                | 11            | 10          | 9                 | 8          | 7          |
|-----------------|-------------------|---------------|-------------|-------------------|------------|------------|
| RESERVED        | LPTIM1_INF_CLK_EN | LPTIM1_CLK_EN | RNGC_CLK_EN | LPTIM0_INF_CLK_EN | I2S_CLK_EN | SAC_CLK_EN |
| r               | r/w               | r/w           | r/w         | r/w               | r/w        | r/w        |
| <b>6</b>        | <b>5</b>          | <b>4</b>      | <b>3</b>    | <b>2</b>          | <b>1</b>   | <b>0</b>   |
| WWDG_CNT_CLK_EN | QSPI_CLK_EN       | LPTIM0_CLK_EN | IWDG_CLK_EN | WWDG_CLK_EN       | RTC_CLK_EN | SEC_CLK_EN |
| r/w             | r/w               | r/w           | r/w         | r/w               | r/w        | r/w        |

**Bits 31-13 RESERVED:** Must be kept, and cannot be modified.

**Bit 12 LPTIM1\_INF\_CLK\_EN:** LPTIM1 interface PCLK0 clock enable

- 0: disabled
- 1: enabled

**Bit 11 LPTIM1\_CLK\_EN:** LPTIM1 clock enable

- 0: disabled
- 1: enabled

**Notice:** If PCLK0 is selected as the clock source, the LPTIM1\_INF\_CLK\_EN bit must be enabled before enabling the LPTIM1 clock, while it must be disabled after the LPTIM1 clock is disabled.

**Bit 10 RNGC\_CLK\_EN:** RNGC clock enable

- 0: disabled
- 1: enabled

**Bit 9 LPTIM0\_INF\_CLK\_EN:** LPTIM0 interface PCLK0 clock enable

- 0: disabled
- 1: enabled

**Bit 8 I2S\_CLK\_EN:** I2S clock enable

- 0: disabled
- 1: enabled

**Bit 7 SAC\_CLK\_EN:** SAC clock enable

- 0: disabled
- 1: enabled

**Bit 6 WWDG\_CNT\_CLK\_EN:** WWDG counter clock enable

- 0: disabled
- 1: enabled

**Bit 5 QSPI\_CLK\_EN:** QSPI clock enable

- 0: disabled
- 1: enabled

**Bit 4 LPTIM0\_CLK\_EN:** LPTIM0 clock enable

- 0: disabled
- 1: enabled

**Notice:** If PCLK0 is selected as the clock source, the LPTIM0\_INF\_CLK\_EN bit must be enabled before enabling the LPTIM0 clock, while it must be disabled after the LPTIM0 clock is disabled.

**Bit 3 IWDG\_CLK\_EN:** IWDG clock enable

- 0: disabled
- 1: enabled

**Bit 2 WWDG\_CLK\_EN:** WWDG clock enable

- 0: disabled
- 1: enabled

**Bit 1 RTC\_CLK\_EN:** RTC clock enable

- 0: disabled
- 1: enabled

**Bit 0 SEC\_CLK\_EN:** SEC clock enable

- 0: disabled
- 1: enabled

**8.3.6 RCC\_CGR2**

Address Offset: 0x014

Reset Value: 0x00000000

This register is in the AON power domain. Read the [RCC\\_SR](#) register before configuring this register. When the corresponding bit is set in the [RCC\\_SR](#) register, this register can be read; when all the bits are set in the [RCC\\_SR](#) register, this register can be written.

| 31-6     | 5                  | 4                | 3                  | 2                  | 1              | 0               |
|----------|--------------------|------------------|--------------------|--------------------|----------------|-----------------|
| RESERVED | LPTIM1_AO_N_CLK_EN | LPTIM_AON_CLK_EN | LCDCTRL_AON_CLK_EN | LPUART_AO_N_CLK_EN | RTC_AON_CLK_EN | IWDG_AON_CLK_EN |
| r        | r/w                | r/w              | r/w                | r/w                | r/w            | r/w             |

**Bits 31-6 RESERVED:** Must be kept, and cannot be modified.

**Bit 5 LPTIM1\_AON\_CLK\_EN:** Enable the LPTIM1 interface clock in AON domain

- 0: disabled
- 1: enabled

**Bit 4 LPTIM\_AON\_CLK\_EN:** Enable the LPTIM interface clock in AON domain

- 0: disabled
- 1: enabled

**Bit 3 LCDCTRL\_AON\_CLK\_EN:** Enable the LCDCTRL interface clock in AON domain

- 0: disabled
- 1: enabled

**Bit 2 LPUART\_AON\_CLK\_EN:** Enable the LPUART interface clock in AON domain

- 0: disabled
- 1: enabled

**Bit 1 RTC\_AON\_CLK\_EN:** Enable the RTC interface clock in AON domain

- 0: disabled
- 1: enabled

**Bit 0 IWDG\_AON\_CLK\_EN:** Enable the IWDG interface clock in AON domain

- 0: disabled
- 1: enabled

### 8.3.7 RCC\_RST0

Address Offset: 0x018

Reset Value: 0xffffffff

| 31                  | 30               | 29              | 28               | 27               | 26                | 25               | 24                  |
|---------------------|------------------|-----------------|------------------|------------------|-------------------|------------------|---------------------|
| UART0_R<br>ST_N     | UART1_R<br>ST_N  | UART2_R<br>ST_N | UART3_R<br>ST_N  | LPUART_<br>RST_N | SSP0_RS<br>T_N    | SSP1_RS<br>T_N   | SSP2_RS<br>T_N      |
| r/w                 | r/w              | r/w             | r/w              | r/w              | r/w               | r/w              | r/w                 |
| 23                  | 22               | 21              | 20               | 19               | 18                | 17               | 16                  |
| QSPI_RST<br>_N      | I2C0_RST<br>_N   | I2C1_RST<br>_N  | I2C2_RST<br>_N   | RESERVE<br>D     | ADCCTRL<br>_RST_N | AFEC_RS<br>T_N   | LCDCTRL<br>_RST_N   |
| r/w                 | r/w              | r/w             | r/w              | r                | r/w               | r/w              | r/w                 |
| 15                  | 14               | 13              | 12               | 11               | 10                | 9                | 8                   |
| DACCTRL<br>_RST_N   | LORAC_R<br>ST_N  | IOM_RST<br>_N   | GPTIM0_<br>RST_N | GPTIM1_<br>RST_N | GPTIM2_<br>RST_N  | GPTIM3_<br>RST_N | BASICTIM<br>0_RST_N |
| r/w                 | r/w              | r/w             | r/w              | r/w              | r/w               | r/w              | r/w                 |
| 7                   | 6                | 5               | 4                | 3                | 2                 | 1                | 0                   |
| BASICTIM<br>1_RST_N | LPTIM0_R<br>ST_N | IWDG_RS<br>T_N  | WWDG_R<br>ST_N   | RTC_RST<br>_N    | CRC_RST<br>_N     | SEC_RST<br>_N    | SAC_RST<br>_N       |
| r/w                 | r/w              | r/w             | r/w              | r/w              | r/w               | r/w              | r/w                 |

**Bit 31 UART0\_RST\_N:** UART0 reset control

- 0: reset
- 1: not reset

**Bit 30 UART1\_RST\_N:** UART1 reset control

- 0: reset
- 1: not reset

**Bit 29 UART2\_RST\_N:** UART2 reset control

- 0: reset
- 1: not reset

**Bit 28 UART3\_RST\_N:** UART3 reset control

- 0: reset
- 1: not reset

**Bit 27 LPUART\_RST\_N:** LPUART reset control

- 0: reset
- 1: not reset

**Bit 26 SSP0\_RST\_N:** SSP0 reset control

- 0: reset
- 1: not reset

**Bit 25 SSP1\_RST\_N:** SSP1 reset control

- 0: reset
- 1: not reset

**Bit 24 SSP2\_RST\_N:** SSP2 reset control

- 0: reset
- 1: not reset

**Bit 23 QSPI\_RST\_N:** QSPI reset control

- 0: reset
- 1: not reset

**Bit 22 I2C0\_RST\_N:** I2C0 reset control

- 0: reset
- 1: not reset

**Bit 21 I2C1\_RST\_N:** I2C1 reset control

- 0: reset
- 1: not reset

**Bit 20 I2C2\_RST\_N:** I2C2 reset control

- 0: reset
- 1: not reset

**Bit 19 RESERVED:** Must be kept, and cannot be modified.

**Bit 18 ADCCTRL\_RST\_N:** ADCCTRL reset control

- 0: reset
- 1: not reset

**Bit 17 AFEC\_RST\_N:** AFEC reset control

- 0: reset
- 1: not reset

**Bit 16 LCDCTRL\_RST\_N:** LCDCTRL reset control

- 0: reset
- 1: not reset

**Bit 15 DACCTRL\_RST\_N:** DACCTRL reset control

- 0: reset
- 1: not reset

**Bit 14 LORAC\_RST\_N:** LORAC reset control

- 0: reset
- 1: not reset

**Bit 13 IOM\_RST\_N:** IOM reset control

- 0: reset
- 1: not reset

**Bit 12 GPTIM0\_RST\_N:** GPTIM0 reset control

- 0: reset
- 1: not reset

**Bit 11 GPTIM1\_RST\_N:** GPTIM1 reset control

- 0: reset
- 1: not reset

**Bit 10 GPTIM2\_RST\_N:** GPTIM2 reset control

- 0: reset
- 1: not reset

**Bit 9 GPTIM3\_RST\_N:** GPTIM3 reset control

- 0: reset
- 1: not reset

**Bit 8 BASICTIM0\_RST\_N:** BASICTIM0 reset control

- 0: reset
- 1: not reset

**Bit 7 BASICTIM1\_RST\_N:** BASICTIM1 reset control

- 0: reset
- 1: not reset

**Bit 6 LPTIM0\_RST\_N:** LPTIM0 reset control

- 0: reset
- 1: not reset

**Bit 5 IWDG\_RST\_N:** IWDG reset control

- 0: reset
- 1: not reset

**Bit 4 WWDG\_RST\_N:** WWDG reset control

- 0: reset
- 1: not reset

**Bit 3 RTC\_RST\_N:** RTC reset control

- 0: reset
- 1: not reset

**Bit 2 CRC\_RST\_N:** CRC reset control

- 0: reset
- 1: not reset

**Bit 1 SEC\_RST\_N:** SEC reset control

- 0: reset
- 1: not reset

**Bit 0 SAC\_RST\_N:** SAC reset control

- 0: reset
- 1: not reset

### 8.3.8 RCC\_RST1

Address Offset: 0x01C

Reset Value: 0x0000001f

| 31-5     | 4            | 3          | 2         | 1           | 0           |
|----------|--------------|------------|-----------|-------------|-------------|
| RESERVED | LPTIM1_RST_N | RNGC_RST_N | I2S_RST_N | DMAC0_RST_N | DMAC1_RST_N |
| r        | r/w          | r/w        | r/w       | r/w         | r/w         |

**Bits 31-5 RESERVED:** Must be kept, and cannot be modified.

**Bit 4 LPTIM1\_RST\_N:** LPTIM1 reset control

- 0: reset
- 1: not reset

**Bit 3 RNGC\_RST\_N:** RNGC reset control

- 0: reset
- 1: not reset

**Bit 2 I2S\_RST\_N:** I2S reset control

- 0: reset
- 1: not reset

**Bit 1 DMAC0\_RST\_N:** DMAC0 reset control

- 0: reset
- 1: not reset

**Bit 0 DMAC1\_RST\_N:** DMAC1 reset control

- 0: reset
- 1: not reset

### 8.3.9 RCC\_RST\_SR

Address Offset: 0x020

Reset Value: 0x00000040

**Notice:** The BOR\_RESET\_SR and STANDBY\_RESET\_SR are in the AON domain.

| 31-7     | 6                | 5                 | 4                 | 3                | 2                | 1                | 0                    |
|----------|------------------|-------------------|-------------------|------------------|------------------|------------------|----------------------|
| RESERVED | BOR_RE<br>SET_SR | IWDG_RE<br>SET_SR | WWDG_RE<br>SET_SR | EFC_RE<br>SET_SR | CPU_RE<br>SET_SR | SEC_RE<br>SET_SR | STANDBY_<br>RESET_SR |
| r        | r/w              | r/w               | r/w               | r/w              | r/w              | r/w              | r/w                  |

**Bits 31-7 RESERVED:** Must be kept, and cannot be modified.

**Bit 6 BOR\_RESET\_SR:** BOR reset status. This bit is set by hardware and cleared by software writing 1 to it.

- 0: no BOR reset occurred
- 1: a BOR reset occurred

**Bit 5 IWDG\_RESET\_SR:** IWDG reset status. This bit is set by hardware and cleared by software writing 1 to it.

- 0: no IWDG reset occurred
- 1: an IWDG reset occurred

**Bit 4 WWDG\_RESET\_SR:** WWDG reset status. This bit is set by hardware and cleared by software writing 1 to it.

- 0: no WWDG reset occurred
- 1: a WWDG reset occurred

**Bit 3 EFC\_RESET\_SR:** EFC reset status. This bit is set by hardware and cleared by software writing 1 to it.

- 0: no EFC reset occurred
- 1: a EFC reset occurred

**Bit 2 CPU\_RESET\_SR:** CPU reset status. This bit is set by hardware and cleared by software writing 1 to it.

- 0: no CPU reset occurred
- 1: a CPU reset occurred

**Bit 1 SEC\_RESET\_SR:** SEC reset status. This bit is set by hardware and cleared by software writing 1 to it.

- 0: no SEC reset occurred
- 1: a SEC reset occurred

**Bit 0 STANDBY\_RESET\_SR:** Standby reset status. This bit is set by hardware and cleared by software writing 1 to it.

- 0: no MPU reset occurred
- 1: a MPU reset occurred

### 8.3.10 RCC\_RST\_CR

Address Offset: 0x024

Reset Value: 0x00000004

| 31-6     | 5                     | 4                     | 3                    | 2                    | 1                    | 0        |
|----------|-----------------------|-----------------------|----------------------|----------------------|----------------------|----------|
| RESERVED | IWDG_RESE<br>T_REQ_EN | WWDG_RES<br>ET_REQ_EN | EFC_RESE<br>T_REQ_EN | CPU_RESE<br>T_REQ_EN | SEC_RESE<br>T_REQ_EN | RESERVED |
| r        | r/w                   | r/w                   | r/w                  | r/w                  | r/w                  | r        |

**Bits 31-6 RESERVED:** Must be kept, and cannot be modified.

**Bit 5 IWDG\_RESET\_REQ\_EN:** IWDG reset enable

- 0: disabled
- 1: enabled

**Bit 4 WWDG\_RESET\_REQ\_EN:** WWDG reset enable

- 0: disabled
- 1: enabled

**Bit 3 EFC\_RESET\_REQ\_EN:** EFC reset enable

- 0: disabled
- 1: enabled

**Bit 2 CPU\_RESET\_REQ\_EN:** CPU reset enable

- 0: disabled
- 1: enabled

**Bit 1 SEC\_RESET\_REQ\_EN:** SEC reset enable

- 0: disabled
- 1: enabled

**Bit 0 RESERVED:** Must be kept, and cannot be modified.

### 8.3.11 RCC\_SR

Address Offset: 0x028

Reset Value: 0x0000003f

| 31-6                        |                            | 5                          | 4                         |
|-----------------------------|----------------------------|----------------------------|---------------------------|
| RESERVED                    |                            | SET_LPTIM1_AON_CLK_EN_DONE | SET_LPTIM_AON_CLK_EN_DONE |
| r                           |                            | r                          | r                         |
| 3                           | 2                          | 1                          | 0                         |
| SET_LCDCTRL_AON_CLK_EN_DONE | SET_LPUART_AON_Clk_EN_DONE | SET_RTC_AON_CLK_EN_DONE    | SET_IWDG_AON_CLK_EN_DONE  |
| r                           | r                          | r                          | r                         |

**Bits 31-6 RESERVED:** Must be kept, and cannot be modified.

**Bit 5 SET\_LPTIM1\_AON\_CLK\_EN\_DONE:** LPTIM1\_AON\_CLK\_EN configuration status

This bit is set and cleared by hardware.

- 0: configuration is in progress
- 1: configuration is complete

**Bit 4 SET\_LPTIM0\_AON\_CLK\_EN\_DONE:** LPTIM0\_AON\_CLK\_EN configuration status

This bit is set and cleared by hardware.

- 0: configuration is in progress
- 1: configuration is complete

**Bit 3 SET\_LCDCTRL\_AON\_CLK\_EN\_DONE:** LCDCTRL\_AON\_CLK\_EN configuration status

This bit is set and cleared by hardware.

- 0: configuration is in progress
- 1: configuration is complete

**Bit 2 SET\_LPUART\_AON\_CLK\_EN\_DONE:** LPUART\_AON\_CLK\_EN configuration status

This bit is set and cleared by hardware.

- 0: configuration is in progress
- 1: configuration is complete

**Bit 1 SET\_RTC\_AON\_CLK\_EN\_DONE:** RTC\_AON\_CLK\_EN configuration status

This bit is set and cleared by hardware.

- 0: configuration is in progress
- 1: configuration is complete

**Bit 0 SET\_IWDG\_AON\_CLK\_EN\_DONE:** IWDG\_AON\_CLK\_EN configuration status

This bit is set and cleared by hardware.

- 0: configuration is in progress
- 1: configuration is complete

### 8.3.12 RCC\_SR1

Address Offset: 0x02C

Reset Value: 0x00000000

The clock should be disabled before the clock source is switched or the frequency division changes to avoid glitches. This register is used to determine whether the clock is disabled.

| 31-21                   | 20                      | 19                      | 18                   | 17                | 16                     |
|-------------------------|-------------------------|-------------------------|----------------------|-------------------|------------------------|
| RESERVED                | LPTIM1_CLK_EN_SYNC      | LPTIM1_AON_C_LK_EN_SYNC | UART0_CLK_EN_SYNC    | UART1_CLK_EN_SYNC | UART2_CLK_E_N_SYNC     |
| r                       | r                       | r                       | r                    | r                 | r                      |
| <b>15</b>               | <b>14</b>               | <b>13</b>               | <b>12</b>            | <b>11</b>         | <b>10</b>              |
| UART3_CLK_EN_SYNC       | RESERVED                | ADCCTRL_CLK_EN_SYNC     | LPTIM0_CLK_EN_SYNC   | QSPI_CLK_E_N_SYNC | LPUART_CLK_EN_SYNC     |
| r                       | r                       | r                       | r                    | r                 | r                      |
| <b>9</b>                | <b>8</b>                | <b>7</b>                | <b>6</b>             | <b>5</b>          | <b>4</b>               |
| LCDCTRL_CL_K_EN_SYNC    | IWDG_CLK_EN_SYNC        | RTC_CLK_EN_SYNC         | MCO_CLK_E_N_SYNC     | I2S_CLK_EN_SYNC   | LPTIM0_AON_CLK_EN_SYNC |
| r                       | r                       | r                       | r                    | r                 | r                      |
| <b>3</b>                | <b>2</b>                | <b>1</b>                |                      |                   | <b>0</b>               |
| LCDCTRL_AON_CLK_EN_SYNC | LPUART_AON_CLK_E_N_SYNC | RTC_AON_CLK_EN_SYNC     | IWDG_AON_CLK_EN_SYNC |                   |                        |
| r                       | r                       | r                       | r                    |                   | r                      |

**Bits 31-21 RESERVED:** Must be kept, and cannot be modified.

**Bit 20 LPTIM1\_CLK\_EN\_SYNC:** Indicate LPTIM1\_CLK\_EN actual status

- 0: LPTIM1 clock is disabled
- 1: LPTIM1 clock is enabled

**Bit 19 LPTIM1\_AON\_CLK\_EN\_SYNC:** Indicate LPTIM1\_AON\_CLK\_EN actual status

- 0: LPTIM1 clock is disabled in AON domain
- 1: LPTIM1 clock is enabled in AON domain

**Bit 18 UART0\_CLK\_EN\_SYNC:** Indicate UART0\_CLK\_EN actual status

- 0: UART0 clock is disabled
- 1: UART0 clock is enabled

**Bit 17 UART1\_CLK\_EN\_SYNC:** Indicate UART1\_CLK\_EN actual status

- 0: UART1 clock is disabled
- 1: UART1 clock is enabled

**Bit 16 UART2\_CLK\_EN\_SYNC:** Indicate UART2\_CLK\_EN actual status

- 0: UART2 clock is disabled
- 1: UART2 clock is enabled

**Bit 15 UART3\_CLK\_EN\_SYNC:** Indicate UART3\_CLK\_EN actual status

- 0: UART3 clock is disabled

- 1: UART3 clock is enabled

**Bit 14 RESERVED:** Must be kept, and cannot be modified.

**Bit 13 ADCCTRL\_CLK\_EN\_SYNC:** Indicate ADCCTRL\_CLK\_EN actual status

- 0: ADCCTRL clock is disabled
- 1: ADCCTRL clock is enabled

**Bit 12 LPTIM0\_CLK\_EN\_SYNC:** Indicate LPTIM0\_CLK\_EN actual status

- 0: LPTIM0 clock is disabled
- 1: LPTIM0 clock is enabled

**Bit 11 QSPI\_CLK\_EN\_SYNC:** Indicate QSPI\_CLK\_EN actual status

- 0: QSPI clock is disabled
- 1: QSPI clock is enabled

**Bit 10 LPUART\_CLK\_EN\_SYNC:** Indicate LPUART\_CLK\_EN actual status

- 0: LPUART clock is disabled
- 1: LPUART clock is enabled

**Bit 9 LCDCTRL\_CLK\_EN\_SYNC:** Indicate LCDCTRL\_CLK\_EN actual status

- 0: LCDCTRL clock is disabled
- 1: LCDCTRL clock is enabled

**Bit 8 IWDG\_CLK\_EN\_SYNC:** Indicate IWDG\_CLK\_EN actual status

- 0: IWDG clock is disabled
- 1: IWDG clock is enabled

**Bit 7 RTC\_CLK\_EN\_SYNC:** Indicate RTC\_CLK\_EN actual status

- 0: RTC clock is disabled
- 1: RTC clock is enabled

**Bit 6 MCO\_CLK\_EN\_SYNC:** Indicate MCO\_CLK\_EN actual status

- 0: MCO clock is disabled
- 1: MCO clock is enabled

**Bit 5 I2S\_CLK\_EN\_SYNC:** Indicate I2S\_CLK\_EN actual status

- 0: I2S clock is disabled
- 1: I2S clock is enabled

**Bit 4 LPTIM0\_AON\_CLK\_EN\_SYNC:** Indicate LPTIM0\_AON\_CLK\_EN actual status

- 0: LPTIM0 clock in AON domain is disabled
- 1: LPTIM0 clock in AON domain is enabled

**Bit 3 LCDCTRL\_AON\_CLK\_EN\_SYNC:** Indicate LCDCTRL\_AON\_CLK\_EN actual status

- 0: LCDCTRL clock is disabled in AON domain
- 1: LCDCTRL clock is enabled in AON domain

**Bit 2 LPUART\_AON\_CLK\_EN\_SYNC:** Indicate LPUART\_AON\_CLK\_EN actual status

- 0: LPUART clock is disabled in AON domain
- 1: LPUART clock is enabled in AON domain

**Bit 1 RTC\_AON\_CLK\_EN\_SYNC:** Indicate RTC\_AON\_CLK\_EN actual status

- 0: RTC clock is disabled in AON domain
- 1: RTC clock is enabled in AON domain

**Bit 0 IWDG\_AON\_CLK\_EN\_SYNC:** Indicate IWDG\_AON\_CLK\_EN actual status

- 0: IWDG clock is disabled in AON domain
- 1: IWDG clock is enabled in AON domain

### 8.3.13 RCC\_CR3

Address Offset: 0x030

Reset Value: 0x00000000

| 31-16    | 15-8         | 7-0          |
|----------|--------------|--------------|
| RESERVED | I2S_MCLK_DIV | I2S_SCLK_DIV |
| r        | r/w          | r/w          |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-8 I2S\_MCLK\_DIV:** I2S interface clock MCLK frequency division

- 0: not divided
- 1: not divided
- 2: divided by 2
- 3: divided by 3
- N: divided by N

**Notice:**

1. Make sure to configure I2S\_MCLK\_DIV when I2S\_CLK\_EN=0. If the I2S\_CLK\_EN bit is enabled, the user must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure I2S\_MCLK\_DIV.
2. When I2S acts as a slave, this bit must be configured to 0 or 1; when I2S acts as a master, this bit is configured according to functional requirements.
3. The duty cycle of the output clock is 50%.

**Bits 7-0 I2S\_SCLK\_DIV:** I2S interface clock SCLK frequency division

- 0: not divided
- 1: not divided
- 2: divided by 2
- 3: divided by 3
- N: divided by N

**Notice:**

1. Make sure to configure I2S\_SCLK\_DIV when I2S\_CLK\_EN=0. If the I2S\_CLK\_EN bit is enabled, the user must disable it by software first, wait for at least 2 current clock cycles or query the [RCC\\_SR1](#) register, and then configure I2S\_SCLK\_DIV.
2. When I2S acts as a slave, this bit must be configured to 0 or 1; when I2S acts as a master, this bit is configured according to functional requirements.
3. The duty cycle of the output clock is 50%.

# 9.

# Interrupts

## 9.1 Main Features

- Support 37 IRQ interrupts
- Configurable 0~7 priority levels for each IRQ interrupt

## 9.2 SysTick

SysTick calibration value is 0x147. Using a 32.768 kHz clock source for SysTick counting gives a reference time base of 10 ms.

## 9.3 Interrupt Vector Table

**Table 9-1 Interrupt Vector**

| Position | Priority | Type of priority | Acronym            | Description                             | Address                   |
|----------|----------|------------------|--------------------|-----------------------------------------|---------------------------|
| -        | -        | -                | -                  | Reserved                                | 0x0000_0000               |
| -3       | fixed    |                  | Reset              | Reset                                   | 0x0000_0004               |
| -2       | fixed    |                  | NMI_Handler        | Secure area check error                 | 0x0000_0008               |
| -1       | fixed    |                  | HardFault_Handler  | fault                                   | 0x0000_000C               |
| 0        | settable |                  | MemManage_Handler  | fault                                   | 0x0000_0010               |
| 1        | settable |                  | BusFault_Handler   | fault                                   | 0x0000_0014               |
| 2        | settable |                  | UsageFault_Handler | fault                                   | 0x0000_0018               |
| -        | -        | -                | -                  | Reserved                                | 0x0000_001C - 0x0000_002B |
| 3        | settable |                  | SVC_Handler        | System service call via SWI instruction | 0x0000_002C               |
| -        | -        | -                | -                  | Reserved                                | 0x0000_0030 - 0x0000_0037 |
| 5        | settable |                  | PendSV_Handler     | Pendable request for system service     | 0x0000_0038               |
| 6        | settable |                  | SysTick_Handler    | System tick timer                       | 0x0000_003C               |
| 0        | 7        | settable         | sec                | Include mpu                             | 0x0000_0040               |
| 1        | 8        | settable         | rtc                | Include tamper io, cyc, wakeup io       | 0x0000_0044               |
| 2        | 9        | settable         | wwdg               |                                         | 0x0000_0048               |
| 3        | 10       | settable         | efc                |                                         | 0x0000_004C               |

| Position | Priority | Type of priority | Acronym   | Description | Address     |
|----------|----------|------------------|-----------|-------------|-------------|
| 4        | 11       | settable         | uart3     |             | 0x0000_0050 |
| 5        | 12       | settable         | i2c2      |             | 0x0000_0054 |
| 6        | 13       | settable         | uart0     |             | 0x0000_0058 |
| 7        | 14       | settable         | uart1     |             | 0x0000_005C |
| 8        | 15       | settable         | uart2     |             | 0x0000_0060 |
| 9        | 16       | settable         | lpuart    |             | 0x0000_0064 |
| 10       | 17       | settable         | ssp0      |             | 0x0000_0068 |
| 11       | 18       | settable         | ssp1      |             | 0x0000_006C |
| 12       | 19       | settable         | qspi      |             | 0x0000_0070 |
| 13       | 20       | settable         | i2c0      |             | 0x0000_0074 |
| 14       | 21       | settable         | i2c1      |             | 0x0000_0078 |
| 15       | 22       | settable         | -         |             | 0x0000_007C |
| 16       | 23       | settable         | adcctrl   |             | 0x0000_0080 |
| 17       | 24       | settable         | afec      |             | 0x0000_0084 |
| 18       | 25       | settable         | ssp2      |             | 0x0000_0088 |
| 19       | 26       | settable         | dmac1     |             | 0x0000_008C |
| 20       | 27       | settable         | dacctrl   |             | 0x0000_0090 |
| 21       | 28       | settable         | lorac     |             | 0x0000_0094 |
| 22       | 29       | settable         | iom       |             | 0x0000_0098 |
| 23       | 30       | settable         | gptim0    |             | 0x0000_009C |
| 24       | 31       | settable         | gptim1    |             | 0x0000_00A0 |
| 25       | 32       | settable         | gptim2    |             | 0x0000_00A4 |
| 26       | 33       | settable         | gptim3    |             | 0x0000_00A8 |
| 27       | 34       | settable         | basictim0 |             | 0x0000_00AC |
| 28       | 35       | settable         | basictim1 |             | 0x0000_00B0 |
| 29       | 36       | settable         | lptim0    |             | 0x0000_00B4 |
| 30       | 37       | settable         | sac       |             | 0x0000_00B8 |
| 31       | 38       | settable         | dmac0     |             | 0x0000_00BC |
| 32       | 39       | settable         | i2s       |             | 0x0000_00C0 |
| 33       | 40       | settable         | lcdctrl   |             | 0x0000_00C4 |
| 34       | 41       | settable         | pwr       |             | 0x0000_00C8 |
| 35       | 42       | settable         | lptim1    |             | 0x0000_00CC |
| 36       | 43       | settable         | iwdg      |             | 0x0000_00D0 |

# 10.

# Embedded Flash

## 10.1 Introduction

- The whole Flash is divided into Flash info area and Flash main area
- Flash size:
  - ◆ Flash info area: 16 KB in total
  - ◆ Flash main area: 256 KB for ASR6601SE/SER, 128 KB for ASR6601CB/CBR
- Page erase (4 KB) and Mass erase (all flash main)

## 10.2 Main Features

- Flash operations include read, program, page erase and mass erase
- Read access latency
- Acceleration for accessing the Flash memory
- Support instruction prefetch with 1 deep buffer
- Flash program operation supports single and continuous mode
- Option bytes in Flash info area
- Can be used to generate interrupt signals

## 10.3 Functional Description

### 10.3.1 Flash Info Area Division

The Flash info area is divided into four parts: Option Bytes, Factory Bytes, OTP and BootLoader. See the table below for details.

Table 10-1 Flash Info Area Division

| Start Address | Description   | Size |
|---------------|---------------|------|
| 0x10003000    | Option Bytes  | 4KB  |
| 0x10002000    | Factory Bytes | 4KB  |
| 0x10001C00    | OTP           | 1KB  |
| 0x10000000    | BootLoader    | 7KB  |

### 10.3.2 EFC\_CR Protection

By default, the EFC\_CR register cannot be modified, to modify it, the user must configure the protection sequence correctly through the [EFC\\_PROTECT\\_SEQ](#) register in the following order. If there is an error in the configuration, then the configuration is invalid, and the protection sequence should be reconfigured.

- (1) First write “0x8C9DAEBF” to EFC\_PROTECT\_SEQ register
- (2) Then write “0x13141516” to EFC\_PROTECT\_SEQ register

### 10.3.3 Read Access Latency

In order to improve Flash read performance, the number of wait states (READ\_NUM[19:16]) should be correctly programmed in [EFC\\_TIMING\\_CFG](#) register according to the frequency of SYS\_CLK. The number of wait states (READ\_NUM) equals to (READ\_NUM+1) multiplied by SYS\_CLK clock period. Details are as follows:

- When SYS\_CLK is 48MHz frequency, READ\_NUM must  $\geq 2$ .
- When SYS\_CLK is 32MHz frequency, READ\_NUM must  $\geq 1$ .
- When SYS\_CLK is 24MHz frequency, READ\_NUM must  $\geq 1$ .
- When SYS\_CLK is 3.6MHz frequency, READ\_NUM must  $\geq 0$ .
- When SYS\_CLK is 32kHz frequency, READ\_NUM must  $\geq 0$ .

**The operations to switch to a high-frequency clock source for SYS\_CLK:**

- (1) Modify the READ\_NUM value in [EFC\\_TIMING\\_CFG](#) register to match the SYS\_CLK after its clock source is switched.
- (2) Wait for the READ\_NUM\_DONE status bit in [EFC\\_SR](#) register to be set.
- (3) Modify the SYS\_CLK\_SEL field in [RCC\\_CRO](#) register to switch to the target clock source.

**The operations to switch to a low-frequency clock source for SYS\_CLK:**

- (1) Modify the SYS\_CLK\_SEL field in [RCC\\_CRO](#) register to switch to the target clock source.
- (2) Modify the READ\_NUM value in [EFC\\_TIMING\\_CFG](#) register to match the SYS\_CLK after its clock source is switched.
- (3) Wait for the READ\_NUM\_DONE status bit in [EFC\\_SR](#) register to be set.

**Notice:** When the user wants to switch to a high-frequency clock source, first increase the READ\_NUM, and then configure the clock source selection bit; otherwise, first configure the clock source selection bit, and then decrease the READ\_NUM.

### 10.3.4 Acceleration for Accessing the Flash Memory

Read acceleration is disabled by default. If  $\text{READ\_NUM} < (2^{\text{HCLK\_DIV}})$ , read acceleration can be enabled to achieve the maximum bus access efficiency. Note that read acceleration must be enabled after `READ_NUM` and `HCLK_DIV` are configured.

**Notice:** *Read acceleration and instruction prefetch can't be enabled at the same time.*

### 10.3.5 Instruction Prefetch

It is disabled by default. If  $\text{READ\_NUM} \geq (2^{\text{HCLK\_DIV}})$ , read acceleration cannot be enabled. You can choose to enable instruction prefetch to improve access efficiency.

**Notice:** *Read acceleration and instruction prefetch can't be enabled at the same time.*

### 10.3.6 Flash Program Operation

There are two modes for Flash programming:

- **Single Programming Mode**

In single mode, it programs 2 words (8 Bytes) each time.

- **Continuous Programming Mode**

In continuous mode, it programs a complete word line (512 Bytes) each time.

During continuous programming, Flash cannot be read or executed, so the continuous programming code must be executed in RAM.

#### Steps for single programming:

- (1) Set the `PROG_EN` bit in register `EFC_CR`.
- (2) Write the low 4 Bytes data into register `EFC_PROG_DATA0`.
- (3) Write the high 4 Bytes data into register `EFC_PROG_DATA1`.
- (4) Write any value to the Flash address to be written into.
- (5) Wait for the `OPERATION_DONE` bit in register `EFC_SR` to be set.
- (6) Write 1 to the `OPERATION_DONE` bit in register `EFC_SR` to clear the flag.

#### Steps for continuous programming:

- (1) Set the `PROG_EN`, `WRITE_RELEASE_EN` and `PROG_MODE` bits in register `EFC_CR`.
- (2) Wait for the `PROG_DATA_WAIT` bit in register `EFC_SR` to be set.
- (3) Write the low 4 Bytes data into register `EFC_PROG_DATA0`.
- (4) Write the high 4 Bytes data into register `EFC_PROG_DATA1`.
- (5) Write any value to the Flash address to be written into.
- (6) Wait for the `PROG_DATA_WAIT` bit in register `EFC_SR` to be set.

- (7) Continue to write data to the *EFC\_PROG\_DATA0* and *EFC\_PROG\_DATA1* registers.
- (8) Repeat **Step 6** and **Step 7** until 512 Bytes are written.
- (9) Wait for the OPERATION\_DONE bit in register *EFC\_SR* to be set.
- (10) Write 1 to the OPERATION\_DONE bit in register *EFC\_SR* to clear the flag.

### 10.3.7 Flash Erase Operation

The Flash memory erase operation can be performed at page level (page erase) or on the whole memory (mass erase).

- **Page Erase**

The page erase is measured in 4 Bytes.

- **Mass Erase**

After a mass erase, the entire Flash main area will be 0xFF.

**Steps for page erase:**

- (1) Set the PAGE\_ERASE\_EN bit in register *EFC\_CR*.
- (2) Write any value to the Flash address to be erased.
- (3) Wait for the OPERATION\_DONE bit in register *EFC\_SR* to be set.
- (4) Write 1 to the OPERATION\_DONE bit in register *EFC\_SR* to clear the flag.

**Steps for mass erase:**

- (1) Set the MASS\_ERASE\_EN bit in register *EFC\_CR*.
- (2) Write any value to the Flash address 0x08000000.
- (3) Wait for the OPERATION\_DONE bit in register *EFC\_SR* to be set.
- (4) Write 1 to the OPERATION\_DONE bit in register *EFC\_SR* to clear the flag.

## 10.4 Flash Option Bytes

Flash option bytes is divided into option0 and option1.

### 10.4.1 Flash Option0

Option0 has 64 bits in total, and its format is as follows:

**Table 10-2 Flash Option0**

| 63-50               | 49-44              | 43-38                | 37-32              | 31-26               | 25                   | 24-19             |
|---------------------|--------------------|----------------------|--------------------|---------------------|----------------------|-------------------|
| RESERVED            | WR_PROT<br>ECT_END | WR_PROTE<br>CT_START | EXE_ONLY2<br>_END  | EXE_ONLY2<br>_START | EXE_ONLY<br>_KEEP    | EXE_ONLY1<br>_END |
| 18-13               | 12-5               | 4                    | 3                  | 2                   | 1                    | 0                 |
| EXE_ONLY<br>1_START | DEBUG_L<br>EVEL    | RESERVED             | SYS_SRAM<br>_RESET | FLASH_BOO<br>T1     | USE_FLASH<br>H_BOOT0 | FLASH_BOO<br>T0   |

**Bits 63-50 RESERVED:** Must be kept, and cannot be modified.

**Bits 49-44 WR\_PROTECT\_END:** Write-protected area end

When *WR\_PROTECT\_START* > *WR\_PROTECT\_END*, the write-protected area is disabled. It is disabled by default.

**Bits 43-38 WR\_PROTECT\_START:** Write-protected area start

When *WR\_PROTECT\_START* > *WR\_PROTECT\_END*, the write-protected area is disabled. It is disabled by default.

**Bits 37-32 EXE\_ONLY2\_END:** Exe\_Only2 area end

When *EXE\_ONLY2\_START* > *EXE\_ONLY2\_END*, the Exe\_Only2 area is disabled. It is disabled by default. Once enabled, this area can only be expanded but can't be disabled or narrowed.

**Bits 31-26 EXE\_ONLY2\_START:** Exe\_Only2 area start

When *EXE\_ONLY2\_START* > *EXE\_ONLY2\_END*, the Exe\_Only2 area is disabled. It is disabled by default. Once enabled, this area can only be expanded but can't be disabled or narrowed.

**Bit 25 EXE\_ONLY\_KEEP:** Whether Exe\_Only area is kept when the Debug\_Level changes from 1 to 0

- 0: not keep Exe\_Only area
- 1: keep the Exe\_Only area

This bit can only be set to 0 by software. When Debug\_Level changes from 1 to 0, EXE\_ONLY\_KEEP is set to 1 automatically by hardware.

**Bits 24-19 EXE\_ONLY1\_END:** Exe\_Only1 area end

When *EXE\_ONLY1\_START* > *EXE\_ONLY1\_END*, the Exe\_Only1 area is disabled. It is disabled by default. Once enabled, this area can only be expanded but can't be disabled or narrowed.

**Bits 18-13 EXE\_ONLY1\_START:** Exe\_Only1 area start

When *EXE\_ONLY1\_START* > *EXE\_ONLY1\_END*, the Exe\_Only1 area is disabled. It is disabled by default. Once enabled, this area can only be expanded but can't be disabled or narrowed.

**Bits 12-5 DEBUG\_LEVEL:** Debug\_level configuration

- AA: Level 0
- CC: Level 2
- Others: Level 1

**Bit 4 RESERVED:** Must be kept, and cannot be modified.**Bit 3 SYS\_SRAM\_RESET:** Whether to clear system SRAM during system startup after its reset

- 1: clear system SRAM
- 0: not clear system SRAM

**Bit 2 FLASH\_BOOT1:** This bit can be used to identify the boot mode.**Bit 1 USE\_FLASH\_BOOT0:** This bit can be used to identify the boot mode.**Bit 0 FLASH\_BOOT0:** This bit can be used to identify the boot mode.

See below table for the boot mode configuration summary:

**Table 10-3 ASR6601 Boot Mode Configuration**

| DEBUG_LEVEL | USE_FLASH_BOOT0 | FLASH_BOOT0 | BOOT0 PIN | FLASH_BOOT1 | MAIN_FLASH_EMPTY | Boot Config                |
|-------------|-----------------|-------------|-----------|-------------|------------------|----------------------------|
| 2           | X               | X           | X         | X           | X                | Boot from Flash Main       |
| <2          | 0               | X           | 0         | X           | 0                | Boot from Flash Main       |
| <2          | 0               | X           | 0         | X           | 1                | Boot from inner Bootloader |
| <2          | 0               | X           | 1         | 1           | X                | Boot from inner Bootloader |
| <2          | 0               | X           | 1         | 0           | X                | Boot from System SRAM      |
| <2          | 1               | 1           | X         | X           | 0                | Boot from Flash Main       |
| <2          | 1               | 1           | X         | X           | 1                | Boot from inner Bootloader |
| <2          | 1               | 0           | X         | 1           | X                | Boot from inner Bootloader |
| <2          | 1               | 0           | X         | 0           | X                | Boot from System SRAM      |

## 10.4.2 Flash Option1

Option1 has 64 bits in total, and its format is as follows:

**Table 10-4 Flash Option1**

| 63-56                   | 55                 | 54-49                 | 48                      | 47-42                 | 41-37                  |
|-------------------------|--------------------|-----------------------|-------------------------|-----------------------|------------------------|
| RESERVED                | SYSRAM_HID<br>E_EN | SYSRAM_HID<br>E_START | FLASH_HIDE_<br>EN       | FLASH_HIDE_<br>_START | RETRAM_SEC<br>URE_END  |
| 36-32                   | 31-24              | 23-18                 | 17-12                   | 11-6                  | 5-0                    |
| RETRAM_SEC<br>URE_START | RESERVED           | SYSRAM_SEC<br>URE_END | SYSRAM_SEC<br>URE_START | FLASH_SEC<br>URE_END  | FLASH_SECU<br>RE_START |

**Bits 63-56 RESERVED:** Must be kept, and cannot be modified.

**Bit 55 SYSRAM\_HIDE\_EN:** SysRamHide area enable control

- 0: SysRamHide area enabled
- 1: SysRamHide area disabled

The configuration is only valid when the FlashSecure area is enabled by bits[11:0].

**Bits 54-49 SYSRAM\_HIDE\_START:** SysRamHide area start

The configuration is only valid when the SysRamHide area is within the SysRamSecure area and the FlashSecure area is enabled by bits[11:0].

The SysRamHide area is from SysRamHideStart to SysRamSecureEnd.

**Bit 48 FLASH\_HIDE\_EN:** FlashHide area enable control

- 0: FlashHide area enabled
- 1: FlashHide area disabled

The configuration is only valid when the FlashSecure area is enabled by bits[11:0].

**Bits 47-42 FLASH\_HIDE\_START:** FlashHide area start

The configuration is only valid when the FlashHide area is within the FlashSecure area and the FlashSecure area is enabled by bits[11:0].

The FlashHide area is from FlashHideStart to FlashSecureEnd.

**Bits 41-37 RETRAM\_SECURE\_END:** RetRam Secure area end

When *RETRAM\_SECURE\_START > RETRAM\_SECURE\_END*, the RetRam Secure area is disabled.

The configuration is only valid when the FlashSecure area is enabled by bits[11:0].

**Bits 36-32 RETRAM\_SECURE\_START:** RetRam Secure area start

When *RETRAM\_SECURE\_START > RETRAM\_SECURE\_END*, the RetRam Secure area is disabled.

The configuration is only valid when the FlashSecure area is enabled by bits[11:0].

**Bits 31-24 RESERVED:** Must be kept, and cannot be modified.

**Bits 23-18 SYSRAM\_SECURE\_END:** SysRam Secure area end

When *SYSRAM\_SECURE\_START > SYSRAM\_SECURE\_END*, the SysRam Secure area is disabled.

The configuration is only valid when the FlashSecure area is enabled by bits[11:0].

**Bits 17-12 SYSRAM\_SECURE\_START:** SysRam Secure area start

When *SYSRAM\_SECURE\_START* > *SYSRAM\_SECURE\_END*, the SysRam Secure area is disabled.

The configuration is only valid when the FlashSecure area is enabled by bits[11:0].

**Bits 11-6 FLASH\_SECURE\_END:** Flash Secure area end

When *FLASH\_SECURE\_START* > *FLASH\_SECURE\_END*, the Flash Secure area is disabled.

The Flash Secure area enable is the master switch for enabling other secure areas. When the Flash Secure area is disabled, the erase operation is triggered.

**Bits 5-0 FLASH\_SECURE\_START:** Flash Secure area start

When *FLASH\_SECURE\_START* > *FLASH\_SECURE\_END*, the Flash Secure area is disabled.

The Flash Secure area enable is the master switch for enabling other secure areas. When the Flash Secure area is disabled, the erase operation is triggered.

## 10.5 Embedded Flash Registers

Embedded Flash Base Address: 0x40020000

**Table 10-5 Embedded Flash Register Summary**

| Register Name           | Address Offset | Description                                        |
|-------------------------|----------------|----------------------------------------------------|
| EFC_CR                  | 0x00           | Control register                                   |
| EFC_INT_EN              | 0x04           | Interrupt enable register                          |
| EFC_SR                  | 0x08           | Status register                                    |
| EFC_PROG_DATA0          | 0x0C           | Program Data 0                                     |
| EFC_PROG_DATA1          | 0x10           | Program Data 1                                     |
| EFC_TIMING_CFG          | 0x14           | Timing configuration register                      |
| EFC_PROTECT_SEQ         | 0x18           | Protection Sequence                                |
| RESERVED                | 0x1C-0x28      | Reserved                                           |
| SERIAL_NUM_LOW          | 0x2C           | Less Significant 32 bits of the Chip Serial Number |
| SERIAL_NUM_HIGH         | 0x30           | More Significant 32 bits of the Chip Serial Number |
| RESERVED                | 0x34-0x38      | Reserved                                           |
| OPTION_CSR_BYTES        | 0x3C           | OPTION control and status data                     |
| OPTION_EXE_ONLY_BYTES   | 0x40           | OPTION Execution-only data                         |
| OPTION_WR_PROTECT_BYTES | 0x44           | OPTION Write-protection data                       |
| OPTION_SECURE_BYTES0    | 0x48           | OPTION Secure Data 0                               |
| OPTION_SECURE_BYTES1    | 0x4C           | OPTION Secure Data 0                               |

### 10.5.1 EFC\_CR

Address Offset: 0x00

Reset Value: 0x00000000

| 31                 | 30-10       | 9         | 8                 | 7                   | 6                      |
|--------------------|-------------|-----------|-------------------|---------------------|------------------------|
| INFO_BYTE_LO<br>AD | RESERVED    | ECC_DIS   | OPTION_OPR<br>_EN | RESERVED            | WRITE_RELEASE<br>SE_EN |
| w                  | r           | r/w       | r/w               | r                   | r/w                    |
| 5                  | 4           | 3         | 2                 | 1                   | 0                      |
| PREFETCH_EN        | READ_ACC_EN | PROG_MODE | PROG_EN           | PAGE_ERASE<br>SE_EN | MASS_ERASE<br>_EN      |
| r/w                | r/w         | r/w       | r/w               | r/w                 | r/w                    |

**Bit 31 INFO\_BYTE\_LOAD:** Info byte load reset request

- 0: invalid
- 1: system will reset, and reload the information in the Flash info area, such as options. This bit is automatically cleared by hardware.

**Bits 30-10 RESERVED:** Must be kept, and cannot be modified.

**Bit 9 ECC\_DIS:** ECC encoding disable

**Bit 8 OPTION\_OPR\_EN:** Option operation enable

- 0: Option operation disabled
- 1: Option operation enabled

**Notice:**

1. Any two of *OPTION\_OPR\_EN*, *PROG\_EN* and *PAGE\_ERASE\_EN* cannot be enabled at the same time.
2. After each option operation is performed, the system should be reset for the configuration to take effect.

**Bit 7 RESERVED:** Must be kept, and cannot be modified.

**Bit 6 WRITE\_RELEASE\_EN:** When the system executes Flash program, erase (including Mass) and option operations, the AHB bus mode should be selected.

- 0: hold mode
- 1: release mode

**Notice:** Once configured in the release mode, the Flash cannot be read or executed during programming/erasing operation, otherwise, the *FLASHBUSY\_ERR* error flag will be set. But you can access the [EFC\\_SR](#) register and wait the operation to be completed.

**Bit 5 PREFETCH\_EN:** Flash instruction prefetch enable

- 0: prefetch disabled
- 1: prefetch enabled

**Notice:** Read acceleration and instruction prefetch can't be enabled at the same time.

**Bit 4 READ\_ACC\_EN:** Flash read acceleration enable

- 0: read acceleration disabled (in hold mode)
- 1: read acceleration enabled (in release mode)

**Notice:**

1. When  $READ\_NUM < (2^HCLK\_DIV)$ , the read acceleration can be enabled. And it must be enabled after  $READ\_NUM$  and  $HCLK\_DIV$  configurations are completed.
2. Read acceleration and instruction prefetch can't be enabled at the same time.

**Bit 3 PROG\_MODE:** flash program mode selection

- 0: single programming mode. In this mode, the data in the *EFC\_PROG\_DATA1* and *EFC\_PROG\_DATA0* registers are written to the specified address in each program.
- 1: WL continuous programming mode. In this mode, a word line (512 Bytes) is programmed to the continuous address of the Flash memory automatically. During the procedure, the software checks the PROG\_DATA\_WAIT flag to determine whether to write new data into the *EFC\_PROG\_DATA1* and *EFC\_PROG\_DATA0* registers.

**Notice:**

1. The ECC encoding format in Flash is 64+8, so an even number of words are programmed each time.
2. In WL continuous programming mode, the *WRITE\_RELEASE\_EN* bit should be set to 1. During the programming process, only the *EFC\_SR*, *EFC\_PROG\_DATA1* and *EFC\_PROG\_DATA0* registers can be read or written, the Flash cannot be read or executed.

**Bit 2 PROG\_EN:** Flash programming enable

- 0: a write to the Flash memory does not trigger Flash programming operation
- 1: a write to the Flash memory triggers Flash programming operation

**Notice:**

1. In single programming mode, the programming is started by writing data to the 8-Byte aligned Flash address. The data of register *EFC\_PROG\_DATA0* will be written into the low 4-Byte address space, and the data of register *EFC\_PROG\_DATA1* will be written into the high 4-Byte address space.
2. In WL continuous programming mode, programming is started by writing data to the Flash address, and the programming address is accumulated by 8 Bytes until the end of a WL programming.

**Bit 1 PAGE\_ERASE\_EN:** Flash page erasing enable

- 0: a write to the Flash memory does not trigger Flash page erasing operation
- 1: a write to the Flash memory triggers Flash page erasing operation

**Bit 0 MASS\_ERASE\_EN:** Flash mass erasing enable

- 0: a write to the Flash memory does not trigger Flash mass erasing operation
- 1: a write to the Flash memory triggers Flash mass erasing operation

**Notice:**

1. When the bit is set, if there is a write to the address belonging to the Flash main area, mass erase is only performed on the main area; if there is a write to the address belonging to the Flash info area, mass erase is performed on both the main and info areas.
2. **Do not** perform mass erase on the Flash info area, otherwise the chip will be destroyed.

## 10.5.2 EFC\_INT\_EN

Address Offset: 0x04

Reset Value: 0x00000000

| <b>31-9</b>          | <b>8</b>             | <b>7</b>               | <b>6</b>        | <b>5</b>              |
|----------------------|----------------------|------------------------|-----------------|-----------------------|
| RESERVED             | TWO_BIT_ERROR_INT_EN | ONE_BIT_CORRECT_INT_EN | PROG_ERR_INT_EN | PAGE_ERASE_ERR_INT_EN |
| r                    | r/w                  | r/w                    | r/w             | r/w                   |
| <b>4</b>             | <b>3</b>             | <b>2</b>               | <b>1</b>        | <b>0</b>              |
| OPTION_WR_ERR_INT_EN | FLASHBUSY_ERR_INT_EN | PROG_DATA_WAIT_INT_EN  | RESERVED        | OPERATION_DONE_INT_EN |
| r/w                  | r/w                  | r/w                    | r               | r/w                   |

**Bits 31-9 RESERVED:** Must be kept, and cannot be modified.

**Bit 8 TWO\_BIT\_ERROR\_INT\_EN:** ECC TWO\_BIT\_ERROR interrupt enable

- 0: disabled
- 1: enabled

**Bit 7 ONE\_BIT\_CORRECT\_INT\_EN:** ECC ONE\_BIT\_CORRECT interrupt enable

- 0: disabled
- 1: enabled

**Bit 6 PROG\_ERR\_INT\_EN:** PROG\_ERR interrupt enable

- 0: disabled
- 1: enabled

**Bit 5 PAGE\_ERASE\_ERR\_INT\_EN:** PAGE\_ERASE\_ERR interrupt enable

- 0: disabled
- 1: enabled

**Bit 4 OPTION\_WR\_ERR\_INT\_EN:** OPTION\_WR\_ERR interrupt enable

- 0: disabled
- 1: enabled

**Bit 3 FLASHBUSY\_ERR\_INT\_EN:** FLASHBUSY\_ERR interrupt enable

- 0: disabled
- 1: enabled

**Bit 2 PROG\_DATA\_WAIT\_INT\_EN:** PROG\_DATA\_WAIT interrupt enable

- 0: disabled
- 1: enabled

**Bit 1 RESERVED:** Must be kept, and cannot be modified.

**Bit 0 OPERATION\_DONE\_INT\_EN:** OPERATION\_DONE interrupt enable

- 0: disabled
- 1: enabled

### 10.5.3 EFC\_SR

Address Offset: 0x08

Reset Value: 0x00000006

| 31-9          | 8             | 7               | 6             | 5              |
|---------------|---------------|-----------------|---------------|----------------|
| RESERVED      | TWO_BIT_ERROR | ONE_BIT_CORRECT | PROG_ERR      | PAGE_ERASE_ERR |
| r             | r/w           | r/w             | r/w           | r/w            |
| 4             | 3             | 2               | 1             | 0              |
| OPTION_WR_ERR | FLASHBUSY_ERR | PROG_DATA_WAIT  | READ_NUM_DONE | OPERATION_DONE |
| r/w           | r/w           | r/w             | r             | r/w            |

**Bits 31-9 RESERVED:** Must be kept, and cannot be modified.

**Bit 8 TWO\_BIT\_ERROR:** TWO\_BIT\_ERROR flag is set when the Flash memory is read

- 0: no two-bit error occurred
- 1: two-bit error occurred when reading the Flash memory and ECC did not correct

**Bit 7 ONE\_BIT\_CORRECT:** ONE\_BIT\_CORRECT flag is set when the Flash memory is read

- 0: no one-bit error occurred
- 1: one-bit error occurred when reading the Flash memory and ECC corrected it

**Bit 6 PROG\_ERR:** Some partitions within the Flash info area don't support programming operation (PROG\_EN). Programming operation to these partitions will be blocked, and this bit will be set by hardware and cleared by software writing 1 to it.

- 0: no programming error occurred
- 1: a programming error occurred

**Notice:** The option area cannot be written by direct program operations. The bootloader area cannot be programmed.

**Bit 5 PAGE\_ERASE\_ERR:** The Flash info area don't support erasing operation. Erasing operation to the info area will be blocked, and this bit will be set by hardware and cleared by software writing 1 to it.

- 0: no page erase error occurred
- 1: a page erase error occurred

**Bit 4 OPTION\_WR\_ERR:** The Option area should be configured with the limitations respected, or the configuration is invalid and this bit is set by hardware. It is cleared by software writing 1 to it.

- 0: no write permission error on Option byte
- 1: a write permission error on Option byte occurred

The configuration for the Option area must respect the following limitations:

1. Flash EXE\_Only1/EXE\_Only2 area can't be disabled or narrowed once it is enabled.
2. Bit EXE\_ONLY\_KEEP can't be modified from 0 to 1.
3. When SECURE\_AREA\_EN=1, operations initiated by non-secure areas only act on the FLASH\_SECURE\_END/FLASH\_SECURE\_START bits in Option bytes to clear the secure\_area\_en status bit.

**Bit 3 FLASHBUSY\_ERR:** When Flash is performing programming, erasing (including mass), and option operations, the read operation by the software will be blocked, the data returned by the bus is uncertain, it is an abnormal state, this bit will be set by hardware and cleared by software writing 1 to it.

- 0: no error occurred
- 1: a read error occurred during a Flash operation

**Bit 2 PROG\_DATA\_WAIT:** Waiting for data to be written to the Flash memory in WL continuous programming mode. This bit is set by hardware and is cleared automatically by hardware when the software writes new data to the *EFC\_PROG\_DATA0* and *EFC\_PROG\_DATA1* registers. It can also be cleared by software writing 1 to it.

- 0: the value of registers *EFC\_PROG\_DATA0* and *EFC\_PROG\_DATA1* has been written to the Flash memory
- 1: wait for the value of registers *EFC\_PROG\_DATA0* and *EFC\_PROG\_DATA1* to be written to the Flash memory

**Bit 1 READ\_NUM\_DONE:** *READ\_NUM* configuration status flag, it indicates whether the *READ\_NUM* configuration is complete. This bit is set and cleared by hardware.

- 0: not complete
- 1: complete

**Bit 0 OPERATION\_DONE:** Flash operation status flag, it indicates whether Flash mass erase/page erase/program option operation is complete. This bit is set by hardware and cleared by software writing 1 to it.

- 0: not complete
- 1: complete

#### 10.5.4 EFC\_PROG\_DATA0

Address Offset: 0x0C

Reset Value: 0x00000000

| 31-0       |
|------------|
| PROG_DATA0 |
| r/w        |

**Bits 31-0 PROG\_DATA0:** programming data 0

**Notice:** When programming, write data to register *EFC\_PROG\_DATA0* first.

### 10.5.5 EFC\_PROG\_DATA1

Address Offset: 0x10

Reset Value: 0x00000000

|             |
|-------------|
| <b>31-0</b> |
| PROG_DATA1  |
| r/w         |

**Bits 31-0 PROG\_DATA1:** programming data 1

**Notice:** When programming, write data to register EFC\_PROG\_DATA0 first.

### 10.5.6 EFC\_TIMING\_CFG

Address Offset: 0x14

Reset Value: 0x00031D1D

| <b>31-20</b> | <b>19-16</b> | <b>15-0</b> |
|--------------|--------------|-------------|
| RESERVED     | READ_NUM     | RESERVED    |
| r            | r/w          | r           |

**Bits 31-20 RESERVED:** Must be kept, and cannot be modified.

**Bits 19-16 READ\_NUM:** Program the number of wait states.

The READ\_NUM equals to (READ\_NUM+1) multiplied by SYS\_CLK clock period.

- When SYS\_CLK is 48 MHz frequency, READ\_NUM must  $\geq 2$ .
- When SYS\_CLK is 32 MHz frequency, READ\_NUM must  $\geq 1$ .
- When SYS\_CLK is 24 MHz frequency, READ\_NUM must  $\geq 1$ .
- When SYS\_CLK is 4 MHz frequency, READ\_NUM must  $\geq 0$ .
- When SYS\_CLK is 32 kHz frequency, READ\_NUM must  $\geq 0$ .

**Notice:** When changing the SYS\_CLK clock source in register RCC\_CRO, pay attention to the sequence of operations. If you intend to switch to a faster clock source, first increase the READ\_NUM, and then configure the clock source selection bit; otherwise, first configure the clock source selection bit, and then decrease the READ\_NUM.

**Bits 15-0 RESERVED:** Must be kept, and cannot be modified.

### 10.5.7 EFC\_PROTECT\_SEQ

Address Offset: 0x18

Reset Value: 0x00000000

|             |
|-------------|
| 31-0        |
| PROTECT_SEQ |
| w           |

**Bits 31-0 PROTECT\_SEQ:** Protection sequence for the configuration of register [EFC\\_CR](#)

By default, the EFC\_CR register cannot be modified, to modify it, the user must configure the protection sequence correctly through the EFC\_PROTECT\_SEQ register in the following order. If there is an error in the configuration, then the configuration is invalid, and the protection sequence should be reconfigured.

1. First write 0x8C9DAEBF
2. Then write 0x13141516

### 10.5.8 SERIAL\_NUM\_LOW

Address Offset: 0x2C

|                |
|----------------|
| 31-0           |
| SERIAL_NUM_LOW |
| r              |

**Bits 31-0 SERIAL\_NUM\_LOW:** Less significant 32 bits of the chip serial number

### 10.5.9 SERIAL\_NUM\_HIGH

Address Offset: 0x30

|                 |
|-----------------|
| 31-0            |
| SERIAL_NUM_HIGH |
| r               |

**Bits 31-0 SERIAL\_NUM\_HIGH:** More significant 32 bits of the chip serial number

### 10.5.10 OPTION\_CSR\_BYTES

Address Offset: 0x3C

Reset Value: 0x000000BD

| 31-7     | 6-5         | 4                  | 3                | 2               | 1                   | 0               |
|----------|-------------|--------------------|------------------|-----------------|---------------------|-----------------|
| RESERVED | DEBUG_LEVEL | SECURE_AREA<br>_EN | SYS_SRAM<br>_RST | FLASH_<br>BOOT1 | USE_FLASH<br>_BOOT0 | FLASH_<br>BOOT0 |
| r        | r           | r                  | r                | r               | r                   | r               |

**Bits 31-7 RESERVED:** Must be kept, and cannot be modified.

**Bits 6-5 DEBUG\_LEVEL:** Debug level setting

- 0: Level 0
- 1: Level 1
- 2: Level 2

**Bit 4 SECURE\_AREA\_EN:** Flash secure area status flag

- 0: secure area is disabled
- 1: secure area is enabled

**Bit 3 SYS\_SRAM\_RST:** Whether to clear system SRAM during system startup after its reset

- 0: not clear system SRAM
- 1: clear system SRAM

**Bit 2 FLASH\_BOOT1:** This bit can be used to identify the boot mode. See [Table 7-7](#) for more details.

- 0: 0
- 1: 1

**Bit 1 USE\_FLASH\_BOOT0:** This bit can be used to identify the boot mode. See [Table 7-7](#) for more details.

- 0: 0
- 1: 1

**Bit 0 FLASH\_BOOT0:** This bit can be used to identify the boot mode, and the configuration is only valid when USE\_FLASH\_BOOT0=1. See [Table 7-7](#) for more details.

- 0: 0
- 1: 1

### 10.5.11 OPTION\_EXE\_ONLY\_BYTES

Address Offset: 0x40

Reset Value: 0x00FC0FC0

| 31-25    | 24                | 23-18             | 17-12               | 11-6              | 5-0                 |
|----------|-------------------|-------------------|---------------------|-------------------|---------------------|
| RESERVED | EXE_ONLY_K<br>EEP | EXE_ONLY2_<br>END | EXE_ONLY2_<br>START | EXE_ONLY1_<br>END | EXE_ONLY1_<br>START |
| r        | r                 | r                 | r                   | r                 | r                   |

**Bits 31-25 RESERVED:** Must be kept, and cannot be modified.

**Bit 24 EXE\_ONLY\_KEEP:** Whether Exe\_Only area is kept when the Debug\_Level changes from 1 to 0

- 0: erase data in the ExeOnly area
- 1: keep the ExeOnly area

This bit can only be set to 0 by software.

**Bits 23-18 EXE\_ONLY2\_END:** Exe\_Only2 area end offset

When *EXEONLY2\_START* > *EXEONLY2\_END*, the ExeOnly2 area is disabled.

**Bits 17-12 EXE\_ONLY2\_START:** Exe\_Only2 area start offset

When *EXEONLY2\_START* > *EXEONLY2\_END*, the ExeOnly2 area is disabled.

Once enabled, this area can only be expanded but can't be disabled or narrowed.

**Bits 11-6 EXE\_ONLY1\_END:** Exe\_Only1 area end offset

When *EXEONLY1\_START* > *EXEONLY1\_END*, the ExeOnly1 area is disabled.

**Bits 5-0 EXE\_ONLY1\_START:** Exe\_Only1 area start offset

When *EXEONLY1\_START* > *EXEONLY1\_END*, the ExeOnly1 area is disabled.

Once enabled, this area can only be expanded but can't be disabled or narrowed.

### 10.5.12 OPTION\_WR\_PROTECT\_BYTES

Address Offset: 0x44

Reset Value: 0x0003F03F

| 31-12    | 11-6          | 5-0             |
|----------|---------------|-----------------|
| RESERVED | WRPROTECT_END | WRPROTECT_START |
| r        | r             | r               |

**Bits 31-12 RESERVED:** Must be kept, and cannot be modified.

**Bits 11-6 WRPROTECT\_END:** Write-protected area end offset

When *WRPROTECT\_START* > *WRPROTECT\_END*, the write-protected area is disabled.

**Bits 5-0 WRPROTECT\_START:** Write-protected area start offset

When *WRPROTECT\_START* > *WRPROTECT\_END*, the write-protected area is disabled.

### 10.5.13 OPTION\_SECURE\_BYTES0

Address Offset: 0x48

Reset Value: 0x00FC0FC0

| 31-24    | 23-18                 | 17-12                   | 11-6                 | 5-0                    |
|----------|-----------------------|-------------------------|----------------------|------------------------|
| RESERVED | SYSRAM_SECURE_<br>END | SYSRAM_SECURE_<br>START | FLASH_SECURE_<br>END | FLASH_SECURE_<br>START |
| r        | r                     | r                       | r                    | r                      |

**Bits 31-24 RESERVED:** Must be kept, and cannot be modified.

**Bits 23-18 SYSRAM\_SECURE\_END:** SysRam Secure area end

When *SYSRAM\_SECURE\_START > SYSRAM\_SECURE\_END*, the SysRam Secure area is disabled.

The configuration is only valid when SECURE\_AREA\_EN=1.

**Bits 17-12 SYSRAM\_SECURE\_START:** SysRam Secure area start

When *SYSRAM\_SECURE\_START > SYSRAM\_SECURE\_END*, the SysRam Secure area is disabled.

The configuration is only valid when SECURE\_AREA\_EN=1.

**Bits 11-6 FLASH\_SECURE\_END:** Flash Secure area end

When *FLASH\_SECURE\_START > FLASH\_SECURE\_END*, the Flash Secure area is disabled.

**Bits 5-0 FLASH\_SECURE\_START:** Flash Secure area start

When *FLASH\_SECURE\_START > FLASH\_SECURE\_END*, the Flash Secure area is disabled.

The Flash Secure area enable is the master switch for enabling other secure areas.

When the Flash Secure area is enabled, the SECURE\_AREA\_EN bit is set, which means all the other secure areas can be enabled.

When the Flash Secure area is disabled, the SECURE\_AREA\_EN bit is cleared, which triggers the erase operation.

### 10.5.14 OPTION\_SECURE\_BYTES1

Address Offset: 0x4C

Reset Value: 0x008103E0

| 31-24             | 23                 |                   | 22-17               |
|-------------------|--------------------|-------------------|---------------------|
| RESERVED          | SYSRAM_HIDE_ENABLE |                   | SYSRAM_HIDE_START   |
| r                 | r                  |                   | r                   |
| 16                | 15-10              | 9-5               | 4-0                 |
| FLASH_HIDE_ENABLE | FLASH_HIDE_START   | RETRAM_SECURE_END | RETRAM_SECURE_START |
| r                 | r                  | r                 | r                   |

**Bits 31-24 RESERVED:** Must be kept, and cannot be modified.

**Bit 23 SYSRAM\_HIDE\_ENABLE:** SysRamHide area enable control

- 0: SysRamHide area enabled
- 1: SysRamHide area disabled

The configuration is only valid when SECURE\_AREA\_EN=1.

**Bits 22-17 SYSRAM\_HIDE\_START:** SysRamHide area start

The configuration is only valid when the SysRamHide area is within the SysRamSecure area and when SECURE\_AREA\_EN=1.

The SysRamHide area is from SYSRAM\_HIDE\_START to SYSRAM\_SECURE\_END.

**Bit 16 FLASH\_HIDE\_ENABLE:** FlashHide area enable control

- 0: FlashHide area enabled
- 1: FlashHide area disabled

The configuration is only valid when SECURE\_AREA\_EN=1.

**Bits 15-10 FLASH\_HIDE\_START:** FlashHide area start

The configuration is only valid when the FlashHide area is within the FlashSecure area and when SECURE\_AREA\_EN=1.

The FlashHide area is from FLASH\_HIDE\_START to FLASH\_SECURE\_END.

**Bits 9-5 RETRAM\_SECURE\_END:** RetRam Secure area end

When RETRAM\_SECURE\_START > RETRAM\_SECURE\_END, the RetRam Secure area is disabled.

The configuration is only valid when SECURE\_AREA\_EN=1.

**Bits 4-0 RETRAM\_SECURE\_START:** RetRam Secure area start

When RETRAM\_SECURE\_START > RETRAM\_SECURE\_END, the RetRam Secure area is disabled.

The configuration is only valid when SECURE\_AREA\_EN=1.

# 11.

# GPIO

## 11.1 Introduction

ASR6601 GPIOs are divided into four groups: Ports A, B, C, and D. The SFR registers of each group are allocated the same, and they are distinguished by different base addresses. PortD Pin8 ~ Pin15 are located in the AON domain, and the other IOs are located in the Main domain.

All GPIOs support input and output, pull-up and pull-down, push-pull output and open-drain output. The output drive current can be configured as 4mA or 8mA. All GPIOs can generate interrupts, which can be triggered by rising edge, falling edge or both edges. In Sleep/Stop0~2 mode, all GPIOs can be used for wake-up; while in Stop3 mode, only some GPIOs can be used to wake-up MCU. All GPIOs support alternate functions.

## 11.2 Output Configuration

GPIO data output is configured by the [GPIOx\\_OER](#) and [GPIOx\\_ODR](#) registers.

GPIO output can be set or cleared. Writing 1 to bits[15:0] in register [GPIOx\\_BRR](#) or writing 1 to bits[31-16] in register [GPIOx\\_BSRR](#) can **clear** the corresponding bit in register [GPIOx\\_ODR](#). And writing 1 to bits[15:0] in register [GPIOx\\_BSRR](#) can **set** the corresponding bit in register [GPIOx\\_ODR](#).

GPIO port is configured as **push-pull** output through register [GPIOx\\_OTYPER](#). As to output in **open-drain** mode, for PortD Pin8 ~ PortD Pin15, it is enabled by configuring the [GPIOx\\_IER](#), [GPIOx\\_OER](#), [GPIOx\\_ODR](#) and [GPIOx\\_PSR](#) registers, and for other IO ports, it is enabled by configuring the [GPIOx\\_OER](#), [GPIOx\\_IER](#), [GPIOx\\_ODR](#) and [GPIOx\\_OTYPER](#) registers. Not implementing a real open drain struct, the open drain function is achieved by control of the [GPIOx\\_OER](#) and [GPIOx\\_ODR](#) registers.

GPIO can be configured as analog output.

## 11.3 Input Configuration

GPIO data input is enabled by configuring register [GPIOx\\_IER](#), and you can read register [GPIOx\\_IDR](#) to get the input status.

Input floating mode is realized by configuring register [GPIOx\\_PER](#) to disable pull-up and pull-down.

Pull-up or pull-down is enabled by configuring register [GPIOx\\_PER](#), and register [GPIOx\\_PSR](#) is used for pull-up or pull-down selection.

GPIO can be configured as analog input.

## 11.4 Output Drive Strength

High (8 mA) or low (4 mA) output drive strength is configured by [\*GPIOx\\_DSR\*](#) register.

## 11.5 GPIO Interrupts

All GPIOs support interrupts, which can be triggered by rising edge, falling edge or both edges. Interrupts are enabled by configuring [\*GPIOx\\_INT\\_CR\*](#) register.

## 11.6 Wakeup from Sleep/Stop0~2 Mode

In Sleep or Stop 0/1/2 mode, MCU can be woken up at high level or low level, and the output wake-up signal is high level. GPIO00-GPIO63 can all be used for wakeup, four IOs make up a group. A group can generate a wakeup signal, and each IO in a group can wake up MCU at high level or low level. In Sleep/Stop0~2 mode, the wakeup function is enabled by configuring the [\*GPIOx\\_WU\\_EN\*](#) register, and the high-level or low-level wakeup is selected by configuring the [\*GPIOx\\_WU\\_LVL\*](#) register.

## 11.7 Wakeup from Stop3 Mode

For GPIO00~GPIO55 in the Main domain, every 4 IO MUX outputs a wake-up signal, thus a total of 14 wake-up signals.

In Stop3 mode, wakeup enabling and wakeup at high or low level are configured by the corresponding bits in registers [\*GPIOA\\_STOP3\\_WU\\_CR\*](#), [\*GPIOx\\_STOP3\\_WU\\_CR\*](#) ( $x=B, C$ ) and [\*GPIOD\\_STOP3\\_WU\\_CR\*](#).

## 11.8 Alternate Function Configuration

GPIO can be used as general I/O or configured as alternate function. GPIO input/output is enabled or disabled by the [\*GPIOx\\_OER\*](#) and [\*GPIOx\\_IER\*](#) registers, while the alternate function input/output is enabled or disabled by alternate peripherals. The I/O pull-up or pull-down is configured by the [\*GPIOx\\_PER\*](#) and [\*GPIOx\\_PSR\*](#) registers.

As to alternate function control, 3-bit for each pin among PortD Pin8~Pin15, and 4-bit for each of the other pins. By default, PortA Pin6 and Pin7 are configured as SWD pins, and the other IOs are configured as GPIO.

Configure the function of Portx Pin[7:0] by register [\*GPIOx\\_AFRL\*](#), and configure the function of Portx Pin[15:8] by registers [\*GPIOx\\_AFRH\*](#) ( $x=A, B, C$ ) and [\*GPIOD\\_AFRH\*](#).

## 11.9 Clock Reset

There are four groups of APB bus clock and APB bus reset, each group has an independent bus clock and bus reset.

## 11.10 Power Domain

### Main Domain:

For all pins except PortD Pin8~Pin15, the corresponding PADs are in the Main domain.

### AON (always-on) Domain:

The PADs corresponds to PortD Pin8~Pin15 are in the AlwaysOn domain. If they are configured as alternate function, they are directly controlled by the peripherals. Otherwise, they will be controlled by the GPIO registers in the AlwaysOn domain.

## 11.11 Low-power Mode Operation and Wakeup

1. In Sleep mode, all GPIOs can work and output wake-up signal.
2. In Stop0/Stop1/Stop2 mode, all GPIOs can work and output wake-up signal.
3. In Stop3 mode, GPIO00~GPIO55 can retain the state, and can be configured as wake-up signal.
4. In Stop3 mode, PortD Pin8~Pin15 in AlwaysOn domain can retain the state, CPU can also be woken up through RTC.
5. In Standby mode, PortD Pin8~PortD Pin15 can work, while the other IOs can't work.

## 11.12 SWD IO

**Default Control:** The GPIO alternate function low register selects SWD by default, and SWC pull-down (PortA Pin7) and SWD pull-up (PortA Pin6) are default.

**Seal Control:** IO status is determined by the default value of the [GPIOx\\_AFRL](#) register at power-on until the DebugLevel decision is carried out. If sealing is needed, then the SWD interface will be sealed (disabled) eternally, otherwise, it is still controlled by the register.

**Software Configuration:** The SWD port can be disabled by the [GPIOx\\_AFRL](#) register. Note that it is one-way sealing, which means it cannot be enabled after being disabled.

## 11.13 BOOT0 Control

**Default Control:** Since all IOs except the SWC and SWD IOs are analog IOs by default, the BOOT0, SWC and SWD pins require special control at power-on.

**BOOT0 (GPIO02):** BOOT0 is in input pull-down status before io\_lock. After EFC is locked, it switches to GPIO mode.

## 11.14 GPIO Registers

GPIO Port A Base Address: 0x4001F000

GPIO Port B Base Address: 0x4001F400

GPIO Port C Base Address: 0x4001F800

GPIO Port D Base Address: 0x4001FC00

Table 11-1 GPIO Register Summary

| Register Name     | Address Offset | Description                                           |
|-------------------|----------------|-------------------------------------------------------|
| GPIOx_OER         | 0x00           | General output enable register                        |
| GPIOx_OTYPER      | 0x04           | General output type control register                  |
| GPIOx_IER         | 0x08           | General input enable register                         |
| GPIOx_PER         | 0x0C           | Pull-up/pull-down enable register                     |
| GPIOx_PSR         | 0x10           | Pull-up/pull-down selection register                  |
| GPIOx_IDR         | 0x14           | Input data register                                   |
| GPIOx_ODR         | 0x18           | Output data register                                  |
| GPIOx_BRR         | 0x1C           | Bit reset register                                    |
| GPIOx_BSRR        | 0x20           | Bit set or reset register                             |
| GPIOx_DSR         | 0x24           | Output drive strength register                        |
| GPIOx_INT_CR      | 0x28           | Interrupt enable register                             |
| GPIOx_FR          | 0x2C           | Interrupt edge flag register                          |
| GPIOx_WU_EN       | 0x30           | Wake-up enable register for Sleep/Stop0~2 mode        |
| GPIOx_WU_LVL      | 0x34           | Wake-up level control register for Sleep/Stop0~2 mode |
| GPIOx_AFRL        | 0x38           | GPIO alternate function low register                  |
| GPIOx_AFRH        | 0x3C           | GPIO alternate function high register                 |
| GPIOx_STOP3_WU_CR | 0x40           | Wake-up enable control register in Stop3 mode         |

### 11.14.1 GPIOx\_OER (x=A, B, C, D)

Address Offset: 0x00

Reset Value: 0x0000FFFF

| 31-16    | 15-0     |
|----------|----------|
| RESERVED | OEN      |
| r-0h     | rw-ffffh |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 OEN:** Portx Pin[15:0] output enable.

- 0: output enabled
- 1: output disabled

### 11.14.2 GPIOx\_OTYPER (x=A, B, C, D)

Address Offset: 0x04

Reset Value: 0x00000000

| 31-16    | 15-0  |
|----------|-------|
| RESERVED | OTYPE |
| r-0h     | rw-0h |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 OTYPE:** Portx Pin[15:0] output type control

- 0: push-pull
- 1: open-drain

**Note:** The output type of the pads in the AON domain (PortD\_Pin[15:8]) is controlled by the [GPIOx\\_IER](#), [GPIOx\\_OER](#), [GPIOx\\_ODR](#) and [GPIOx\\_PSR](#) registers instead of this register. For the other pins, the open-drain mode is enabled through the [GPIOx\\_IER](#), [GPIOx\\_OER](#), [GPIOx\\_ODR](#) and [GPIOx\\_OTYPER](#) registers.

### 11.14.3 GPIOx\_IER (x=A, B, C, D)

Address Offset: 0x08

Reset Value: 0x00000000

| 31-16    | 15-0  |
|----------|-------|
| RESERVED | IE    |
| r-0h     | rw-0h |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 IE:** Portx Pin[15:0] input enable

- 0: input disabled
- 1: input enabled

#### 11.14.4 GPIOx\_PER (x=A, B, C, D)

Address Offset: 0x0C

Reset Value: 0x00000000

| 31-16    | 15-0  |
|----------|-------|
| RESERVED | PE    |
| r-0h     | rw-0h |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 PE:** Portx Pin[15:0] pull-up/pull-down enable

- 0: pull-up/pull-down disabled
- 1: pull-up/pull-down enabled

GPIO pull-up and pull-down is selected by the [GPIOx\\_PSR](#) register. By default, pull-up/pull-down is disabled, and all the IOs except PortA\_Pin[7:6] are in analog mode. PortA\_Pin[7:6] are used as SWD function.

#### 11.14.5 GPIOx\_PSR (x=A, B, C, D)

Address Offset: 0x10

Reset Value: 0x00000000

| 31-16    | 15-0  |
|----------|-------|
| RESERVED | PS    |
| r-0h     | rw-0h |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 PS:** Portx Pin[15:0] pull-up/pull-down selection.

- 0: pull-down
- 1: pull-up

#### 11.14.6 GPIOx\_IDR (x=A, B, C, D)

Address Offset: 0x14

Reset Value: 0x00000000

| 31-16    | 15-0 |
|----------|------|
| RESERVED | ID   |
| r-0h     | r-0h |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 ID:** Portx Pin[15:0] input

- 0: low level
- 1: high level

### 11.14.7 GPIOx\_ODR (x=A, B, C, D)

Address Offset: 0x18

Reset Value: 0x00000000

| 31-16    | 15-0  |
|----------|-------|
| RESERVED | OD    |
| r-0h     | rw-0h |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 OD:** Portx Pin[15:0] output

- 0: low level
- 1: high level

### 11.14.8 GPIOx\_BRR (x=A, B, C, D)

Address Offset: 0x1C

Reset Value: 0x00000000

| 31-16    | 15-0 |
|----------|------|
| RESERVED | BR   |
| r-0h     | w-0h |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 BR:** Portx Pin[15:0] output data clear

- 0: invalid
- 1: clear the corresponding bit of the GPIOx\_ODR register

### 11.14.9 GPIOx\_BSRR (x=A, B, C, D)

Address Offset: 0x20

Reset Value: 0x00000000

| 31-16 | 15-0 |
|-------|------|
| BR    | BSR  |
| w-0h  | w-0h |

**Bits 31-16 BR:** Portx Pin[15:0] output data clear

- 0: disabled
- 1: clear the corresponding bit of the GPIOx\_ODR register

**Bits 15-0 BSR:** Portx Pin[15:0] output data set

- 0: disabled
- 1: set the corresponding bit of the GPIOx\_ODR register

**Note:** If both the BSR and BR bits are enabled, the BSR bit has a higher priority.

### 11.14.10 GPIOx\_DSR (x=A, B, C, D)

Address Offset: 0x24

Reset Value: 0x00000000

| 31-16    | 15-0 |
|----------|------|
| RESERVED | DS   |
| r-0h     | w-0h |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 DS:** Portx Pin[15:0] output drive strength configuration

- 0: low drive strength (4 mA)
- 1: high drive strength (8 mA)

### 11.14.11 GPIOx\_INT\_CR (x=A, B, C, D)

Address Offset: 0x28

Reset Value: 0x00000000

| 2*n + 1 (n≤15) | 2*n (n≤15) |
|----------------|------------|
| NEG_INT_EN     | POS_INT_EN |
| rw-0h          | rw-0h      |

**Bits 2\*n + 1 NEG\_INT\_EN:** Portx Pin[15:0] enable interrupt triggered by falling edge

- 0: interrupt triggered by falling edge disabled
- 1: interrupt triggered by falling edge enabled

**Bits 2\*n POS\_INT\_EN:** Portx Pin[15:0] enable interrupt triggered by rising edge

- 0: interrupt triggered by rising edge disabled
- 1: interrupt triggered by rising edge enabled

### 11.14.12 GPIOx\_FR (x=A, B, C, D)

Address Offset: 0x2C

Reset Value: 0x00000000

| 2*n + 1 (n≤15) | 2*n (n≤15) |
|----------------|------------|
| NEG_F          | POS_F      |
| rw1c-0h        | rw1c-0h    |

**Bits 2\*n + 1 NEG\_INT\_EN:** Portx Pin[15:0] interrupt flag (falling edge)

- 0: no interrupt triggered by falling edge occurred
- 1: interrupt triggered by falling edge occurred

**Bits 2\*n POS\_INT\_EN:** Portx Pin[15:0] interrupt flag (rising edge)

- 0: no interrupt triggered by rising edge occurred
- 1: interrupt triggered by rising edge occurred

### 11.14.13 GPIOx\_WU\_EN (x=A, B, C, D)

Address Offset: 0x30

Reset Value: 0x00000000

| 31-16    | 15-0  |
|----------|-------|
| RESERVED | WU_EN |
| r-0h     | rw-0h |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 WU\_EN:** Enable/disable Portx Pin[15:0] to wake-up CPU from Sleep/Stop0~2 mode

- 0: disabled
- 1: enabled

### 11.14.14 GPIOx\_WU\_LVL (x=A, B, C, D)

Address Offset: 0x34

Reset Value: 0x00000000

| 31-16    | 15-0   |
|----------|--------|
| RESERVED | WU_LVL |
| r-0h     | rw-0h  |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 WU\_LVL:** Configure the Portx Pin[15:0] to wakeup CPU from Sleep/Stop0~2 mode in high or low level

- 0: wake-up at low level
- 1: wake-up at high level

### 11.14.15 GPIOx\_AFRL (x=A, B, C, D)

Address Offset: 0x38

Reset Value: 0x00000000

| 31-28 | 27-24 | 23-20 | 19-16 | 15-12 | 11-8  | 7-4   | 3-0   |
|-------|-------|-------|-------|-------|-------|-------|-------|
| AF7   | AF6   | AF5   | AF4   | AF3   | AF2   | AF1   | AF0   |
| rw-0h |

**Bits 31-28 AF7:** Portx Pin7 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4

- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

**Bits 27-24 AF6:** Portx Pin6 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

**Bits 23-20 AF5:** Portx Pin5 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

**Bits 19-16 AF4:** Portx Pin4 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

**Bits 15-12 AF3:** Portx Pin3 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7

- others: Reserved

**Bits 11-8 AF2:** Portx Pin2 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

**Bits 7-4 AF1:** Portx Pin1 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

**Bits 3-0 AF0:** Portx Pin0 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

### 11.14.16 GPIOx\_AFRH (x=A, B, C)

Address Offset: 0x3C

Reset Value: 0x00000000

| 31-28 | 27-24 | 23-20 | 19-16 | 15-12 | 11-8  | 7-4   | 3-0   |
|-------|-------|-------|-------|-------|-------|-------|-------|
| AF15  | AF14  | AF13  | AF12  | AF11  | AF10  | AF9   | AF8   |
| rw-0h |

#### Bits 31-28 AF15: Portx Pin15 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

#### Bits 27-24 AF14: Portx Pin14 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

#### Bits 23-20 AF13: Portx Pin13 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

#### Bits 19-16 AF12: Portx Pin12 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2

- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

**Bits 15-12 AF11:** Portx Pin11 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

**Bits 11-8 AF10:** Portx Pin10 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

**Bits 7-4 AF9:** Portx Pin9 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5
- 0110: Function6
- 0111: Function7
- others: Reserved

**Bits 3-0 AF8:** Portx Pin8 function selection

- 0000: Function0
- 0001: Function1
- 0010: Function2
- 0011: Function3
- 0100: Function4
- 0101: Function5

- 0110: Function6
- 0111: Function7
- others: Reserved

### 11.14.17 GPIOD\_AFRH

Address Offset: 0x3C

Reset Value: 0x00000000

| <b>31-24</b> | <b>23-21</b> | <b>20-18</b> | <b>17-15</b> | <b>14-12</b> | <b>11-9</b> | <b>8-6</b> | <b>5-3</b> | <b>2-0</b> |
|--------------|--------------|--------------|--------------|--------------|-------------|------------|------------|------------|
| RESERVED     | AF15         | AF14         | AF13         | AF12         | AF11        | AF10       | AF9        | AF8        |
| r-0h         | rw-0h        | rw-0h        | rw-0h        | rw-0h        | rw-0h       | rw-0h      | rw-0h      | rw-0h      |

**Bits 31-24 RESERVED:** Must be kept, and cannot be modified.

- 001: Function1
- 010: Function2
- 011: Function3
- 100: Function4
- 101: Function5
- 110: Function6
- 111: Function7

**Bits 23-21 AF15:** PortD Pin15 function selection

- 001: Function1
- 010: Function2
- 011: Function3
- 100: Function4
- 101: Function5
- 110: Function6
- 111: Function7

**Bits 20-18 AF14:** PortD Pin14 function selection

- 001: Function1
- 010: Function2
- 011: Function3
- 100: Function4
- 101: Function5
- 110: Function6
- 111: Function7

**Bits 17-15 AF13:** PortD Pin13 function selection

- 001: Function1
- 010: Function2
- 011: Function3
- 100: Function4
- 101: Function5

- 110: Function6
- 111: Function7

**Bits 14-12 AF12:** PortD Pin12 function selection

- 001: Function1
- 010: Function2
- 011: Function3
- 100: Function4
- 101: Function5
- 110: Function6
- 111: Function7

**Bits 11-9 AF11:** PortD Pin11 function selection

- 001: Function1
- 010: Function2
- 011: Function3
- 100: Function4
- 101: Function5
- 110: Function6
- 111: Function7

**Bits 8-6 AF10:** PortD Pin10 function selection

- 001: Function1
- 010: Function2
- 011: Function3
- 100: Function4
- 101: Function5
- 110: Function6
- 111: Function7

**Bits 5-3 AF9:** PortD Pin9 function selection

- 001: Function1
- 010: Function2
- 011: Function3
- 100: Function4
- 101: Function5
- 110: Function6
- 111: Function7

**Bits 2-0 AF8:** PortD Pin8 function selection

- 001: Function1
- 010: Function2
- 011: Function3
- 100: Function4
- 101: Function5
- 110: Function6
- 111: Function7

### 11.14.18 GPIOA\_STOP3\_WU\_CR

Address Offset: 0x40

Reset Value: 0x00000000

| <b>31-16</b>    | <b>15</b>       | <b>14</b>       | <b>13-12</b>    | <b>11</b>      |
|-----------------|-----------------|-----------------|-----------------|----------------|
| RESERVED        | STOP3_WU_EN_G1  | STOP3_WU_LVL_G3 | STOP3_WU_SEL_G3 | STOP3_WU_EN_G2 |
| r-0h            | rw-0h           | rw-0h           | rw-0h           | rw-0h          |
| <b>10</b>       | <b>9-8</b>      | <b>7</b>        | <b>6</b>        |                |
| STOP3_WU_LVL_G2 | STOP3_WU_SEL_G2 | STOP3_WU_EN_G1  | STOP3_WU_LVL_G1 |                |
| rw-0h           | rw-0h           | rw-0h           | rw-0h           |                |
| <b>5-4</b>      | <b>3</b>        | <b>2</b>        | <b>1-0</b>      |                |
| STOP3_WU_SEL_G1 | STOP3_WU_EN_G0  | STOP3_WU_LVL_G0 | STOP3_WU_SEL_G0 |                |
| rw-0h           | rw-0h           | rw-0h           | rw-0h           |                |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bit 15 STOP3\_WU\_EN\_G3:** PortA Group3 wake-up pin enable control in Stop3 mode

- 0: disabled
- 1: enabled

**Bit 14 STOP3\_WU\_LVL\_G3:** PortA Group3 wake-up pin level selection in Stop3 mode

- 0: wake-up at low level
- 1: wake-up at high level

**Bits 13-12 STOP3\_WU\_SEL\_G3:** PortA Pin Group3 wake-up source selection in Stop3 mode

- 00: PortA Pin6
- 01: PortA Pin7
- 10: PortA Pin14
- 11: PortA Pin15

**Bit 11 STOP3\_WU\_EN\_G2:** PortA Group2 wake-up pin enable control in Stop3 mode

- 0: disabled
- 1: enabled

**Bit 10 STOP3\_WU\_LVL\_G2:** PortA Group2 wake-up pin level selection in Stop3 mode

- 0: wake-up at low level
- 1: wake-up at high level

**Bits 9-8 STOP3\_WU\_SEL\_G2:** PortA Pin Group2 wake-up source selection in Stop3 mode

- 00: PortA Pin8
- 01: PortA Pin9
- 10: PortA Pin10
- 11: PortA Pin11

**Bit 7 STOP3\_WU\_EN\_G1:** PortA Group1 wake-up pin enable control in Stop3 mode

- 0: disabled
- 1: enabled

**Bit 6 STOP3\_WU\_LVL\_G1:** PortA Group1 wake-up pin level selection in Stop3 mode

- 0: wake-up at low level
- 1: wake-up at high level

**Bits 5-4 STOP3\_WU\_SEL\_G1:** PortA Pin Group1 wake-up source selection in Stop3 mode

- 00: PortA Pin4
- 01: PortA Pin5
- 10: PortA Pin12
- 11: PortA Pin13

**Bit 3 STOP3\_WU\_EN\_G0:** PortA Group0 wake-up pin enable control in Stop3 mode

- 0: disabled
- 1: enabled

**Bit 2 STOP3\_WU\_LVL\_G0:** PortA Group0 wake-up pin level selection in Stop3 mode

- 0: wake-up at low level
- 1: wake-up at high level

**Bits 1-0 STOP3\_WU\_SEL\_G0:** PortA Pin Group0 wake-up source selection in Stop3 mode

- 00: PortA Pin0
- 01: PortA Pin1
- 10: PortA Pin2
- 11: PortA Pin3

#### 11.14.19 GPIOx\_STOP3\_WU\_CR (x=B, C)

Address Offset: 0x40

Reset Value: 0x00000000

| 31-16           | 15              | 14              | 13-12           | 11             |
|-----------------|-----------------|-----------------|-----------------|----------------|
| RESERVED        | STOP3_WU_EN_G3  | STOP3_WU_LVL_G3 | STOP3_WU_SEL_G3 | STOP3_WU_EN_G2 |
| r-0h            | rw-0h           | rw-0h           | rw-0h           | rw-0h          |
| 10              | 9-8             | 7               | 6               |                |
| STOP3_WU_LVL_G2 | STOP3_WU_SEL_G2 | STOP3_WU_EN_G1  | STOP3_WU_LVL_G1 |                |
| rw-0h           | rw-0h           | rw-0h           | rw-0h           |                |
| 5-4             | 3               | 2               | 1-0             |                |
| STOP3_WU_SEL_G1 | STOP3_WU_EN_G0  | STOP3_WU_LVL_G0 | STOP3_WU_SEL_G0 |                |
| rw-0h           | rw-0h           | rw-0h           | rw-0h           |                |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bit 15 STOP3\_WU\_EN\_G3:** Portx Pin Group3 wake-up enable control in Stop3 mode

- 0: disabled
- 1: enabled

**Bit 14 STOP3\_WU\_LVL\_G3:** Portx Pin Group3 wake-up level selection in Stop3 mode

- 0: wake-up at low level
- 1: wake-up at high level

**Bits 13-12 STOP3\_WU\_SEL\_G3:** Portx Pin Group3 wake-up source selection in Stop3 mode

- 00: Portx Pin12
- 01: Portx Pin13
- 10: Portx Pin14
- 11: Portx Pin15

**Bit 11 STOP3\_WU\_EN\_G2:** Portx Pin Group2 wake-up enable control in Stop3 mode

- 0: disabled
- 1: enabled

**Bit 10 STOP3\_WU\_LVL\_G2:** Portx Pin Group2 wake-up level selection in Stop3 mode

- 0: wake-up at low level
- 1: wake-up at high level

**Bits 9-8 STOP3\_WU\_SEL\_G2:** Portx Pin Group2 wake-up source selection in Stop3 mode

- 00: Portx Pin8
- 01: Portx Pin9
- 10: Portx Pin10
- 11: Portx Pin11

**Bit 7 STOP3\_WU\_EN\_G1:** Portx Pin Group1 wake-up enable control in Stop3 mode

- 0: disabled
- 1: enabled

**Bit 6 STOP3\_WU\_LVL\_G1:** Portx Pin Group1 wake-up level selection in Stop3 mode

- 0: wake-up at low level
- 1: wake-up at high level

**Bits 5-4 STOP3\_WU\_SEL\_G1:** Portx Pin Group1 wake-up source selection in Stop3 mode

- 00: Portx Pin4
- 01: Portx Pin5
- 10: Portx Pin6
- 11: Portx Pin7

**Bit 3 STOP3\_WU\_EN\_G0:** Portx Pin Group0 wake-up enable control in Stop3 mode

- 0: disabled
- 1: enabled

**Bit 2 STOP3\_WU\_LVL\_G0:** Portx Pin Group0 wake-up level selection in Stop3 mode

- 0: wake-up at low level
- 1: wake-up at high level

**Bits 1-0 STOP3\_WU\_SEL\_G0:** Portx Pin Group0 wake-up source selection in Stop3 mode

- 00: Portx Pin0
- 01: Portx Pin1
- 10: Portx Pin2
- 11: Portx Pin3

#### 11.14.20 GPIOD\_STOP3\_WU\_CR

Address Offset: 0x40

Reset Value: 0x00000000

| <b>31-8</b>     |                | <b>7</b>        | <b>6</b>        |
|-----------------|----------------|-----------------|-----------------|
| RESERVED        |                | STOP3_WU_EN_G1  | STOP3_WU_LVL_G1 |
| r-0h            |                | rw-0h           | rw-0h           |
| <b>5-4</b>      | <b>3</b>       | <b>2</b>        | <b>1-0</b>      |
| STOP3_WU_SEL_G1 | STOP3_WU_EN_G0 | STOP3_WU_LVL_G0 | STOP3_WU_SEL_G0 |
| rw-0h           | rw-0h          | rw-0h           | rw-0h           |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bit 7 STOP3\_WU\_EN\_G1:** PortD Pin Group1 wake-up enable control in Stop3 mode

- 0: disabled
- 1: enabled

**Bit 6 STOP3\_WU\_LVL\_G1:** PortD Pin Group1 wake-up level selection in Stop3 mode

- 0: wake-up at low level
- 1: wake-up at high level

**Bits 5-4 STOP3\_WU\_SEL\_G1:** PortD Pin Group1 wake-up source selection in Stop3 mode

- 00: PortD Pin4
- 01: PortD Pin5
- 10: PortD Pin6
- 11: PortD Pin7

**Bit 3 STOP3\_WU\_EN\_G0:** PortD Pin Group0 Stop3 wake-up enable control in Stop3 mode

- 0: disabled
- 1: enabled

**Bit 2 STOP3\_WU\_LVL\_G0:** PortD Pin Group0 Stop3 wake-up level selection in Stop3 mode

- 0: wake-up at low level
- 1: wake-up at high level

**Bits 1-0 STOP3\_WU\_SEL\_G0:** PortD Pin Group0 Stop3 wake-up source selection in Stop3 mode

- 00: PortD Pin0
- 01: PortD Pin1
- 10: PortD Pin2
- 11: PortD Pin3

# 12.

# LoRa Controller (LoRaC)

## 12.1 Introduction

LoRa Controller is mainly used to control the internal RF TRX to transmit and reception LoRa signal.

## 12.2 Main Features

- Support SPI interface to connect with RF TRX
- Support interrupt signal generation

## 12.3 Functional Description

### 12.3.1 Internal SPI Interface

There is an internal SPI interface in the LoRa Controller, which allows the LoRa Controller to directly control RF TRX through registers. The communication between the MCU and RF TRX is as follows:

1. Initialize the internal SSP in LoRa Controller
2. Check whether the BUSY\_DIG\_SR bit in register `LORAC_SR` is 0, if it is 0, it means that RF TRX is currently free for communication.
3. Write the REG\_NSS bit in register `LORAC_NSS_CR` to 0.
4. Write data into register `SSP_DR` which belonging to the internal SSP of LoRa Controller.
5. Wait for the transmission to be completed.
6. Read back the data through register `SSP_DR`.
7. Repeat Steps 4 ~ Step 6 as required.
8. Write the REG\_NSS bit in register `LORAC_NSS_CR` to 1.

### 12.3.2 Timing Sequence of Power-on



Figure 12-1 Timing Sequence of Power-on

As shown in the figure above, the process of power-on is:

- (1) Set the NRESET\_BAT bit in register *LORAC\_CR1* to 1.
- (2) Set the POR\_BAT bit in register *LORAC\_CR1* to 0.
- (3) Wait for the BUSY\_DIG\_SR bit in register *LORAC\_SR* to be cleared.

$T_{por\_min}$  is 100  $\mu$ s and  $T_{nrst\_min}$  is 50  $\mu$ s.

### 12.3.3 Interrupts

The LoRa Controller transparently transmits the RF TRX interrupt request, and this generates the interrupt signal. Note that once the interrupt request of the LoRa Controller is triggered, software must send the *ClearIrqStatus* command to the RF TRX to clear the interrupt, otherwise the interrupt request will be triggered all the time.

## 12.4 LoRaC Registers

LORAC Base Address: 0x40009000

**Table 12-1 LORAC Register Summary**

| Register Name | Address Offset | Description                                          |
|---------------|----------------|------------------------------------------------------|
| SSP_CR0       | 0x00           | LORAC Internal SSP Control Register 0                |
| SSP_CR1       | 0x04           | LORAC Internal SSP Control Register 1                |
| SSP_DR        | 0x08           | LORAC Internal SSP Data Register                     |
| SSP_SR        | 0x0C           | LORAC Internal SSP Status Register                   |
| SSP_CPSR      | 0x10           | LORAC Internal SSP Clock Prescaler Register          |
| SSP_IMSC      | 0x14           | LORAC Internal SSP Interrupt Mask Set/Clear Register |
| SSP_RIS       | 0x18           | LORAC Internal SSP Raw Interrupt Status register     |
| SSP_MIS       | 0x1C           | LORAC Internal SSP Masked Interrupt Status register  |
| SSP_ICR       | 0x20           | LORAC Internal SSP Interrupt Clear Register          |
| SSP_DMACR     | 0x24           | LORAC Internal SSP DMA Control Register              |
| RESERVED      | 0x28-0xFC      | Must be kept, and cannot be modified.                |
| LORAC_CR0     | 0x100          | LORAC Control Register 0                             |
| LORAC_CR1     | 0x104          | LORAC Control Register 1                             |
| LORAC_SR      | 0x108          | LORAC Status Register                                |
| LORAC_NSS_CR  | 0x10C          | LORAC NSS Control Register                           |
| LORAC_SCK_CR  | 0x110          | LORAC SCK Control Register                           |
| LORAC_MOSI_CR | 0x114          | LORAC MOSI Control Register                          |
| LORAC_MISO_SR | 0x118          | LORAC MISO Status Register                           |

### 12.4.1 SSP\_CR0

Address Offset: 0x00

Reset Value: 0x00000000

| 31-16    | 15-8 | 7   | 6   | 5-4 | 3-0 |
|----------|------|-----|-----|-----|-----|
| RESERVED | SCR  | SPH | SPO | FRF | DSS |
| r        | r/w  | r/w | r/w | r/w | r/w |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-8 SCR:** Serial clock rate, used to set the SSP transfer rate.

$$F_{SSPCLKOUT} = \frac{F_{SSPCLK}}{CPSDVR \times (1+SCR)}$$

The formula to calculate the SSP transfer rate is as above, where CPSDVR is an even number ranging from 2 to 254.

**Bit 7 SPH:** SSP phase setting, only applied in Motorola SPI format

**Bit 6 SPO:** SSP polarity setting, only applied in Motorola SPI format

**Bits 5-4 FRF:** SSP frame formats setting

- 0: Motorola SPI
- 1: Texas Instruments SPI
- 2: National Semiconductor Microwire
- 3: reserved

**Bits 3-0 DSS:** Data width setting

- 0: reserved
- 1: reserved
- 2: reserved
- 3: 4 bit
- 4: 5 bit
- 5: 6 bit
- 6: 7 bit
- 7: 8 bit
- 8: 9 bit
- 9: 10 bit
- 10: 11 bit
- 11: 12 bit
- 12: 13 bit
- 13: 14 bit
- 14: 15 bit
- 15: 16 bit

### 12.4.2 SSP\_CR1

Address Offset: 0x04

Reset Value: 0x00000000

| 31-4     | 3   | 2   | 1   | 0   |
|----------|-----|-----|-----|-----|
| RESERVED | SOD | MS  | SSE | LBM |
| r        | r/w | r/w | r/w | r/w |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bit 3 SOD:** SSP output disable in slave mode

- 0: SSP output enabled in slave mode
- 1: SSP output disabled in slave mode

**Bit 2 MS:** Master/slave mode selection

- 0: master mode
- 1: slave mode

**Bit 1 SSE:** SSP enable

- 0: disabled
- 1: enabled

**Bit 0 LBM:** loopback mode

- 0: normal mode
- 1: loopback mode

### 12.4.3 SSP\_DR

Address Offset: 0x08

Reset Value: 0x00000000

| 31-16    | 15-0 |
|----------|------|
| RESERVED | DATA |
| r        | r/w  |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 DATA:** SSP TX/RX data

#### 12.4.4 SSP\_SR

Address Offset: 0x0C

Reset Value: 0x00000003

| 31-5     | 4   | 3   | 2   | 1   | 0   |
|----------|-----|-----|-----|-----|-----|
| RESERVED | BSY | RFF | RNE | TNF | TFE |
| r        | r   | r   | r   | r   | r   |

**Bits 31-5 RESERVED:** Must be kept, and cannot be modified.

**Bit 4 BSY:** SSP busy flag

- 0: SSP is idle
- 1: SSP transfer is on going

**Bit 3 RFF:** RX FIFO full flag

- 0: RX FIFO is not full
- 1: RX FIFO is full

**Bit 2 RNE:** RX FIFO not empty flag

- 0: RX FIFO is empty
- 1: RX FIFO is not empty

**Bit 1 TNF:** TX FIFO not full flag

- 0: TX FIFO is full
- 1: TX FIFO is not full

**Bit 0 TFE:** TX FIFO empty flag

- 0: TX FIFO is not empty
- 1: TX FIFO is empty

#### 12.4.5 SSP\_CPSR

Address Offset: 0x0C

Reset Value: 0x00000000

| 31-8     | 7-0    |
|----------|--------|
| RESERVED | CPSDVS |
| r        | r/w    |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-0 CPSDVS:** Clock prescaler divider, must be an even number between 2~254.

### 12.4.6 SSP\_IMSC

Address Offset: 0x00

Reset Value: 0x00000000

| 31-4     | 3    | 2    | 1    | 0     |
|----------|------|------|------|-------|
| RESERVED | TXIM | RXIM | RTIM | RORIM |
| r        | r/w  | r/w  | r/w  | r/w   |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bit 3 TXIM:** TX interrupt mask bit

- 0: TX interrupt is masked
- 1: TX interrupt is not masked

**Bit 2 RXIM:** RX interrupt mask bit

- 0: RX interrupt is masked
- 1: RX interrupt is not masked

**Bit 1 RTIM:** RX timeout interrupt mask bit

- 0: RX timeout interrupt is masked
- 1: RX timeout interrupt is not masked

**Bit 0 RORIM:** RX overrun interrupt mask bit

- 0: RX overrun interrupt is masked
- 1: RX overrun interrupt is not masked

### 12.4.7 SSP\_RIS

Address Offset: 0x00

Reset Value: 0x00000008

| 31-4     | 3     | 2     | 1     | 0      |
|----------|-------|-------|-------|--------|
| RESERVED | TXRIS | RXRIS | RTRIS | RORRIS |
| r        | r     | r     | r     | r      |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bit 3 TXRIS:** TX raw interrupt status

**Bit 2 RXRIS:** RX raw interrupt status

**Bit 1 RTRIS:** RX timeout raw interrupt status

**Bit 0 RORRIS:** RX overrun raw interrupt status

### 12.4.8 SSP\_MIS

Address Offset: 0x00

Reset Value: 0x00000000

| 31-4     | 3     | 2     | 1     | 0      |
|----------|-------|-------|-------|--------|
| RESERVED | TXMIS | RXMIS | RTMIS | RORMIS |
| r        | r     | r     | r     | r      |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bit 3 TXMIS:** TX masked interrupt status

**Bit 2 RXMIS:** RX masked interrupt status

**Bit 1 RTMIS:** RX timeout masked interrupt status

**Bit 0 RORMIS:** RX overrun masked interrupt status

### 12.4.9 SSP\_ICR

Address Offset: 0x00

Reset Value: 0x00000000

| 31-2     | 1    | 0     |
|----------|------|-------|
| RESERVED | RTIC | RORIC |
| r        | w    | w     |

**Bits 31-2 RESERVED:** Must be kept, and cannot be modified.

**Bit 1 RTIC:** RX timeout interrupt clear. This bit is cleared by software writing 1 to it, while writing 0 has no effect.

**Bit 0 RORIC:** RX overrun interrupt clear. This bit is cleared by software writing 1 to it, while writing 0 has no effect.

### 12.4.10 SSP\_DMACR

Address Offset: 0x00

Reset Value: 0x00000000

| 31-2     | 1      | 0      |
|----------|--------|--------|
| RESERVED | TXDMAE | RXDMAE |
| r        | r/w    | r/w    |

**Bits 31-2 RESERVED:** Must be kept, and cannot be modified.

**Bit 1 TXDMAE:** DMA TX enable

- 0: DMA TX disabled
- 1: DMA TX enabled

**Bit 0 RXDMAE:** DMA RX enable

- 0: DMA RX disabled
- 1: DMA RX enabled

**12.4.11 LORAC\_CR0**

Address Offset: 0x100

Reset Value: 0x00000000

| 31-11    | 10      | 9            | 8        | 7-5            | 4-0      |
|----------|---------|--------------|----------|----------------|----------|
| RESERVED | NSS_SEL | SCK_MOSI_SEL | RESERVED | IRQ_DIG_INT_EN | RESERVED |
| r        | r/w     | r/w          | r        | r/w            | r        |

**Bits 31-11 RESERVED:** Must be kept, and cannot be modified.**Bit 10 NSS\_SEL:** NSS source selection for RF TRX

- 0: from register LORAC\_NSS\_CR
- 1: from internal SSP of LORAC

**Bit 9 SCK\_MOSI\_SEL:** SCK/MOSI/MISO source selection for RF TRX

- 0: from LORAC\_SCK\_CR, LORAC\_MOSI\_CR and LORA\_MISO\_SR
- 1: from internal SSP of LORAC

**Bit 8 RESERVED:** Must be kept, and cannot be modified.**Bits 7-5 IRQ\_DIG\_INT\_EN:** IRQ\_DIG\_INT high level interrupt enable

Bit[5] corresponds to IRQ\_DIG[0], bit[6] corresponds to IRQ\_DIG[1] and bit[7] corresponds to IRQ\_DIG[2].

- 0: disabled
- 1: enabled

**Bits 4-0 RESERVED:** Must be kept, and cannot be modified.**12.4.12 LORAC\_CR1**

Address Offset: 0x104

Reset Value: 0x00000080

| 31-8     | 7              | 6           | 5              |
|----------|----------------|-------------|----------------|
| RESERVED | POR_BAT        | RESERVED    | NRESET_BAT     |
| r        | r/w            | r           | r/w            |
| 4-3      | 2              | 1           | 0              |
| RESERVED | CLK_32M_EN_BAT | TCXO_EN_BAT | PWRTCXO_EN_BAT |
| r        | r/w            | r/w         | r/w            |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.**Bit 7 POR\_BAT:** POR\_BAT control

- 0: not reset
- 1: reset

**Bit 6 RESERVED:** Must be kept, and cannot be modified.

**Bit 5 NRESET\_BAT:** NRESET\_BAT control

- 0: reset
- 1: not reset

**Bits 4-3 RESERVED:** Must be kept, and cannot be modified.

**Bit 2 CLK\_32M\_EN\_BAT:** CLK\_32M\_EN\_BAT control

- 0: disabled
- 1: enabled

**Bit 1 TCXO\_EN\_BAT:** TCXO\_EN\_BAT control

- 0: disabled
- 1: enabled

**Bit 0 PWRTCXO\_EN\_BAT:** PWRTCXO\_EN\_BAT control

- 0: disabled
- 1: enabled

#### 12.4.13 LORAC\_SR

Address Offset: 0x108

Reset Value: 0x00000100

| 31-9     | 8           | 7-5        | 4-2      | 1                  | 0        |
|----------|-------------|------------|----------|--------------------|----------|
| RESERVED | BUSY_DIG_SR | IRQ_DIG_SR | RESERVED | CLK_32M_RDY_BAT_SR | RESERVED |
| r        | r           | r          | r        | r                  | r        |

**Bits 31-9 RESERVED:** Must be kept, and cannot be modified.

**Bit 8 BUSY\_DIG\_SR:** BUSY\_DIG status flag, it indicates whether the RF TRX is busy with processing commands. This bit is set and cleared by hardware.

- 0: RF TRX is not busy
- 1: RF TRX is busy with processing commands

**Bits 7-5 IRQ\_DIG\_SR:** IRQ\_DIG flag, it indicates the RF TRX interrupt request. This bit is set and cleared by hardware. Noted that once the interrupt request is triggered, software must send the *ClearIrqStatus* command to the RF TRX to clear the interrupt, otherwise the interrupt request will be triggered all the time.

- 0: no interrupt
- 1: an interrupt occurred

**Bits 4-2 RESERVED:** Must be kept, and cannot be modified.

**Bit 1 CLK\_32M\_RDY\_BAT\_SR:** CLK\_32M\_RDY\_BAT status flag, it indicates whether the XO32M clock for RF TRX is ready. This bit is set and cleared by hardware.

- 0: not ready
- 1: ready

**Bit 0 RESERVED:** Must be kept, and cannot be modified.

#### 12.4.14 LORAC\_NSS\_CR

Address Offset: 0x10C

Reset Value: 0x00000001

| 31-1     | 0       |
|----------|---------|
| RESERVED | REG_NSS |
| r        | r/w     |

**Bits 31-1 RESERVED:** Must be kept, and cannot be modified.

**Bit 0 REG\_NSS:** NSS control bit

- 0: pull down NSS pin
- 1: pull up NSS pin

#### 12.4.15 LORAC\_SCK\_CR

Address Offset: 0x110

Reset Value: 0x00000000

| 31-1     | 0       |
|----------|---------|
| RESERVED | REG_SCK |
| r        | r/w     |

**Bits 31-1 RESERVED:** Must be kept, and cannot be modified.

**Bit 0 REG\_SCK:** SCK control bit

- 0: pull down SCK pin
- 1: pull up SCK pin

#### 12.4.16 LORAC\_MOSI\_CR

Address Offset: 0x114

Reset Value: 0x00000000

| 31-1     | 0        |
|----------|----------|
| RESERVED | REG_MOSI |
| r        | r/w      |

**Bits 31-1 RESERVED:** Must be kept, and cannot be modified.

**Bit 0 REG\_MOSI:** MOSI control bit.

- 0: pull down MOSI pin

- 1: pull up MOSI pin

#### 12.4.17 LORAC\_MISO\_SR

Address Offset: 0x118

Reset Value: 0x00000000

| 31-1     | 0        |
|----------|----------|
| RESERVED | REG_MISO |
| r        | r        |

**Bits 31-1 RESERVED:** Must be kept, and cannot be modified.

**Bit 0 REG\_MISO:** MISO status flag, it indicates the status of MISO (RF TRX output pin). This bit is set and cleared by hardware.

- 0: low
- 1: high

# 13.

# UART

## 13.1 Introduction

ASR6601 UART unit supports UART and IrDA modes.

- **UART mode:**
  - ◆ Independent Receive FIFO and transmit FIFO
  - ◆ FIFO enable (16 deep) or disable (1 deep)
  - ◆ Programmable FIFO trigger levels:  $1/8$ ,  $1/4$ ,  $1/2$ ,  $3/4$ ,  $7/8$
  - ◆ Baud rate divisor: 16-bit integer part and 6-bit fractional part
  - ◆ Standard asynchronous communication bits: support 5, 6, 7 or 8 data bits, the parity bit and 1 or 2 stop bits
  - ◆ Support DMA
  - ◆ Support false start bit detection
  - ◆ Support line break generation and detection
  - ◆ Support hardware flow control
- **IrDA mode:**
  - ◆ Support the maximum baud rates (460800 bps) in IrDA mode, and the maximum baud rates (115200 bps) in Low-power IrDA mode (half-duplex)
  - ◆ Support normal  $3/16$  and low-power ( $1.41\sim2.23\ \mu s$ ) bit durations.
  - ◆ Appropriate bit duration generated by the UARTCLK reference clock division in low-power IrDA mode

Each UART port can be uniquely identified by the ID register.

## 13.2 Clock Reset

Each UART has independent APB bus clock and independent APB bus reset.

## 13.3 Reference Clock

The frequency of UARTCLK must meet the required range of baud rates:

$$\begin{aligned} F_{\text{UARTCLK(min)}} &\geq 16 \times \text{baudrate}_{(\max)} \\ F_{\text{UARTCLK(max)}} &\leq 16 \times 65535 \times \text{baudrate}_{(\min)} \end{aligned}$$

For example, to generate baud rates from 110 bps to 460800 bps, the UARTCLK frequency must be between 7.3728 MHz to 115.34 MHz.

In the meantime, the UARTCLK frequency cannot be greater than  $\frac{5}{3}$  times the frequency of PCLK:

$$F_{\text{UARTCLK}} \leq \frac{5}{3} * F_{\text{PCLK}}$$

For example, in UART mode, when UARTCLK is 14.7456 MHz, to generate 921600 baud, PCLK must be greater than or equal to 8.85276 MHz. This ensures that the UART has enough time to write the received data into the receive FIFO.

## 13.4 Baud Rate Generator

The baud rate generator contains free-running counters that generate the internal  $\times 16$  clocks, *Baud16* and *IrLPBaud16*. *Baud16* provides timing information for UART transmission and reception control. *Baud16* is a pulse stream with a width of one UARTCLK clock cycle and a frequency of 16 times the baud rate. *IrLPBaud16* provides timing information to generate the pulse width of the IrDA encoded transmit bit stream in low-power IrDA mode.

## 13.5 FIFO

The transmit FIFO and receive FIFO are independent, and they are enabled or disabled by the FEN bit in the UART Line Control Register ([UARTx\\_LCR\\_H](#)). The transmit FIFO is an 8-bit wide and 16 deep FIFO memory buffer. The receive FIFO is a 12-bit wide and 16 deep FIFO memory buffer, and it has four extra bits per character for status information. You can program the watermark level to  $\frac{1}{8}$ ,  $\frac{1}{4}$ ,  $\frac{1}{2}$ ,  $\frac{3}{4}$  or  $\frac{7}{8}$  for each FIFO through the Interrupt FIFO Level Selection Register ([UARTx\\_IFLS](#)). When FIFO is disabled, the depth is 1 byte. The FIFO status can be read from the Flag Register ([UARTx\\_FR](#)).

Bits[10:8] of the receive FIFO are error bits indicating associated errors. Bit[11] of the receive FIFO serves as an overrun indicator.

**Table 13-1 Receive FIFO Bit Functions**

| FIFO Bit | Function          |
|----------|-------------------|
| 11       | Overrun indicator |
| 10       | Break error       |

| FIFO Bit | Function      |
|----------|---------------|
| 9        | Parity error  |
| 8        | Framing error |
| 7:0      | Received data |

## 13.6 UART Operation

### 13.6.1 Baud Rate Divisor

The baud rate divisor consists of a 16-bit integer and a 6-bit fractional part. The 16-bit integer is written to register [UARTx\\_IBRD](#). The 6-bit fractional part is written to register [UARTx\\_FBRD](#). The fractional baud rate divider enables the use of any clock with a frequency >3.6864 MHz to act as UARTCLK, while it is still possible to generate all the standard baud rates. The Baud Rate Divisor has the following relationship to UARTCLK:

$$\text{Baud Rate Divisor} = \text{UARTCLK} / (16 \times \text{BaudRate}) = \text{BRD}_I + \text{BRD}_F$$

where  $\text{BRD}_I$  is the integer part and  $\text{BRD}_F$  is the fractional part separated by a decimal point as shown below.



The 6-bit number can be calculated by taking the fractional part of the required baud rate divisor and multiplying it by 64 (that is,  $2^n$ , where n is the effective width of the [UARTx\\_FBRD](#) register) and adding 0.5 to account for rounding errors:

$$\text{Fractional Part} = \text{integer}(\text{BRD}_F \times 2^n + 0.5)$$

### 13.6.2 Data Transmission

Data received or transmitted is stored in two 16-Byte FIFOs, and the receive FIFO has four extra bits per character for status information.

For transmission, data is written into the TX FIFO through the Data Register ([UARTx\\_DR](#)). Enable the UART through the UARTEN bit in the Data Register ([UARTx\\_CR](#)), then data starts transmitting with the data bit, stop bits, parity bit and other parameters indicated in the Line Control Register ([UARTx\\_LCR\\_H](#)) until the TX FIFO is empty. Once data is written into the TX FIFO, the BUSY signal goes high and remains high while data is being transmitted. Only when the TX FIFO is empty and the stop bits included in the last character have been transmitted from the shift register, the BUSY signal will go low. Even though the UART is no longer enabled, the BUSY signal is still high.

### 13.6.3 Data Reception

Enable the UART through the UARTEN bit in the Data Register ([UARTx\\_CR](#)) and configure the data bit, stop bits, parity bit and other parameters by the Line Control Register ([UARTx\\_LCR\\_H](#)).

When the receiver is idle, UARTRXD is pulled low, Baud16 enables the receive counter to start running, and data is sampled on the 8th cycle of that counter in UART mode or the 4th cycle of the counter in IrDA mode to allow for the shorter logic 0 pulses.

If UARTRXD remains low on the 8th cycle of Baud16, then a valid start bit is detected, otherwise a false start bit is detected and is ignored.

If the start bit is valid, then data sampling is performed every 16th cycle of Baud16 according to the length configured by the WLEN bit in register [UARTx\\_LCR\\_H](#). If parity mode is enabled, the parity bit will be checked.

Finally, if UARTRXD is high, a valid stop bit is confirmed, otherwise a framing error is occurred. The full character received is stored in the RX FIFO along with the associated error bits.

## 13.7 IrDA SIR Operation

The IrDA SIR ENDEC provides the function of converting between an UART data stream and half-duplex serial SIR interface. The role of the SIR ENDEC is to provide a digital encoded output, and decoded input to the UART. There are two modes of operation:

- **In IrDA mode**, a zero logic level is transmitted as high pulse, and the pulse width is specified as  $\frac{3}{16}$  of the selected baud rate bit period on the nSIROUT signal, while logic one levels are transmitted as a LOW signal.
- **In low-power IrDA mode**, the width of the transmitted infrared pulse is set to three times the period of the internally generated IrLPBAud16 signal (1.63  $\mu$ s, assuming a nominal frequency of 1.842 MHz).

The IrDA SIR physical layer specifies a half-duplex communication link, with a minimum 10ms delay between transmission and reception. This delay must be generated by software because it is not supported by the UART. The delay is required because the infrared receiver electronics might become biased.

### 13.7.1 Low-Power Divisor

The IrLPBAUD16 signal is generated by dividing the UARTCLK signal according to the low-power divider value configured by the ILPDVSR bit in register [UARTx\\_ILPR](#).

$$\text{Low-Power Divisor} = (F_{\text{UARTCLK}} / F_{\text{IrLPBAUD16}})$$

$F_{\text{IrLPBAUD16}}$  is nominally 1.8432 MHz, which meets the requirement of **1.42MHz <  $F_{\text{IrLPBAUD16}}$  < 2.12MHz**.

### 13.7.2 IrDA SIR Transmit Encoder

The SIR transmit encoder modulates the NRZ (Non Return-to-Zero) transmit bit stream output from the UART. The IrDA SIR physical layer specifies use of a RZI (Return to Zero, Inverted) modulation scheme, which represents logic 0 as an infrared light pulse. The modulated output pulse stream is transmitted to an external output driver and infrared LED.

In IrDA mode the transmitted pulse width is specified as three times the period of the internal  $\times 16$  clock (Baud16), that is,  $3/16$  of a bit period.

In low-power IrDA mode the transmit pulse width is specified as  $3/16$  of a 115200 bps bit period. This is implemented as three times the period of a nominal 1.8432 MHz clock (IrLPBaud16).

In normal and low-power IrDA modes, when the fractional baud rate divider is used, the transmitted SIR pulse stream includes more jitter. This is because the Baud16 pulses cannot be generated at regular intervals when fractional division is used. That is, the Baud16 cycles have a different number of UARTCLK cycles. The worst case jitter in the SIR pulse stream can be up to three UARTCLK cycles. Provided that the UARTCLK is  $> 3.6864$  MHz and the baud rate used for IrDA mode is  $\leq 115200$  bps, the jitter is less than 9%. This is within the limits of the SIR IrDA Specification where the maximum amount of jitter permitted is 13%.

### 13.7.3 IrDA SIR Receive Decoder

The SIR receive decoder demodulates the Return-to-Zero bit stream from the infrared detector and outputs the received NRZ serial bit stream to the UART received data input. The decoder input is normally HIGH in the idle state. The transmit encoder output has the opposite polarity to the decoder input.

A START bit is detected when the decoder input is LOW.

To prevent the UART from responding to glitches on the received data input, SIRIN pulses less than  $3/16$  of Baud16 will be ignored in IrDA mode; and SIRIN pulses less than  $3/16$  of IrLPBaud16 will be ignored in low-power IrDA mode.

## 13.8 UART Character Frame

The UART character frame is shown below.



Figure 13-1 UART Character Frame

## 13.9 IrDA Data Modulation

The effect of IrDA  $\frac{3}{16}$  data modulation is shown below.



Figure 13-2 IrDA Data Modulation ( $\frac{3}{16}$ )

## 13.10 Hardware Flow Control

The hardware flow control is selectable using the CTSEn and RTSEn bits in the [UARTx\\_CR](#) register.

When RTS flow control is enabled, the nUARTRTS signal is asserted until the receive FIFO is filled up to the watermark level.

When the CTS flow control is enabled, the transmitter can only transfer data when nUARTCTS signal is asserted and the transmit FIFO is not empty.

## 13.11 Interrupts

The UART supports the generation of Tx Done, Rx Done, Rx Timeout, Frame Error, Break Error, Parity Error and Overrun Error interrupts. The individual interrupts can be enabled or disabled by configuring the mask bits in the Interrupt Mask Set/Clear Register ([UARTx\\_IMSC](#)). The status of all interrupt signals, including the interrupt bits that are disabled, can be read from the Raw Interrupt Status Register ([UARTx\\_RIS](#)). The status of the enabled interrupt signals can be read from the Masked Interrupt Status Register ([UARTx\\_MIS](#)). The interrupt is cleared by writing “1” to the corresponding bit in the Interrupt Clear Register ([UARTx\\_ICR](#)).

## 13.12 DMA

The UART module supports DMA transmission and reception, which is configured by register [UARTx\\_DMACR](#).

## 13.13 UART Registers

UART0 Base Address: 0x40003000

UART1 Base Address: 0x40004000

UART2 Base Address: 0x40010000

UART3 Base Address: 0x40011000

Table 13-2 UART Register Summary

| Register Name   | Address Offset | Description                                  |
|-----------------|----------------|----------------------------------------------|
| UARTx_DR        | 0x00           | Data Register                                |
| UARTx_RSR_ECR   | 0x04           | Receive Status Register/Error Clear Register |
| UARTx_RSV0[4]   | 0x08           | 4 x 4 Bytes reserved                         |
| UARTx_FR        | 0x18           | Flag Register                                |
| UARTx_RSV1      | 0x1C           | 4 Bytes reserved                             |
| UARTx_ILPR      | 0x20           | IrDA Low-Power Counter Register              |
| UARTx_IBRD      | 0x24           | Integer Baud Rate Register                   |
| UARTx_FBRD      | 0x28           | Fractional Baud Rate Register                |
| UARTx_LCR_H     | 0x2C           | Line Control Register                        |
| UARTx_CR        | 0x30           | Control Register                             |
| UARTx_IFLS      | 0x34           | Interrupt FIFO Level Selection Register      |
| UARTx_IMSC      | 0x38           | Interrupt Mask Set/Clear Register            |
| UARTx_RIS       | 0x3C           | Raw Interrupt Status Register                |
| UARTx_MIS       | 0x40           | Masked Interrupt Status Register             |
| UARTx_ICR       | 0x44           | Interrupt Clear Register                     |
| UARTx_DMACR     | 0x48           | DMA Control Register                         |
| UARTx_RSV2[997] | 0x4C           | 4 x 997 Bytes reserved                       |

### 13.13.1 UARTx\_DR (x=0, 1, 2, 3)

Address Offset: 0x00

Reset Value: 0x00000000

| 31-12    | 11   | 10   | 9    | 8    | 7-0   |
|----------|------|------|------|------|-------|
| RESERVED | OE   | BE   | PE   | FE   | DATA  |
| r-0h     | r-0h | r-0h | r-0h | r-0h | rw-0h |

**Bits 31-12 RESERVED:** Must be kept, and cannot be modified.

**Bit 11 OE:** Overrun error flag

- 0: no overrun error
- 1: overrun occurred

**Bit 10 BE:** Break error flag

- 0: no break error
- 1: break error occurred

When this bit is set, it indicates that the received data input was held LOW for longer than a full-word (defined as start, data, parity and stop bits) transmission time.

In FIFO mode, this error is associated with the character at the top of the FIFO. When a break occurs, only one 0 character is loaded into the FIFO.

**Bit 9 PE:** Parity error flag

- 0: no parity error
- 1: parity error occurred

When this bit is set, it indicates that the parity of the received data character does not match the configuration of the EPS bit in the [UARTx\\_LCR\\_H](#) Register.

In FIFO mode, this error is associated with the character at the top of the FIFO.

**Bit 8 FE:** Framing error flag

- 0: no framing error
- 1: framing error occurred

When this bit is set, it indicates that the received character did not have a valid stop bit.

In FIFO mode, this error is associated with the character at the top of the FIFO.

**Bits 7-0 DATA:** Transmit data character/Receive data character.

### 13.13.2 **UARTx\_RSR\_ECR (x=0, 1, 2, 3)**

Address Offset: 0x04

Reset Value: 0x00000000

| <b>31-4</b> | <b>3</b> | <b>2</b> | <b>1</b> | <b>0</b> |
|-------------|----------|----------|----------|----------|
| RESERVED    | OE       | BE       | PE       | FE       |
| r-0h        | r-0h     | r-0h     | r-0h     | r-0h     |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bit 3 OE:** Overrun error flag

- 0: no overrun error
- 1: overrun occurred

**Bit 2 BE:** Break error flag

- 0: no break error
- 1: break error occurred

When this bit is set, it indicates that the received data input was held LOW for longer than a full-word (defined as start, data, parity and stop bits) transmission time.

In FIFO mode, this error is associated with the character at the top of the FIFO. When a break occurs, only one 0 character is loaded into the FIFO.

**Bit 1 PE:** Parity error flag

- 0: no parity error
- 1: parity error occurred

When this bit is set, it indicates that the parity of the received data character does not match the configuration of the EPS bit in the [UARTx\\_LCR\\_H Register](#).

In FIFO mode, this error is associated with the character at the top of the FIFO.

**Bit 0 FE:** Framing error flag

- 0: no framing error
- 1: framing error occurred

When this bit is set, it indicates that the received character did not have a valid stop bit.

In FIFO mode, this error is associated with the character at the top of the FIFO.

### 13.13.3 UARTx\_FR (x=0, 1, 2, 3)

Address Offset: 0x18

Reset Value: 0x00000000

| 31-8     | 7    | 6    | 5    | 4    | 3    | 2-0      |
|----------|------|------|------|------|------|----------|
| RESERVED | TXFE | RXFF | TXFF | RXFE | BUSY | RESERVED |
| r-0h     | r-0h | r-0h | r-0h | r-0h | r-0h | r-0h     |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bit 7 TXFE:** Transmit FIFO empty

- 0: transmit FIFO/UART\_DR register not empty
- 1: transmit FIFO/UART\_DR empty

This bit is associated with the FEN bit in the [UARTx\\_LCR\\_H](#) register.

This bit does not indicate if there is data in the transmit shift register.

**Bit 6 RXFF:** Receive FIFO full

- 0: receive FIFO/UART\_DR not full
- 1: receive FIFO/UART\_DR full

This bit is associated with the FEN bit in the [UARTx\\_LCR\\_H](#) register.

**Bit 5 TXFF:** Transmit FIFO full

- 0: transmit FIFO/UART\_DR not full
- 1: transmit FIFO/UART\_DR full

This bit is associated with the FEN bit in the [UARTx\\_LCR\\_H](#) register.

**Bit 4 RXFE:** Receive FIFO empty

- 0: receive FIFO/UART\_DR not empty
- 1: receive FIFO/UART\_DR empty

This bit is associated with the FEN bit in the [UARTx\\_LCR\\_H](#) register.

**Bit 3 BUSY:** UART busy

- 0: no transmission
- 1: transmission on going

This bit is set to 1 as soon as the transmit FIFO becomes non-empty, irrespective of whether the UART is enabled or not.

**Bits 2-0 RESERVED:** Must be kept, and cannot be modified.

### 13.13.4 UARTx\_ILPR (x=0, 1, 2, 3)

Address Offset: 0x20

Reset Value: 0x00000000

| 31-8     | 7-0     |
|----------|---------|
| RESERVED | ILPDVSR |
| r-0h     | rw-0h   |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-0 ILPDVSR:** low-power divisor value. Zero is an illegal value. Writing “0” results in no generation of IrLPBaud16 pulses.

### 13.13.5 UARTx\_IBRD (x=0, 1, 2, 3)

Address Offset: 0x24

Reset Value: 0x00000000

| 31-16    | 15-0        |
|----------|-------------|
| RESERVED | BAUD_DIVINT |
| r-0h     | rw-0h       |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 BAUD\_DIVINT:** The integer baud rate divisor.

### 13.13.6 UARTx\_FBRD (x=0, 1, 2, 3)

Address Offset: 0x28

Reset Value: 0x00000000

| 31-6     | 5-0          |
|----------|--------------|
| RESERVED | BAUD_DIVFRAC |
| r-0h     | rw-0h        |

**Bits 31-6 RESERVED:** Must be kept, and cannot be modified.

**Bits 5-0 BAUD\_DIVFRAC:** The fractional baud rate divisor.

### 13.13.7 UARTx\_LCR\_H (x=0, 1, 2, 3)

Address Offset: 0x2C

Reset Value: 0x00000000

| 31-7     | 6-5   | 4     | 3     | 2     | 1     | 0     |
|----------|-------|-------|-------|-------|-------|-------|
| RESERVED | WLEN  | FEN   | STP2  | EPS   | PEN   | BRK   |
| r-0h     | rw-0h | rw-0h | rw-0h | rw-0h | rw-0h | rw-0h |

**Bits 31-7 RESERVED:** Must be kept, and cannot be modified.

**Bits 6-5 WLEN:** Word length

- 00: 5 bits
- 01: 6 bits
- 10: 7 bits
- 11: 8 bits

**Bit 4 FEN:** FIFO enable

- 0: FIFO disabled
- 1: FIFO enabled

**Bit 3 STP2:** Stop bits selection

- 0: 1 stop bit
- 1: 2 stop bits

**Bit 2 EPS:** Even parity selection

- 0: odd parity
- 1: even parity

This bit has no effect when the PEN bit is 0.

**Bit 1 PEN:** Parity enable

- 0: parity checking disabled
- 1: parity checking enabled.

**Bit 0 BRK:** Send break

- write 0: end the Break command
- write 1: a low-level is continually output on the UART\_TXD pin, after completing transmission of the current character.

For the proper execution of the Break command, the software must set this bit for at least two complete frames.

### 13.13.8 UARTx\_CR (x=0, 1, 2, 3)

Address Offset: 0x30

Reset Value: 0x00000000

| 31-24    |          | 23-16      | 15       | 14       | 13-10    |
|----------|----------|------------|----------|----------|----------|
| RESERVED |          | RESERVED   | CTSEn    | RTSEn    | RESERVED |
| r-0h     |          | r-0h       | rw-0h    | rw-0h    | r-0h     |
| <b>9</b> | <b>8</b> | <b>7-3</b> | <b>2</b> | <b>1</b> | <b>0</b> |
| RXE      | TXE      | RESERVED   | SIRLP    | SIREN    | UARTEN   |
| rw-0h    | rw-0h    | r-0h       | rw-0h    | rw-0h    | rw-0h    |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bit 15 CTSEn:** CTS hardware flow control enable

- 0: CTS hardware flow control disabled
- 1: CTS hardware flow control enabled

**Bit 14 RTSEn:** RTS hardware flow control enable

- 0: RTS hardware flow control disabled
- 1: RTS hardware flow control enabled

**Bits 13-10 RESERVED:** Must be kept, and cannot be modified.

**Bit 9 RXE:** Receive enable

- 0: reception disabled. If the UART is disabled in the middle of reception, then it completes the current character before stopping.
- 1: reception enabled

**Bit 8 TXE:** Transmit enable

- 0: transmission disabled. If the UART is disabled in the middle of transmission, then it completes the current character before stopping.
- 1: transmission enabled

**Bits 7-3 RESERVED:** Must be kept, and cannot be modified.

**Bit 2 SIRLP:** Low-power IrDA SIR encoding mode selection

- 0: low-level bits are transmitted with a pulse width of  $\frac{3}{16}$  of the bit period.
- 1: low-level bits are transmitted with a pulse width of 3 times the period of the IrLPBaud16 input signal. Setting this bit helps reduce power consumption, but might reduce transmission distances.

**Bit 1 SIRE:** IrDA SIR enable

- 0: IrDA SIR ENDEC is disabled. SIR\_OUT remains LOW, and signal transitions on SIR\_IN are ignored. Data is transmitted and received on UART\_TXD and UART\_RXD.
- 1: IrDA SIR ENDEC is enabled. UARTRXD remains HIGH, and signal transitions on UARTRXD are ignored. Data is transmitted and received on SIR\_OUT and SIR\_IN.

This bit has no effect if the UARTEN bit is 0.

**Bit 0 UARTEN:** UART enable

- 0: UART disabled. If the UART is disabled in the middle of transmission or reception, then it

completes the current character before stopping.

- 1: UART enabled

### 13.13.9 UART<sub>x</sub>\_IFLS (x=0, 1, 2, 3)

Address Offset: 0x34

Reset Value: 0x00000000

| 31-6     | 5-3      | 2-0      |
|----------|----------|----------|
| RESERVED | RXIFLSEL | TXIFLSEL |
| r-0h     | rw-0h    | rw-0h    |

**Bits 31-6 RESERVED:** Must be kept, and cannot be modified.

**Bits 5-3 RXIFLSEL:** Receive interrupt FIFO level selection

- 000: receive FIFO becomes  $\geq \frac{1}{8}$  full
- 001: receive FIFO becomes  $\geq \frac{1}{4}$  full
- 010: receive FIFO becomes  $\geq \frac{1}{2}$  full
- 011: receive FIFO becomes  $\geq \frac{3}{4}$  full
- 100: receive FIFO becomes  $\geq \frac{7}{8}$  full
- 101~111: reserved

**Bits 2-0 TXIFLSEL:** Transmit interrupt FIFO level selection

- 000: transmit FIFO becomes  $\geq \frac{1}{8}$  full
- 001: transmit FIFO becomes  $\geq \frac{1}{4}$  full
- 010: transmit FIFO becomes  $\geq \frac{1}{2}$  full
- 011: transmit FIFO becomes  $\geq \frac{3}{4}$  full
- 100: transmit FIFO becomes  $\geq \frac{7}{8}$  full
- 101~111: reserved

### 13.13.10 UART<sub>x</sub>\_IMSC (x=0, 1, 2, 3)

Address Offset: 0x38

Reset Value: 0x00000000

| 31-16    | 15-11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3-0      |
|----------|----------|-------|-------|-------|-------|-------|-------|-------|----------|
| RESERVED | RESERVED | OEIM  | BEIM  | PEIM  | FEIM  | RTIM  | TXIM  | RXIM  | RESERVED |
| r-0h     | r-0h     | rw-0h | r-0h     |

**Bits 31-11 RESERVED:** Must be kept, and cannot be modified.

**Bit 10 OEIM:** Overrun error interrupt mask bit

- 0: overrun error interrupt disabled
- 1: overrun error interrupt enabled

**Bit 9 BEIM:** Break error interrupt mask bit

- 0: break error interrupt disabled

- 1: break error interrupt enabled

**Bit 8 PEIM:** Parity error interrupt mask bit

- 0: parity error interrupt disabled
- 1: parity error interrupt enabled

**Bit 7 FEIM:** Framing error interrupt mask bit

- 0: framing error interrupt disabled
- 1: framing error interrupt enabled

**Bit 6 RTIM:** Receive timeout interrupt mask bit

- 0: receive timeout interrupt disabled
- 1: receive timeout interrupt enabled

**Bit 5 TXIM:** Transmission completion interrupt mask bit

- 0: transmission completion interrupt disabled
- 1: transmission completion interrupt enabled

**Bit 4 RXIM:** Reception completion interrupt mask bit

- 0: reception completion interrupt disabled
- 1: reception completion interrupt enabled

**Bits 3-0 RESERVED:** Must be kept, and cannot be modified.

### 13.13.11 UARTx\_RIS (x=0, 1, 2, 3)

Address Offset: 0x3C

Reset Value: 0x00000000

| 31-16    | 15-11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3-0      |
|----------|----------|-------|-------|-------|-------|-------|-------|-------|----------|
| RESERVED | RESERVED | OERIS | BERIS | PERIS | FERIS | RTRIS | TXRIS | RXRIS | RESERVED |
| r-0h     | r-0h     | r-0h  | r-0h  | r-0h  | r-0h  | r-0h  | r-0h  | r-0h  | r-0h     |

**Bits 31-11 RESERVED:** Must be kept, and cannot be modified.

**Bit 10 OERIS:** Overrun error raw interrupt status

**Bit 9 BERIS:** Break error raw interrupt status

**Bit 8 PERIS:** Parity error raw interrupt status

**Bit 7 FERIS:** Framing error raw interrupt status

**Bit 6 RTRIS:** Receive timeout raw interrupt status

**Bit 5 TXRIS:** Transmission completion raw interrupt status

**Bit 4 RXRIS:** Reception completion raw interrupt status

**Bits 3-0 RESERVED:** Must be kept, and cannot be modified.

### 13.13.12 UARTx\_MIS (x=0, 1, 2, 3)

Address Offset: 0x40

Reset Value: 0x00000000

| <b>31-16</b> | <b>15-11</b> | <b>10</b> | <b>9</b> | <b>8</b> | <b>7</b> | <b>6</b> | <b>5</b> | <b>4</b> | <b>3-0</b> |
|--------------|--------------|-----------|----------|----------|----------|----------|----------|----------|------------|
| RESERVED     | RESERVED     | OEMIS     | BEMIS    | PEMIS    | FEMIS    | RTMIS    | TXMIS    | RXMIS    | RESERVED   |
| r-0h         | r-0h         | r-0h      | r-0h     | r-0h     | r-0h     | r-0h     | r-0h     | r-0h     | r-0h       |

**Bits 31-11 RESERVED:** Must be kept, and cannot be modified.

**Bit 10 OEMIS:** Overrun error masked interrupt status

**Bit 9 BEMIS:** Break error masked interrupt status

**Bit 8 PEMIS:** Parity error masked interrupt status

**Bit 7 FEMIS:** Framing error masked interrupt status

**Bit 6 RTMIS:** Receive timeout masked interrupt status

**Bit 5 TXMIS:** Transmission completion masked interrupt status

**Bit 4 RXMIS:** Reception completion masked interrupt status

**Bits 3-0 RESERVED:** Must be kept, and cannot be modified.

### 13.13.13 UARTx\_ICR (x=0, 1, 2, 3)

Address Offset: 0x44

Reset Value: 0x00000000

| <b>31-16</b> | <b>15-11</b> | <b>10</b> | <b>9</b> | <b>8</b> | <b>7</b> | <b>6</b> | <b>5</b> | <b>4</b> | <b>3-0</b> |
|--------------|--------------|-----------|----------|----------|----------|----------|----------|----------|------------|
| RESERVED     | RESERVED     | OEIC      | BEIC     | PEIC     | FEIC     | RTIC     | TXIC     | RXIC     | RESERVED   |
| r-0h         | r-0h         | w-0h      | w-0h     | w-0h     | w-0h     | w-0h     | w-0h     | w-0h     | r-0h       |

**Bits 31-11 RESERVED:** Must be kept, and cannot be modified.

**Bit 10 OEIC:** Overrun error interrupt clear

- 0: a write of 0 has no effect
- 1: write 1 to clear overrun error interrupt

**Bit 9 BEIC:** Break error interrupt clear

- 0: a write of 0 has no effect
- 1: write 1 to clear break error interrupt

**Bit 8 PEIC:** Parity error interrupt clear

- 0: a write of 0 has no effect
- 1: write 1 to clear parity error interrupt

**Bit 7 FEIC:** Framing error interrupt clear

- 0: a write of 0 has no effect
- 1: write 1 to clear framing error interrupt

**Bit 6 RTIC:** Receive timeout interrupt clear

- 0: a write of 0 has no effect
- 1: write 1 to clear receive timeout interrupt

**Bit 5 TXIC:** Transmission completion interrupt clear

- 0: a write of 0 has no effect
- 1: write 1 to clear transmission completion interrupt

**Bit 4 RXIC:** Reception completion interrupt clear

- 0: a write of 0 has no effect
- 1: write 1 to clear reception completion interrupt

**Bits 3-0 RESERVED:** Must be kept, and cannot be modified.

#### 13.13.14 UARTx\_DMACR (x=0, 1, 2, 3)

Address Offset: 0x48

Reset Value: 0x00000000

| 31-3     | 2        | 1      | 0      |
|----------|----------|--------|--------|
| RESERVED | DMAONERR | TXDMAE | RXDMAE |
| r-0h     | rw-0h    | rw-0h  | rw-0h  |

**Bits 31-3 RESERVED:** Must be kept, and cannot be modified.

**Bit 2 DMAONERR:** DMA on error

**Bit 1 TXDMAE:** Transmit DMA enable

- 0: disabled
- 1: enabled

**Bit 0 RXDMAE:** Receive DMA enable

- 0: disabled
- 1: enabled

### 13.13.15 UARTx\_ID[8] (x=0, 1, 2, 3)

#### 13.13.15.1 PeriphID0

Address Offset: 0x0FE0

Reset Value: 0x00000000

| 31-8     | 7-0         |
|----------|-------------|
| RESERVED | PARTNUMBER0 |
| r-0h     | r-11h       |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-0 PARTNUMBER0:** =0x11

#### 13.13.15.2 PeriphID1

Address Offset: 0x0FE4

Reset Value: 0x00000000

| 31-8     | 7-4       | 3-0         |
|----------|-----------|-------------|
| RESERVED | DESIGNER0 | PARTNUMBER1 |
| r-0h     | r-1h      | r-0h        |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-4 DESIGNER0:** =0x1

**Bits 3-0 PARTNUMBER1:** =0x0

#### 13.13.15.3 PeriphID2

Address Offset: 0x0FE8

Reset Value: 0x00000000

| 31-8     | 7-4       | 3-0       |
|----------|-----------|-----------|
| RESERVED | REVISION0 | DESIGNER1 |
| r-0h     | r-xh      | r-0h      |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-4 REVISION0:**

- 0x0: r1p0
- 0x1: r1p1
- 0x2: r1p3/r1p4
- 0x3: r1p5

**Bits 3-0 DESIGNER1:** =0x0

#### 13.13.15.4 PeriphID3

Address Offset: 0x0FEC

Reset Value: 0x00000000

| 31-8     | 7-0           |
|----------|---------------|
| RESERVED | CONFIGURATION |
| r-0h     | r-0h          |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-0 CONFIGURATION:** =0x00

#### 13.13.15.5 PCellID0

Address Offset: 0x0FD0

Reset Value: 0x00000000

| 31-8     | 7-0     |
|----------|---------|
| RESERVED | CellID0 |
| r-0h     | r-dh    |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-0 CellID0:** =0x0d

#### 13.13.15.6 PCellID1

Address Offset: 0x0FD4

Reset Value: 0x00000000

| 31-8     | 7-0     |
|----------|---------|
| RESERVED | CellID1 |
| r-0h     | r-f0h   |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-0 CellID1:** =0xf0

### 13.13.15.7 PCellID2

Address Offset: 0x0FD8

Reset Value: 0x00000000

| 31-8     | 7-0     |
|----------|---------|
| RESERVED | CellID2 |
| r-0h     | r-5h    |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-0 CellID2:** =0x05

### 13.13.15.8 PCellID3

Address Offset: 0x0FDC

Reset Value: 0x00000000

| 31-8     | 7-0     |
|----------|---------|
| RESERVED | CellID3 |
| r-0h     | r-b1h   |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-0 CellID3:** =0xb1

# 14.

# SSP

## 14.1 Introduction

All three SSP (synchronous serial port) can be configured as a master or slave device.

SSP support multiple frame formats, with configurable data width and transmission rate.

## 14.2 Main Features

- Master or slave operation
- Support up to 16 MHz output
- Support 16-bit wide TX/RX FIFO with a depth of 8
- Support multiple frame formats
- Support 4-bit to 16-bit data width
- Support DMA
- Support interrupt signal generation

## 14.3 Functional Description

### 14.3.1 Basic Information

Four I/O pins (SSP\_NSS, SSP\_CLK, SSP\_TX, SSP\_RX) are dedicated to SSP communication with external devices.

#### 1. **SSP\_NSS**

The chip select pin is active at low level.

#### 2. **SSP\_CLK**

SSP clock pin acts as clock output in master mode and acts as the clock input in slave mode.

#### 3. **SSP\_TX**

The SSP TX pin is used to transmit data in both master and slave modes.

#### 4. **SSP\_RX**

The SSP RX pin is used to receive data in both master and slave modes.

The connection between SSP and SPI device is shown in the figure below. Note the difference

between SSP\_TX/SSP\_RX and SPI\_MOSI/SPI\_MISO.



Figure 14-1 Connection between a SSP Master and a SPI Slave



Figure 14-2 Connection between a SPI Master and a SSP Slave

### 14.3.2 Clock Division

SSP clock should meet below requirements:

- (1) Support up to 16 MHz output clock
- (2) The clock frequency in master mode is at most 1/2 of PCLK clock frequency
- (3) The clock frequency in slave mode is at most 1/12 of PCLK clock frequency

The formula to calculate clock output in master mode is as follows:

$$F_{SSPCLKOUT} = \frac{F_{SSPCLK}}{CPSDVR \times (1+SCR)}$$

Figure 14-3 The Formula to Calculate Clock Output in Master Mode

SSPCLK is the interface clock for SSP, and SSPCLKOUT is the output clock. For example, SSPCLK is 24MHz by default and 1MHz SSPCLKOUT is required, then the user should set bit CPSDVR in register [SSP\\_CPSR](#) to 2, and set bit SCR in register [SSP\\_CR0](#) to 11.

### 14.3.3 Data Format

SSP support three frame formats:

- Motorola SPI
- Texas Instruments SPI
- National Semiconductor Microwire

### 14.3.4 DMA Transaction

#### SSP DMA Transmission Process

- (1) Enable the TXDMAE bit in register *SSP\_DMACR*.
- (2) Configure register *SSP\_DR* as the destination address of DMA.
- (3) Configure the memory address of the data to be sent as the source address of DMA.
- (4) Configure the data width of DMA transfer to 8 bits by configuring the SRC\_TR\_WIDTH and DES\_TR\_WIDTH bits to 0 in the *DMA\_CTLx* register.
- (5) Configure the DMA burst length to 4 by configuring the SRC\_MSIZE and DEST\_MSIZE bits to 1 in the *DMA\_CTLx* register.
- (6) Configure the total length of DMA data transfer.
- (7) Configure DMA handshake type to the corresponding SSP TX type (for example, for SSP0, configure it to DMA\_HANDSHAKE\_SSP\_0\_TX).
- (8) Activate the DMA.

When the DMA transfer is completed, the CH\_EN\_x bit in the DMA\_CHENREG register is cleared.

#### SSP DMA Reception Process:

- (1) Enable the RXDMAE bit in register *SSP\_DMACR*.
- (2) Configure register *SSP\_DR* as the source address of DMA.
- (3) Configure the memory address of the data to be received as the destination address of DMA.
- (4) Configure the data width of DMA transfer to 8 bits by configuring the SRC\_TR\_WIDTH and DES\_TR\_WIDTH bits to 0 in the *DMA\_CTLx* register.
- (5) Configure the DMA burst length to 4 by configuring the SRC\_MSIZE and DEST\_MSIZE bits to 1 in the *DMA\_CTLx* register.
- (6) Configure the total length of DMA data transfer.
- (7) Configure DMA handshake type to the corresponding SSP RX type (for example, for SSP0, configure it to DMA\_HANDSHAKE\_SSP\_0\_RX).
- (8) Activate the DMA.

When the DMA transfer is completed, the CH\_EN\_x bit in the DMA\_CHENREG register is cleared.

### 14.3.5 SSP Interrupts

There are four SSP interrupt signals.

#### 1. SSP RX Interrupt

SSP RX interrupt is triggered when there are 4 or more locations in SSP RX FIFO.

#### 2. SSP TX Interrupt

SSP TX interrupt is triggered when there are 4 or less locations in SSP TX FIFO.

#### 3. SSP RX Overrun Interrupt

SSP RX overrun interrupt is triggered when the SSP RX FIFO is full and continues to receive data.

#### 4. SSP RX Timeout Interrupt

SSP RX timeout interrupt is triggered when the SSP RX FIFO is not empty but SSP has not received any new data for the duration time of 32-bit data transfer.

## 14.4 SSP Registers

SSP0 Base Address: 0x40006000

SSP1 Base Address: 0x40012000

SSP2 Base Address: 0x40013000

Table 14-1 SSP Register Summary

| Register Name | Address Offset | Description                           |
|---------------|----------------|---------------------------------------|
| SSP_CR0       | 0x00           | SSP Control register 0                |
| SSP_CR1       | 0x04           | SSP Control register 1                |
| SSP_DR        | 0x08           | SSP Data register                     |
| SSP_SR        | 0x0C           | SSP Status register                   |
| SSP_CPSR      | 0x10           | SSP Clock Prescaler Register          |
| SSP_IMSC      | 0x14           | SSP Interrupt Mask Set/Clear Register |
| SSP_RIS       | 0x18           | SSP Raw Interrupt Status register     |
| SSP_MIS       | 0x1C           | SSP Masked Interrupt Status register  |
| SSP_ICR       | 0x20           | SSP Interrupt Clear Register          |
| SSP_DMACR     | 0x24           | SSP DMA Control Register              |

### 14.4.1 SSP\_CR0

Address Offset: 0x00

Reset Value: 0x00000000

| 31-16    | 15-8 | 7   | 6   | 5-4 | 3-0 |
|----------|------|-----|-----|-----|-----|
| RESERVED | SCR  | SPH | SPO | FRF | DSS |
| r        | r/w  | r/w | r/w | r/w | r/w |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-8 SCR:** Serial clock rate, used to set the SSP transfer rate.

$$F_{SSPCLKOUT} = \frac{F_{SSPCLK}}{CPSDVR \times (1+SCR)}$$

The formula to calculate the SSP transfer rate is as above, where CPSDVR is an even number ranging from 2 to 254.

**Bit 7 SPH:** SSP phase setting, only applied in Motorola SPI format

**Bit 6 SPO:** SSP polarity setting, only applied in Motorola SPI format

**Bits 5-4 FRF:** SSP frame formats setting

- 0: Motorola SPI
- 1: Texas Instruments SPI
- 2: National Semiconductor Microwire
- 3: reserved

**Bits 3-0 DSS:** Data width setting

- 0: reserved
- 1: reserved
- 2: reserved
- 3: 4 bit
- 4: 5 bit
- 5: 6 bit
- 6: 7 bit
- 7: 8 bit
- 8: 9 bit
- 9: 10 bit
- 10: 11 bit
- 11: 12 bit
- 12: 13 bit
- 13: 14 bit
- 14: 15 bit
- 15: 16 bit

### 14.4.2 SSP\_CR1

Address Offset: 0x04

Reset Value: 0x00000000

| 31-4     | 3   | 2   | 1   | 0   |
|----------|-----|-----|-----|-----|
| RESERVED | SOD | MS  | SSE | LBM |
| r        | r/w | r/w | r/w | r/w |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bit 3 SOD:** SSP output disable in slave mode

- 0: SSP output enabled in slave mode
- 1: SSP output disabled in slave mode

**Bit 2 MS:** Master/slave mode selection

- 0: master mode
- 1: slave mode

**Bit 1 SSE:** SSP enable

- 0: disabled
- 1: enabled

**Bit 0 LBM:** loopback mode

- 0: normal mode
- 1: loopback mode

### 14.4.3 SSP\_DR

Address Offset: 0x08

Reset Value: 0x00000000

| 31-16    | 15-0 |
|----------|------|
| RESERVED | DATA |
| r        | r/w  |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 DATA:** SSP TX/RX data

#### 14.4.4 SSP\_SR

Address Offset: 0x0C

Reset Value: 0x00000003

| 31-5     | 4   | 3   | 2   | 1   | 0   |
|----------|-----|-----|-----|-----|-----|
| RESERVED | BSY | RFF | RNE | TNF | TFE |
| r        | r   | r   | r   | r   | r   |

**Bits 31-5 RESERVED:** Must be kept, and cannot be modified.

**Bit 4 BSY:** SSP busy flag

- 0: SSP is idle
- 1: SSP transfer is on going

**Bit 3 RFF:** RX FIFO full flag

- 0: RX FIFO is not full
- 1: RX FIFO is full

**Bit 2 RNE:** RX FIFO not empty flag

- 0: RX FIFO is empty
- 1: RX FIFO is not empty

**Bit 1 TNF:** TX FIFO not full flag

- 0: TX FIFO is full
- 1: TX FIFO is not full

**Bit 0 TFE:** TX FIFO empty flag

- 0: TX FIFO is not empty
- 1: TX FIFO is empty

#### 14.4.5 SSP\_CPSR

Address Offset: 0x0C

Reset Value: 0x00000000

| 31-8     | 7-0    |
|----------|--------|
| RESERVED | CPSDVS |
| r        | r/w    |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-0 CPSDVS:** Clock prescaler divider, must be an even number between 2~254.

#### 14.4.6 SSP\_IMSC

Address Offset: 0x00

Reset Value: 0x00000000

| 31-4     | 3    | 2    | 1    | 0     |
|----------|------|------|------|-------|
| RESERVED | TXIM | RXIM | RTIM | RORIM |
| r        | r/w  | r/w  | r/w  | r/w   |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bit 3 TXIM:** TX interrupt mask bit

- 0: TX interrupt is masked
- 1: TX interrupt is not masked

**Bit 2 RXIM:** RX interrupt mask bit

- 0: RX interrupt is masked
- 1: RX interrupt is not masked

**Bit 1 RTIM:** RX timeout interrupt mask bit

- 0: RX timeout interrupt is masked
- 1: RX timeout interrupt is not masked

**Bit 0 RORIM:** RX overrun interrupt mask bit

- 0: RX overrun interrupt is masked
- 1: RX overrun interrupt is not masked

#### 14.4.7 SSP\_RIS

Address Offset: 0x00

Reset Value: 0x00000008

| 31-4     | 3     | 2     | 1     | 0      |
|----------|-------|-------|-------|--------|
| RESERVED | TXRIS | RXRIS | RTRIS | RORRIS |
| r        | r     | r     | r     | r      |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bit 3 TXRIS:** TX raw interrupt status

**Bit 2 RXRIS:** RX raw interrupt status

**Bit 1 RTRIS:** RX timeout raw interrupt status

**Bit 0 RORRIS:** RX overrun raw interrupt status

#### 14.4.8 SSP\_MIS

Address Offset: 0x00

Reset Value: 0x00000000

| 31-4     | 3     | 2     | 1     | 0      |
|----------|-------|-------|-------|--------|
| RESERVED | TXMIS | RXMIS | RTMIS | RORMIS |
| r        | r     | r     | r     | r      |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bit 3 TXMIS:** TX masked interrupt status

**Bit 2 RXMIS:** RX masked interrupt status

**Bit 1 RTMIS:** RX timeout masked interrupt status

**Bit 0 RORMIS:** RX overrun masked interrupt status

#### 14.4.9 SSP\_ICR

Address Offset: 0x00

Reset Value: 0x00000000

| 31-2     | 1    | 0     |
|----------|------|-------|
| RESERVED | RTIC | RORIC |
| r        | w    | w     |

**Bits 31-2 RESERVED:** Must be kept, and cannot be modified.

**Bit 1 RTIC:** RX timeout interrupt clear. This bit is cleared by software writing 1 to it, while writing 0 has no effect.

**Bit 0 RORIC:** RX overrun interrupt clear. This bit is cleared by software writing 1 to it, while writing 0 has no effect.

#### 14.4.10 SSP\_DMACR

Address Offset: 0x00

Reset Value: 0x00000000

| 31-2     | 1      | 0      |
|----------|--------|--------|
| RESERVED | TXDMAE | RXDMAE |
| r        | r/w    | r/w    |

**Bits 31-2 RESERVED:** Must be kept, and cannot be modified.

**Bit 1 TXDMAE:** DMA TX enable

- 0: DMA TX disabled
- 1: DMA TX enabled

**Bit 0 RXDMAE:** DMA RX enable

- 0: DMA RX disabled
- 1: DMA RX enabled

ASR Confidential

# 15.

# I2C

## 15.1 Introduction

The main features of I2C (inter-integrated circuit) bus interface are as follows:

- Supports master mode and slave mode.
- SDA is the data transmission line, and SCL is the reference clock line
- Supports multi-master and bus arbitration
- Support standard mode (up to 100 Kbps) and fast mode (up to 400 Kbps)
- Support FIFO mode with configurable read and write pointers, TxFIFO depth is 8, and RxFIFO depth is 16



Figure 15-1 I2C Block Diagram

## 15.2 Start and Stop Conditions

**Start condition:** When SCL level is high, SDA level changes from high to low, thus generating a Start condition.

**Stop condition:** When SCL level is high, SDA level changes from low to high, thus generating a Stop condition.



Figure 15-2 SDA and SCL Signals During Start and Stop Conditions

Start a byte transmission or generate Start, Repeated Start or Stop conditions by configuring the START and STOP bits in register [I2Cx\\_CR](#).

Table 15-1 Start and Stop Conditions

| Start Bit | Stop Bit | Condition Type          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------|----------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0         | 0        | No Start or Stop        | When multiple data bytes are to be transmitted, I2C will not send a Start or Stop condition.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0         | 1        | Start or Repeated Start | I2C sends a Start condition and then transmits the 8-bit data in the <a href="#">I2Cx_DB</a> register. Before a Start condition is sent, register <a href="#">I2Cx_DB</a> must contain the 7-bit slave address and the R/nW bit.<br>For a Repeated Start, the <a href="#">I2Cx_DB</a> register must contain the target slave address and the R/nW bit, which allows a master to perform multiple transfers without freeing the bus.<br>The interface stays in master transmit mode for writes, and switches to master receive mode for reads. |
| 1         | x        | Stop                    | In master transmit mode, a Stop condition is sent on the I2C bus after the 8-bit data in the <a href="#">I2Cx_DB</a> register has been transferred.<br>In master receive mode, bit ACKNAK in the <a href="#">I2Cx_CR</a> register must be set to send a NAK. The received data is stored in the <a href="#">I2Cx_DB</a> register, and then a Stop condition is sent on the I2C bus.                                                                                                                                                           |

### 1. Start Condition

The Start condition and the data in register *I2Cx\_DB* will be sent after bit TB in register *I2Cx\_CR* is set. I2C bus stays in master transmit mode for write requests and stays in master receive mode for read requests. For a Repeated Start, a change in Read, Write or the target slave address, the register *I2Cx\_DB* contains the updated target slave address and the R/nW bit.

The START condition will not be cleared by the I2C. If I2C loses bus arbitration when it starts to send a Start condition, it will try to resend the Start condition when the bus is freed.

### 2. No Start or Stop Condition

When I2C is transmitting multiple data bytes, the START and STOP bits in the *I2Cx\_CR* register are set to 0, there is no Start or Stop condition. Software writes the data byte, and I2C sets bit ITE in register *I2Cx\_SR* and clears bit TB in register *I2Cx\_CR*. Then software writes a new byte to register *I2Cx\_DB* and sets bit TB in register *I2Cx\_CR*, which starts the new byte transmission. This process continues until the START or STOP bit in register *I2Cx\_CR* is set by software. After a Start, Stop or Repeated Start condition is transmitted, the START and STOP bits in register *I2Cx\_CR* are not cleared automatically by I2C.

After each byte and ACK/NAK are transferred, I2C holds the SCL line low and waits until the TB bit in register *I2Cx\_CR* is set.

### 3. Stop Condition

A Stop condition terminates a data transfer. In master transmit mode, the STOP and TB bits in register *I2Cx\_CR* must be set to start the transmission of the last byte. In master receive mode, the ACKNAK, STOP and TB bits in register *I2Cx\_CR* must be set to start the reception of the last byte. After a Stop condition is transmitted, software must clear the STOP bit in register *I2Cx\_CR*.

## 15.3 Data Transmission Sequence

I2C transmits data in 1-byte increments and follows below sequence:

1. Start
2. 7-bit slave address
3. R/nW bit
4. Acknowledge pulse
5. 8 bits of data
6. Acknowledge pulse
7. Repeat of Step 5 and Step 6
8. Repeated Start (repeat Step 1) or Stop

## 15.4 Data and Addressing

The I2C Data Buffer Register (*I2Cx\_DBR*) and the I2C Slave Address Register (*I2Cx\_SAR*) manage data and slave addressing. *I2Cx\_DBR* contains 1 byte of data or a 7-bit target slave address and the R/nW bit. *I2Cx\_SAR* contains the ASR6601 I2C slave address when the I2C is in slave mode. After I2C receives a full byte of data and an ACK, it stores the data in register *I2Cx\_DBR*. To transmit data, the CPU writes to the *I2Cx\_DBR* register, and the I2C transmits the data to the serial bus when the TB bit in register *I2Cx\_CR* is set.

### 1. When the I2C is in Master/Slave Transmit mode:

- (1) Software writes data to the *I2Cx\_DBR* register, which makes the I2C to start a master transaction or to send the next data byte after the ITE bit in register *I2Cx\_SR* is set.
- (2) When bit TB in register *I2Cx\_CR* is set, the data in register *I2Cx\_DBR* is transmitted.
- (3) If the ITEIE bit in register *I2Cx\_CR* is set, an *I2Cx\_DBR* transmit-empty interrupt is triggered after a byte and an ACK is transferred.
- (4) When the I2C is ready to send the next byte before the CPU writes to the *I2Cx\_DBR* register and there is no Stop condition, the I2C is in a wait state until the CPU writes to the *I2Cx\_DBR* register and sets the TB bit in the *I2Cx\_CR* register.

**Notice:** In FIFO mode, software writes to the TX FIFO instead of the *I2Cx\_DBR* register.

### 2. When the I2C is in Master/Slave Receive mode:

- (1) When a full byte of data is received (if the DRFIE bit in register *I2Cx\_CR* is set), the *I2Cx\_DBR* receive-full interrupt is generated and the IRF bit in register *I2Cx\_SR* is set, the CPU then reads the *I2Cx\_DBR* register to retrieve the data.
- (2) After the ACK cycle is completed, I2C transfers data from the shift register to the *I2Cx\_DBR* register.
- (3) I2C is in wait state until the *I2Cx\_DBR* register is read by the CPU.
- (4) After the CPU reads the *I2Cx\_DBR* register, the I2C updates the ACKNAK and TB bits in register *I2Cx\_CR* to allow the transmission of the next byte.

**Notice:** In FIFO mode, software reads from the RX FIFO instead of the *I2Cx\_DBR* register.

### 3. Addressing a Slave Device:

As a master device, the I2C must form and send the first byte of a transaction. This byte consists of a 7-bit slave address and a R/nW bit. After the first byte is transmitted, the I2C must receive an ACK from the slave device. When it is a Write transaction, the I2C remains in master transmit mode, and the slave device remains in slave receive mode. When it is a Read transaction, the I2C switches to master receive mode immediately after receiving an ACK, and the slave device switches to slave transmit mode. When a NAK is returned, the I2C automatically sends a Stop condition and sets the BED bit in register *I2Cx\_SR* to abort the current transaction.

## 15.5 Acknowledge

Each byte transmission must be accompanied by an ACK generated by the master or slave receiver. The transmitter must release the SDA line for the receiver to transmit the ACK.

In master transmit mode, if the target slave receiver does not generate an ACK, the SDA line remains high, which indicates a NAK. The lack of an ACK causes I2C to set the BED bit in register *I2Cx\_SR* and generate an interrupt. I2C automatically generates a Stop condition and aborts the transmission.

In master receive mode, I2C sends a NAK to notify the slave transmitter to stop sending data. The ACKNAK bit in the *I2Cx\_CR* register controls the generation of ACK/NAK on the bus. According to the I2C protocol, the BED bit in the *I2Cx\_SR* register is not set for a master receive mode NAK. I2C automatically sends the ACK every time it receives a byte from the bus. Before the master receiver receives the last byte, software must set the ACKNAK bit in the *I2Cx\_CR* register to generate a NAK. The NAK is sent after the last byte to indicate that the last byte has been sent.

In slave receive mode, I2C automatically acknowledges its own slave address, irrespective of whether the ACKNAK bit in the *I2Cx\_CR* register is set. In slave mode, I2C automatically sends the ACK after receiving a byte, irrespective of whether the ACKNAK bit in the *I2Cx\_CR* register is set.

In slave transmit mode, receiving a NAK indicates that the last byte has been transferred. The master then sends a Stop condition or Repeated Start condition. The UB bit in register *I2Cx\_SR* remains set until a Stop condition or Repeated Start condition is received.

## 15.6 Arbitration

I2C bus arbitration is required by a multi-master capability. Bus arbitration is used when two or more masters simultaneously generate a Start condition within the minimum time of a Start condition.

Arbitration can last for a long time. If the slave address and the R/nW bit are the same, the arbitration moves to the data. Due to the Wired-And nature of the I2C bus, no data is lost if two or all masters are outputting the same bus state. If the address, the R/nW bit, or the data are different, the master that transitioned to the high state (the master data is different from the SDA line) loses arbitration and aborts the data transfer. The I2C bus sets bit ALD in register *I2Cx\_SR*, then returns to the idle state.

In FIFO mode, software must empty the FIFOs once arbitration is lost. This can be done by clearing the read and write pointer registers for TxFIFO and RxFIFO.

## 15.7 I2C Master Mode

When software starts a read or write operation on the I2C bus, the I2C switches from the default slave receive mode to master transmit mode. The Start condition is followed by the 7-bit slave address and the R/nW bit.

After receiving an ACK, the I2C enters one of the two master modes:

- Master transmit: I2C writes data
- Master receive: I2C reads data

The CPU writes to register *I2Cx\_CR* to start a master transaction.

**Table 15-2 Master Transactions**

| I2C Master Action                             | Mode of Operation                 | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Generate clock output                         | Master transmit<br>Master receive | <ul style="list-style-type: none"> <li>• The master drives the SCL line.</li> <li>• The SCLE and UE bits in the <i>I2Cx_CR</i> register must be set.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Write target slave address to <i>I2Cx_DBR</i> | Master transmit<br>Master receive | <ul style="list-style-type: none"> <li>• CPU writes to bits[7:1] in the <i>I2Cx_DBR</i> register before a Start condition is enabled.</li> <li>• The first 7 bits are sent after Start.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Write R/nW bit to <i>I2Cx_DBR</i>             | Master transmit<br>Master receive | <ul style="list-style-type: none"> <li>• CPU writes the R/nW control bit to the least significant bit in register <i>I2Cx_DBR</i>.</li> <li>• If the R/nW bit is low, master remains a master transmitter, if the R/nW bit is high, master switches to a master receiver.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                          |
| Send Start condition                          | Master transmit<br>Master receive | <p>After the 7-bit target slave address and the R/nW bit are written into the <i>I2Cx_DBR</i> register,</p> <ul style="list-style-type: none"> <li>• Software sets the START bit in register <i>I2Cx_CR</i>.</li> <li>• Software sets the TB bit in register <i>I2Cx_CR</i> to initiate the Start condition.</li> </ul>                                                                                                                                                                                                                                                                                                                                                       |
| Initiate first data byte transmission         | Master transmit<br>Master receive | <ul style="list-style-type: none"> <li>• CPU writes one data byte to the <i>I2Cx_DBR</i> register.</li> <li>• Software sets the TB bit in register <i>I2Cx_CR</i> and I2C starts the transmission of the Byte.</li> <li>• The TB bit in register <i>I2Cx_CR</i> is cleared and the ITE bit in register <i>I2Cx_SR</i> is set when the transfer is complete.</li> </ul>                                                                                                                                                                                                                                                                                                        |
| Arbitrate for I2C bus                         | Master transmit<br>Master receive | <p>If 2 or more masters send a Start condition within the same clock period, then bus arbitration must occur.</p> <ul style="list-style-type: none"> <li>• I2C arbitrates as long as there is a need. Bus arbitration takes place during the transmission of target slave address, R/nW bit or data, and it continues until all masters except one master lose the bus. No data is lost.</li> <li>• If I2C loses arbitration, the ALD bit in register <i>I2Cx_SR</i> is set, and I2C switches to slave receive mode.</li> <li>• If I2C loses arbitration when it starts to send the target slave address, it will try to resend the address when the bus is freed.</li> </ul> |

| I2C Master Action                 | Mode of Operation                 | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Write one data byte to I2Cx_DBDR  | Master transmit only              | <ul style="list-style-type: none"> <li>When the ITE bit in the <i>I2Cx_SR</i> register is set and the TB bit in the <i>I2Cx_CR</i> register is cleared, if enabled, the I2Cx_DBDR transmit-empty interrupt is generated.</li> <li>The CPU writes a data byte to the <i>I2Cx_DBDR</i> register, sets the appropriate Start/Stop condition combination as required, and sets the TB bit in register <i>I2Cx_CR</i> to send data. The 8 bits of data are transferred from the shift register to the serial bus. If the STOP bit in register <i>I2Cx_CR</i> is set before the transfer, then the 8 bits of data is followed by a Stop condition.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Wait for ACK from slave receiver  | Master transmit only              | As a master transmitter, the I2C generates the ACK clock, and releases the SDA line for the slave receiver to transmit the ACK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Read one byte from I2Cx_DBDR      | Master receive only               | <p>After the ACKNAK bit in register <i>I2Cx_CR</i> is read, the 8 bits of data in the shift register is transferred to the I2Cx_DBDR register,</p> <ul style="list-style-type: none"> <li>The CPU reads the I2Cx_DBDR register when the IRF bit in register <i>I2Cx_SR</i> is set and the TB bit in register <i>I2Cx_CR</i> is cleared. If the I2Cx_DBDR receive-full interrupt is enabled, it is signalled to the CPU.</li> <li>When the <i>I2Cx_DBDR</i> register is read, if the ACKNAK bit in register <i>I2Cx_SR</i> is cleared (indicating ACK), the software must clear the ACKNAK bit and set the TB bit in register <i>I2Cx_CR</i> to start the next byte Read.</li> <li>If the ACKNAK bit in <i>I2Cx_SR</i> is set (indicating NAK), the TB bit in <i>I2Cx_CR</i> is cleared, the STOP bit in <i>I2Cx_CR</i> is set, and the UB bit in <i>I2Cx_SR</i> is set, then the last byte has been read from the <i>I2Cx_DBDR</i> register, and the I2C is sending the Stop.</li> <li>If the ACKNAK bit in <i>I2Cx_SR</i> is set (indicating NAK) and the TB bit in <i>I2Cx_CR</i> is cleared, but the STOP bit in <i>I2Cx_CR</i> is cleared, then the software has two options:             <ol style="list-style-type: none"> <li>Set the START bit in <i>I2Cx_CR</i>, write a new target slave address to the <i>I2Cx_DBDR</i> register, set the TB bit in <i>I2Cx_CR</i>, and send a Repeated Start.</li> <li>Set the MA bit in <i>I2Cx_CR</i> and keep the TB bit as 0 in <i>I2Cx_CR</i>, and only send a Stop.</li> </ol> </li> </ul> |
| Transmit ACK to slave transmitter | Master receive only               | <ul style="list-style-type: none"> <li>As a master receiver, the I2C generates the ACK clock and drives the SDA line during the ACK cycle.</li> <li>If the next data byte is the last transaction, the user software sets the ACKNAK bit in register <i>I2Cx_CR</i> to generate NAK.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Generate a Repeated Start         | Master transmit<br>Master receive | <p>Use a Repeated Start condition instead of a Stop condition to initiate a new transaction without releasing the bus.</p> <ul style="list-style-type: none"> <li>The Repeated Start is generated after the last data byte has been transmitted.</li> <li>Software must write the next 7-bit target slave address and the R/nW bit to the <i>I2Cx_DBDR</i> register, set the START bit in register <i>I2Cx_CR</i>, and set the TB bit in register <i>I2Cx_CR</i>.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| I2C Master Action | Mode of Operation                 | Definition                                                                                                                                                                                                                  |
|-------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Generate a Stop   | Master transmit<br>Master receive | <ul style="list-style-type: none"> <li>A Stop is generated after the last data byte has been transmitted.</li> <li>The STOP bit in register <i>I2Cx_CR</i> must be set before the transmission of the last byte.</li> </ul> |

## 15.8 FIFO Mode

The FIFO mode can only be used when the I2C is in *Master Mode*.



Figure 15-3 FIFO Mode Block Diagram

FIFOs can be used for both transmission and reception to help reducing the empty and full interrupts of register I2Cx\_DB.R. The FIFOs allow reading and writing multiple bytes without interrupting the CPU after each byte.

DMA is used to improve I2C transactions (typically more than 8 Bytes). The entire transaction can be completed by DMA without generating multiple FIFO interrupts.

The FIFO mode is backward compatible, and it is disabled by clearing the FIFO\_EN bit in the *I2Cx\_CR* register.

Transmit FIFO has a width of 12 (4 control bits and 8 data bits) and a depth of 8. The 4 control bits are bits[3:0] in register *I2Cx\_CR*, which are required for each data byte transmission. After a byte is transmitted, the next byte is copied from the TX FIFO into the shift register, and the control bits are copied into the *I2Cx\_CR* register. This byte is now transferred, and it continues like that until the Stop bit is set.

Receive FIFO has a width of 8 (8 data bits) and a depth of 16, which is used to store the received data. The control bits for each byte and dummy data are put in the corresponding position in the TX FIFO. When the RX FIFO is half full, an interrupt or DMA request is sent out for the data in the RX FIFO to be read out.

In order to support the FIFO mode and fully utilize its capabilities, the following status and control bits need to be configured:

- (1) Set the FIFO\_EN bit in register *I2Cx\_CR* to enable the FIFO mode.
- (2) Set the TXBEGIN bit in register *I2Cx\_CR* to start a transaction.
- (3) Bits[31:28] in register *I2Cx\_CR* enables or disables all the FIFO related interrupts, and bits[31:28] in register *I2Cx\_SR* is used to inquire the interrupt status.
- (4) TXDONE interrupt is generated when each transaction is completed (that is, a Stop condition is sent).
- (5) The DMA\_EN bit in register *I2Cx\_CR* is used to enable/disable DMA mode

In DMA mode, all the FIFO related interrupts must be disabled in register *I2Cx\_CR* (bits[31:28]), and the DMA\_EN bit in this register must be set. In this way, all DMA requests are sent to the DMA without interrupting the CPU. The TXDONE\_IE bit in the *I2Cx\_CR* register needs to be set in both FIFO and DMA modes to generate an interrupt to the CPU after each transaction is completed.

## 15.9 I2C Slave Mode

Table 15-3 Slave Transaction

| Slave Operation                     | Type                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Slave receive mode (default)        | Slave receive only              | <ul style="list-style-type: none"> <li>The I2C monitors all slave address transactions.</li> <li>The UE bit in register <i>I2Cx_CR</i> must be set.</li> <li>I2C monitors the Start conditions on the bus. When a Start condition is detected, the interface reads the first 8 bits of data and compares the most significant 7 bits with those in the <i>I2Cx_SAR</i> register. If they match, the I2C sends an ACK.</li> <li>If the 8th bit (R/nW bit) of the first byte is low, then I2C stays in slave receive mode, and the SAD bit in register <i>I2Cx_SR</i> is cleared. If the R/nW bit is high, I2C switches to slave transmit mode and sets the SAD bit in register <i>I2Cx_SR</i>.</li> </ul>                                                            |
| Set the slave address detection bit | Slave receive<br>Slave transmit | <ul style="list-style-type: none"> <li>Indicates that the interface has detected the matching slave address</li> <li>If enabled, an slave address detection interrupt is generated after the matching slave address is received and acknowledged, and the SAD bit in register <i>I2Cx_SR</i> is set.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Read one byte from <i>I2Cx_DBR</i>  | Slave receive only              | <ul style="list-style-type: none"> <li>Eight bits are read from the serial bus into the shift register. When a full byte has been received and the ACK/NAK bit is completed, the byte in the shift register is transferred to the <i>I2Cx_DBR</i> register.</li> <li>When the IRF bit in register <i>I2Cx_SR</i> is set, and the TB bit in register <i>I2Cx_CR</i> is cleared, if enabled, the <i>I2Cx_DBR</i> receive-full interrupt is generated.</li> <li>Software reads one data byte from the <i>I2Cx_DBR</i> register, then configures the ACKNAK bit in register <i>I2Cx_CR</i> as required and sets the TB bit in register <i>I2Cx_CR</i>. This makes the I2C exit from the wait state and continue to receive data from the master transmitter.</li> </ul> |
| Transmit ACK to master transmitter  | Slave receive only              | <ul style="list-style-type: none"> <li>As a slave receiver, the I2C pulls the SDA line low to generate the ACK when SCL is high.</li> <li>ACK/NAK is controlled by bit ACKNAK in register <i>I2Cx_CR</i>.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Write one byte to <i>I2Cx_DBR</i>   | Slave transmit only             | <ul style="list-style-type: none"> <li>When the ITE bit in register <i>I2Cx_SR</i> is set and the TB bit in register <i>I2Cx_CR</i> is cleared, if enabled, the <i>I2Cx_DBR</i> transmit-empty interrupt is generated.</li> <li>Software writes a byte into register <i>I2Cx_DBR</i> and then sets the TB bit in register <i>I2Cx_CR</i> to start the transmission.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                      |

|                                      |                     |                                                                                                                         |
|--------------------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------|
| Waiting for ACK from master receiver | Slave transmit only | As a slave transmitter, the I2C releases the SDA line for the master receiver to pull the line low to transmit the ACK. |
|--------------------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------|

## 15.10 I2C Clock Reset

Each I2C interface has independent APB bus clock and independent APB bus reset.

Software must ensure that the I2C unit is disabled (*I2Cx\_CR*[UE]=0) before reset, and ensure that the I2C bus is idle (*I2Cx\_SR*[IBB]=0) when the unit is enabled after reset. When reset, all registers except the *I2Cx\_SAR*, return to the default reset condition. *I2Cx\_SAR* is not affected by a reset.

Steps for I2C clock reset:

1. Set the UR bit in the *I2Cx\_CR* register, and clear the remaining bits of this register;
2. Clear the *I2Cx\_SR* register;
3. Clear the UR bit in the *I2Cx\_CR* register.

## 15.11 I2C Interrupts

I2C interrupts are configured by register *I2Cx\_CR*, and the interrupt status can be obtained by querying the corresponding bit in register *I2Cx\_SR*.

## 15.12 DMA Requests

DMA (Direct Memory Access) is enabled by setting the DMA\_EN bit in register *I2Cx\_CR* to support transmission and reception.

## 15.13 I2C Registers

I2C0 Base Address: 0x40007000

I2C1 Base Address: 0x40014000

I2C2 Base Address: 0x40015000

Table 15-4 I2C Register Summary

| Register Name     | Address Offset | Description                       |
|-------------------|----------------|-----------------------------------|
| I2Cx_CR           | 0x00           | Control Register                  |
| I2Cx_SR           | 0x04           | Status Register                   |
| I2Cx_SAR          | 0x08           | Slave Address Register            |
| I2Cx_DBR          | 0x0C           | Data Buffer Register              |
| I2Cx_LCR          | 0x10           | Load Count Register               |
| I2Cx_WCR          | 0x14           | Wait Count Register               |
| I2Cx_RST_CYCL     | 0x18           | Reset SCL Cycle                   |
| I2Cx_BMR          | 0x1C           | Bus Monitor Register              |
| I2Cx_WFIFO        | 0x20           | Write FIFO Register               |
| I2Cx_WFIFO_WPTR   | 0x24           | Write FIFO Write Pointer Register |
| I2Cx_WFIFO_RPTR   | 0x28           | Write FIFO Read Pointer Register  |
| I2Cx_RFIFO        | 0x2C           | Read FIFO Register                |
| I2Cx_RFIFO_WPTR   | 0x30           | Read FIFO Write Pointer Register  |
| I2Cx_RFIFO_RPTR   | 0x34           | Read FIFO Read Pointer Register   |
| I2Cx_RESV[2]      | 0x38           | Reserved                          |
| I2Cx_WFIFO_STATUS | 0x40           | Write FIFO Status Register        |
| I2Cx_RFIFO_STATUS | 0x44           | Read FIFO Status Register         |

### 15.13.1 I2Cx\_CR (x=0, 1, 2)

Address Offset: 0x00

Reset Value: 0x000000200

| 31        | 30        | 29        | 28        | 27        | 26        | 25           | 24       |
|-----------|-----------|-----------|-----------|-----------|-----------|--------------|----------|
| RXOV_IE   | RXF_IE    | RXHF_IE   | TXE_IE    | TXDONE_IE | MSDE      | MSDIE        | SSDIE    |
| rw-0h        | rw-0h    |
| <b>23</b> | <b>22</b> | <b>21</b> | <b>20</b> | <b>19</b> | <b>18</b> | <b>17-16</b> |          |
| SADIE     | BEIE      | RESERVED  | DRFIE     | ITEIE     | ALDIE     | RESERVED     |          |
| rw-0h     | rw-0h     | r-0h      | rw-0h     | rw-0h     | rw-0h     |              | r-0h     |
| <b>15</b> | <b>14</b> | <b>13</b> | <b>12</b> | <b>11</b> | <b>10</b> | <b>9-8</b>   |          |
| RESERVED  | UE        | SCLE      | MA        | IBRR      | UR        | MODE         |          |
| r-0h      | rw-0h     | rw-0h     | rw-0h     | rw-0h     | rw-0h     |              | rw-2h    |
| <b>7</b>  | <b>6</b>  | <b>5</b>  | <b>4</b>  | <b>3</b>  | <b>2</b>  | <b>1</b>     | <b>0</b> |
| DMA_EN    | RESERVED  | FIFOEN    | TXBEGIN   | TB        | ACKNAK    | STOP         | START    |
| rw-0h     | r-0h      | rw-0h     | rw-0h     | rw-0h     | rw-0h     | rw-0h        | rw-0h    |

**Bit 31 RXOV\_IE:** Receive FIFO overrun interrupt enable

- 0: receive FIFO overrun interrupt disabled
- 1: receive FIFO overrun interrupt enable

**Bit 30 RXF\_IE:** Receive FIFO full interrupt enable

- 0: receive FIFO full interrupt disabled
- 1: receive FIFO full interrupt enabled

**Bit 29 RXHF\_IE:** Receive FIFO half full interrupt enable

- 0: Receive FIFO half full interrupt disabled
- 1: Receive FIFO half full interrupt enabled

**Bit 28 TXE\_IE:** Transmit FIFO empty interrupt enable

- 0: Transmit FIFO empty interrupt disabled
- 1: Transmit FIFO empty interrupt enabled

**Bit 27 TXDONE\_IE:** Transaction done interrupt enable

- 0: transaction done interrupt disabled
- 1: transaction done interrupt enabled

**Bit 26 MSDE:** Master Stop detection enable

- 0: Master Stop detection disabled
- 1: Master Stop detection enabled

**Bit 25 MSDIE:** Master Stop detection interrupt enable

- 0: Master Stop detection interrupt disabled
- 1: Master Stop detection interrupt enabled

**Bit 24 SSDIE:** Slave Stop detection interrupt enable

- 0: Slave Stop detection interrupt disabled
- 1: Slave Stop detection interrupt enabled

**Bit 23 SADIE:** Slave address detection interrupt enable

- 0: Slave address detection interrupt disabled
- 1: Slave address detection interrupt enabled

**Bit 22 BEIE:** Bus error interrupt enable

- 0: Bus error interrupt disabled
- 1: Bus error interrupt enabled

**Bit 21 RESERVED:** Must be kept, and cannot be modified.

**Bit 20 DRFIE:** I2Cx\_DB<sub>R</sub> receive-full interrupt enable

- 0: I2Cx\_DB<sub>R</sub> receive-full interrupt disabled
- 1: I2Cx\_DB<sub>R</sub> receive-full interrupt enabled

**Bit 19 ITEIE:** I2Cx\_DB<sub>R</sub> transmit-empty interrupt enable

- 0: I2Cx\_DB<sub>R</sub> transmit-empty interrupt disabled
- 1: I2Cx\_DB<sub>R</sub> transmit-empty interrupt enabled

**Bit 18 ALDIE:** Arbitration loss detection interrupt enable

- 0: Arbitration loss detection interrupt disabled
- 1: Arbitration loss detection interrupt enabled

**Bits 17-15 RESERVED:** Must be kept, and cannot be modified.

**Bit 14 UE:** I2C unit enable

- 0: I2C unit disabled
- 1: I2C unit enabled (the default is slave receive mode)

Software must ensure that the I2C bus is idle before enabling the I2C unit, and ensure that the internal I2C clock is enabled before setting or clearing this bit.

**Bit 13 SCLE:** SCL enable

- 0: disable the I2C from driving the SCL line
- 1: enable the I2C clock output for master-mode operation

**Bit 12 MA:** Master abort

This bit is used for the I2C to generate a Stop condition in master mode.

- 0: a Stop condition is generated when the STOP bit in this register is set
- 1: a Stop condition is generated without data transmission

In master transmit mode, after a data byte is transmitted, the TB bit in this register is cleared and the ITE bit in register *I2Cx\_SR* is set. When no more data bytes need to be sent, setting the MA bit to generate a Stop condition to free the bus. In master receive mode, when a NAK is sent with the STOP bit=0 and without a Repeated Start condition followed, setting the MA bit to generate a Stop condition to free the bus. The TB bit in this register must remain clear.

**Bit 11 IBRR:** I2C bus reset request

- 0: invalid
- 1: I2C bus reset, and this bit is cleared automatically

**Bit 10 UR:** Unit reset

- 0: no reset
- 1: reset the I2C unit

**Bits 9-8 MODE:** Bus clock mode for the master

- 00: standard mode – 100 Kbps
- 01: fast mode – 400 Kbps

**Bit 7 DMA\_EN:** DMA enable

- 0: DMA requests disabled
- 1: DMA requests enabled

**Bit 6 RESERVED:** Must be kept, and cannot be modified.

**Bit 5 FIFOEN:** FIFO mode enable

- 0: FIFO mode disabled
- 1: FIFO mode enabled

**Bit 4 TXBEGIN:** Transaction begin

- 0: no transaction begins
- 1: a new transaction begins

This bit is cleared by hardware after a Stop condition is generated, and the software needs to set it again to start a new transaction.

**Bit 3 TB:** Transfer byte, used to send or receive a byte on the I2C bus

- 0: cleared by I2C when one byte is sent or received
- 1: send or receive a byte

The I2C unit monitors this bit to determine whether the byte transfer has completed. In master or slave mode, after each byte including the ACK is transferred, I2C holds the SCL line low until the TB bit is set.

**Bit 2 ACKNAK:** The positive/negative acknowledge (ACK/NAK) control bit in master receive mode

- 0: send a ACK after receiving a data byte
- 1: send a NAK after receiving a data byte

In slave mode, when the I2C responds to its slave address or the reception is complete, it automatically sends an ACK, regardless of whether the ACKNAK bit is set.

**Bit 1 STOP:** Generate a Stop condition

- 0: no Stop condition is generated
- 1: generate a Stop condition

This bit is used to generate a Stop condition on the I2C bus after the transmission of the next data byte in master mode. In master receive mode, the ACKNAK bit and the STOP bit must be set to 1 at the same time.

**Bit 0 START:** Generate a Start condition

- 0: no Start condition is generated
- 1: generate a Start condition

This bit is used to generate a Start condition on the I2C bus in master mode.

### 15.13.2 I2Cx\_SR (x=0, 1, 2)

Address Offset: 0x04

Reset Value: 0x00000000

| 31       | 30      | 29      | 28       | 27       | 26       | 25       |
|----------|---------|---------|----------|----------|----------|----------|
| RXOV     | RXF     | RXHF    | TXE      | TXDONE   | MSD      | RESERVED |
| rw1c-0h  | rw1c-0h | rw1c-0h | rw1c-0h  | rw1c-h   | r1ch     | r-0h     |
| 24       | 23      | 22      | 21       | 20       | 19       | 18       |
| SSD      | SAD     | BED     | RESERVED | IRF      | ITE      | ALD      |
| rw1c-0h  | rw1c-0h | rw1c-0h | r-0h     | rw1c-0h  | rw1c-0h  | rw1c-0h  |
| 17       | 16      | 15      | 14       | 13-8     | 7-0      |          |
| RESERVED | IBB     | UB      | ACKNAK   | RESERVED | RESERVED |          |
| r-0h     | r-0h    | r-0h    | r-0h     | r-0h     | r-0h     |          |

**Bit 31 RXOV:** Receive FIFO overrun flag

- 0: no receive FIFO overrun occurred
- 1: receive FIFO overrun occurred, and it is cleared by software writing 1 to it.

**Bit 30 RXF:** Receive FIFO full flag

- 0: receive FIFO is not full
- 1: receive FIFO is full, and it is cleared by software writing 1 to it.

**Bit 29 RXHF:** Receive FIFO half-full flag

- 0: receive FIFO is not half full
- 1: receive FIFO is half full, and it is cleared by software writing 1 to it.

**Bit 28 TXE:** Transmit FIFO empty flag

- 0: transmit FIFO is not empty
- 1: transmit FIFO is empty, and it is cleared by software writing 1 to it.

**Bit 27 TXDONE:** Transaction done flag (used in FIFO mode)

- 0: transaction is not done
- 1: transaction is done, and it is cleared by software writing 1 to it.

**Bit 26 MSD:** Master Stop detection flag (only effective in master mode)

- 0: no master Stop was detected
- 1: a master Stop was detected, and it is cleared by software writing 1 to it.

**Bit 25 RESERVED:** Must be kept, and cannot be modified.

**Bit 24 SSDIE:** Slave Stop detection flag

- 0: no slave Stop was detected
- 1: a slave Stop was detected, and it is cleared by software writing 1 to it.

**Bit 23 SAD:** Slave address detection flag

- 0: no matching slave address was detected
- 1: the matching slave address was detected, and it is cleared by software writing 1 to it.

**Bit 22 BED:** Bus error detection flag

- 0: no bus error was detected
- 1: a bus error was detected, and it is cleared by software writing 1 to it.

This bit is set in two cases:

- As a master transmitter, the I2C did not receive an ACK after sending a byte.
- As a slave receiver, the I2C generates a NAK.

**Bit 21 RESERVED:** Must be kept, and cannot be modified.**Bit 20 IRF:** I2Cx\_DB<sub>R</sub> receive full flag

- 0: the I2Cx\_DB<sub>R</sub> register has not received a new data byte or the I2C bus is idle.
- 1: the I2Cx\_DB<sub>R</sub> register received a new data byte, and it is cleared by software writing 1 to it.

**Bit 19 ITE:** I2Cx\_DB<sub>R</sub> transmit empty flag

- 0: the data byte is still being transmitted.
- 1: the I2C has finished transmitting a byte on the I2C bus, and it is cleared by software writing 1 to it.

**Bit 18 ALD:** Arbitration loss detection flag, used in multi-master scenarios

- 0: the I2C wins the arbitration or no arbitration took place
- 1: the I2C loses the arbitration, and it is cleared by software writing 1 to it.

**Bit 17 RESERVED:** Must be kept, and cannot be modified.**Bit 16 IBB:** I2C bus busy flag

- 0: the I2C bus is idle, or the ASR6601 I2C is using the bus
- 1: the I2C bus is busy but not used by the ASR6601 I2C

**Bit 15 UB:** I2C unit busy flag

- 0: the I2C unit is idle
- 1: the I2C unit is busy

**Bit 14 ACKNAK:** ACK/NAK status flag

- 0: the I2C received or sent an ACK
- 1: the I2C received or sent a NAK

In slave transmit mode, this bit is used to determine whether the byte transmitted is the last one. This bit is updated after each byte and ACK/NAK information is received.

**Bits 13-0 RESERVED:** Must be kept, and cannot be modified.**15.13.3 I2Cx\_SAR (x=0, 1, 2)**

Address Offset: 0x08

Reset Value: 0x00000000

| 31-7     | 6-0           |
|----------|---------------|
| RESERVED | SLAVE_ADDRESS |
| r-0h     | rw-0h         |

**Bits 31-7 RESERVED:** Must be kept, and cannot be modified.**Bits 6-0 SLAVE\_ADDRESS:** The ASR6601 I2C slave address used in slave mode.

#### 15.13.4 I2Cx\_DBR (x=0, 1, 2)

Address Offset: 0x0C

Reset Value: 0x00000000

| 31-8     | 7-0         |
|----------|-------------|
| RESERVED | DATA_BUFFER |
| r-0h     | rw-0h       |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-0 DATA\_BUFFER:** Buffer for I2C bus transmit/receive data.

#### 15.13.5 I2Cx\_LCR (x=0, 1, 2)

Address Offset: 0x10

Reset Value: 0x18183a7e

| 31-18    | 17-9   | 8-0    |
|----------|--------|--------|
| RESERVED | FLV    | SLV    |
| r-1818h  | rw-1dh | rw-7eh |

**Bits 31-18 RESERVED:** Must be kept, and cannot be modified.

**Bits 17-9 FLV:** Phase decrementer load value for fast mode SCL in master mode

**Bits 8-0 SLV:** Phase decrementer load value for standard mode SCL in master mode

#### 15.13.6 I2Cx\_WCR (x=0, 1, 2)

Address Offset: 0x14

Reset Value: 0x0000143a

| 31-5     | 4-0    |
|----------|--------|
| RESERVED | COUNT  |
| r-a1h    | rw-1ah |

**Bits 31-5 RESERVED:** Must be kept, and cannot be modified.

**Bits 4-0 COUNT:** Counter values for defining the setup and hold times in standard and fast modes

### 15.13.7 I2Cx\_RST\_CYCL (x=0, 1, 2)

Address Offset: 0x18

Reset Value: 0x00000000

| 31-4     | 3-0     |
|----------|---------|
| RESERVED | RST_CYC |
| r-0h     | rw-0h   |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bits 3-0 RST\_CYC:** Serial bus reset SCL cycle count.

### 15.13.8 I2Cx\_BMR (x=0, 1, 2)

Address Offset: 0x1C

Reset Value: 0x00000003

| 31-2     | 1    | 0    |
|----------|------|------|
| RESERVED | SCL  | SDA  |
| r-0h     | r-1h | r-1h |

**Bits 31-2 RESERVED:** Must be kept, and cannot be modified.

**Bit 1 SCL:** SCL pin state

**Bit 0 SDA:** SDA pin state

### 15.13.9 I2Cx\_WFIFO (x=0, 1, 2)

Address Offset: 0x20

Reset Value: 0x00000000

| 31-12    | 11-8    | 7-0  |
|----------|---------|------|
| RESERVED | CONTROL | DATA |
| r-0h     | w-0h    | w-0h |

**Bits 31-12 RESERVED:** Must be kept, and cannot be modified.

**Bits 11-8 CONTROL:** I2C bus transmit/receive data control bits.

**Bits 7-0 DATA:** I2C bus send data for write transactions and dummy data for read transactions.

### 15.13.10 I2Cx\_WFIFO\_WPTR (x=0, 1, 2)

Address Offset: 0x24

Reset Value: 0x00000000

| 31-4     | 3-0   |
|----------|-------|
| RESERVED | DATA  |
| r-0h     | rw-0h |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bits 3-0 DATA:** The position in the Transmit FIFO where the software will write the next entry

### 15.13.11 I2Cx\_WFIFO\_RPTR (x=0, 1, 2)

Address Offset: 0x28

Reset Value: 0x00000000

| 31-4     | 3-0   |
|----------|-------|
| RESERVED | DATA  |
| r-0h     | rw-0h |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bits 3-0 DATA:** The position in the Transmit FIFO where the hardware will read the next entry

### 15.13.12 I2Cx\_RFIFO (x=0, 1, 2)

Address Offset: 0x2C

Reset Value: 0x00000000

| 31-8     | 7-0  |
|----------|------|
| RESERVED | DATA |
| r-0h     | r-0h |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-0 DATA:** I2C bus receive data for read transactions.

### 15.13.13 I2Cx\_RFIFO\_WPTR (x=0, 1, 2)

Address Offset: 0x30

Reset Value: 0x00000000

| 31-4     | 3-0  |
|----------|------|
| RESERVED | DATA |
| r-0h     | r-0h |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bits 3-0 DATA:** The position in the Receive FIFO where the hardware will write the next entry

### 15.13.14 I2Cx\_RFIFO\_RPTR (x=0, 1, 2)

Address Offset: 0x34

Reset Value: 0x00000000

| 31-4     | 3-0  |
|----------|------|
| RESERVED | DATA |
| r-0h     | r-0h |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bits 3-0 DATA:** The position in the Receive FIFO where the software will read the next entry

### 15.13.15 I2Cx\_WFIFO\_STATUS (x=0, 1, 2)

Address Offset: 0x40

Reset Value: 0x00000000

| 31-16    | 15-9       | 8-1         | 0          |
|----------|------------|-------------|------------|
| RESERVED | WFIFO_SIZE | WFIFO_EMPTY | WFIFO_FULL |
| r-0h     | r-0h       | r-0h        | r-0h       |

**Bits 31-6 RESERVED:** Must be kept, and cannot be modified.

**Bits 5-2 WFIFO\_SIZE:** The Transmit FIFO size

**Bit 1 WFIFO\_EMPTY:** Transmit FIFO empty

**Bit 0 WFIFO\_FULL:** Transmit FIFO full

### 15.13.16 I2Cx\_RFIFO\_STATUS (x=0, 1, 2)

Address Offset: 0x44

Reset Value: 0x00000000

| 31-24       | 23-16      | 15-8           | 7-4           |
|-------------|------------|----------------|---------------|
| RESERVED    | RESERVED   | RESERVED       | RFIFO_SIZE    |
| r-0h        | r-0h       | r-0h           | r-0h          |
| <b>3</b>    | <b>2</b>   | <b>1</b>       | <b>0</b>      |
| RFIFO_EMPTY | RFIFO_FULL | RFIFO_HALFFULL | RFIFO_OVERRUN |
| r-0h        | r-0h       | r-0h           | r-0h          |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-4 RFIFO\_SIZE:** The Receive FIFO size

**Bit 3 RFIFO\_EMPTY:** Receive FIFO empty

**Bit 2 RFIFO\_FULL:** Receive FIFO full

**Bit 1 RFIFO\_HALFFULL:** Receive FIFO half full

**Bit 0 RFIFO\_OVERRUN:** Receive FIFO overrun

# 16.

# ADC

## 16.1 Introduction

The 12-bit ADC (Analog to Digital Converter) has 8 external channels and 7 internal channels for measuring signals with up to 1M sampling rate. The internal VBAT/3 channel allows the ADC to measure the VBAT/3 signal. ADC analog input channels can be configured in single-ended (range: 0.1V~1.1V) or differential mode (range: -1.0~1.0V). The ADC conversion supports a programmable channel sequence with a length between 1 to 16 in continuous, single, or discontinuous sampling modes. The conversion can be initiated by software or hardware configurable trigger sources. In addition, the ADC supports DMA request and interrupt generation.



Figure 16-1 ADC Diagram

## 16.2 ADC Input Mode

Channels can be configured to be either single-ended input or differential input through the differential mode selection register ([ADC\\_DIFFSEL](#)). External channels support both single-ended and differential modes, and internal channels only support single-ended mode. A fixed combination is required in differential mode, channel 0 and 1 is a differential group, channel 2 and 3 is a differential group, channel 4 and 5 is a differential group, and channel 6 and 7 is a

differential group. The width of the last data result of a conversion stored in the data buffer is 12-bit, where the MSB is a sign bit and the other 11 bits are data bits in differential input mode, but no sign bit is presented in single-ended mode, all 12 bits are data bits.

## 16.3 Sampling Channels

- **8 External Channels:** In single-ended mode, each channel is independent. In differential mode, every two channels form a group and cannot be split.
- **7 Internal Channels:** include DAC output, internal VRef, VBAT/3 (battery voltage), Vts (internal temperature sensor) and a channel dedicated for internal tests. The internal channels do not support differential mode.

Table 16-1 ADC Sampling Channels

| Sampling Channel No. | Signal        | Remark           |
|----------------------|---------------|------------------|
| 1                    | ADC_PAD_IN<0> | GPIO11           |
| 2                    | ADC_PAD_IN<1> | GPIO08           |
| 3                    | ADC_PAD_IN<2> | GPIO05           |
| 4                    | ADC_PAD_IN<3> | GPIO04           |
| 5                    | ADC_PAD_IN<4> | GPIO50           |
| 6                    | ADC_PAD_IN<5> | GPIO49           |
| 7                    | ADC_PAD_IN<6> | GPIO48           |
| 8                    | ADC_PAD_IN<7> | GPIO47           |
| 9                    | OPA0_ADC_OUT  | Internal channel |
| 10                   | OPA1_ADC_OUT  | Internal channel |
| 11                   | OPA2_ADC_OUT  | Internal channel |
| 12                   | DCTEST_OUT    | Internal channel |
| 13                   | TD_OUT_TEST   | Internal channel |
| 14                   | DAC_CORE_AOUT | Internal channel |
| 15                   | VBAT31        | Internal channel |

To generate VBAT31 signal, it is necessary to enable VBAT/3 voltage division circuit by setting the D\_VBAT\_DIV3\_EN bit in the RESV1 register of the analog part. This channel is nominally 1/3 of VBAT and it is 1/3.06 of VBAT actually.

## 16.4 Trigger Source

- **By software:** The conversion starts immediately when a rising edge on the START bit of ADC\_CR is detected.
- **By hardware:** The conversion is triggered by Timer or IO, containing 10 selectable trigger

sources with a configurable level.

The trigger mode is selected through the TRIG\_SEL bit in register [ADC\\_CFGR](#) and the external trigger source is selected through the EXT\_TRIG\_SEL bit in register [ADC\\_CFGR](#).

## 16.5 Low-power Operation

A new trigger request can only be received after the [ADC\\_DR](#) register has been read or the EOC flag is cleared, which can prevent overrun but might bypass some trigger requests.

## 16.6 ADC Overrun

Configure the ADC\_DR register to hold old data or update with new data when an overrun occurs.

## 16.7 Conversion Modes

The sampling mode is configured by the CONV\_MODE bit in register [ADC\\_CFGR](#):

The ADC conversion supports a programmable channel sequence with a length between 1 to 16, and the channels can be configured in single-ended or differential mode. In differential mode, only the P input of the channels in the sequence need to be configured. A channel can be selected more than once in the sequence, and thus the conversion of the same channel will be performed multiple times in each sequence. The conversion sequence is configured through the [ADC\\_SEQR0](#) and [ADC\\_SEQR1](#) registers, and every 4 bits configures one channel number. The two 32-bit registers have 64 bits in total, and thus up to 16 channels can be configured to be converted.

- **Continuous Mode:** When a software or hardware trigger event occurs, the ADC performs a sequence of conversions. After the conversions are completed, the ADC automatically re-starts and continuously performs the same sequence of conversions until a STOP command is issued by software.
- **Single Mode:** When a software or hardware trigger event occurs, the ADC performs a single sequence of conversions and then stops automatically after the conversions are completed.
- **Discontinuous Mode:** Each conversion defined in the sequence requires a hardware or software trigger event. When a sequence of conversions is completed, a new trigger event restarts the conversion of the first channel defined in the sequence. While in continuous and single modes, the complete sequence is converted upon a single trigger event.

## 16.8 Voltage Reference

The reference voltage is configured through the D\_ADC\_SEL\_VREF bit in the RST register of the analog part. The external or internal reference voltage is configured by clearing or setting this bit, and the default value is 1.

- **Internal Voltage Reference:** VRef, 1.2V
- **External Voltage Reference:** VREFP/3, VREFP $\leq$ 3.6V. VREFP is connected to VDDA in the ASR6601CB/CBR (48-pin) chip.

## 16.9 Data Buffer

For the 12-bit data buffer, the most significant bit is the sign bit in differential input mode.

| ADC Value      | Definition (differential) | Definition (single-ended)        |
|----------------|---------------------------|----------------------------------|
| 1111_1111_1111 | +Vref <sup>(1)</sup>      | +Vref <sup>(1)</sup>             |
| ...            | ...                       | ...                              |
| ...            | ...                       | ...                              |
| ...            | ...                       | ...                              |
| ...            | ...                       | ...                              |
| ...            | ...                       | ...                              |
| 1000_0000_0001 | +Vref/2048 <sup>(1)</sup> | +Vref/2+Vref/4096 <sup>(1)</sup> |
| 1000_0000_0000 | 0                         | +Vref/2 <sup>(1)</sup>           |
| 0111_1111_1111 | -Vref/2048 <sup>(1)</sup> | +Vref/2-Vref/4096 <sup>(1)</sup> |
| ...            | ...                       | ...                              |
| ...            | ...                       | ...                              |
| ...            | ...                       | ...                              |
| ...            | ...                       | ...                              |
| ...            | ...                       | ...                              |
| 0000_0000_0000 | -Vref <sup>(1)</sup>      | 0                                |

<sup>(1)</sup> This value should be calibrated by software to correct error on the ADC hardware.

The measure range in differential mode is -1.0~1.0V, and the measure range in single-ended mode is 0.1~1.1V. In order to correct the error on the ADC hardware, ASR6601 is calibrated before leaving the factory. The calibration data (Offset and Gain) are stored in Flash. The user needs to convert the data read from register [ADC\\_DR](#) to get the final AD value. The formula is as follows:

$$V = (V_{out} - Offset) / Gain$$

where **Vout** is the value read from the data buffer.

## 16.10 DMA Request

When the 12-bit data buffer is full, the DMA request is generated if the DMA\_EN bit in register ADC\_CFGR is set. And the DMA request is disabled by writing '0' to the DMA\_EN bit.

## 16.11 Interrupts

The interrupt sources include the end of conversion (EOC), end of a sequence of conversions (EOS), and a data overrun (OVERRUN). The interrupts are enabled through register [ADC\\_IER](#), and the interrupt status is inquired through the [ADC\\_ISR](#) register.

## 16.12 Wakeup

The MCU wakes up from the Sleep mode if an interrupt or event is generated.

## 16.13 ADC Clock and Reset

The ADC bus reset and the ADC clock reset are independent. The ADC module supports the APB bus clock. The ADC interface clock source can be one of the following sources (divided or not): sys\_clk, apb\_x\_pclk, pll\_clk or rco48m\_clk.

## 16.14 ADC Registers

Base Address: 0x40017000

Table 16-2 ADC Register Summary

| Register Name | Address Offset | Description                              |
|---------------|----------------|------------------------------------------|
| ADC_CR        | 0x00           | ADC Control Register                     |
| ADC_CFGR      | 0x04           | ADC Configuration Register               |
| ADC_SEQR0     | 0x08           | ADC Sequence Register 0                  |
| ADC_SEQR1     | 0x0C           | ADC Sequence Register 1                  |
| ADC_DIFFSEL   | 0x10           | ADC Differential Mode Selection Register |
| ADC_ISR       | 0x14           | ADC Interrupt and Status Register        |
| ADC_IER       | 0x18           | ADC Interrupt Enable Register            |
| ADC_DR        | 0x1C           | ADC Data Register                        |

### 16.14.1 ADC\_CR

Address Offset: 0x00

Reset Value: 0x00000000

| 31-4     | 3     | 2     | 1    | 0     |
|----------|-------|-------|------|-------|
| RESERVED | STOP  | START | DIS  | EN    |
| r-0h     | rw-0h | rw-0h | w-0h | rw-0h |

**Bits 31-4 RESERVED:** Must be kept, and cannot be modified.

**Bit 3 STOP:** ADC stop conversion command

- 0: A write of 0 has no effect.
- 1: Write 1 to stop the ADC. Read 1 means that the STOP command is under execution.

**Notice:**

1. Software writes 1 to this bit to stop and discard an ongoing conversion, thus the conversion sequence is reset; this bit is cleared automatically by hardware.
2. After the START bit is cleared, software must wait for 3 ADCCLK ticks before reconfigure the START bit; or wait for 1 CLK\_DIV (set in register [ADC\\_CFGR](#)) tick to set the DIS bit to disable the ADC.
3. Software is allowed to set this bit only when START=1 and STOP=0.
4. Before setting the STOP bit, it is recommended to disable the trigger source first, or keep the trigger level in an invalid state.

**Bit 2 START:** ADC start conversion command

- 0: A write of 0 has no effect.
- 1: Write 1 to start the ADC. Read 1 means that the ADC conversion is being performed.

This bit is set by software to start the ADC conversion. Software is allowed to set this bit only when EN=1 and DIS=0. Whether an ADC conversion starts immediately (software trigger mode) or won't start until a hardware trigger event occurs depends on the TRIG\_SEL[18:17] configuration bits in register [ADC\\_CFGR](#).

This bit is automatically cleared by hardware in the following the following circumstances:

- In single conversion mode, if software trigger is selected (TRIG\_SEL=00 in register [ADC\\_CFGR](#)), the START bit is cleared when the EOS flag in register [ADC\\_ISR](#) is set.
- In discontinuous conversion mode, if software trigger is selected, the START bit is cleared when the EOC flag in register [ADC\\_ISR](#) is set.
- In any case, after the execution of the STOP command, the START and STOP bits are cleared by hardware at the same time.

**Bit 1 DIS:** ADC disable

- 0: A write of 0 has no effect.
- 1: Write 1 to disable the ADC

Software is allowed to set this bit only when EN=1 and START=0 (no conversion is ongoing).

**Bit 0 EN:** ADC enable

- 0: A write of 0 has no effect.
- 1: Write 1 to enable the ADC. Read 1 means that the ADC is enabled.

This bit is set by software to enable the ADC module. The software is allowed to set this bit only when all

bits of register *ADC\_CR* equal 0. Reading this bit reflects whether the ADC is enabled or not. The software must wait at least 100us for the ADC analog circuit to stabilize after initialization before it enables the ADC conversion.

### 16.14.2 ADC\_CFGR

Address Offset: 0x04

Reset Value: 0x00000002

| 31-24           | 23                | 22        | 21-20         | 19           | 18-17    |
|-----------------|-------------------|-----------|---------------|--------------|----------|
| RESERVED        | RESERVED          | WAIT_MODE | CONV_MODE     | OVERRUN_MODE | TRIG_SEL |
| r-0h            | r-0h              | r-0h      | r-0h          | r-0h         | rw-0h    |
| 16              | 15-13             | 12        | 11-8          | 7-0          |          |
| EXT_TRIG_SEL[3] | EXT_TRIG_SEL[2:0] | DMA_EN    | CLK_DIV[11:8] | CLK_DIV[7:0] |          |
| rw-0h           | rw-0h             | rw-0h     | rw-0h         | rw-0h        | rw-2h    |

**Bits 31-23 RESERVED:** Must be kept, and cannot be modified.

**Bit 22 WAIT\_MODE:** Wait conversion mode

- 0: wait conversion mode disabled
- 1: wait conversion mode enabled

Wait for the conversion mode, that is, a new trigger request can only be received after register *ADC\_DR* has been read or the EOC flag (in *ADC\_ISR*) is cleared, which can prevent overrun but may bypass some trigger requests.

Software is allowed to write this bit only when START=0 (in register *ADC\_CR*).

**Bits 21-20 CONV\_MODE:** ADC conversion mode selection

- 00: single conversion mode
- 01: continuous conversion mode
- 1x: discontinuous conversion mode

Software is allowed to write this bit only when START=0 (in register *ADC\_CR*).

**Notice:**

1. In single conversion mode, when a software or hardware trigger event occurs, the ADC performs a single sequence of conversions (set by *ADC\_SEQR0/1*). After the conversions are completed, the ADC stops until a new trigger occurs.
2. In continuous conversion mode, when a software or hardware trigger event occurs, the ADC performs a sequence of conversions (set by *ADC\_SEQR0/1*). After the conversions are completed, the ADC automatically re-starts and continuously performs the same sequence of conversions until a STOP command is issued by software.
3. In discontinuous conversion mode, each conversion defined in the sequence (set by *ADC\_SEQR0/1*) requires a hardware or software trigger event. When a sequence of conversions is completed, a new trigger event restarts the conversion of the first channel defined in the sequence.

**Bit 19 OVERRUN\_MODE:** Overrun management mode

- 0: the old data in the *ADC\_DR* register is hold when an overrun is occurred.
- 1: the *ADC\_DR* register is overwritten with the newly converted data when an overrun is occurred.

Software is allowed to write this bit only when START=0 (in register [ADC\\_CR](#)).

#### Bits 18-17 TRIG\_SEL: Trigger mode and polarity selection

- 00: software trigger. The conversion starts immediately when a rising edge on the START bit of ADC\_CR is detected.
- 01: hardware trigger detection on the rising edge
- 10: hardware trigger detection on the falling edge
- 11: hardware trigger detection on both edges

Software is allowed to write this bit only when START=0 (in register [ADC\\_CR](#)).

When a hardware trigger is selected, after the START bit is configured, software must wait for 3 ADCCLK ticks before receiving the trigger signal.

#### Bits 16-13 EXT\_TRIG\_SEL: External trigger selection for the start of ADC conversion

- 0000~0100: Reserved
- 0101: GPIO47
- 0110: GPIO31
- 0111: GPIO19
- 1000: GPIO10
- 1001: GPTIM1\_TRGO
- 1010: GPTIM0\_CH2\_OUT
- 1011: GPTIM3\_TRGO
- 1100: GPTIM0\_CH3\_OUT
- 1101: GPTIM0\_TRGO
- 1110: GPTIM2\_CH1\_OUT
- 1111: Reserved

##### **Notice:**

- (1) Software is allowed to write this bit only when START=0 (in register [ADC\\_CR](#)).
- (2) If the TRGO signal of GPTIMx is used as the trigger source for the ADC conversion, the MMS bit in the GPTIM0\_CR2 and GPTIM1\_CR2 registers can only be configured as 0b100 (OC0REF), 0b101 (OC1REF), 0b110 (OC2REF) or 0b111 (OC3REF). For GPTIM2\_CR2 and GPTIM3\_CR2, only 0b100 (OC0REF) or 0b101 (OC1REF) can be selected.
- (3) To achieve timed trigger or periodic trigger, you need to configure the selected channel as output mode, select the corresponding output mode, and configure the corresponding GPTIMx\_ARR and GPTIMx\_CCRx according to the required time.

#### Bit 12 DMA\_EN: DMA enable

- 0: DMA disabled
- 1: DMA enabled

#### Bits 11-0 CLK\_DIV: ADCCLK prescale

- 000: not divided
- 001: not divided
- n: ADC\_IP\_CLK=ADCCLK/n, 50% duty cycle

##### **Notice:**

- (1) This bit can only be configured when all bits of the [ADC\\_CR](#) register are 0; the clock source selection for ADCCLK is configured in the [RCC\\_CR2](#) register.

(2) The clock division and clock source selection need to consider the data readout speed. The ADC samples every 16 ADC clock cycles, if a high-speed ADC clock source is chosen, the converted data cannot be read in time by the software or the DMA, which may cause overflow.

### 16.14.3 ADC\_SEQR0

Address Offset: 0x08

Reset Value: 0x00000000

**Notice:** Software is allowed to configure this register only when START=0 and EN=0 (in [ADC\\_CR](#)).

| 31-28 | 27-24 | 23-20 | 19-16 | 15-12 | 11-8  | 7-4   | 3-0   |
|-------|-------|-------|-------|-------|-------|-------|-------|
| SEL7  | SEL6  | SEL5  | SEL4  | SEL3  | SEL2  | SEL1  | SEL0  |
| rw-0h |

**Bits 31-28 SEL7:** Select the channel number from 1 to 15 as the 7th in the conversion sequence

If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

**Bits 27-24 SEL6:** Select the channel number from 1 to 15 as the 6th in the conversion sequence

If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

**Bits 23-20 SEL5:** Select the channel number from 1 to 15 as the 5th in the conversion sequence

If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

**Bits 19-16 SEL4:** Select the channel number from 1 to 15 as the 4th in the conversion sequence

If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

**Bits 15-12 SEL3:** Select the channel number from 1 to 15 as the 3th in the conversion sequence

If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

#### **Bits 11-8 SEL2:** Select the channel number from 1 to 15 as the 2nd in the conversion sequence

If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

#### **Bits 7-4 SEL1:** Select the channel number from 1 to 15 as the 1st in the conversion sequence

If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

#### **Bits 3-0 SEL0:** Select the channel number from 1 to 15 as the 0th in the conversion sequence

If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

### 16.14.4 ADC\_SEQR1

Address Offset: 0x0C

Reset Value: 0x00000000

**Notice:** Software is allowed to configure this register only when START=0 and EN=0 (in [ADC\\_CR](#)).

| 31-28 | 27-24 | 23-20 | 19-16 | 15-12 | 11-8  | 7-4   | 3-0   |
|-------|-------|-------|-------|-------|-------|-------|-------|
| SEL15 | SEL14 | SEL13 | SEL12 | SEL11 | SEL10 | SEL9  | SEL8  |
| rw-0h |

#### **Bits 31-28 SEL15:** Select the channel number from 1 to 15 as the 15th in the conversion sequence

If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software,

and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

**Bits 27-24 SEL14:** Select the channel number from 1 to 15 as the 14th in the conversion sequence  
If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

**Bits 23-20 SEL13:** Select the channel number from 1 to 15 as the 13th in the conversion sequence  
If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

**Bits 19-16 SEL12:** Select the channel number from 1 to 15 as the 12th in the conversion sequence  
If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

**Bits 15-12 SEL11:** Select the channel number from 1 to 15 as the 11th in the conversion sequence  
If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

**Bits 11-8 SEL10:** Select the channel number from 1 to 15 as the 10th in the conversion sequence  
If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

**Bits 7-4 SEL9:** Select the channel number from 1 to 15 as the 9th in the conversion sequence

If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software,

and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

**Bits 3-0 SEL8:** Select the channel number from 1 to 15 as the 8th in the conversion sequence

If 0 rather than 1 to 15 is configured, it marks the end of the sequence and itself cannot be converted. If the channel numbers selected by bits SELx are the same, the conversion of the same channel in a sequence will be performed multiple times.

In differential input mode, only the channel number of the positive input needs to be configured by software, and the channel number of the negative input is selected automatically by hardware according to register [ADC\\_DIFFSEL](#).

#### 16.14.5 ADC\_DIFFSEL

Address Offset: 0x10

Reset Value: 0x00000000

**Notice:** Software is allowed to configure this register only when START=0 and EN=0 (in [ADC\\_CR](#)).

| 31-16    | 15-9 | 8-1   | 0        |
|----------|------|-------|----------|
| RESERVED | SEL1 | SEL0  | RESERVED |
| r-0h     | r-0h | rw-0h | r-0h     |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-9 SEL1:** Channels 9 to 15 are internal channels

These channels can only be configured in single-ended mode. These bits are read-only.

**Bits 8-1 SEL0:** Differential or single-ended mode selection for Channels 1 to 8

Each bit controls a channel with the same number as it:

- 0: channel x is configured in single-ended mode
- 1: channel x is configured in differential mode

In Differential mode, a group consists of two adjacent external channels, such as Group 1 consisting of Channel 2 and Channel 3, so the corresponding two control bits of this register should be set to 1 at the same time.

**Bit 0 RESERVED:** Must be kept, and cannot be modified.

### 16.14.6 ADC\_ISR

Address Offset: 0x14

Reset Value: 0x00000000

**Notice:** It is recommended to clear all bits of this register before software sets the START bit (in register [ADC\\_CR](#)).

| 31-3     | 2       | 1       | 0       |
|----------|---------|---------|---------|
| RESERVED | OVERRUN | EOS     | EOC     |
| r-0h     | rw1c-0h | rw1c-0h | rw1c-0h |

**Bits 31-3 RESERVED:** Must be kept, and cannot be modified.

**Bit 2 OVERRUN:** ADC conversion overrun flag

- 0: no overrun occurred
- 1: overrun has occurred

This bit is set by hardware when an overrun occurs and a new conversion is completed when the EOC flag was already set, but the [ADC\\_DR](#) register has not been read or software writing 1 to clear this bit was not configured.

It is cleared by software writing 1 to it.

**Bit 1 EOS:** End of sequence of conversions flag

- 0: conversion sequence is not complete
- 1: conversion sequence is complete

This bit is set by hardware when a sequence of conversions (set by [ADC\\_SEQR0/1](#)) is completed.

It is cleared by software writing 1 to it.

**Bit 0 EOC:** End of conversion flag

- 0: channel conversion is not completed
- 1: channel conversion is completed

This flag is set by hardware at the end of each conversion of a channel (when the newly converted data is stored in the [ADC\\_DR](#) register).

It is cleared by software writing 1 to it or by reading the [ADC\\_DR](#) register.

### 16.14.7 ADC\_IER

Address Offset: 0x18

Reset Value: 0x00000000

| 31-3     | 2              | 1          | 0          |
|----------|----------------|------------|------------|
| RESERVED | OVERRUN_INT_EN | EOS_INT_EN | EOC_INT_EN |
| r-0h     | rw-0h          | rw-0h      | rw-0h      |

**Bits 31-3 RESERVED:** Must be kept, and cannot be modified.

**Bit 2 OVERRUN\_INT\_EN:** ADC conversion overrun interrupt enable

- 0: overrun interrupt disabled
- 1: overrun interrupt enabled

**Bit 1 EOS\_INT\_EN:** End of conversion sequence interrupt enable

- 0: end of conversion sequence interrupt disabled
- 1: end of conversion sequence interrupt enabled

**Bit 0 EOC\_INT\_EN:** End of conversion interrupt enable

- 0: end of conversion interrupt disabled
- 1: end of conversion interrupt enabled

### 16.14.8 ADC\_DR

Address Offset: 0x1C

Reset Value: 0x00000000

| 31-12    | 11-0 |
|----------|------|
| RESERVED | DATA |
| r-0h     | r-0h |

**Bits 31-12 RESERVED:** Must be kept, and cannot be modified.

**Bits 11-0 DATA:** ADC converted data. In differential mode, bit[11] is the sign bit.

# 17.

# RTC

## 17.1 Introduction

The Real-time Clock is an independent BCD timer/counter. It has two 32-bit registers, which contain the seconds, minutes, hours (12-hour or 24-hour format), day of week, date of month, month, and year, expressed in binary coded decimal format (BCD). In addition, there is a 32-bit register used to indicate sub-seconds value. The RTC supports operation under low-power mode.

## 17.2 Main Features

The main features of RTC are as follows:

1. Calendar with the seconds, minutes, hours (12-hour or 24-hour format), day of week, date of month, month, and year, expressed in binary coded decimal format (BCD)
2. Support RTC frequency calibration with a resolution of about 0.5 ppm with a range from -1024 ppm to +1024 ppm.
3. Support wake-up from low-power mode
4. Tamper/wakeup IO detection is activated at high or low level with configurable filter
5. 32-bit counter for periodic count
6. 2 Alarms support calendar matching
7. Retention SRAM is cleared once tamper/wakeup alarm occurs
8. Internal signal is output by GPIO, including Alarm0 pulse, Alarm1 pulse, periodic counter pulse and second signal
9. Support reading calendar values
10. Support reading the sub-seconds value
11. Support reading the period counting value
12. Support interrupt signal generation

## 17.3 Interface Clock

Both XO32K and RCO32K can be RTC clock source and XO32K accuracy is higher than RCO32K.

See Chapter [RCC](#) for clock configuration details.

## 17.4 Calendar

The RTC calendar time and date are accessed through two types of registers, which are the asynchronous registers and the synchronous registers.

- *RTC\_SYNCDATA* and *RTC\_SYNCDATA\_H* are **asynchronous registers**.  
*RTC\_SYNCDATA* indicates the seconds, minutes and hours;  
*RTC\_SYNCDATA\_H* indicates the day of week, date of month, month and year.
- *RTC\_CALENDAR\_R* and *RTC\_CALENDAR\_R\_H* are **synchronous registers**.  
*RTC\_CALENDAR\_R* indicates the seconds, minutes and hours;  
*RTC\_CALENDAR\_R\_H* indicates the day of week, date of month, month and year.

### 17.4.1 Reading the Calendar

This document only introduces reading the RTC calendar values by **synchronous registers**. The synchronous registers should be read several times with the same result obtained to ensure that the data is correct. Follow below steps to read the calendar:

- (1) Read the *RTC\_SUB\_SECOND* register to get the subsecond\_count value.
- (2) Read the value of the *RTC\_CALENDAR\_R* register for two consecutive times, if the values read are different, then continue reading until the values read for two consecutive times are the same.
- (3) Read the value of the *RTC\_CALENDAR\_R\_H* register for two consecutive times, if the values read are different, then continue reading until the values read for two consecutive times are the same.
- (4) Read the value of the *RTC\_SUB\_SECOND* register again, if the value is not equal to the value in Step 1, then software will restart reading the calendar from Step 1.
- (5) When the subseconds downcounter reaches 0, the value of the *RTC\_CALENDAR\_R* or *RTC\_CALENDAR\_R\_H* register may have no change, so if the subsecond\_count value is 0, then the software will restart reading the calendar from Step 1; if subsecond\_count value is not 0, then it indicates that the complete calendar time has been read correctly.

For converting subsecond\_count to sub-second (unit: microsecond), first obtain the frequency of the RTC interface clock (fRTCCLK) through the RTC\_CLK\_SEL bit in the *RCC\_CR1* register, then use the formula below to calculate the sub-second:

$$\text{sub-second} = (1000000 * \text{SUBSECOND\_COUNT}) / \text{fRTCCLK}$$

### 17.4.2 Setting the Calendar

The *RTC\_CALENDAR\_H* and *RTC\_CALENDAR* registers are used to set the calendar. *RTC\_CALENDAR\_H* sets the year, month, date of month and day of week. *RTC\_CALENDAR* sets the hours, minutes and seconds. Since the *RTC\_SUB\_SECOND* register is read-only, the sub-second is read-only. Follow below steps to set the calendar:

- (1) Read the *RTC\_SR1* register, and wait for all WRITE\_XXX\_DONE bits and the SECOND\_SR bit (bits[11:1]) to be set. After that, writing to the *RTC\_CALENDAR\_H* and *RTC\_CALENDAR* registers is allowed.
- (2) Configure the year, month, date of month and day of week in the *RTC\_CALENDAR\_H* register.
- (3) Read the *RTC\_SR1* register, and wait for all WRITE\_XXX\_DONE bits and the SECOND\_SR bit (bits[11:1]) to be set. After that, writing to the *RTC\_CALENDAR\_H* and *RTC\_CALENDAR* registers is allowed.
- (4) Configure the hours, minutes and seconds in the *RTC\_CALENDAR* register.

## 17.5 RTC PPM Calibration

The RTC frequency can be calibrated with a resolution of about 0.5 ppm with a range from -1024 ppm to +1024 ppm. Configure register *RTC\_PPMADJUST* to set the adjustment value. When the value is set to 0x7FFF, it means to adjust 0 ppm, that is, no adjustment is required. Follow below steps to conduct the PPM calibration:

- (1) Read the *RTC\_SR1* register, and wait for all WRITE\_XXX\_DONE bits and the SECOND\_SR bit (bits[11:1]) to be set. After that, writing to the *RTC\_PPMADJUST* register is allowed.
- (2) Configure the adjustment value in the *RTC\_PPMADJUST* register.

## 17.6 Wake-up from Low-power Mode

RTC can wake up the MCU from Sleep, Stop or Standby mode through an interrupt or wakeup signal.

**Table 17-1 RTC Wake-up Source**

| Mode                    | Description                                                                                                  |
|-------------------------|--------------------------------------------------------------------------------------------------------------|
| Sleep                   | RTC interrupts can wake up the device from the Sleep mode.                                                   |
| Stop0/Stop1/Stop2/Stop3 | RTC wakeup, RTC tamper event, RTC alarm, and periodic count signal can wake up the device from Stop mode.    |
| Standby                 | RTC wakeup, RTC tamper event, RTC alarm, and periodic count signal can wake up the device from Standby mode. |

Enable the wakeup/tamper IO, RTC alarm and periodic count signal for wake-up through the corresponding bit in register *RTC\_CR*:

**Table 17-2 Bits to Enable Wake-up Signals**

| Function   | Bits in Register RTC_CR |
|------------|-------------------------|
| WAKEUP_IO0 | WAKEUP0_WKEN1           |
| WAKEUP_IO1 | WAKEUP1_WKEN1           |
| WAKEUP_IO2 | WAKEUP2_WKEN1           |
| TAMPER     | TAMPER_WKEN1            |
| ALARM0     | RTC_ALARM0_WKEN         |
| ALARM1     | RTC_ALARM1_WKEN         |
| CYC        | CYC_WKEN                |

## 17.7 Tamper/Wakeup IO Detection

The tamper/wakeup IO input events can be configured for edge detection or level detection with filtering. Edge detection means to detect the rising or falling edge of GPIO, while level detection means to detect the high or low level of GPIO. If GPIO is active at high level, a tamper detection event is generated when a high level is detected on GPIO input; if GPIO is active at low level, a tamper detection event is generated when a high level is detected on GPIO input. When an input event is detected, the following actions can be conducted:

- Erase the retention SRAM
- Generate an interrupt, capable to wakeup from Sleep mode
- Generate a wakeup signal (WAKEUP\_IO0/WAKEUP\_IO1/WAKEUP\_IO2/TAMPER), capable to wakeup from Stop and Standby modes

### 17.7.1 Tamper/Wakeup Initialization and Configuration

Before Tamper/Wakeup initialization, the corresponding GPIO should be configured as tamper/wakeup function. In addition, if it is level detection, GPIO should be configured with pull-up or pull-down. If GPIO is active at high level, pull down GPIO; if GPIO is active at low level, pull up GPIO.

Taking Tamper as an example, the initialization and configuration process is as follows:

- (1) If it is level detection, set the filter length by configuring bit TAMPER\_FILTER\_CFG in the [RTC\\_CR](#) register, configure the active level by bit TAMPER\_LEVEL\_SEL, and then enable the tamper pin level wakeup by the TAMPER\_WKEN0 bit. **If it is edge detection, ignore this step.**
- (2) Configure bit TAMPER\_WKEN1 in register [RTC\\_CR](#) to enable TAMPER\_SR to wake up the MCU from Stop or Standby mode. **If no such need, ignore this step.**
- (3) Set the TAMPER\_EN bit in the [RTC\\_CR](#) register to enable tamper detection.

### 17.7.2 Erase Operation on Retention SRAM

When the tamper/wakeup IO input event is detected, the hardware can erase the retention SRAM. This is configured by setting the corresponding bit of RTC\_RET\_SRAM\_ERASE\_EN in register [RTC\\_CR2](#). Bit0 corresponds to wakeup IO0, bit1 corresponds to wakeup IO1, bit2 corresponds to wakeup IO2, and bit3 corresponds to tamper function.

## 17.8 Periodic Counter

The periodic counter generates interrupts or wakeup events at regular intervals. The regular interval is set according to the configured CYC\_MAX\_VALUE in the [RTC\\_CYC\\_MAX\\_VALUE](#) register. Obtain the RTC interface clock frequency (fRTCCLK) through the RTC\_CLK\_SEL bit in the [RCC\\_CR1](#) register, and then use the formula below to calculate the regular interval (in microseconds):

$$\text{Regular interval} = (1000000 * \text{CYC\_MAX\_VALUE}) / f\text{RTCCLK}$$

During the periodic count, the number of elapsed cycles is read from the CYC\_CNT\_VALUE bits in the [RTC\\_CYC\\_CNT\\_VALUE](#) register. On this basis, the interval (in microseconds) from the start of the ongoing counting to the current moment can be calculated by the formula below:

$$\text{Interval} = (1000000 * \text{CYC\_CNT\_VALUE}) / f\text{RTCCLK}$$

Follow below steps to configure the periodic count:

- (1) When the regular interval is known, calculate the CYC\_MAX\_VALUE according to the above formula, and configure this value to register [RTC\\_CYC\\_MAX\\_VALUE](#).
- (2) Configure bit CYC\_WKEN in register [RTC\\_CR](#) to enable CYC\_SR to wake up CPU from Stop or Standby mode. **If no such need, ignore this step.**
- (3) Set bit CYC\_START\_COUNTER in register [RTC\\_CR](#) to enable periodic counter.

## 17.9 RTC Alarms

RTC provides two alarms: Alarm 0 and Alarm 1. Both support mask selection and matching with calendar. With Mask configuration, each calendar field (sub-seconds, seconds, minutes, hours, date or day of week) can be independently selected to match the values programmed in the alarm registers. Note that for the date and the day of week, we can only choose one of them for the match.

If bit ALARMx\_WEEK\_SEL (Alarmx means Alarm 0 or Alarm 1, similarly hereinafter) is 0 in the register [RTC\\_ALARMx](#), the date is selected for the match; if bit ALARMx\_WEEK\_SEL is 1, the day of week is selected for the match.

If the sub-seconds and seconds are not involved but the minutes are involved in Alarmx

comparison, when **Alarmx** values match with those of the RTC Calendar, 60 interrupts or/and 60 wake-up events are generated at a one-second interval in one minute. If the sub-seconds, seconds, and minutes are not involved but the hours are involved in **Alarmx** comparison, when **Alarmx** values match with those of the RTC Calendar, 3600 interrupts or/and 3600 wake-up events are generated at a one-second interval in one hour. Whether the interrupts or/and wake-up events are generated depends on whether the alarm interrupt or/and the alarm wake-up is enabled.

The seconds, minutes, hours, date or day mask are configured through the **ALARMx\_MASK** bit field in the *RTC\_ALARMx* register, and the sub-seconds mask is configured through the **RTC\_ALARMx\_SUB\_MASK** bit field in the *RTC\_ALARMx\_SUB* register. The sub-seconds value is set by the **RTC\_ALARMx\_SUB\_VALUE** bit field in the *RTC\_ALARMx\_SUB* register. The **RTC\_ALARMx\_SUB\_VALUE** indicates RTC clock cycles, and the formula for converting clock cycles to time is the same as that in periodic count.

Take Alarm 0 as an example to describe the alarm configuration process as follows:

- (1) Set the calendar.
- (2) Configure the Alarm 0 values (including the hours, minutes, seconds, date or day) by the **ALARM0\_VALUE** bit field in the *RTC\_ALARM0* register.
- (3) Configure the sub-seconds value for Alarm 0 through the **RTC\_ALARM0\_SUB\_VALUE** bit field in the *RTC\_ALARM0\_SUB* register.
- (4) Configure the seconds, minutes, hours, date or day mask for Alarm 0.
- (5) Configure the sub-seconds mask for Alarm 0.
- (6) Whether the **ALARM0\_SR** interrupt or **ALARM0\_SR** wake-up is enabled depends on the specific needs. They are configured through the **ALARM0\_SR\_INT\_EN** bit in register *RTC\_CR1* and the **RTC\_ALARM0\_WKEN** bit in register *RTC\_CR*.
- (7) Enable the Alarm 0 through the **ALARM0\_EN** bit in register *RTC\_ALARM0*.
- (8) Enable the calendar by setting the **RTC\_START\_RTC** bit in register *RTC\_CR*.

## 17.10 Internal Signal Output through IO

The internal signals that can be output through IO include Alarm 0 pulse, Alarm 1 pulse, periodic counter pulse, and the second signal. The alarm pulse and periodic counter pulse are pulses with a width of one RTC clock cycle. The Alarm pulse is output when the programmed values match with the Calendar. The periodic counter pulse is output every time the programmed count value is reached. The second signal is a square wave with a duty cycle of 50% and the frequency is 1 Hz. The RTC IO can output inverted levels. When the **RTC\_OUT\_POL** bit of the *RTC\_CR2* register is 0, it means that the level is non-inverted, and when this bit is 1, it means that the level is inverted. Configure the **RTC\_OUT\_SEL** bit of the *RTC\_CR2* register to select the RTC IO output signal.

## 17.11 RTC Interrupts

Table 17-3 RTC Interrupts

| Interrupt                 | Description                                                              |
|---------------------------|--------------------------------------------------------------------------|
| Alarm 0 interrupt         | Interrupt is generated when the interval set by Alarm 0 is reached.      |
| Alarm 1 interrupt         | Interrupt is generated when the interval set by Alarm 1 is reached.      |
| Periodic wakeup interrupt | Interrupt is generated at regular intervals.                             |
| Tamper interrupt          | Interrupt is generated when an input event is detected by tamper IO.     |
| Wakeup IO0 interrupt      | Interrupt is generated when an input event is detected by Wakeup IO0 IO. |
| Wakeup IO1 interrupt      | Interrupt is generated when an input event is detected by Wakeup IO1 IO. |
| Wakeup IO2 interrupt      | Interrupt is generated when an input event is detected by Wakeup IO2 IO. |
| Second signal interrupt   | Interrupt is generated by the second signal every second.                |

The above interrupts are enabled by configuring the [RTC\\_CR1](#) register. The second signal interrupt status is indicated by the SECOND\_SR bit in the [RTC\\_SR1](#) register, and the other interrupts' status is indicated by the [RTC\\_SR](#) register.

## 17.12 RTC Registers

Base Address: 0x4000E000

**Table 17-4 RTC Register Summary**

| Register Name     | Address Offset | Description                                                            |
|-------------------|----------------|------------------------------------------------------------------------|
| RTC_CR            | 0x00           | RTC Control Register 1                                                 |
| RTC_ALARM0        | 0x04           | RTC Alarm 0 Register                                                   |
| RTC_ALARM1        | 0x08           | RTC Alarm 1 Register                                                   |
| RTC_PPMADJUST     | 0x0c           | RTC PPMADJUST Register                                                 |
| RTC_CALENDAR      | 0x10           | RTC Calendar Configuration Register<br>(second, minute, hour)          |
| RTC_CALENDAR_H    | 0x14           | RTC Calendar Configuration Register<br>(date/day of week, month, year) |
| RTC_CYC_MAX_VALUE | 0x18           | RTC Periodic Counter Value Configuration Register                      |
| RTC_SR            | 0x1c           | RTC Status Register                                                    |
| RTC_ASYNCDATA     | 0x20           | RTC Calendar ASYNCDATA Register<br>(second, minute, hour)              |
| RTC_ASYNCDATA_H   | 0x24           | RTC Calendar ASYNCDATA Register<br>(date/day of week, month, year)     |
| RTC_CR1           | 0x28           | RTC Control register 1 (interrupt enable)                              |
| RTC_SR1           | 0x2c           | RTC Status Register 1                                                  |
| RTC_CR2           | 0x30           | RTC Control register 2                                                 |
| RTC_SUB_SECOND    | 0x34           | RTC Sub-second Register                                                |
| RTC_CYC_CNT_VALUE | 0x38           | RTC Periodic Counter Value Register (read-only)                        |
| RTC_ALARM0_SUB    | 0x3c           | RTC Alarm 0 Sub-second Register                                        |
| RTC_ALARM1_SUB    | 0x40           | RTC Alarm 1 Sub-second Register                                        |
| RTC_CALENDAR_R    | 0x44           | RTC Calendar SYNCDATA Register<br>(second, minute, hour)               |
| RTC_CALENDAR_R_H  | 0x48           | RTC Calendar SYNCDATA Register<br>(date/day of week, month, year)      |

### 17.12.1 RTC\_CR

Address Offset: 0x00

Reset Value: 0x00000000

| 31-29                  | 28                | 27                    | 26                  | 25                |
|------------------------|-------------------|-----------------------|---------------------|-------------------|
| RESERVED               | RTC_START_RT<br>C | RTC_ALARM0_W<br>KEN   | RTC_ALARM1_W<br>KEN | CYC_WKEN          |
| r-0h                   | rw-0h             | rw-0h                 | rw-0h               | rw-0h             |
| <b>24</b>              | <b>23</b>         | <b>22</b>             | <b>21</b>           | <b>20</b>         |
| CYC_START_CO<br>UNTER  | TAMPER_EN         | TAMPER_LEVEL_<br>SEL  | TAMPER_WKEN0        | TAMPER_WKEN1      |
| rw-0h                  | rw-0h             | rw-0h                 | rw-0h               | rw-0h             |
| <b>19-18</b>           | <b>17</b>         | <b>16</b>             | <b>15</b>           | <b>14</b>         |
| TAMPER_FILTER<br>_CFG  | WAKEUP0_EN        | WAKEUP0_LEVE<br>L_SEL | WAKEUP0_WKE<br>N0   | WAKEUP0_WKE<br>N1 |
| rw-0h                  | rw-0h             | rw-0h                 | rw-0h               | rw-0h             |
| <b>13-12</b>           | <b>11</b>         | <b>10</b>             | <b>9</b>            | <b>8</b>          |
| WAKEUP0_FILTE<br>R_CFG | WAKEUP1_EN        | WAKEUP1_LEVE<br>L_SEL | WAKEUP1_WKE<br>N0   | WAKEUP1_WKE<br>N1 |
| rw-0h                  | rw-0h             | rw-0h                 | rw-0h               | rw-0h             |
| <b>7-6</b>             | <b>5</b>          | <b>4</b>              | <b>3</b>            | <b>2</b>          |
| WAKEUP1_FI<br>LTER_CFG | WAKEUP2_E<br>N    | WAKEUP2_LE<br>VEL_SEL | WAKEUP2_W<br>KEN0   | WAKEUP2_W<br>KEN1 |
| rw-0h                  | rw-0h             | rw-0h                 | rw-0h               | rw-0h             |
| <b>1-0</b>             |                   |                       |                     |                   |

**Bits 31-29 RESERVED:** Reserved.

**Bit 28 RTC\_START\_RTC:** RTC calendar enable

- 0: disabled
- 1: enabled

**Bit 27 RTC\_ALARM0\_WKEN:** ALARM0\_SR wake-up enable

- 0: disabled
- 1: enabled

**Bit 26 RTC\_ALARM1\_WKEN:** ALARM1\_SR wake-up enable

- 0: disabled
- 1: enabled

**Bit 25 CYC\_WKEN:** CYC\_SR wake-up enable

- 0: disabled
- 1: enabled

**Bit 24 CYC\_START\_COUNTER:** Periodic counter enable

- 0: disabled
- 1: enabled

**Bit 23 TAMPER\_EN:** Tamper enable

- 0: disabled
- 1: enabled

**Bit 22 TAMPER\_LEVEL\_SEL:** Tamper active level selection

- 0: active at low level
- 1: active at high level

**Bit 21 TAMPER\_WKEN0:** Tamper level wake-up enable

- 0: disabled
- 1: enabled

When TAMPER\_EN is set to 0, this configuration is still valid.

**Bit 20 TAMPER\_WKEN1:** TAMPER\_SR wake-up enable

- 0: disabled
- 1: enabled

**Bits 19-18 TAMPER\_FILTER\_CFG:** Tamper filter control

- 0: no filter
- 1: the filter length is 1 RTC interface clock cycle
- 2: the filter length is 3 RTC interface clock cycles
- 3: the filter length is 7 RTC interface clock cycles

**Bit 17 WAKEUP0\_EN:** WAKEUP0 enable

- 0: disabled
- 1: enabled

**Bit 16 WAKEUP0\_LEVEL\_SEL:** WAKEUP0 active level selection

- 0: active at low level
- 1: active at high level

**Bit 15 WAKEUP0\_WKEN0:** WAKEUP0 level wake-up enable

- 0: disabled
- 1: enabled

When WAKEUP0\_EN is set to 0, this configuration is still valid.

**Bit 14 WAKEUP0\_WKEN1:** WAKEUP0\_SR wake-up enable

- 0: disabled
- 1: enabled

**Bits 13-12 WAKEUP0\_FILTER\_CFG:** WAKEUP0 filter control

- 0: no filter
- 1: the filter length is 1 RTC interface clock cycle
- 2: the filter length is 3 RTC interface clock cycles
- 3: the filter length is 7 RTC interface clock cycles

**Bit 11 WAKEUP1\_EN:** WAKEUP1 enable

- 0: disabled
- 1: enabled

**Bit 10 WAKEUP1\_LEVEL\_SEL:** WAKEUP1 active level selection

- 0: active at low level
- 1: active at high level

**Bit 9 WAKEUP1\_WKEN0:** WAKEUP1 level wake-up enable

- 0: disabled
- 1: enabled

When WAKEUP1\_EN is set to 0, this configuration is still valid.

**Bit 8 WAKEUP1\_WKEN1:** WAKEUP1\_SR wake-up enable

- 0: disabled
- 1: enabled

**Bits 7-6 WAKEUP1\_FILTER\_CFG:** WAKEUP1 filter control

- 0: no filter
- 1: the filter length is 1 RTC interface clock cycle
- 2: the filter length is 3 RTC interface clock cycles
- 3: the filter length is 7 RTC interface clock cycles

**Bit 5 WAKEUP2\_EN:** WAKEUP2 enable

- 0: disabled
- 1: enabled

**Bit 4 WAKEUP2\_LEVEL\_SEL:** WAKEUP2 active level selection

- 0: active at low level
- 1: active at high level

**Bit 3 WAKEUP2\_WKEN0:** WAKEUP2 level wake-up enable

- 0: disabled
- 1: enabled

When WAKEUP2\_EN is set to 0, this configuration is still valid.

**Bit 2 WAKEUP2\_WKEN1:** WAKEUP2\_SR wake-up enable

- 0: disabled
- 1: enabled

**Bits 1-0 WAKEUP2\_FILTER\_CFG:** WAKEUP2 filter control

- 0: no filter
- 1: the filter length is 1 RTC interface clock cycle
- 2: the filter length is 3 RTC interface clock cycles
- 3: the filter length is 7 RTC interface clock cycles

### 17.12.2 RTC\_ALARM0

Address Offset: 0x04

Reset Value: 0x00000000

| 31        | 30              | 29-26       | 25-0         |
|-----------|-----------------|-------------|--------------|
| ALARM0_EN | ALARM0_WEEK_SEL | ALARM0_MASK | ALARM0_VALUE |
| rw-0h     | rw-0h           | rw-0h       | rw-0h        |

**Bit 31 ALARM0\_EN:** Alarm 0 enable

- 0: disabled
- 1: enabled

**Bit 30 ALARM0\_WEEK\_SEL:** Date or day of week selection for Alarm 0

- 0: match the date
- 1: match the day of week

**Bits 29-26 ALARM0\_MASK:** Alarm 0 mask configuration

[26] Alarm 0 seconds mask

- 0: match the seconds
- 1: seconds are not involved in Alarm 0 comparison

[27] Alarm 0 minutes mask

- 0: match the minutes
- 1: minutes are not involved in Alarm 0 comparison

[28] Alarm 0 hours mask

- 0: match the hours
- 1: hours are not involved in Alarm 0 comparison

[29] Alarm 0 date or day of week mask

- 0: match the date or day of week
- 1: date or day of week is not involved in Alarm 0 comparison

**Bits 25-0 ALARM0\_VALUE:** Alarm 0 value configuration. When the calendar sub-seconds, seconds, minutes, hours, date or day of week match the values programmed in this register and the [RTC\\_ALARM0\\_SUB](#) register, the ALARM0\_SR bit is set.

[3:0]: second units

[6:4]: second tens

[10:7]: minute units

[13:11]: minute tens

[17:14]: hour units

[19:18]: hour tens

[23:20]: bits[23:20] configure date units or bits[22:20] configure day of week

[25:24]: date tens

### 17.12.3 RTC\_ALARM1

Address Offset: 0x08

Reset Value: 0x00000000

| 31        | 30              | 29-26       | 25-0         |
|-----------|-----------------|-------------|--------------|
| ALARM1_EN | ALARM1_WEEK_SEL | ALARM1_MASK | ALARM1_VALUE |
| rw-0h     | rw-0h           | rw-0h       | rw-0h        |

**Bit 31 ALARM1\_EN:** Alarm 1 enable

- 0: disabled
- 1: enabled

**Bit 30 ALARM1\_WEEK\_SEL:** Date or day of week selection for Alarm 1

- 0: match the date
- 1: match the day of week

**Bits 29-26 ALARM1\_MASK:** Alarm 1 mask configuration

[26] Alarm 1 seconds mask

- 0: match the seconds
- 1: seconds are not involved in Alarm 1 comparison

[27] Alarm 1 minutes mask

- 0: match the minutes
- 1: minutes are not involved in Alarm 1 comparison

[28] Alarm 1 hours mask

- 0: match the hours
- 1: hours are not involved in Alarm 1 comparison

[29] Alarm 1 date or day of week mask

- 0: match the date or day of week
- 1: date or day of week is not involved in Alarm 1 comparison

**Bits 25:0 ALARM1\_VALUE:** Alarm 1 value configuration. When the calendar sub-seconds, seconds, minutes, hours, date or day of week match the values programmed in this register and the [RTC\\_ALARM1\\_SUB](#) register, the ALARM1\_SR bit is set.

[3:0]: second units

[6:4]: second tens

[10:7]: minute units

[13:11]: minute tens

[17:14]: hour units

[19:18]: hour tens

[23:20]: bits[23:20] configure date units or bits[22:20] configure day of week

[25:24]: date tens

#### 17.12.4 RTC\_PPMAJUST

Address Offset: 0x0c

Reset Value: 0x000007fff

| 31-16    | 15-0            |
|----------|-----------------|
| RESERVED | PPMADJUST_VALUE |
| r-0h     | rw-7ffffh       |

**Bits 31-16 RESERVED:** Must be kept, and cannot be modified.

**Bits 15-0 PPMADJUST\_VALUE:** The RTC clock frequency can be calibrated with a resolution of about 0.5 ppm with a range from -1024 ppm to +1024 ppm.

- 77ff: increase frequency of RTC by 1024 ppm
- 7800: increase frequency of RTC by 1023.5 ppm
- ...
- 7ffd: increase frequency of RTC by 1 ppm
- 7ffe: increase frequency of RTC by 0.5 ppm
- 7fff: no adjustment
- 8000: decrease frequency of RTC by 0.5 ppm
- 8001: decrease frequency of RTC by 1 ppm
- ...
- 87fe: decrease frequency of RTC by 1023.5 ppm
- 87ff: decrease frequency of RTC by 1024 ppm

#### 17.12.5 RTC\_CALENDAR

Address Offset: 0x10

Reset Value: 0x00000000

| 31-20    | 19-0           |
|----------|----------------|
| RESERVED | CALENDAR_VALUE |
| r-0h     | w-0h           |

**Bits 31-20 RESERVED:** Must be kept, and cannot be modified.

**Bits 19-0 CALENDAR\_VALUE:** RTC calendar time values

- [3:0]: second units
- [6:4]: second tens
- [10:7]: minute units
- [13:11]: minute tens
- [17:14]: hour units
- [19:18]: hour tens

### 17.12.6 RTC\_CALENDAR\_H

Address Offset: 0x14

Reset Value: 0x00000841

| 31-22    | 21-0             |
|----------|------------------|
| RESERVED | CALENDAR_H_VALUE |
| r-0h     | w-841h           |

**Bits 31-22 RESERVED:** Must be kept, and cannot be modified.

**Bits 21-0 CALENDAR\_H\_VALUE:** RTC calendar date values

- [3:0]: date units
- [5:4]: date tens
- [9:6]: month units
- [10]: month tens
- [13:11]: week day units
- [17:14]: year units
- [21:18]: year tens

### 17.12.7 RTC\_CYC\_MAX\_VALUE

Address Offset: 0x18

Reset Value: 0x00008000

| 31-0          |
|---------------|
| CYC_MAX_VALUE |
| rw-8000h      |

**Bits 31-0 CYC\_MAX\_VALUE:** The programmed count value for the periodic counter to reach.

When the periodic counter reaches the CYC\_MAX\_VALUE, the periodic counter status flag (bit CYC\_SR) is set. The periodic counter is clocked by the RTC interface clock.

### 17.12.8 RTC\_SR

Address Offset: 0x1c

Reset Value: 0x00000000

| 31-7      | 6          | 5          | 4          |
|-----------|------------|------------|------------|
| RESERVED  | ALARM0_SR  | ALARM1_SR  | CYC_SR     |
| r-0h      | rw-0h      | rw-0h      | rw-0h      |
| <b>3</b>  | <b>2</b>   | <b>1</b>   | <b>0</b>   |
| TAMPER_SR | WAKEUP0_SR | WAKEUP1_SR | WAKEUP2_SR |
| rw-0h     | rw-0h      | rw-0h      | rw-0h      |

**Bits 31-7 RESERVED:** Must be kept, and cannot be modified.

**Bit 6 ALARM0\_SR:** Alarm 0 flag

This flag is set by hardware and cleared by software writing 1 to it.

- 0: the Alarm 0 values doesn't match the Calendar
- 1: the Alarm 0 values match the Calendar

**Bit 5 ALARM1\_SR:** Alarm 1 flag

This flag is set by hardware and cleared by software writing 1 to it.

- 0: the Alarm 1 values doesn't match the Calendar
- 1: the Alarm 1 values match the Calendar

**Bit 4 CYC\_SR:** Periodic counter flag

This flag is set by hardware and cleared by software writing 1 to it.

- 0: the CYC\_MAX\_VALUE is not reached
- 1: the CYC\_MAX\_VALUE is reached

**Bit 3 TAMPER\_SR:** Tamper flag

This flag is set by hardware and cleared by software writing 1 to it.

- 0: the tamper pin active level is not detected
- 1: the tamper pin active level is detected

**Bit 2 WAKEUP0\_SR:** Wakeup0 flag

This flag is set by hardware and cleared by software writing 1 to it.

- 0: the Wakeup0 active level is not detected
- 1: the Wakeup0 active level is detected

**Bit 1 WAKEUP1\_SR:** Wakeup1 flag

This flag is set by hardware and cleared by software writing 1 to it.

- 0: the Wakeup1 active level is not detected
- 1: the Wakeup1 active level is detected

**Bit 0 WAKEUP2\_SR:** Wakeup2 flag

This flag is set by hardware and cleared by software writing 1 to it.

- 0: the Wakeup2 active level is not detected
- 1: the Wakeup2 active level is detected

### 17.12.9 RTC\_ASYNCDATA

Address Offset: 0x20

Reset Value: 0x00000000

| 31-20    | 19-0     |
|----------|----------|
| RESERVED | SYN_DATA |
| r-0h     | r-0h     |

**Bits 31-20 RESERVED:** Must be kept, and cannot be modified.

**Bits 19-0 SYN\_DATA:** RTC calendar time values. This register is read-only by software.

- [3:0]: second units
- [6:4]: second tens
- [10:7]: minute units
- [13:11]: minute tens
- [17:14]: hour units
- [19:18]: hour tens

### 17.12.10 RTC\_ASYNCDATA\_H

Address Offset: 0x24

Reset Value: 0x00000000

| 31-22    | 21-0       |
|----------|------------|
| RESERVED | SYN_DATA_H |
| r-0h     | r-0h       |

**Bits 31-22 RESERVED:** Must be kept, and cannot be modified.

**Bits 21-0 SYN\_DATA\_H:** RTC calendar date values. This register is read-only by software.

- [3:0]: date units
- [5:4]: date tens
- [9:6]: month units
- [10]: month tens
- [13:11]: week day units
- [17:14]: year units
- [21:18]: year tens

### 17.12.11 RTC\_CR1

Address Offset: 0x28

Reset Value: 0x00000000

| 31-8              | 7                 | 6                 |
|-------------------|-------------------|-------------------|
| RESERVED          | SECOND_SR_INT_EN  | ALARM0_SR_INT_EN  |
| r-0h              | rw-0h             | rw-0h             |
| <b>5</b>          | <b>4</b>          | <b>3</b>          |
| ALARM1_SR_INT_EN  | CYC_SR_INT_EN     | TAMPER_SR_INT_EN  |
| rw-0h             | rw-0h             | rw-0h             |
| <b>2</b>          | <b>1</b>          | <b>0</b>          |
| WAKEUP0_SR_INT_EN | WAKEUP1_SR_INT_EN | WAKEUP2_SR_INT_EN |
| rw-0h             | rw-0h             | rw-0h             |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bit 7 SECOND\_SR\_INT\_EN:** SECOND\_SR interrupt enable

- 0: disabled
- 1: enabled

**Bit 6 ALARM0\_SR\_INT\_EN:** ALARM0\_SR interrupt enable

- 0: disabled
- 1: enabled

**Bit 5 ALARM1\_SR\_INT\_EN:** ALARM1\_SR interrupt enable

- 0: disabled
- 1: enabled

**Bit 4 CYC\_SR\_INT\_EN:** CYC\_SR (periodic counter) interrupt enable

- 0: disabled
- 1: enabled

**Bit 3 TAMPER\_SR\_INT\_EN:** TAMPER\_SR interrupt enable

- 0: disabled
- 1: enabled

**Bit 2 WAKEUP0\_SR\_INT\_EN:** WAKEUP0\_SR interrupt enable

- 0: disabled
- 1: enabled

**Bit 1 WAKEUP1\_SR\_INT\_EN:** WAKEUP1\_SR interrupt enable

- 0: disabled
- 1: enabled

**Bit 0 WAKEUP2\_SR\_INT\_EN:** WAKEUP2\_SR interrupt enable

- 0: disabled
- 1: enabled

### 17.12.12 RTC\_SR1

Address Offset: 0x2c

Reset Value: 0x00000dff

| <b>31-12</b>             | <b>11</b>             |  | <b>10</b>             |  | <b>9</b>  |
|--------------------------|-----------------------|--|-----------------------|--|-----------|
| RESERVED                 | WRITE_ALARM0_SUB_DONE |  | WRITE_ALARM1_SUB_DONE |  | SECOND_SR |
| r-0h                     | r-1h                  |  | r-1h                  |  | rw-0h     |
| <b>8</b>                 | <b>7</b>              |  | <b>6</b>              |  |           |
| WRITE_RTCCR2_DONE        | WRITE_RTCCR_DONE      |  | WRITE_ALARM0_DONE     |  |           |
| r-1h                     | r-1h                  |  | r-1h                  |  |           |
| <b>5</b>                 | <b>4</b>              |  | <b>3</b>              |  |           |
| WRITE_ALARM1_DONE        | WRITE_PPMADJUST_DONE  |  | WRITE_CALENDAR_DONE   |  |           |
| r-1h                     | r-1h                  |  | r-1h                  |  |           |
| <b>2</b>                 | <b>1</b>              |  | <b>0</b>              |  |           |
| WRITE_CYC_MAX_VALUE_DONE | WRITE_RTCSCR_DONE     |  | READ_CALENDAR_DONE    |  |           |
| r-1h                     | r-1h                  |  | r-1h                  |  |           |

**Bits 31-12 RESERVED:** Must be kept, and cannot be modified.

**Bit 11 WRITE\_ALARM0\_SUB\_DONE:** The complete flag of the write operation to register [RTC\\_ALARM0\\_SUB](#). This bit is set and cleared by hardware.

- 0: a write operation is ongoing
- 1: a write operation is completed

**Bit 10 WRITE\_ALARM1\_SUB\_DONE:** The complete flag of the write operation to register [RTC\\_ALARM1\\_SUB](#). This bit is set and cleared by hardware.

- 0: a write operation is ongoing
- 1: a write operation is completed

**Bit 9 SECOND\_SR:** Second signal interrupt status. This bit is set by hardware and cleared by software writing 1 to it.

- 0: no second signal interrupt is generated
- 1: a second signal interrupt is generated

**Bit 8 WRITE\_RTCCR2\_DONE:** The complete flag of the write operation to register [RTC\\_CR2](#). This bit is set and cleared by hardware.

- 0: a write operation is ongoing
- 1: a write operation is completed

**Bit 7 WRITE\_RTCCR\_DONE:** The complete flag of the write operation to register [RTC\\_CR](#). This bit is set and cleared by hardware.

- 0: a write operation is ongoing
- 1: a write operation is completed

**Bit 6 WRITE\_ALARM0\_DONE:** The complete flag of the write operation to register [RTC\\_ALARM0](#). This bit is set and cleared by hardware.

- 0: a write operation is ongoing

- 1: a write operation is completed

**Bit 5 WRITE\_ALARM1\_DONE:** The complete flag of the write operation to register [RTC\\_ALARM1](#). This bit is set and cleared by hardware.

- 0: a write operation is ongoing
- 1: a write operation is completed

**Bit 4 WRITE\_PPMADJUST\_DONE:** The complete flag of the write operation to register [RTC\\_PPMADJUST](#). This bit is set and cleared by hardware.

- 0: a write operation is ongoing
- 1: a write operation is completed

**Bit 3 WRITE\_CALENDAR\_DONE:** The complete flag of the write operations to registers [RTC\\_CALENDAR](#) and [RTC\\_CALENDAR\\_H](#). This bit is set and cleared by hardware.

- 0: a write operation is ongoing
- 1: a write operation is completed

**Bit 2 WRITE\_CYC\_MAX\_VALUE\_DONE:** The complete flag of the write operation to register [RTC\\_CYC\\_MAX\\_VALUE](#). This bit is set and cleared by hardware.

- 0: a write operation is ongoing
- 1: a write operation is completed

**Bit 1 WRITE\_RTC\_SR\_DONE:** The complete flag of the write operation to register [RTC\\_SR](#). This bit is set and cleared by hardware.

- 0: a write operation is ongoing
- 1: a write operation is completed

**Bit 0 READ\_CALENDAR\_DONE:** The complete flag of the read operations to registers [RTC\\_CALENDAR\\_R](#) and [RTC\\_CALENDAR\\_R\\_H](#). This bit is set and cleared by hardware.

- 0: a write operation is ongoing
- 1: a write operation is completed

### 17.12.13 RTC\_CR2

Address Offset: 0x30

Reset Value: 0x00000000

| 31-8     | 7           | 6-4         | 3-0                   |
|----------|-------------|-------------|-----------------------|
| RESERVED | RTC_OUT_POL | RTC_OUT_SEL | RTC_RET_SRAM_ERASE_EN |
| r-0h     | rw-0h       | rw-0h       | rw-0h                 |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bit 7 RTC\_OUT\_POL:** RTC IO output polarity

- 0: RTC IO output level is non-inverted
- 1: RTC IO output level is inverted

**Bits 6-4 RTC\_OUT\_SEL:** RTC IO output selection

- 0-3: no output

- 4: alarm 0 pulse
- 5: alarm 1 pulse
- 6: cyc pulse
- 7: second signal (50% duty cycle)

**Bits 3-0 RTC\_RET\_SRAM\_ERASE\_EN:** If enabled, the Retention SRAM is erased upon a tamper or a wakeup event. [0]: wakeup0, [1]: wakeup1, [2]: wakeup2, [3]: tamper.

- 0: disabled
- 1: enabled

#### 17.12.14 RTC\_SUB\_SECOND

Address Offset: 0x34

Reset Value: 0x00000000

| 31-15    | 14-0                 |
|----------|----------------------|
| RESERVED | RTC_SUB_SECOND_VALUE |
| r-0h     | r-0h                 |

**Bits 31-15 RESERVED:** Must be kept, and cannot be modified.

**Bits 14-0 RTC\_SUB\_SECOND\_VALUE:** The subsecond count value of the RTC calendar counter. This register should be read several times with the same result obtained to ensure that the data is correct.

#### 17.12.15 RTC\_CYC\_CNT\_VALUE

Address Offset: 0x38

Reset Value: 0x00000000

| 31-0          |
|---------------|
| CYC_CNT_VALUE |
| r-0h          |

**Bits 31-0 CYC\_CNT\_VALUE:** Periodic counter value. This register should be read several times with the same result obtained to ensure that the data is correct.

### 17.12.16 RTC\_ALARM0\_SUB

Address Offset: 0x3c

Reset Value: 0x00000000

| 31-20    | 19-16               | 15       | 14-0                 |
|----------|---------------------|----------|----------------------|
| RESERVED | RTC_ALARM0_SUB_MASK | RESERVED | RTC_ALARM0_SUB_VALUE |
| r-0h     | rw-0h               | r-0h     | rw-0h                |

**Bits 31-20 RESERVED:** Must be kept, and cannot be modified.

**Bits 19-16 RTC\_ALARM0\_SUB\_MASK:** Alarm 0 sub-second mask configuration. If sub-seconds are used in Alarm 0, it is recommended not to perform RTC PPM calibration.

- 0: No comparison on sub-seconds for Alarm 0.
- 1: RTC\_ALARM0\_SUB\_VALUE [14:1] are not involved in Alarm 0 comparison. Only bit0 is compared.
- 2: RTC\_ALARM0\_SUB\_VALUE [14:2] are not involved in Alarm 0 comparison. Only bits[1:0] are compared.
- ...
- 14: RTC\_ALARM0\_SUB\_VALUE [14] are not involved in Alarm 0 comparison. Bits[13:0] are compared.
- 15: All 15 RTC\_ALARM0\_SUB\_VALUE bits are compared.

**Bit 15 RESERVED:** Must be kept, and cannot be modified.

**Bits 14-0 RTC\_ALARM0\_SUB\_VALUE:** Alarm 0 sub-seconds value. When the calendar subseconds, seconds, minutes, hours, date or day of week match the values programmed in this register and the [RTC\\_ALARM0](#) register, the ALARM0\_SR bit is set.

### 17.12.17 RTC\_ALARM1\_SUB

Address Offset: 0x40

Reset Value: 0x00000000

| 31-20    | 19-16               | 15       | 14-0                 |
|----------|---------------------|----------|----------------------|
| RESERVED | RTC_ALARM1_SUB_MASK | RESERVED | RTC_ALARM1_SUB_VALUE |
| r-0h     | rw-0h               | r-0h     | rw-0h                |

**Bits 31-20 RESERVED:** Must be kept, and cannot be modified.

**Bits 19-16 RTC\_ALARM1\_SUB\_MASK:** Alarm 1 sub-second mask configuration. If sub-seconds are used in Alarm 1, it is recommended not to perform RTC PPM calibration.

- 0: No comparison on sub-seconds for Alarm 1.
- 1: RTC\_ALARM1\_SUB\_VALUE [14:1] are not involved in Alarm 1 comparison. Only bit0 is compared.
- 2: RTC\_ALARM1\_SUB\_VALUE [14:2] are not involved in Alarm 1 comparison. Only bits[1:0] are compared.
- ...
- 14: RTC\_ALARM1\_SUB\_VALUE [14] are not involved in Alarm 1 comparison. Bits[13:0] are compared.

compared.

- 15: All 15 RTC\_ALARM1\_SUB\_VALUE bits are compared.

**Bit 15 RESERVED:** Must be kept, and cannot be modified.

**Bits 14-0 RTC\_ALARM1\_SUB\_VALUE:** Alarm 1 sub-seconds value. When the calendar subseconds, seconds, minutes, hours, date or day of week match the values programmed in this register and the [RTC\\_ALARM1](#) register, the ALARM1\_SR bit is set.

### 17.12.18 RTC\_CALENDAR\_R

Address Offset: 0x44

Reset Value: 0x00000000

| 31-20    | 19-0          |
|----------|---------------|
| RESERVED | CALENDAR_SYNC |
| r-0h     | r-0h          |

**Bits 31-20 RESERVED:** Must be kept, and cannot be modified.

**Bits 19-0 CALENDAR\_SYNC:** RTC\_CALENDAR\_R register values (seconds, minutes and hours). This register should be read several times with the same result obtained to ensure that the data is correct.

### 17.12.19 RTC\_CALENDAR\_R\_H

Address Offset: 0x48

Reset Value: 0x00000841

| 31-22    | 21-0            |
|----------|-----------------|
| RESERVED | CALENDAR_H_SYNC |
| r-0h     | r-841h          |

**Bits 31-22 RESERVED:** Must be kept, and cannot be modified.

**Bits 21-0 CALENDAR\_H\_SYNC:** RTC\_CALENDAR\_R\_H register values (date or day of week, month and year). This register should be read several times with the same result obtained to ensure that the data is correct.

# 18.

# LPUART

## 18.1 Introduction

LPUART (Low-power Universal Asynchronous Receiver/Transmitter) is a low-power serial port peripheral. When the 32K clock is used, the LPUART communications can be up to 9600 baud/s. Even in Deepsleep mode, the LPUART can be woken up by received data.

In addition, LPUART supports CTS (Clear To Send)/RTS (Require To Send) flow control.

DMA (direct memory access) can be used for data transmission and reception.

## 18.2 Main Features

- Programmable baud rate
- Programmable data format (support 5, 6, 7 or 8 data bits, 1 or 2 stop bits and 1 or no parity bit)
- Support DMA request
- 1-deep TX FIFO/RX FIFO
- Support CTS/RTS flow control
- Support LPUART interrupt generation
- Wakeup CPU from low-power modes

## 18.3 Functional Description

### 18.3.1 Data Format



Figure 18-1 LPUART Data Format

When LPUART is idle, its data line should be kept at high level.

For data transmission, the start bit (START), data bits (DATA), parity bit (PARITY) and stop bits (STOP) are sequentially transmitted. The meaning of each bit is as follows:

- (1) **Start Bit:** 0 signal is sent first to indicate the start of data transmission.

- (2) **Data Bits:** 5, 6, 7 or 8 data bits are transmitted in sequence.
- (3) **Parity Bit:** After the data bits, the parity bit is transmitted, or it can be configured as no parity bit.
- (4) **Stop Bit:** 1 or 2 stop bits mark the end of data transmission.

### 18.3.2 Baud Rate Generation

The LPUART baud rate divisor consists of an integer part and a fractional part. This is mainly configured through the LPUART\_BAUD\_RATE\_INT and LPUART\_BAUD\_RATE\_FRA bits in the [LPUART\\_CRO](#) register.

Taking an LPUART interface clock frequency of 32.768kHz and 9600 baud/s as an example, the baud rate divisor is  $32768/9600=3.413$ . Thus, set the integer part of the baud rate divisor to **3** through the LPUART\_BAUD\_RATE\_INT bit, and set the fractional part of the baud rate divisor to **7** ( $0.413*16=6.608$ , rounded to 7) through the LPUART\_BAUD\_RATE\_FRA bit.

### 18.3.3 CTS/RTS Flow Control

The connection between two LPUART devices is shown in the following figure:



Figure 18-2 Connection between Two LPUART Devices

**RTS (Require to Send)** is an output signal used to determine whether the device is ready to receive data. It is active low, so the low level indicates that the device is ready for data reception.

**CTS (Clear to Send)** is an input signal used to determine whether the device can send data to the other. It is active low, so the low level indicates that the device can send data to the other.

### 18.3.4 DMA Transaction

#### LPUART DMA Transmitter Process:

- (1) Enable the DMA\_TX\_EN bit in register *LPUART\_CR1*.
- (2) Configure register *LPUART\_DATA* as the destination address of DMA.
- (3) Configure the memory address of the data to be sent as the source address of DMA.
- (4) Configure the data width of DMA transfer to 8 bits by configuring the SRC\_TR\_WIDTH and DES\_TR\_WIDTH bits to 0 in the *DMA\_CTLx* register.
- (5) Configure the DMA burst length to 1 by configuring the SRC\_MSIZE and DEST\_MSIZE bits to 0 in the *DMA\_CTLx* register.
- (6) Configure the total length of DMA data transfer.
- (7) Configure DMA handshake type to DMA\_HANDSHAKE\_LPUART\_TX.
- (8) Activate the DMA.

When the DMA transfer is completed, the CH\_EN\_x bit in the DMA\_CHENREG register is cleared.

#### LPUART DMA Reception Process:

- (1) Enable the DMA\_RX\_EN bit in register *LPUART\_CR1*.
- (2) Configure register *LPUART\_DATA* as the source address of DMA.
- (3) Configure the memory address of the data to be received as the destination address of DMA.
- (4) Configure the data width of DMA transfer to 8 bits by configuring the SRC\_TR\_WIDTH and DES\_TR\_WIDTH bits to 0 in the *DMA\_CTLx* register.
- (5) Configure the DMA burst length to 1 by configuring the SRC\_MSIZE and DEST\_MSIZE bits to 0 in the *DMA\_CTLx* register.
- (6) Configure the total length of DMA data transfer.
- (7) Configure DMA handshake type to DMA\_HANDSHAKE\_LPUART\_RX.
- (8) Activate the DMA.

When the DMA transfer is completed, the CH\_EN\_x bit in the DMA\_CHENREG register is cleared.

### 18.3.5 LPUART Interrupt Signals

- TX\_DONE interrupt
- TXFIFO\_EMPTY interrupt
- RXFIFO\_NOT\_EMPTY interrupt
- RX\_OVERFLOW interrupt
- STOP\_ERR interrupt
- PARITY\_ERR interrupt
- START\_INVALID interrupt
- RX\_DONE interrupt
- START\_VALID interrupt

### 18.3.6 CPU Wakeup from Low-power Mode

RX low-level, START\_VALID and RX\_DONE signals can be used to wakeup the CPU from low-power modes.

LPUART wakeup is enabled by configuring the LPUART\_WAKEUP\_EN[[24:22] bits in register [LPUART\\_CR0](#).

## 18.4 LPUART Registers

LPUART Base Address: 0x40005000

Table 18-1 LPUART Register Summary

| Register Name | Address Offset | Description               |
|---------------|----------------|---------------------------|
| LPUART_CR0    | 0x00           | LPUART Control Register 0 |
| LPUART_CR1    | 0x04           | LPUART Control Register 1 |
| LPUART_SR0    | 0x08           | LPUART Status Register 0  |
| LPUART_SR1    | 0x0C           | LPUART Status Register 1  |
| LPUART_DATA   | 0x10           | LPUART Data Register      |

### 18.4.1 LPUART\_CR0

Address Offset: 0x00

Reset Value: 0x00000E13

| 31-27                | 26              | 25                | 24-22            | 21-10                |
|----------------------|-----------------|-------------------|------------------|----------------------|
| RESERVED             | LPUART_RTS_EN   | LPUART_RX_EN      | LPUART_WAKEUP_EN | LPUART_BAUD_RATE_INT |
| r                    | r/w             | r/w               | r/w              | r/w                  |
| 9-6                  | 5               | 4-2               | 1-0              |                      |
| LPUART_BAUD_RATE_FRA | LPUART_STOP_LEN | LPUART_PARITY_CFG | LPUART_DATA_LEN  |                      |
| r/w                  | r/w             | r/w               | r/w              |                      |

**Bits 31-27 RESERVED:** Must be kept, and cannot be modified.

**Bit 26 LPUART\_RTS\_EN:** LPUART RTS flow control enable

- 0: disabled
- 1: enabled

**Bit 25 LPUART\_RX\_EN:** LPUART reception enable

- 0: disabled
- 1: enabled

**Bits 24-22 LPUART\_WAKEUP\_EN:** LPUART wakeup enable

[22] Enable RX low-level signal as a wakeup source

- 0: disabled
- 1: enabled

[23] Enable START\_VALID signal as a wakeup source

- 0: disabled
- 1: enabled

[24] Enable RX\_DONE signal as a wakeup source

- 0: disabled
- 1: enabled

**Bits 21-10 LPUART\_BAUD\_RATE\_INT:** The integer part of the baud rate divisor

*Baud rate divisor=UART interface clock frequency/Baud rate*

Taking an LPUART interface clock frequency of 32.768 kHz and 9600 baud/s as an example, the baud rate divisor is  $32768/9600=3.413$ . Thus, set the integer part of the baud rate divisor to **3** through the LPUART\_BAUD\_RATE\_INT bit, and set the fractional part of the baud rate divisor to **6 or 7** (based on  $0.413*16=6.608$ ) through the LPUART\_BAUD\_RATE\_FRA bit.

**Bits 9-6 LPUART\_BAUD\_RATE\_FRA:** The fractional part of the baud rate divisor

**Bit 5 LPUART\_STOP\_LEN:** LPUART STOP bits configuration

- 0: 1 stop bit
- 1: 2 stop bits

**Bits 4-2 LPUART\_PARITY\_CFG:** LPUART parity bit configuration

- 0: even parity
- 1: odd parity
- 2: parity bit is 0
- 3: parity bit is 1
- >3: no parity

**Bits 1-0 LPUART\_DATA\_LEN:** LPUART data length

Data width=LPUART\_DATA\_LEN+5

**18.4.2 LPUART\_CR1**

Address Offset: 0x04

Reset Value: 0x00000000

| <b>31-13</b>      | <b>12</b>            | <b>11</b>               | <b>10</b>          | <b>9</b>        |
|-------------------|----------------------|-------------------------|--------------------|-----------------|
| RESERVED          | LPUART_CTS_EN        | DMA_TX_EN               | DMA_RX_EN          | LPUART_TX_EN    |
| r                 | r/w                  | r/w                     | r/w                | r/w             |
| <b>8</b>          | <b>7</b>             | <b>6</b>                | <b>5</b>           | <b>4</b>        |
| TX_DONE_INT_EN    | TXFIFO_EMPTY_INT_EN  | RXFIFO_NOT_EMPTY_INT_EN | RX_OVERFLOW_INT_EN | STOP_ERR_INT_EN |
| r/w               | r/w                  | r/w                     | r/w                | r/w             |
| <b>3</b>          | <b>2</b>             | <b>1</b>                |                    | <b>0</b>        |
| PARITY_ERR_INT_EN | START_INVALID_INT_EN | RX_DONE_INT_EN          | START_VALID_INT_EN |                 |
| r/w               | r/w                  | r/w                     | r/w                |                 |

**Bits 31:13 RESERVED:** Must be kept, and cannot be modified.**Bit 12 LPUART\_CTS\_EN:** LPUART CTS flow control enable

- 0: disabled
- 1: enabled

**Bit 11 DMA\_TX\_EN:** DMA transmission requests enable

- 0: disabled
- 1: enabled

**Bit 10 DMA\_RX\_EN:** DMA reception requests enable

- 0: disabled
- 1: enabled

**Bit 9 LPUART\_TX\_EN:** LPUART transmission enable

- 0: disabled
- 1: enabled

**Bit 8 TX\_DONE\_INT\_EN:** TX\_DONE interrupt enable

- 0: disabled
- 1: enabled

**Bit 7 TXFIFO\_EMPTY\_INT\_EN:** TXFIFO\_EMPTY interrupt enable

- 0: disabled
- 1: enabled

**Bit 6 RXFIFO\_NOT\_EMPTY\_INT\_EN:** RXFIFO\_NOT\_EMPTY interrupt enable

- 0: disabled
- 1: enabled

**Bit 5 RX\_OVERFLOW\_INT\_EN:** RX\_OVERFLOW interrupt enable

- 0: disabled
- 1: enabled

**Bit 4 STOP\_ERR\_INT\_EN:** STOP\_ERR interrupt enable

- 0: disabled
- 1: enabled

**Bit 3 PARITY\_ERR\_INT\_EN:** PARITY\_ERR interrupt enable

- 0: disabled
- 1: enabled

**Bit 2 START\_INVALID\_INT\_EN:** START\_INVALID interrupt enable

- 0: disabled
- 1: enabled

**Bit 1 RX\_DONE\_INT\_EN:** RX\_DONE interrupt enable

- 0: disabled
- 1: enabled

**Bit 0 START\_VALID\_INT\_EN:** START\_VALID interrupt enable

- 0: disabled
- 1: enabled

### 18.4.3 LPUART\_SR0

Address Offset: 0x08

Reset Value: 0x00000000

| 31-6          |                  | 5              | 4              |
|---------------|------------------|----------------|----------------|
| RESERVED      |                  | RX_OVERFLOW_SR | STOP_ERR_SR    |
| 3             | 2                | 1              | 0              |
| PARITY_ERR_SR | START_INVALID_SR | RX_DONE_SR     | START_VALID_SR |
| r/w           | r/w              | r/w            | r/w            |

**Bits 31-6 RESERVED:** Must be kept, and cannot be modified.

**Bit 5 RX\_OVERFLOW\_SR:** RX\_OVERFLOW flag is used to indicate whether a RX buffer overflow has occurred. This bit is set by hardware and cleared by software writing 1 to it.

- 0: no RX buffer overflow occurred
- 1: an RX buffer overflow occurred

**Bit 4 STOP\_ERR\_SR:** STOP\_ERR flag is used to indicate whether a Stop error has occurred. This bit is set by hardware and cleared by software writing 1 to it.

- 0: no Stop error occurred
- 1: a Stop error occurred

**Bit 3 PARITY\_ERR\_SR:** PARITY\_ERR flag is used to indicate whether a parity error has occurred. This bit is set by hardware and cleared by software writing 1 to it.

- 0: no parity error occurred
- 1: a parity error occurred

**Bit 2 START\_INVALID\_SR:** START\_INVALID flag is used to indicate whether an invalid Start bit has been received. This bit is set by hardware and cleared by software writing 1 to it.

- 0: no invalid Start
- 1: an invalid Start bit has been received

**Bit 1 RX\_DONE\_SR:** RX\_DONE flag is used to indicate whether the data reception is completed. This bit is set by hardware and cleared by software writing 1 to it.

- 0: data reception is not completed
- 1: data reception is completed

**Bit 0 START\_VALID\_SR:** START\_VALID flag is used to indicate whether a valid Start bit has been received. This bit is set by hardware and cleared by software writing 1 to it.

- 0: no valid Start
- 1: a valid Start bit has been received

#### 18.4.4 LPUART\_SR1

Address Offset: 0x0C

Reset Value: 0x00000016

| 31-6             |                | 5              | 4            |
|------------------|----------------|----------------|--------------|
| RESERVED         |                | TX_DONE        | TXFIFO_EMPTY |
| r                |                | r/w            | r            |
| 3                | 2              | 1              | 0            |
| RXFIFO_NOT_EMPTY | WRITE_CR0_DONE | WRITE_SR0_DONE | RESERVED     |
| r                | r              | r              | r            |

**Bits 31-6 RESERVED:** Must be kept, and cannot be modified.

**Bit 5 TX\_DONE:** TX\_DONE flag. This bit is set by hardware and cleared by software writing 1 to it.

- 0: data transmission is on-going
- 1: data transmission is completed

**Bit 4 TXFIFO\_EMPTY:** TXFIFO\_EMPTY flag. This bit is set by hardware and cleared by software writing to the [LPUART\\_DATA](#) register.

- 0: non-empty
- 1: empty

**Bit 3 RXFIFO\_NOT\_EMPTY:** RXFIFO\_NOT\_EMPTY flag. This bit is set by hardware and cleared by software reading the [LPUART\\_DATA](#) register.

- 0: empty
- 1: non-empty

**Bit 2 WRITE\_CR0\_DONE:** The status of a write operation to the [LPUART\\_CR0](#) register. This bit is set and cleared by hardware.

- 0: a write operation to the [LPUART\\_CR0](#) register is on-going
- 1: a write operation to the [LPUART\\_CR0](#) register has been completed

**Bit 1 WRITE\_SR0\_DONE:** The status of a write operation to the [LPUART\\_SR0](#) register. This bit is set and cleared by hardware.

- 0: a write operation to the [LPUART\\_SR0](#) register is on-going
- 1: a write operation to the [LPUART\\_SR0](#) register has been completed

**Bit 0 RESERVED:** Must be kept, and cannot be modified.

### 18.4.5 LPUART\_DATA

Address Offset: 0x10

Reset Value: 0x00000000

| 31-8     | 7-0         |
|----------|-------------|
| RESERVED | LPUART_DATA |
| r        | r/w         |

**Bits 31-8 RESERVED:** Must be kept, and cannot be modified.

**Bits 7-0 LPUART\_DATA:** LPUART TX/RX data

**Notice:**

1. If the data width is less than 8 bits, the less significant bits of the LPUART\_DATA register is valid.
2. Before reading the LPUART\_DATA register, check the RXFIFO\_NOT\_EMPTY flag to ensure that there is data in RXFIFO; before writing to the LPUART\_DATA register, check the TXFIFO\_EMPTY flag to ensure that the TXFIFO can be written.

# 19.

# DMA

## 19.1 Introduction

DMA supports peripheral-to-peripheral, peripheral-to-memory, memory-to-peripheral, and memory-to-memory data transfers, 8-bit, 16-bit, or 32-bit data width, as well as auto-reloading and linked-list (LLI) of data. There are two DMAs, DMA0 and DMA1, each with 4 channels that are independent of each other and can work simultaneously, as are the four channels in each DMA.

## 19.2 Main Features

- Supports transfer data length configuration
- Supports data transfer method configuration
- Supports auto-reloading
- Supports LLI

## 19.3 Transfer Data Length Configuration

DMA allows transferring data of multiple blocks. The data of each block is transferred in burst mode first, then in single mode when the data length is not enough for burst. Peripheral data transfer is as follows:



Figure 19-1 Data Transfer

DMA source and destination data bit width are configured via the *SRC\_TR\_WIDTH* and *DST\_TR\_WIDTH* bit fields in the *DMA\_CTLx* register (x is 0, 1, 2 or 3), with a value of 000 for 8 bits, 001 for 16 bits and 002 for 32 bits.

DMA source and destination burst data length are configured via the *SRC\_MSIZE* and *DEST\_MSIZE* bit fields in the *DMA\_CTLx* register, with a value of 000 for 1, 001 for 4, and 002 for 8, which is converted to Bytes as *SRC\_MSIZE* (*DEST\_MSIZE*) \* (data bit width/ 8). The DMA burst data length (Bytes) should be the same as the peripheral input or output FIFO length, otherwise it may lead to data loss.

DMA block size is configured via the *BLOCK\_TS* bit in the *DMA\_CTLx* register, up to 12 bits, with a maximum block size of 4095, which is converted to Bytes as *BLOCK\_TS* \* (data bit width/ 8).

## 19.4 Data Transfer Method

DMA supports peripheral-to-peripheral, peripheral-to-memory, memory-to-peripheral, and memory-to-memory data transfers. Peripheral-to-peripheral means that both the source and destination are peripheral. Peripheral-to-memory means that the source is peripheral and the destination is memory. Memory-to-peripheral means that the source is memory and the destination is peripheral. Memory-to-memory means that both the source and destination are memory. The data transfer method is configured through the *TT\_FC* bit field in the *DMA\_CTLx* register. Except for the memory-to-memory transfer, the handshake between the peripheral and the DMA should be configured for other transfer methods. The peripheral handshake values are shown in the following table:

Table 19-1 Handshake Values

| Handshake Value | Peripheral Signal | Peripheral Signal Description |
|-----------------|-------------------|-------------------------------|
| 4               | lorac_tx          | LORA's tx                     |
| 5               | lorac_rx          | LORA's rx                     |
| 6               | daccctrl          | DAC                           |
| 7               | adccctrl          | ADC                           |
| 10              | i2c2_tx           | I2C2's tx                     |
| 11              | i2c2_rx           | I2C2's rx                     |
| 12              | i2c1_tx           | I2C1's tx                     |
| 13              | i2c1_rx           | I2C1's rx                     |
| 14              | i2c0_tx           | I2C0's tx                     |
| 15              | i2c0_rx           | I2C0's rx                     |
| 16              | ssp2_tx           | SSP2's tx                     |
| 17              | ssp2_rx           | SSP2's rx                     |
| 18              | ssp1_tx           | SSP1's tx                     |
| 19              | ssp1_rx           | SSP1's rx                     |

| Handshake Value | Peripheral Signal | Peripheral Signal Description |
|-----------------|-------------------|-------------------------------|
| 20              | ssp0_tx           | SSP0's tx                     |
| 21              | ssp0_rx           | SSP0's rx                     |
| 22              | lpuart_tx         | LPUAR's tx                    |
| 23              | lpuart_rx         | LPUAR's rx                    |
| 24              | uart3_tx          | UART3's tx                    |
| 25              | uart3_rx          | UART3's rx                    |
| 26              | uart2_tx          | UART2's tx                    |
| 27              | uart2_rx          | UART2's rx                    |
| 28              | uart1_tx          | UART1's tx                    |
| 29              | uart1_rx          | UART1's rx                    |
| 30              | uart0_tx          | UART0's tx                    |
| 31              | uart0_rx          | UART0's rx                    |
| 32              | gptim0_ch3        | GPTIMER0's channel3           |
| 33              | gptim0_ch2        | GPTIMER0's channel2           |
| 34              | gptim0_ch1        | GPTIMER0's channel1           |
| 35              | gptim0_ch0        | GPTIMER0's channel0           |
| 36              | gptim0_trg        | GPTIMER0's trigger            |
| 37              | gptim0_up         | GPTIMER0's update             |
| 38              | Gptim1_ch3        | GPTIMER1's channel3           |
| 39              | Gptim1_ch2        | GPTIMER1's channel2           |
| 40              | Gptim1_ch1        | GPTIMER1's channel1           |
| 41              | Gptim1_ch0        | GPTIMER1's channel0           |
| 42              | Gptim1_trg        | GPTIMER1's trigger            |
| 43              | Gptim1_up         | GPTIMER1's update             |
| 44              | gptim2_ch1        | GPTIMER2's channel1           |
| 45              | gptim2_ch0        | GPTIMER2's channel0           |
| 46              | gptim2_trg        | GPTIMER2's trigger            |
| 47              | gptim2_up         | GPTIMER2's update             |
| 48              | Gptim3_ch1        | GPTIMER3's channel1           |
| 49              | Gptim3_ch0        | GPTIMER3's channel0           |
| 50              | Gptim3_trg        | GPTIMER3's trigger            |
| 51              | Gptim3_up         | GPTIMER3's update             |
| 52              | basictim1_up      | BSTIMER1's update             |
| 53              | basictim0_up      | BSTIMER0's update             |

## 19.5 LLI

LLI (i.e., the linked list) can be used when there are multiple discontinuous blocks of memory data to be transferred to peripheral or memory, as shown in the following figure:



Figure 19-2 LLI

LLI(0) and LLI(1) are used to configure block0 and block1 information, including source and destination address, data bit width, burst length and block length. LLPx indicates the address where the current block points to the next block. The LLPx address refers to the address of the current block's LLP pointing to the next block. The address of the first block's LLP pointing to the second block is the first address of the LLI(1). In this order, the last block LLP address is 0. The length of each block can be different, as well as the first address of the memory.

## 19.6 Auto-reloading

Auto-reloading means that when the memory data in the block is finished being transferred or written, the data is transferred or written again from the starting address of this memory until the channel of the DMA used is disabled. The source and destination of the DMA can use the auto-reloading function as long as it is memory.

## 19.7 Interrupt

The DMA interrupt signals are as follows:

**Table 19-2 DMA Interrupt Signals**

| Interrupt Name                                     | Description                                                                |
|----------------------------------------------------|----------------------------------------------------------------------------|
| DMA block transfer complete interrupt              | The interrupt generated after the DMA block transfer is completed          |
| DMA destination port processing complete interrupt | The interrupt generated after DMA destination port processing is completed |
| DMA source port processing complete interrupt      | The interrupt generated after DMA source port processing is completed      |
| DMA transfer error interrupt                       | The interrupt generated when an error occurs during the DMA transfer       |
| DMA full transfer complete interrupt               | The interrupt generated after a full DMA transfer is completed             |

The above interrupts are enabled by configuring the [DMA\\_MaskBlock](#), [DMA\\_MaskDstTran](#), [DMA\\_MaskSrcTran](#), [DMA\\_MaskErr](#) and [DMA\\_MaskTfr](#) registers.

The status of all interrupts is available via the [DMA\\_StatusBlock](#), [DMA\\_StatusDstTran](#), [DMA\\_StatusSrcTran](#), [DMA\\_StatusErr](#) and [DMA\\_StatusTfr](#) registers.

The interrupt status is cleared by configuring the [DMA\\_ClearBlock](#), [DMA\\_ClearDstTran](#), [DMA\\_ClearSrcTran](#), [DMA\\_ClearErr](#), and [DMA\\_ClearTfr](#) registers.

## 19.8 DMA-related Register Description

DMA0 base address: 0x40023000

DMA1 base address: 0x40024000

**Table 19-3 DMA Register List**

| Register          | Offsets | Description                                                                                                                |
|-------------------|---------|----------------------------------------------------------------------------------------------------------------------------|
| DMA_SARx          | 0x00    | Source address register, x means channel 0, 1, 2, 3, corresponding to offsets 0x00, 0x58, 0xb0, 0x108, respectively        |
| DMA_DARx          | 0x08    | Destination address register, x means channel 0, 1, 2, 3, corresponding to offsets 0x08, 0x60, 0xb8, 0x110, respectively   |
| DMA_LLPx          | 0x10    | Linked-list pointer register, x means channel 0, 1, 2, 3, corresponding to offsets 0x10, 0x68, 0xc0, 0x118, respectively   |
| DMA_CTLx          | 0x18    | Channel control register, x means channel 0, 1, 2, 3, corresponding to offsets 0x18, 0x70, 0xc8, 0x120, respectively       |
| DMA_CFGx          | 0x40    | Channel configuration register, x means channel 0, 1, 2, 3, corresponding to offsets 0x40, 0x98, 0xf0, 0x148, respectively |
| DMA_StatusTfr     | 0x2e8   | DMA full transfer complete interrupt status register                                                                       |
| DMA_StatusBlock   | 0x2f0   | DMA block transfer complete interrupt status register                                                                      |
| DMA_StatusSrcTran | 0x2f8   | DMA source port processing complete interrupt status register                                                              |
| DMA_StatusDstTran | 0x300   | DMA destination port processing complete interrupt status register                                                         |
| DMA_StatusErr     | 0x308   | DMA transfer error interrupt status register                                                                               |
| DMA_MaskTfr       | 0x310   | DMA full transfer complete interrupt enable register                                                                       |
| DMA_MaskBlock     | 0x318   | DMA block transfer complete interrupt enable register                                                                      |
| DMA_MaskSrcTran   | 0x320   | DMA source port processing complete interrupt enable register                                                              |
| DMA_MaskDstTran   | 0x328   | DMA destination port processing complete interrupt enable register                                                         |
| DMA_MaskErr       | 0x330   | DMA transfer error interrupt enable register                                                                               |
| DMA_ClearTfr      | 0x338   | DMA full transfer complete interrupt status clear register                                                                 |
| DMA_ClearBlock    | 0x340   | DMA block transfer complete interrupt status clear register                                                                |
| DMA_ClearSrcTran  | 0x348   | DMA source port processing complete interrupt status clear register                                                        |

|                  |       |                                                                          |
|------------------|-------|--------------------------------------------------------------------------|
| DMA_ClearDstTran | 0x350 | DMA destination port processing complete interrupt status clear register |
| DMA_ClearErr     | 0x358 | DMA transfer error interrupt status clear register                       |
| DMA_DmaCfgReg    | 0x398 | DMA enable register                                                      |
| DMA_ChEnReg      | 0x3a0 | DMA channel enable register                                              |

### 19.8.1 DMA\_SARx

Address Offset: 0x00、0x58、0xb0、0x108

Reset Value: 0x000000000000000000000000

| 63-32    | 31-0  |
|----------|-------|
| RESERVED | SAR   |
| r-0h     | rw-0h |

**Bit 63-32 RESERVED:** Reserved.

**Bit 31-0 SAR:** DMA source address register.

### 19.8.2 DMA\_DARx

Address Offset: 0x08、0x60、0xb8、0x110

Reset Value: 0x000000000000000000000000

| 63-32    | 31-0  |
|----------|-------|
| RESERVED | DAR   |
| r-0h     | rw-0h |

**Bit 63-32 RESERVED:** Reserved.

**Bit 31-0 DAR:** DMA destination address register.

### 19.8.3 DMA\_LLPx

Address Offset: 0x10、0x68、0xc0、0x118

Reset Value: 0x000000000000000000000000

| 63-32    | 31-0  |
|----------|-------|
| RESERVED | LOC   |
| r-0h     | rw-0h |

**Bit 63-32 RESERVED:** Reserved.

**Bit 31-0 LOC:** The first address of the next LLI.

#### 19.8.4 DMA\_CTLx

Address Offset: 0x18、0x70、0xc8、0x120

Reset Value: 0x0000000200308801

| <b>63-45</b>   | <b>44</b>     | <b>43-32</b> | <b>31-29</b> | <b>28</b>   |
|----------------|---------------|--------------|--------------|-------------|
| RESERVED       | DONE          | BLOCK_TS     | RESERVED     | LLP_SRC_EN  |
| r-0h           | rw-0h         | rw-2h        | rw-0h        | rw-0h       |
| <b>27</b>      | <b>26-25</b>  | <b>24-23</b> | <b>22-20</b> | <b>19</b>   |
| LLP_DST_EN     | SMS           | DMS          | TT_FC        | RESERVED    |
| rw-0h          | rw-0h         | rw-0h        | rw-3h        | rw-0h       |
| <b>18</b>      | <b>17</b>     | <b>16-14</b> | <b>13-11</b> | <b>10-9</b> |
| DST_SCATTER_EN | SRC_GATHER_EN | SRC_MSIZE    | DEST_MSIZE   | SINC        |
| rw-0h          | rw-0h         | rw-1h        | rw-1h        | rw-0h       |
| <b>8-7</b>     | <b>6-4</b>    | <b>3-1</b>   |              | <b>0</b>    |
| DINC           | SRC_TR_WIDTH  | DST_TR_WIDTH |              | INT_EN      |
| rw-0h          | rw-0h         | rw-0h        |              | rw-1h       |

**Bit 63-45 RESERVED:** Reserved.

**Bit 44 DONE:** Whether a block in LLI is transferred or not.

- 0: Completed
- 1: Not completed

**Bit 43-32 BLOCK\_TS:** Block length.

**Bit 31-29 RESERVED:** Reserved.

**Bit 28 LLP\_SRC\_EN:** DMA source enable LLI.

- 0: Disabled
- 1: Enabled

**Bit 27 LLP\_DST\_EN:** DMA destination enable LLI.

- 0: Disabled
- 1: Enabled

**Bit 26-25 SMS:** AHB master selection for DMA source.

- 00: AHB master 1
- 01: AHB master 2
- 10: AHB master 3
- 11: AHB master 4

**Bit 24-23 SMS:** AHB master selection for DMA destination.

- 00: AHB master 1
- 01: AHB master 2
- 10: AHB master 3
- 11: AHB master 4

**Bit 22-20 TT\_FC:** DMA data transfer method selection.

- 000: Memory-to-Memory of DMA flow control
- 001: Memory-to-peripheral of DMA flow control
- 010: Peripheral-to-memory of DMA flow control
- 011: Peripheral-to-peripheral of DMA flow control
- Other values: Invalid

**Bit 19 RESERVED:** Reserved.

**Bit 18 DST\_SCATTER\_EN:** DMA destination enable scatter.

- 0: Disabled
- 1: Enabled

**Bit 17 SRC\_GATHER\_EN:** DMA source enable gather.

- 0: Disabled
- 1: Enabled

**Bit 16-14 SRC\_MSIZE:** DMA source burst length configuration.

- 000: 1
- 001: 4
- 010: 8
- Other values: Invalid

**Bit 13-11 DEST\_MSIZE:** DMA destination burst length configuration.

- 000: 1
- 001: 4
- 010: 8
- Other values: Invalid

**Bit 10-9 SINC:** DMA source address control.

- 00: Incremented
- 01: Decrement
- 10: Unchanged
- 11: Unchanged

**Bit 8-7 DINC:** DMA destination address control.

- 00: Incremented
- 01: Decrement
- 10: Unchanged
- 11: Unchanged

**Bit 6-4 SRC\_TR\_WIDTH:** DMA source data bit width configuration.

- 000: 8 bits
- 001: 16 bits
- 010: 32 bits
- Other values: Invalid

**Bit 3-1 DST\_TR\_WIDTH:** DMA destination data bit width configuration.

- 000: 8 bits
- 001: 16 bits
- 010: 32 bits

- Other values: Invalid

**Bit 0 INT\_EN:** DMA interrupt enable.

- 0: Disabled
- 1: Enabled

### 19.8.5 DMA\_CFGx

Address Offset: 0x40、0x98、0xf0、0x148

Reset Value: 0x0000000400020e00

| 63-47      | 46-43      | 42-39      | 38           | 37           | 36-34      |
|------------|------------|------------|--------------|--------------|------------|
| RESERVED   | DEST_PER   | SRC_PER    | SS_UPD_EN    | DS_UPD_EN    | PROTCTL    |
| r-0h       | rw-0h      | rw-0h      | rw-0h        | rw-0h        | rw-1h      |
| <b>33</b>  | <b>32</b>  | <b>31</b>  | <b>30</b>    | <b>29-20</b> | <b>19</b>  |
| FIFO_MODE  | FCMODE     | RELOAD_DST | RELOAD_SRC   | RESERVED     | SRC_HS_POL |
| rw-0h      | rw-0h      | rw-0h      | rw-0h        | r-0h         | rw-0h      |
| <b>18</b>  | <b>17</b>  | <b>16</b>  | <b>15-14</b> | <b>13-12</b> | <b>11</b>  |
| DST_HS_POL | LOCK_B     | LOCK_CH    | LOCK_B_L     | LOCK_CH_L    | HS_SEL_SRC |
| rw-0h      | rw-1h      | rw-0h      | rw-0h        | rw-0h        | rw-1h      |
| <b>10</b>  | <b>9</b>   | <b>8</b>   | <b>7-5</b>   | <b>4-0</b>   |            |
| HS_SEL_DST | FIFO_EMPTY | CH_SUSP    | CH_PRIOR     | RESERVED     |            |
| rw-1h      | r-1h       | rw-0h      | rw-0h        | r-0h         |            |

**Bit 63-47 RESERVED:** Reserved.

**Bit 46-43 DEST\_PER:** DMA destination handshake port with valid values of 0 to 3.

**Bit 42-39 SRC\_PER:** DMA source handshake interface with valid values of 0 to 3.

**Bit 38 SS\_UPD\_EN:** DMA source status update enable.

- 0: Disabled
- 1: Enabled

**Bit 37 DS\_UPD\_EN:** DMA destination status update enable.

- 0: Disabled
- 1: Enabled

**Bit 36-34 PROTCTL:** Protect control.

**Bit 33 FIFO\_MODE:** FIFO mode selection.

- 0: All FIFOs are available
- 1: Only half of the FIFOs are available

**Bit 32 FCMODE:** Source port flow control mode selection.

- 0: The request from the source port is processed as soon as it is sent
- 1: The request from the source port is not processed until there is a request from the destination port

**Bit 31 RELOAD\_DST:** DMA destination enable auto-reloading.

- 0: Disabled

- 1: Enabled

**Bit 30 RELOAD\_SRC:** DMA source enables auto-reloading.

- 0: Disabled
- 1: Enabled

**Bit 29-20 RESERVED:** Reserved.

**Bit 19 SRC\_HS\_POL:** DMA source handshake port information polarity.

- 0: Active at high level
- 1: Active at low level

**Bit 18 SRC\_HS\_POL:** DMA destination handshake port information polarity.

- 0: Active at high level
- 1: Active at low level

**Bit 17 LOCK\_B:** Bus lock control.

- 0: Unlocked
- 1: Locked

**Bit 16 LOCK\_CH:** DMA channel lock control.

- 0: Unlocked
- 1: Locked

**Bit 15-14 LOCK\_B\_L:** Bus lock delay.

- 00: Wait until DMA transfer is completed
- 01: Wait until block transfer is completed
- 10: Wait until DMA processing is completed

**Bit 13-12 LOCK\_CH\_L:** DMA channel lock delay.

- 00: Wait until DMA transfer is completed
- 01: Wait until block transfer is completed
- 10: Wait until DMA processing is completed

**Bit 11 HS\_SEL\_SRC:** DMA source handshake signal selection.

- 0: Hardware handshake
- 1: Software handshake

**Bit 10 HS\_SEL\_DST:** DMA destination handshake signal selection.

- 0: Hardware handshake
- 1: Software handshake

**Bit 9 FIFO\_EMPTY:** Whether DMA channel FIFO is empty.

- 0: Not empty
- 1: Empty

**Bit 8 CH\_SUSP:** Whether DMA channel FIFO is suspended.

- 0: Not suspended
- 1: Suspended

**Bit 7-5 CH\_PRIOR:** DMA channel priority configuration with valid values from 0 to 3, 0 being the lowest priority and 3 being the highest priority.

**Bit 4-0 RESERVED:** Reserved.

### 19.8.6 DMA\_StatusTfr

Address Offset: 0x2e8

Reset Value: 0x0000000000000000

| 63-4     | 3            | 2            | 1            | 0            |
|----------|--------------|--------------|--------------|--------------|
| RESERVED | CHAN3_STATUS | CHAN2_STATUS | CHAN1_STATUS | CHAN0_STATUS |
| r-0h     | r-0h         | r-0h         | r-0h         | r-0h         |

**Bit 63-4 RESERVED:** Reserved.

**Bit 3 CHAN3\_STATUS:** DMA channel3 transfer complete status.

- 0: Not completed
- 1: Completed

**Bit 2 CHAN2\_STATUS:** DMA channel2 transfer complete status.

- 0: Not completed
- 1: Completed

**Bit 1 CHAN1\_STATUS:** DMA channel1 transfer complete status.

- 0: Not completed
- 1: Completed

**Bit 0 CHAN0\_STATUS:** DMA channel0 transfer complete status.

- 0: Not completed
- 1: Completed

### 19.8.7 DMA\_StatusBlock

Address Offset: 0x2f0

Reset Value: 0x0000000000000000

| 63-4     | 3            | 2            | 1            | 0            |
|----------|--------------|--------------|--------------|--------------|
| RESERVED | CHAN3_STATUS | CHAN2_STATUS | CHAN1_STATUS | CHAN0_STATUS |
| r-0h     | r-0h         | r-0h         | r-0h         | r-0h         |

**Bit 63-4 RESERVED:** Reserved.

**Bit 3 CHAN3\_STATUS:** DMA channel3 block transfer complete status.

- 0: Not completed
- 1: Completed

**Bit 2 CHAN2\_STATUS:** DMA channel2 block transfer complete status.

- 0: Not completed
- 1: Completed

**Bit 1 CHAN1\_STATUS:** DMA channel1 block transfer complete status.

- 0: Not completed
- 1: Completed

**Bit 0 CHAN0\_STATUS:** DMA channel0 block transfer complete status.

- 0: Not completed
- 1: Completed

### 19.8.8 DMA\_StatusSrcTran

Address Offset: 0x2f8

Reset Value: 0x0000000000000000

| 63-4     | 3            | 2            | 1            | 0            |
|----------|--------------|--------------|--------------|--------------|
| RESERVED | CHAN3_STATUS | CHAN2_STATUS | CHAN1_STATUS | CHAN0_STATUS |
| r-0h     | r-0h         | r-0h         | r-0h         | r-0h         |

**Bit 63-4 RESERVED:** Reserved.

**Bit 3 CHAN3\_STATUS:** DMA channel3 source port transfer complete status.

- 0: Not completed
- 1: Completed

**Bit 2 CHAN2\_STATUS:** DMA channel2 source port transfer complete status.

- 0: Not completed
- 1: Completed

**Bit 1 CHAN1\_STATUS:** DMA channel1 source port transfer complete status.

- 0: Not completed
- 1: Completed

**Bit 0 CHAN0\_STATUS:** DMA channel0 source port transfer complete status.

- 0: Not completed
- 1: Completed

### 19.8.9 DMA\_StatusDstTran

Address Offset: 0x300

Reset Value: 0x0000000000000000

| 63-4     | 3            | 2            | 1            | 0            |
|----------|--------------|--------------|--------------|--------------|
| RESERVED | CHAN3_STATUS | CHAN2_STATUS | CHAN1_STATUS | CHAN0_STATUS |
| r-0h     | r-0h         | r-0h         | r-0h         | r-0h         |

**Bit 63-4 RESERVED:** Reserved.

**Bit 3 CHAN3\_STATUS:** DMA channel3 destination port transfer complete status.

- 0: Not completed

- 1: Completed

**Bit 2 CHAN2\_STATUS:** DMA channel2 destination port transfer complete status.

- 0: Not completed
- 1: Completed

**Bit 1 CHAN1\_STATUS:** DMA channel1 destination port transfer complete status.

- 0: Not completed
- 1: Completed

**Bit 0 CHAN0\_STATUS:** DMA channel0 destination port transfer complete status.

- 0: Not completed
- 1: Completed

#### 19.8.10 DMA\_StatusErr

Address Offset: 0x308

Reset Value: 0x0000000000000000

| 63-4     | 3            | 2            | 1            | 0            |
|----------|--------------|--------------|--------------|--------------|
| RESERVED | CHAN3_STATUS | CHAN2_STATUS | CHAN1_STATUS | CHAN0_STATUS |
| r-0h     | r-0h         | r-0h         | r-0h         | r-0h         |

**Bit 63-4 RESERVED:** Reserved.

**Bit 3 CHAN3\_STATUS:** DMA channel3 transfer error status.

- 0: No error
- 1: Error

**Bit 2 CHAN2\_STATUS:** DMA channel2 transfer error status.

- 0: No error
- 1: Error

**Bit 1 CHAN1\_STATUS:** DMA channel1 transfer error status.

- 0: No error
- 1: Error

**Bit 0 CHAN0\_STATUS:** DMA channel0 transfer error status.

- 0: No error
- 1: Error

#### 19.8.11 DMA\_MaskTfr

Address Offset: 0x310

Reset Value: 0x0000000000000000

| 63-12    | 11            | 10            | 9             | 8             |
|----------|---------------|---------------|---------------|---------------|
| RESERVED | INT_MASK_WE_3 | INT_MASK_WE_2 | INT_MASK_WE_1 | INT_MASK_WE_0 |

|            |            |            |            |            |
|------------|------------|------------|------------|------------|
| r-0h       | w-0h       | w-0h       | w-0h       | w-0h       |
| <b>7-4</b> | <b>3</b>   | <b>2</b>   | <b>1</b>   | <b>0</b>   |
| RESERVED   | INT_MASK_3 | INT_MASK_2 | INT_MASK_1 | INT_MASK_0 |
| r-0h       | rw-0h      | rw-0h      | rw-0h      | rw-0h      |

**Bit 63-12 RESERVED:** Reserved.

**Bit 11 INT\_MASK\_WE\_3:** DMA channel3 transfer complete Interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 10 INT\_MASK\_WE\_2:** DMA channel2 transfer complete Interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 9 INT\_MASK\_WE\_1:** DMA channel1 transfer complete Interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 8 INT\_MASK\_WE\_0:** DMA channel0 transfer complete Interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 7-4 RESERVED:** Reserved.

**Bit 3 INT\_MASK\_3:** DMA channel3 transfer complete Interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 2 INT\_MASK\_2:** DMA channel2 transfer complete Interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 1 INT\_MASK\_1:** DMA channel1 transfer complete Interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 0 INT\_MASK\_0:** DMA channel0 transfer complete Interrupt enable.

- 0: Disabled
- 1: Enabled

### 19.8.12 DMA\_MaskBlock

Address Offset: 0x318

Reset Value: 0x0000000000000000

| <b>63-12</b> | <b>11</b>     | <b>10</b>     | <b>9</b>      | <b>8</b>      |
|--------------|---------------|---------------|---------------|---------------|
| RESERVED     | INT_MASK_WE_3 | INT_MASK_WE_2 | INT_MASK_WE_1 | INT_MASK_WE_0 |
| r-0h         | w-0h          | w-0h          | w-0h          | w-0h          |

| 7-4      | 3          | 2          | 1          | 0          |
|----------|------------|------------|------------|------------|
| RESERVED | INT_MASK_3 | INT_MASK_2 | INT_MASK_1 | INT_MASK_0 |
| r-0h     | rw-0h      | rw-0h      | rw-0h      | rw-0h      |

**Bit 63-12 RESERVED:** Reserved.

**Bit 11 INT\_MASK\_WE\_3:** DMA channel3 block transfer complete Interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 10 INT\_MASK\_WE\_2:** DMA channel2 block transfer complete Interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 9 INT\_MASK\_WE\_1:** DMA channel1 block transfer complete Interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 8 INT\_MASK\_WE\_0:** DMA channel0 block transfer complete Interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 7-4 RESERVED:** Reserved.

**Bit 3 INT\_MASK\_3:** DMA channel3 block transfer complete Interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 2 INT\_MASK\_2:** DMA channel2 block transfer complete Interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 1 INT\_MASK\_1:** DMA channel1 block transfer complete Interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 0 INT\_MASK\_0:** DMA channel0 block transfer complete Interrupt enable.

- 0: Disabled
- 1: Enabled

### 19.8.13 DMA\_MaskSrcTran

Address Offset: 0x320

Reset Value: 0x0000000000000000

| 63-12    | 11            | 10            | 9             | 8             |
|----------|---------------|---------------|---------------|---------------|
| RESERVED | INT_MASK_WE_3 | INT_MASK_WE_2 | INT_MASK_WE_1 | INT_MASK_WE_0 |
| r-0h     | w-0h          | w-0h          | w-0h          | w-0h          |
| 7-4      | 3             | 2             | 1             | 0             |

| RESERVED | INT_MASK_3 | INT_MASK_2 | INT_MASK_1 | INT_MASK_0 |
|----------|------------|------------|------------|------------|
| r-0h     | rw-0h      | rw-0h      | rw-0h      | rw-0h      |

**Bit 63-12 RESERVED:** Reserved.

**Bit 11 INT\_MASK\_WE\_3:** DMA channel3 source port transfer complete interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 10 INT\_MASK\_WE\_2:** DMA channel2 source port transfer complete interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 9 INT\_MASK\_WE\_1:** DMA channel1 source port transfer complete interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 8 INT\_MASK\_WE\_0:** DMA channel0 source port transfer complete interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 7-4 RESERVED:** Reserved.

**Bit 3 INT\_MASK\_3:** DMA channel3 source port transfer complete interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 2 INT\_MASK\_2:** DMA channel2 source port transfer complete interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 1 INT\_MASK\_1:** DMA channel1 source port transfer complete interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 0 INT\_MASK\_0:** DMA channel0 source port transfer complete interrupt enable.

- 0: Disabled
- 1: Enabled

#### 19.8.14 DMA\_MaskDstTran

Address Offset: 0x328

Reset Value: 0x0000000000000000

| 63-12    | 11            | 10            | 9             | 8             |
|----------|---------------|---------------|---------------|---------------|
| RESERVED | INT_MASK_WE_3 | INT_MASK_WE_2 | INT_MASK_WE_1 | INT_MASK_WE_0 |
| r-0h     | w-0h          | w-0h          | w-0h          | w-0h          |
| 7-4      | 3             | 2             | 1             | 0             |
| RESERVED | INT_MASK_3    | INT_MASK_2    | INT_MASK_1    | INT_MASK_0    |

|      |       |       |       |       |
|------|-------|-------|-------|-------|
| r-0h | rw-0h | rw-0h | rw-0h | rw-0h |
|------|-------|-------|-------|-------|

**Bit 63-12 RESERVED:** Reserved.

**Bit 11 INT\_MASK\_WE\_3:** DMA channel3 destination port transfer complete interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 10 INT\_MASK\_WE\_2:** DMA channel2 destination port transfer complete interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 9 INT\_MASK\_WE\_1:** DMA channel1 destination port transfer complete interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 8 INT\_MASK\_WE\_0:** DMA channel0 destination port transfer complete interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 7-4 RESERVED:** Reserved.

**Bit 3 INT\_MASK\_3:** DMA channel3 destination port transfer complete interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 2 INT\_MASK\_2:** DMA channel2 destination port transfer complete interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 1 INT\_MASK\_1:** DMA channel1 destination port transfer complete interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 0 INT\_MASK\_0:** DMA channel0 destination port transfer complete interrupt enable.

- 0: Disabled
- 1: Enabled

### 19.8.15 DMA\_MaskErr

Address Offset: 0x330

Reset Value: 0x0000000000000000

| 63-12    | 11            | 10            | 9             | 8             |
|----------|---------------|---------------|---------------|---------------|
| RESERVED | INT_MASK_WE_3 | INT_MASK_WE_2 | INT_MASK_WE_1 | INT_MASK_WE_0 |

|            |            |            |            |            |
|------------|------------|------------|------------|------------|
| r-0h       | w-0h       | w-0h       | w-0h       | w-0h       |
| <b>7-4</b> | <b>3</b>   | <b>2</b>   | <b>1</b>   | <b>0</b>   |
| RESERVED   | INT_MASK_3 | INT_MASK_2 | INT_MASK_1 | INT_MASK_0 |
| r-0h       | rw-0h      | rw-0h      | rw-0h      | rw-0h      |

**Bit 63-12 RESERVED:** Reserved.

**Bit 11 INT\_MASK\_WE\_3:** DMA channel3 transfer error interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 10 INT\_MASK\_WE\_2:** DMA channel2 transfer error interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 9 INT\_MASK\_WE\_1:** DMA channel1 transfer error interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 8 INT\_MASK\_WE\_0:** DMA channel0 transfer error interrupt mask write enable.

- 0: Disabled
- 1: Enabled

**Bit 7-4 RESERVED:** Reserved.

**Bit 3 INT\_MASK\_3:** DMA channel3 transfer error interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 2 INT\_MASK\_2:** DMA channel2 transfer error interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 1 INT\_MASK\_1:** DMA channel1 transfer error interrupt enable.

- 0: Disabled
- 1: Enabled

**Bit 0 INT\_MASK\_0:** DMA channel0 transfer error interrupt enable.

- 0: Disabled
- 1: Enabled

### 19.8.16 DMA\_ClearTfr

Address Offset: 0x338

Reset Value: 0x0000000000000000

| <b>63-4</b> | <b>3</b>    | <b>2</b>    | <b>1</b>    | <b>0</b>    |
|-------------|-------------|-------------|-------------|-------------|
| RESERVED    | CHAN3_CLEAR | CHAN2_CLEAR | CHAN1_CLEAR | CHAN0_CLEAR |
| r-0h        | w-0h        | w-0h        | w-0h        | w-0h        |

**Bit 63-4 RESERVED:** Reserved.

**Bit 3 CHAN3\_CLEAR:** DMA channel3 transfer complete status clear.

- 0: No action
- 1: Cleared

**Bit 2 CHAN2\_CLEAR:** DMA channel2 transfer complete status clear.

- 0: No action
- 1: Cleared

**Bit 1 CHAN1\_CLEAR:** DMA channel1 transfer complete status clear.

- 0: No action
- 1: Cleared

**Bit 0 CHAN0\_CLEAR:** DMA channel0 transfer complete status clear.

- 0: No action
- 1: Cleared

### 19.8.17 DMA\_ClearBlock

Address Offset: 0x340

Reset Value: 0x0000000000000000

| 63-4     | 3           | 2           | 1           | 0           |
|----------|-------------|-------------|-------------|-------------|
| RESERVED | CHAN3_CLEAR | CHAN2_CLEAR | CHAN1_CLEAR | CHAN0_CLEAR |
| r-0h     | w-0h        | w-0h        | w-0h        | w-0h        |

**Bit 63-4 RESERVED:** Reserved.

**Bit 3 CHAN3\_CLEAR:** DMA channel3 block transfer complete status clear.

- 0: No action
- 1: Cleared

**Bit 2 CHAN2\_CLEAR:** DMA channel2 block transfer complete status clear.

- 0: No action
- 1: Cleared

**Bit 1 CHAN1\_CLEAR:** DMA channel1 block transfer complete status clear.

- 0: No action
- 1: Cleared

**Bit 0 CHAN0\_CLEAR:** DMA channel0 block transfer complete status clear.

- 0: No action
- 1: Cleared

### 19.8.18 DMA\_ClearSrcTran

Address Offset: 0x348

Reset Value: 0x0000000000000000

| 63-4     | 3           | 2           | 1           | 0           |
|----------|-------------|-------------|-------------|-------------|
| RESERVED | CHAN3_CLEAR | CHAN2_CLEAR | CHAN1_CLEAR | CHAN0_CLEAR |
| r-0h     | w-0h        | w-0h        | w-0h        | w-0h        |

**Bit 63-4 RESERVED:** Reserved.

**Bit 3 CHAN3\_CLEAR:** DMA channel3 source port transfer complete status clear.

- 0: No action
- 1: Cleared

**Bit 2 CHAN2\_CLEAR:** DMA channel2 source port transfer complete status clear.

- 0: No action
- 1: Cleared

**Bit 1 CHAN1\_CLEAR:** DMA channel1 source port transfer complete status clear.

- 0: No action
- 1: Cleared

**Bit 0 CHAN0\_CLEAR:** DMA channel0 source port transfer complete status clear.

- 0: No action
- 1: Cleared

### 19.8.19 DMA\_ClearDstTran

Address Offset: 0x350

Reset Value: 0x0000000000000000

| 63-4     | 3           | 2           | 1           | 0           |
|----------|-------------|-------------|-------------|-------------|
| RESERVED | CHAN3_CLEAR | CHAN2_CLEAR | CHAN1_CLEAR | CHAN0_CLEAR |
| r-0h     | w-0h        | w-0h        | w-0h        | w-0h        |

**Bit 63-4 RESERVED:** Reserved.

**Bit 3 CHAN3\_CLEAR:** DMA channel3 destination port transfer complete status clear.

- 0: No action
- 1: Cleared

**Bit 2 CHAN2\_CLEAR:** DMA channel2 destination port transfer complete status clear.

- 0: No action
- 1: Cleared

**Bit 1 CHAN1\_CLEAR:** DMA channel1 destination port transfer complete status clear.

- 0: No action
- 1: Cleared

**Bit 0 CHAN0\_CLEAR:** DMA channel0 destination port transfer complete status clear.

- 0: No action
- 1: Cleared

### 19.8.20 DMA\_ClearErr

Address Offset: 0x358

Reset Value: 0x0000000000000000

| 63-4     | 3           | 2           | 1           | 0           |
|----------|-------------|-------------|-------------|-------------|
| RESERVED | CHAN3_CLEAR | CHAN2_CLEAR | CHAN1_CLEAR | CHAN0_CLEAR |
| r-0h     | w-0h        | w-0h        | w-0h        | w-0h        |

**Bit 63-4 RESERVED:** Reserved.

**Bit 3 CHAN3\_CLEAR:** DMA channel3 transfer error status clear.

- 0: No action
- 1: Cleared

**Bit 2 CHAN2\_CLEAR:** DMA channel2 transfer error status clear.

- 0: No action
- 1: Cleared

**Bit 1 CHAN1\_CLEAR:** DMA channel1 transfer error status clear.

- 0: No action
- 1: Cleared

**Bit 0 CHAN0\_CLEAR:** DMA channel0 transfer error status clear.

- 0: No action
- 1: Cleared

### 19.8.21 DMA\_DmaCfgReg

Address Offset: 0x398

Reset Value: 0x0000000000000000

| 63-1     | 0      |
|----------|--------|
| RESERVED | DMA_EN |
| r-0h     | rw-0h  |

**Bit 63-1 RESERVED:** Reserved.

**Bit 0 DMA\_EN:** DMA enable control.

- 0: Disabled
- 1: Enabled

### 19.8.22 DMA\_ChEnReg

Address Offset: 0x3a0

Reset Value: 0x0000000000000000

| <b>63-12</b> | <b>11</b>  | <b>10</b>  | <b>9</b>   | <b>8</b>   |
|--------------|------------|------------|------------|------------|
| RESERVED     | CH_EN_WE_3 | CH_EN_WE_2 | CH_EN_WE_1 | CH_EN_WE_0 |
| r-0h         | w-0h       | w-0h       | w-0h       | w-0h       |
| <b>7-4</b>   | <b>3</b>   | <b>2</b>   | <b>1</b>   | <b>0</b>   |
| RESERVED     | CH_EN_3    | CH_EN_2    | CH_EN_1    | CH_EN_0    |
| r-0h         | rw-0h      | rw-0h      | rw-0h      | rw-0h      |

**Bit 63-12 RESERVED:** Reserved.

**Bit 11 CH\_EN\_WE\_3:** DMA channel3 enable write enable.

- 0: Disabled
- 1: Enabled

**Bit 10 CH\_EN\_WE\_2:** DMA channel2 enable write enable.

- 0: Disabled
- 1: Enabled

**Bit 9 CH\_EN\_WE\_1:** DMA channel1 enable write enable.

- 0: Disabled
- 1: Enabled

**Bit 8 CH\_EN\_WE\_0:** DMA channel0 enable write enable.

- 0: Disabled
- 1: Enabled

**Bit 7-4 RESERVED:** Reserved.

**Bit 3 CH\_EN\_3:** DMA channel3 enable control. The hardware automatically disables the channel when the DMA transfer is completed.

- 0: Disabled
- 1: Enabled

**Bit 2 CH\_EN\_2:** DMA channel2 enable control. The hardware automatically disables the channel when the DMA transfer is completed.

- 0: Disabled
- 1: Enabled

**Bit 1 CH\_EN\_1:** DMA channel1 enable control. The hardware automatically disables the channel when the DMA transfer is completed.

- 0: Disabled
- 1: Enabled

**Bit 0 CH\_EN\_0:** DMA channel0 enable control. The hardware automatically disables the channel when the DMA transfer is completed.

- 0: Disabled
- 1: Enabled

# 20.

# GPTIMER

## 20.1 Introduction

ASR6601 has 4 general purpose timers (GPTIMER), of which GPTIMER0 and GPTIMER1 have 4 channels and GPTIMER2 and GPTIMER3 have 2 channels, i.e., GPTIMER2 and GPTIMER3 don't have channel 2 and channel 3.

GPTIMER consists of a 16-bit auto reload counter driven by a programmable prescaler of up to 16 bits, featuring 4 channels that can be independently configured as input or output for input capture or output compare, etc. Its counting clock and counting mode are software configurable. It can be connected with the Hall sensor, i.e., supports encoding mode (only for GPTIMER0 and GPTIMER1). It is DMA configurable, with independent interrupt output, supports encoding function, etc. Based on the rich channel configuration and functions, the GPTIMER can be used for timing counting, measuring the pulse lengths of input signals (us-ms level), generating PWM waveforms, etc.

## 20.2 Main Features

- 16-bit edge-aligned (up/down) and center-aligned (up/down) auto-reload counter
- 16-bit programmable prescaler (with frequency division factor between 1 and 65535), configurable during counting
- Up to 4 independent channels for input capture, output compare, PWM waveforms generation, and one-pulse waveform output
- Supports channel output polarity selection and input edge configuration
- Supports synchronization with external inputs or other modules (GPTIMER, ADC, DAC)
- Independent DMA channels with up to 6 sets of DMA requests, including update events, trigger events, and 4 sets of channel events (capture, compare)
- Supports quadrature encoding function
- Supports external trigger channel input clocks for counting and external trigger channels for trigger signal input, and channel input clocks for counting
- Supports channel remapping, i.e., mapping GPIO signals or internal signals from other modules to channels or external channels

The GPTIMER block diagram is shown below:



Figure 20-1 GPTIMER Block Diagram

Table 20-1 GPTIMER Module Introduction

| Module Name       | Description                                                                                     |
|-------------------|-------------------------------------------------------------------------------------------------|
| slave control     | slave mode controller                                                                           |
| master control    | master mode controller                                                                          |
| u_etr_ctrl        | ETR channel control, including polarity, frequency division, filtering and other configurations |
| u_channel_in_x    | input channel x control, including polarity, filtering and edge configuration                   |
| u_icx_div         | input channel x event divider                                                                   |
| u_sampling_clock  | sampling clock for filter generation                                                            |
| u_capture_x       | input channel x capture function                                                                |
| u_compare_x       | output channel x compare function                                                               |
| u_psc_counter     | 16-bit prescaler                                                                                |
| u_counter         | 16-bit counter                                                                                  |
| u_reg_model       | Register-related configuration                                                                  |
| output stage      | output control                                                                                  |
| interrupt control | interrupt control                                                                               |
| dma control       | DMA function control                                                                            |
| itr_input         | other GPTIMER internal input                                                                    |
| etr_input         | external trigger channel input                                                                  |
| channel_input     | channel input                                                                                   |
| dma_ack           | ACK from DMA                                                                                    |
| dma_req           | request sent to DMA                                                                             |

| Module Name    | Description                                                                                     |
|----------------|-------------------------------------------------------------------------------------------------|
| apb_write      | apb bus write                                                                                   |
| apb_read       | apb bus read                                                                                    |
| trigger_output | the signal output in the master mode, an internal signal that will not be output to the outside |
| channel_output | channel output                                                                                  |

## 20.3 Counter

GPTIMER's counter is 16-bit, supporting upward, downward, and center-aligned counting. Counting clock is optional. Counting enable and disable are software configurable. Software can read and write at any time (write is not recommended during counting to avoid unknown errors).

### 20.3.1 Counting Clock Selection

GPTimer has four counting clock sources: internal clock, external clock mode 1, external clock mode 2 and internal trigger signals. Among them, the internal clock is in the default mode ( $SMS==3'b000$ ) and comes from the RCC, which starts counting with the prescaler as soon as CEN is set. The other three clock sources, which use the corresponding signals as count enables, are not used as interface clocks.

In external clock mode 1 ( $SMS==3'b111$  and  $TS==3'b100/101/110$ ), the rising or falling or dual edge on the selected channel input is used as the counter's count enable for count control. For example, if the rising edge on the selected channel 0 is used for count control, each rising edge will add 1 to the counter (upcounting, no dividing). The waveform is shown below.



Figure 20-2 External Clock Mode 1 Counting

In external clock mode 2 ( $ECE==1$ ), the rising or falling edge of ETR is used as the counter's count enable for count control. For example, if the rising edge of ETR is configured to be active, the waveform is shown below.



Figure 20-3 External Clock Mode 2 Counting

The GPTIMER can also select the internal trigger signals to control the count (SMS==3'b111 and TS==3'b001/010/011), i.e., the trigger output signal of the previous stage GPTIMER can be used as its counting clock for GPTIMER chaining. In this case, the previous stage GPTIMER is equivalent to a prescaler. The waveform is shown below.



**Figure 20-4 Internal Trigger Signal for Clock Counting**

ETR as a count clock input can be implemented in two ways: external clock mode 1 configuring SMS to 3'b111 and TS to 3'b111, and external clock mode 2 configuring ECE to 1 in the [GPTIM\\_SMCR register](#).

### 20.3.2 Auto Reload

GPTIMER supports the auto reload function. In upcounting mode, the counter counts from 0 to the auto-reload value (ARR), then restarts from 0. In downcounting mode, the counter counts from the ARR down to 0, then restarts from the ARR. In center-aligned mode, the counter counts from 0 to the ARR-1, then counts from the ARR down to 0.

The ARR can be software configured (ARPE) to enable or disable the shadow register. If ARPE is configured to 0 in the [GPTIM\\_CR1 register](#), the shadow register is disabled and the software-written value is updated to the ARR for counter use synchronously. If ARPE is configured to 1 in the [GPTIM\\_CR1 register](#), the software-written value is not immediately effective and is not updated to the shadow register for counter use until an update event occurs.

### 20.3.3 Upcounting Mode

In upcounting mode, the counter counts from 0 to the ARR when enabled with a count clock, generates an overflow event (overflow), then restarts from 0. If the UG is set (by software or hardware) during the count, the counter, including the prescaler, will be initialized (returns to zero). Regarding timing, the overflow flag will be generated during the last t value counting. If the shadow register is enabled, values in ARR, PSC, CCRx, etc. registers will be updated to the corresponding shadow registers at the start of the next round of counting, as shown in the waveform below:



**Figure 20-5 Upcounting**

### 20.3.4 Downcounting Mode

In downcounting mode, the counter counts from the ARR down to 0 when it is enabled with a count clock, generates an underflow event (underflow), then restarts from the ARR. If the UG is set (by software or hardware) during counting, the counter, including the prescaler, will be initialized (the counter returns to the ARR and the prescaler returns to zero). In terms of timing, the underflow flag will be generated during the last value counting (configuring CNT to 0 in the [GPTIM\\_CNT register](#)). Note that if the shadow register is enabled, values in the ARR register will be updated to the corresponding shadow register before the next round of counting (configuring CNT to 0 in the [GPTIM\\_CNT register](#)) to ensure the latest loading value and prescaler value are available for the next counting. As before, PSC and CCRx update their values to the shadow registers on the next clock when underflow occurs. The waveform is shown below.



Figure 20-6 Downcounting

### 20.3.5 Center-aligned Mode

In center-aligned mode, the counter counts from 0 to the ARR-1 when enabled with a count clock, generates an overflow event, then counts from the ARR down to 1, and generates an underflow event. Then it restarts counting from 0. If the UG is set (by software or hardware) during counting, the counter, including the prescaler, is initialized (returns to zero). Note that If shadow registers are enabled, the ARR and PSC registers will update their values to the corresponding shadow registers when counting up to the old ARR-1 to ensure that the new ARR and PSC are active when counting down. The CCRx is updated as the same before. When counting down, the shadow registers of ARR, PSC and CCRx are updated after underflow is generated. In this mode, the counting direction is controlled by hardware and software non-configurable. The waveform is shown as follows:



Figure 20-7 Center-aligned Counting

## 20.4 Prescaler

GPTIMER supports 16-bit (1~65535) programmable prescaler to divide the counter clock frequency. The count enable signal generated by the previous level circuit is used as the enable of the prescaler for count control. When the prescaler counts to the preloaded prescaler value, a pulse is output as the count enable for the next stage counter, then the prescaler restarts from 0, and so on.

The shadow register of the prescaler is enabled by default, i.e., software write operations do not take effect immediately until an update event (UG set, overflow, and underflow) occurs before the new prescaler value is written to the shadow register. The software reads the written register value instead of the shadow register, so if there are multiple write operations before the update event occurs, the previously written value will be overwritten.

For example, if the prescaler is configured to division by 4, 4 high levels will be input before an effective pulse is output. The waveform is shown below (channel 0, no filtering, selecting the rising edge of channel 0 as an effective pulse, configuring ic0 as division by 4).



Figure 20-8 Prescaler

## 20.5 Sampling Clock

The digital filter can be used for each input channel and external trigger channel, which samples the input signal by using a high-frequency sampling clock (at least 4 times the frequency of the input signal). All Flip-Flop clocks inside GPTIMER are provided by pclk. The frequency of the sampling clock (the CKD is pclk, pclk/2, and pclk/4 respectively) can be configured by the software and divided by a counter. If the sampling frequency is configured as pclk/4, the counter is controlled by pclk for counting, and a pulse is generated every 4 pclk cycles (width of one cycle of pclk) as the enable signal of the next stage counter. Within each channel, the user can configure the sampling clock division frequency of the digital filter again, i.e., configure the value of ETF with the same filtering principle as above.

## 20.6 Channel

Each channel of each GPTIMER has multiple signal sources that are asynchronous to the GPTIMER and therefore need to be synchronized within the module. The synchronized channel input signal can be configured by software to be filtered, with the filter's sampling frequency and window length configured by software (ICxF). The edge signal is generated via an edge detector after the filtered signal is detected, which can be configured by software as an active level (or a valid edge). The processed channel signal can be used as a control signal for the slave mode controller, as a coded mode input signal, or as an input capture enable signal (which can be used to configure frequency division). Each input channel can be mapped to the current channel, to an adjacent channel, or to the internal trigger signal TRC (CCxS[1:0] configuration), as shown in the table (using channel 0 as an example), where ti0fp0 is the input signal mapped to channel 0 and ti1fp0 is the input signal mapped to channel 1.

**Table 20-2 Input Channel Active Polarity Configuration**

| {CCONP, CCOP} | Valid Pulse (applied to input capture, reset mode, trigger mode, and external clock mode) |                        | Active level (applied to Gate mode and encoding mode) |
|---------------|-------------------------------------------------------------------------------------------|------------------------|-------------------------------------------------------|
|               | ti0fp0                                                                                    | ti1fp0                 |                                                       |
| 2'b00         | Channel 0 rising edge                                                                     | Channel 1 rising edge  | Channel 0 high level                                  |
| 2'b01         | Channel 0 falling edge                                                                    | Channel 1 falling edge | Channel 0 low level                                   |
| 2'b10         | Reserved                                                                                  | Reserved               | Reserved                                              |
| 2'b11         | Channel 0 dual edge                                                                       | Channel 0 dual edge    | Channel 0 high level                                  |

**Table 20-3 Input Channel Mapping**

| CCxS  | Icx Mapping                                                    |
|-------|----------------------------------------------------------------|
| 2'b01 | tixfp <sub>x</sub> ( <sub>x</sub> stands for current channel)  |
| 2'b10 | tiyfp <sub>y</sub> ( <sub>y</sub> stands for adjacent channel) |
| 2'b11 | trc (only for TS=3'b000, 3'b001, 3'b010, 3'b100)               |

In addition, unlike other channels, channel 0 can be software configured (TI0S set) to connect to the XOR output of channel 0, channel 1 and channel 2 when the other functions of the channel are still valid, and this function is only available for GPTIMER0 and GPTIMER1.

### 20.6.1 Input Capture

Input capture is only activated when the channel is configured in input mode and CCxE is set. It can be triggered by software (CCxG) or hardware (current channel, adjacent channel or internal interconnect signal). When an active capture trigger signal is generated, GPTIMER latches the current counter value into the corresponding CCRx register and sets the CCxIF flag bit, which generates an interrupt signal or DMA request if the corresponding interrupt or DMA mask bit is enabled. If more than one capture occurs while CCxIF is set (not cleared by software), CCxOF is set, indicating a capture overflow event, and reading the CCxR register (or writing the corresponding bit to 0 in the SR register) clears CCxIF and CCxOF. The waveform is shown below.



Figure 20-9 Input Capture

### 20.6.2 Output Compare

The output compare function is activated only when the channel is configured in output mode and CCxE is set. It controls the channel to output high/low toggle by comparing the counter value with the CCRx value to output a specific waveform.

#### 20.6.2.1 CCRx Preload Function

The CCRx register is written in two ways. If CCxPE is set, the software-written CCRx value is not used directly and is not updated to the shadow register until an update event occurs, where the shadow register works as a buffer. If OCxPE is reset, the software-written CCRx value is used directly and the shadow register is disabled.

#### 20.6.2.2 Output Compare Mode

When a match (CNT==CCR) occurs, the channel output toggles according to the configured mode and the CCxIF flag bit will be set. If the corresponding interrupt or DMA mask bit is enabled, an interrupt or DMA request will be generated. The specific mode control is shown below:

Table 20-4 Description of Output Waveform in Various Output Compare Modes

| Compare Mode      | Counter Mode                             | Output Waveform                                                                                                                                                  |
|-------------------|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FREEZE mode       | Any                                      | Output remains unchanged regardless of CNT changes                                                                                                               |
| SET mode          | Any                                      | Output high level when CNT==CCR                                                                                                                                  |
| RESET mode        | Any                                      | Output low level when CNT==CCR                                                                                                                                   |
| TOGGLE mode       | Any                                      | Toggle current level when CNT==CCR                                                                                                                               |
| Forced RESET mode | Any                                      | Output low level directly and ignore the comparison result in this mode                                                                                          |
| Forced SET mode   | Any                                      | Output high level directly and ignore the comparison result in this mode                                                                                         |
| PWM1 mode         | Upcounting<br>(edge- aligned PWM)        | If CNT<CCR, output high level. If CNT>=CCR, output low level. If CCR>ARR, always output high level(100% PWM). If CCR==0, always output low level (0% PWM).       |
|                   | Downcounting<br>(edge- aligned PWM)      | If CNT<=CCR, output high level. If CNT>CCR, output low level. If CCR>ARR, always output high level (100% PWM). Note: 0% PWM mode is not supported in this case.  |
|                   | Up/down counting<br>(center-aligned PWM) | Equivalent to counting up combined with counting down. If CCR>=ARR, always output high level (100% PWM). If CCR==0, always output low level (0% PWM).            |
| PWM2 mode         | Upcounting<br>(edge- aligned PWM)        | If CNT<CCR, output low level. If CNT>=CCR, output high level. If CCR>ARR, always output low level (0% PWM). If CCR==0, always output high level (100% PWM).      |
|                   | Downcounting<br>(edge- aligned PWM)      | Output low level when CNT<=CCR. Output high level when CNT>CCR. If CCR>ARR, always output low level (0% PWM). Note: 100% PWM mode is not supported in this case. |
|                   | Up/down counting<br>(center-aligned PWM) | Equivalent to counting up combined with counting down. If CCR>=ARR, always output low level (0% PWM). If CCR==0, always output high level (100% PWM).            |

The **output waveforms in each mode** are shown below (with upcounting as an example).



Figure 20-10 Waveforms in Various Output Compare Modes

Among them, PWM mode also supports controlling the output of 0% and 100% waveforms by

configuring ARR and CCR. The edge-aligned counting PWM2 waveform is shown below:



Figure 20-11 Edge- aligned Counting PWM2

The center-aligned counting PWM2 waveform is shown below:



Figure 20-12 Center- aligned Counting PWM2

### 20.6.2.3 Single Pulse Fast Output Function

In single pulse mode (OPM set), two PWM modes can be configured as fast output mode (OCxFE set). When enabled, the output waveform ignores the comparison result of CNT and CCR, and the level toggle is controlled by the rising edge of the trigger signal (selected according to TS), with the output signal level equal to the level after the matching event occurs. For example, configure GPTIMER channel 0 as output mode, select PWM1 mode, and select ETR signal as the trigger input. Then when ETR inputs high level, channel 0 immediately outputs high level (when OCxP is configured to 0 in the [CCMR1 register](#) and [CCMR2 register](#)). This function can effectively reduce the delay between the trigger signal edge and waveform output. The single pulse output waveform when the fast mode is enabled is shown below:



Figure 20-13 Single Pulse Output Waveform when Fast Mode Is Enabled

### 20.6.2.4 External Trigger Signal Clearing Channel Output Function

The output waveform, which is affected by the count value, can be cleared by hardware through

an external trigger signal (ETR). For this function to be used, the OCxCE bit needs to be enabled in advance while ensuring that the ETR is disabled for frequency division (configuring ETP to 2'b00 in the [GPTIM\\_SMCR register](#)) and that the ETR must not be used as a count clock. When this function is enabled (configuring OCxCE to 1 in the [GPTIM\\_CCMR1 register](#) and [GPTIM\\_CCMR2 register](#)), the channel output will be cleared when the level of ETR is active (high level in default), and the active level of ETR will be changed by configuring ETP. When this function is disabled (configuring OCxCE to 0 in the [GPTIM\\_CCMR1 register](#) and [GPTIM\\_CCMR2 register](#)), the channel output will not return to normal immediately but will wait until the next counting cycle starts. A comparison of waveforms of turning on and off the function of clearing channel output by external trigger signal are shown below:



Figure 20-14 External Trigger Signal Clearing Channel Output

## 20.7 Trigger Input Channel

The ETR of each GPTIMER has multiple signal sources fed into the module via MUX, all asynchronous to the GPTIMER and therefore need to be synchronized within the module. The synchronized ETR signal can be configured by software to select the active level (or active edge), configure the frequency division (1, 2, 4, 8), and be filtered. The filter's sampling frequency and window length are software configurable (ETF).

## 20.8 Update Event Management

The main event sources for update events are as follows.

1. Overrun events of counters (overflow and underflow)
2. UG being set

The control signals associated with update event management are mainly URS and UDIS, as follows:

- If UDIS and URS are configured to 0 in the [GPTIM\\_CR1 register](#), the underflow, overflow, and UG being set will initialize the counter and pre-scale counter (the counter in center-aligned mode will not be cleared by overflow or be loaded with ARR by underflow). If the shadow register is enabled, the written value will be updated to the shadow register when an update event occurs (ARR depends on ARPE, and CCRx depends on OCxPE), and UIF will be set. If the interrupt or DMA mask bit is enabled, an interrupt or DMA request will be generated.
- If UDIS and URS are configured to 0 in the [GPTIM\\_CR1 register](#), underflow, overflow, and UG being set will initialize the counter and pre-scale counter (the counter in center-aligned mode will not be cleared by overflow or be loaded with ARR by underflow). If the shadow register is enabled, the written value will be updated to the shadow register when an update event occurs (ARR depends on ARPE, and CCRx depends on OCxPE), and UIF will only be set in overflow or underflow cases. If the interrupt or DMA mask bit is enabled, an interrupt or DMA request will be generated, effectively avoiding both capture interrupt and update interrupt when the UG is set to initialize the counter in input capture mode.
- If UDIS is configured to 1 (ignoring URS) in the [GPTIM\\_CR1 register](#), underflow, overflow, and UG being set will initialize counter and pre-scale counter (counter in center-aligned mode will not be cleared by overflow and will not be loaded with ARR by underflow). Still, shadow register will not be updated and UIF will not be set, so no corresponding interrupt or DMA request will be generated.

## 20.9 Coding Mode Control

This GPTIMER supports quadrature encoding and counting function, which counts and detects direction by inputting quadrature signals on channel 0 and channel 1. There are three coding modes, counting on channel 0 edge only, counting on channel 1 edge only, and counting on both channel 1 and channel 2 edges. With this function, both channel inputs can be configured for digital filtering, while the polarity and frequency division configurations are disabled. These two channel signals can generate count enable and direction control signals that control counter addition and subtraction (if CEN is enabled). Hence, the software-configured count direction is disabled in this mode. The specific combinations are shown below:

**Table 20-5 Coding Mode**

| Coding Mode                                   | Channel 0/1 Level | Channel 0 Edge |              | Channel 1 Level |              |
|-----------------------------------------------|-------------------|----------------|--------------|-----------------|--------------|
|                                               |                   | Rising Edge    | Falling Edge | Rising Edge     | Falling Edge |
| Coding mode 1 (counting at channel 1 edge)    | High Level        | -              | -            | Upcounting      | Downcounting |
|                                               | Low Level         | -              | -            | Downcounting    | Upcounting   |
| Coding mode 2 (counting at channel 0 edge)    | High Level        | Downcounting   | Upcounting   | -               | -            |
|                                               | Low Level         | Upcounting     | Downcounting | -               | -            |
| Coding mode 3 (counting at all channel edges) | High Level        | Downcounting   | Upcounting   | Upcounting      | Downcounting |
|                                               | Low Level         | Upcounting     | Downcounting | Downcounting    | Upcounting   |

In encoding mode, the counter also counts between 0 and ARR, generating overflow when counting up to ARR, then restarts from 0, and underflow when counting down to 0, then restarts from ARR. In addition, the input capture (channel 2 and channel 3), output compare, frequency division, and trigger output functions are still applicable in this mode. The counting waveform diagram in coding mode 1 is shown below:



**Figure 20-15 Counting Waveform in Coding Mode 1**

## 20.10 Slave Mode Control

The GPTIMER supports chaining operation as a slave of external or internal modules. The trigger input signal TRGI in the slave mode has multiple sources selected via TS[2:0], where ITRx comes from the trigger output signal (TRGO) of other internal GPTIMERS. The specific mapping relationships are shown below:

Table 20-6 Internal Trigger Input Mapping for Each GPTIMER

| Slave GPTIMER | ITR0     | ITR1     | ITR2     |
|---------------|----------|----------|----------|
| GPTIMER0      | GPTIMER2 | GPTIMER3 | GPTIMER1 |
| GPTIMER1      | GPTIMER0 | GPTIMER3 | GPTIMER2 |
| GPTIMER2      | GPTIMER3 | GPTIMER0 | -        |
| GPTIMER3      | GPTIMER1 | GPTIMER2 | -        |

There are four main ways for slave mode control as follows:

1. **Reset mode:** the rising edge of TRGI will initialize the counter and prescaler and update the shadow register (configuring UDIS to 0 in the [GPTIM CR1 register](#)). The waveform diagram of reset mode in slave mode is shown below:



Figure 20-16 Reset Mode Waveform in Slave Mode

2. **Gated mode:** TRGI level can control the operation and stop of the counter. At the default active level, the counter counts at high level and stops counting at low level (not reset). In this mode, CEN needs to be set by software. The waveform diagram of gated mode in slave mode is shown below:



Figure 20-17 Gated Mode Waveform in Slave Mode

3. **Trigger mode:** The rising edge of TRGI can control the counter to start counting but cannot stop its counting. In this mode, CEN does not need to be set by software. The waveform diagram of trigger mode in slave mode is shown below:



Figure 20-18 Trigger Mode Waveform in Slave Mode

4. **Clock mode (i.e., external clock mode 1):** the rising edge of TRGI is used as the count enable of counter to control the count when the frequency division circuit is still valid.

In slave mode, the rising edge of the TRGI sets the TIF flag bit, which generates an interrupt or DMA request if the corresponding interrupt or DMA mask bit is enabled. But there is something special about the gated mode, in which the falling edge can also set the TIF in addition to the rising edge.

In addition, the master and slave clocks must be in the same frequency and phase for GPTIMER chaining, otherwise unknown errors will occur.

## 20.11 Slave Mode Control

The GPTIMER can also be used as a master mode to control other GPTIMER, ADC and DAC by generating a trigger output signal (TRGO), the source of which can be configured by software, as follows:

- MMS=3'b000: In reset mode, the UG flag bit is output to the external slave as a TRGO signal.
- MMS=3'b001: In enable mode, the count enable of the counter is output to the external slave as a TRGO signal, which will be a gating signal if the GPTIMER is in slave gated mode at the same time, otherwise the CEN is directly output as a TRGO signal.
- MMS=3'b010: In update mode, the update event is output as a TRGO signal.
- MMS=3'b011: In channel 0 compare pulse mode, if CC0IF is set, a pulse is output as a TRGO signal, regardless of whether CC0IF is set.
- MMS=3'b100: In compare mode 1, OC0REF is output as a TRGO signal.
- MMS=3'b101: In compare mode 2, OC1REF is output as a TRGO signal.
- MMS=3'b110: In compare mode 3, OC2REF is output as a TRGO signal.
- MMS=3'b111: In compare mode 4, OC3REF is output as a TRGO signal.

**Note:** The OC<sub>x</sub>REF output in the last 4 modes is not the final channel output, but an internal signal.

There is a particular application when GPTIMER is configured in master enable mode to synchronize the start of the master and slave counters. However, since the CEN of the master as TRGO to output to the slave and enable the slave counter requires a delay of two clocks (assuming that the master and slave clocks are in the same frequency and phase), when using this function, the CEN of the master is internally delayed by two clock cycles with two-level registers to ensure synchronization. This function can be software configured to enable or disable (MSM).

## 20.12 Outout Control

GPTIMER0 and GPTIMER1 have 4 channel outputs and GPTIMER2 and GPTIMER3 have 2 channel outputs with corresponding output enable signals. The channel output is only active when CCxE is set when the output polarity is controlled by CCxP. Output polarity refers to whether the output active level is high or low. The output enable signal is active at high level, i.e., active when CCxE is set. Meanwhile, the channel must be correctly configured in the output mode, which is configured via CCxS.

## 20.13 Channel Remapping

Channel remapping is to map the input signal of the GPTIMER's channel or external trigger channel ETR from other external or internal signals. The ETR channel, channel 0 and channel 3 of GPTIMER0, channel 2 of GPTIMER0, the ETR channel, channel 0 and channel 1 of GPTIMER2, and the ETR channel and channel 0 of GPTIMER3 support remapping.

## 20.14 Debug Mode Control

GPTIMER can be configured by software to stop counting in debug mode. If this function is enabled, GPTIMER stops counting when entering system debug mode (the counter will not be initialized).

## 20.15 DMA Control

GPTIMER has 6 DMA request sources, which are update event (UIF), 4 channel events (capture event and compare match) (CCxIF) and trigger event (TIF), which can be configured by independent mask bits to enable or disable the corresponding DMA requests. For channel event DMA, the DMA request source of the channel can be software (CCDS bit) configured. If CCDS is configured to 0 in the [GPTIM CR2 register](#), the DMA request of each channel comes from the event of each channel, such as capture and compare match event. If CCDS is configured to 1 in the [GPTIM CR2 register](#), the DMA request of each channel comes from the update event and the channel event will be masked.

Each DMA request is only set when there is no corresponding answer signal, DMA is enabled and a DMA event occurs. When a DMA request is set, it can be cleared by the answer signal, otherwise it will remain set.

In addition to the regular DMA operation, GPTIMER also supports the burst function, which means a DMA request can read or write multiple internal registers in succession. The DBL bit can select the burst length up to 18, DBA can select the starting address of the burst, and the

address of DMAR register can be used as the destination or source address of DMA (DMA does not need to set each increment internally). When a DMA request is set, GPTIMER calculates the actual address of each read/write operation based on the values of DBL and DBA. The actual address is calculated as  $CR1 + (DBA + index) \times 4$ , where the index value is from 0 to DBL.

**Note:** The register address is reserved in the register group, which is also included in the DMA burst operation, and the length to which it is configured needs to be noted in actual use. For example, if the ARR register (0x2C) is selected as the starting address and DBL is configured as 5'b00010 (3 bursts), the three registers actually operated by DMA are GPTIM\_ARR (0x2C), Reserved register (0x30), and GPTIM\_CCR0 (0x34), of which 0x30 is a reserved register that cannot be written to and is always read out to 0.

## 20.16 Interrupt

GPTIMER has 6 interrupt sources, which are update event (UIF), 4 channel events (capture event and compare match) (CCxIF) and trigger event (TIF), which can be configured to enable or disable by independent interrupt mask bits. The interrupt flag bit and the corresponding mask bit are in an "AND" relationship, and the interrupts are in an OR relationship. The interrupt signals of GPTIMER are listed below:

**Table 20-7 GPTIMER Interrupt Signals**

| Interrupt Name            | Description                                                   |
|---------------------------|---------------------------------------------------------------|
| Trigger event interrupt   | Interrupt when the trigger source generates an event          |
| Channel 3 event interrupt | Interrupt when channel 3 generates a capture or compare event |
| Channel 2 event interrupt | Interrupt when channel 2 generates a capture or compare event |
| Channel 1 event interrupt | Interrupt when channel 1 generates a capture or compare event |
| Channel 0 event interrupt | Interrupt when channel 0 generates a capture or compare event |
| Update event interrupt    | Interrupt when generating an update event                     |

The above interrupts are enabled by configuring the TIE, CC3IE, CC2IE, CC1IE, CC0IE, and UIE bits of the DIER register respectively.

## 20.17 GPTIMER Related Register Description

GPTIMER0 base address: 0x4000A000

GPTIMER1 base address: 0x4001A000

GPTIMER2 base address: 0x4000B000

GPTIMER3 base address: 0x4001B000

**Table 20-8 GPTIMER Register List**

| Register    | Offset | Description                        |
|-------------|--------|------------------------------------|
| GPTIM_CR1   | 0x00   | Control register 1                 |
| GPTIM_CR2   | 0x04   | Control register 2                 |
| GPTIM_SMCR  | 0x08   | Slave mode control register        |
| GPTIM_DIER  | 0x0C   | DMA/interrupt enable register      |
| GPTIM_SR    | 0x10   | Status register                    |
| GPTIM_EGR   | 0x14   | Event register                     |
| GPTIM_CCMR1 | 0x18   | Capture compare mode register 1    |
| GPTIM_CCMR2 | 0x1C   | Capture compare mode register 2    |
| GPTIM_CCER  | 0x20   | Capture compare enable register    |
| GPTIM_CNT   | 0x24   | Counting register                  |
| GPTIM_PSC   | 0x28   | Counter divider value register     |
| GPTIM_ARR   | 0x2C   | Counter reload value register      |
| GPTIM_CCR0  | 0x34   | Channel 0 capture compare register |
| GPTIM_CCR1  | 0x38   | Channel 1 Capture Compare Register |
| GPTIM_CCR2  | 0x3C   | Channel 2 capture compare register |
| GPTIM_CCR3  | 0x40   | Channel 3 capture compare register |
| GPTIM_DCR   | 0x48   | DMA control register               |
| GPTIM_DMAR  | 0x4C   | DMA address register               |
| GPTIM_OR    | 0x50   | Channel remapping register         |

### 20.17.1 GPTIM\_CR1

Address Offset: 0x00

Reset Value: 0x0000

| 15-10    | 9-8   | 7     | 6-5   | 4     | 3     | 2     | 1     | 0     |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|
| RESERVED | CKD   | ARPE  | CMS   | DIR   | OPM   | URS   | UDIS  | CEN   |
| r-0h     | rw-0h |

**Bit 15-10 RESERVED:** Preserved.

**Bit 9-8 CKD:** Sampling clock division.

- 00: fDTS = fpclk
- 01: fDTS = fpclk
- 10: fDTS = fpclk
- 11: fDTS = reserved

**Bit 7 ARPE:** Reload shadow register enable.

- 0: ARR shadow register disabled
- 1: ARR shadow register enable

**Bit 6-5 CMS:** Up/down counting mode selection

- 00: Edge-aligned counting mode- DIR controls counting up or down.
- 01: Center-aligned mode 1- The output compare interrupt flag bit is only set during downcounting.
- 10: Center-aligned mode 2- The output compare interrupt flag bit is only set during upcounting.
- 11: Center-aligned mode 3- The output compare interrupt flag bit is set during upcounting and downcounting.

**Bit 4 DIR:** Counting direction selection. In center-aligned mode and encoding mode, this bit is controlled by hardware.

- 0: upcounting
- 1: downcounting

**Bit 3 OPM:** Single pulse mode enable.

- 0: Single pulse mode disabled
- 1: Single pulse mode enabled- the counter stops counting at the next update event

**Bit 2 URS:** Update event source selection. This bit affects only the interrupt and the DMA flag bit (UIF) and does not affect the internal logic.

- 0: Counter overflow, UG bit being set, and trigger in the reset mode of the slave mode can all set UIF.
- 1: Only counter overflow events can set UIF

**Bit 1 UDIS:** Update event disabled.

- 0: Update event enabled in the center-aligned mode 1- the output compare interrupt flag bit is only set during downcounting, but can generate update events during downcounting and upcounting.
- 1: Update event disabled- neither the shadow register nor the UIF is updated, but the counter and prescaler can still be initialized by the UG set event

**Bit 0 CEN:** When the counter is enabled, CEN is set by hardware in trigger mode, and CEN is cleared by hardware in single pulse mode.

- 0: Counter disabled
- 1: Counter enabled

### 20.17.2 GPTIM\_CR2

Address Offset: 0x04

Reset Value: 0x0000

| 15-8     | 7     | 6-4   | 3     | 2-0      |
|----------|-------|-------|-------|----------|
| RESERVED | T10S  | MMS   | CCDS  | RESERVED |
| r-0h     | rw-0h | rw-0h | rw-0h | r-0h     |

**Bit 15-8 RESERVED:** Reserved.

**Bit 7 T10S:** Channel 1 source XOR selection (supported by timer0 and timer1 only)

- 0: Channel 0 mapped to channel 0 input
- 1: Channel 0 is the XOR output of channels 0, 1 and 2

**Bit 6-4 MMS:** Master mode selection to configure TRGO.

- 000: Reset mode- UG is used as trigger output (TRGO).
- 001: Enable mode- CNT\_EN (not CEN) is used as trigger output (TRGO).
- 010: Update mode- The update event (internal signal) is used as trigger output (TRGO).
- 011: Compare pulse mode- TRGO outputs a pulse every time CC0IF is about to be set, even if CC0IF is already set.
- 100: Compare mode- OC0REF (internal signal) is used as trigger output (TRGO).
- 101: Compare mode- OC1REF (internal signal) is used as trigger output (TRGO).
- 110: Compare mode- OC2REF (internal signal) is used as trigger output (TRGO).
- 111: Compare mode- OC3REF (internal signal) is used as trigger output (TRGO).

**Bit 3 CCDS:** Channel DMA request source selection (supported by gptimer0 and gptimer1 only).

- 0: DMA requests for each channel (excluding update event requests and trigger event requests) are generated by channel events (capture, compare)
- 1: DMA requests for each channel (excluding update event requests and trigger event requests) are generated by update events

**Bit 2-0 RESERVED:** Reserved.

### 20.17.3 GPTIM\_SMCR

Address Offset: 0x08

Reset Value: 0x0000

| 15    | 14    | 13-12 | 11-8  | 7     | 6-4   | 3        | 2-0   |
|-------|-------|-------|-------|-------|-------|----------|-------|
| ETP   | ECE   | ETPS  | ETF   | MSM   | TS    | RESERVED | SMS   |
| rw-0h | rw-0h | rw-0h | rw-0h | rw-0h | rw-0h | r-0h     | rw-0h |

**Bit 15 ETP:** External trigger polarity selection (the polarity should be configured without selecting the SMS mode first in case the internal signal toggle triggers an unknown error).

- 0: External trigger input is non-inverted
- 1: External trigger input is inverted

**Bit 14 ECE:** External clock mode 2 enabled.

- 0: External clock mode 2 disabled
- 1: External clock mode 2 enabled

**Bit 13-12 ETPS:** External trigger input frequency division (mainly used for 50% duty cycle frequency reduction. For example, if the 24M signal is divided by 2 to 12M, the level will be extended twice) selection.

- 00: Not divided
- 01: Divided by 2
- 10: Divided by 4
- 11: Divided by 8

**Bit 11-8 ETF:** External trigger input filter configuration.

- 0000: Filter disabled
- 0001: fsampling=fclk, N=2.
- 0010: fsampling=fclk, N=4
- 0011: fsampling=fclk, N=8
- 0100: fsampling=fDTS/2, N=6
- 0101: fsampling=fDTS/2, N=8
- 0110: fsampling=fDTS/4, N=6
- 0111: fsampling=fDTS/4, N=8
- 1000: fsampling=fDTS/8, N=6
- 1001: fsampling=fDTS/8, N=8
- 1010: fsampling=fDTS/16, N=5
- 1011: fsampling=fDTS/16, N=6
- 1100: fsampling=fDTS/16, N=8
- 1101: fsampling=fDTS/32, N=5
- 1110: fsampling=fDTS/32, N=6
- 1111: fsampling=fDTS/32, N=8

**Bit 7 MSM:** Master-slave mode synchronization (when using this function, the clocks of the two timers should be in the same frequency and phase).

- 0: No action

- 1: TRGI will delay the generation of the effect to start counting at the same time as the slave counter.

**Bit 6-4 TS:** TRGI source selection (SMS must be in the clear state when this bit is configured).

- 000: ITR0
- 001: ITR1
- 010: ITR2 (timer2 and timer3 have no such channel)
- 011: Reserved
- 100: Channel 0 edge detection output
- 101: Channel 0 filter output
- 110: Channel 1 filter output
- 111: External trigger input

**Bit 3 RESERVED:** Reserved.

**Bit 2-0 SMS:** Slave mode selection (the channel parameters should be configured before selecting the mode, in case the internal signal toggle triggers an unknown error).

- 000: Slave mode disabled
- 001: Encoding mode 1- Counter counts only on channel 1 edge
- 010: Coding mode 2- Counter counts only on channel 0 edge
- 011: Encoding mode 3- Counter counts on channels 0 and channel 1 edge
- 100: Reset mode- Rising edge of TRGI resets the counter
- 101: Gated mode- Counter counts only during TRGI high level
- 110: Trigger mode- Counter starts counting on the rising edge of TRGI. Only the start of the counter is controlled.
- 111: External clock mode 1- Rising edge of TRGI clocks the counter

#### 20.17.4 GPTIM\_DIER

Address Offset: 0x0C

Reset Value: 0x0000

| 15       | 14    | 13       | 12    | 11    | 10    | 9     | 8     |
|----------|-------|----------|-------|-------|-------|-------|-------|
| RESERVED | TDE   | RESERVED | CC3DE | CC2DE | CC1DE | CC0DE | UDE   |
| r-0h     | rw-0h | r-0h     | rw-0h | rw-0h | rw-0h | rw-0h | rw-0h |
| 7        | 6     | 5        | 4     | 3     | 2     | 1     | 0     |
| RESERVED | TIE   | RESERVED | CC3IE | CC2IE | CC1IE | CC0IE | UIE   |
| r-0h     | rw-0h | r-0h     | rw-0h | rw-0h | rw-0h | rw-0h | rw-0h |

**Bit 15 RESERVED:** Reserved.

**Bit 14 TDE:** Trigger DMA request enable.

- 0: Trigger DMA request disabled
- 1: Trigger DMA request enabled

**Bit 13 RESERVED:** Reserved.

**Bit 12 CC3DE:** Channel 3 DMA request enable.

- 0: Channel 3 DMA request disabled
- 1: Channel 3 DMA request enabled

**Bit 11 CC3DE:** Channel 2 DMA request enable.

- 0: Channel 2 DMA request disabled
- 1: Channel 2 DMA request enabled

**Bit 10 CC3DE:** Channel 1 DMA request enable.

- 0: Channel 1 DMA request disabled
- 1: Channel 1 DMA request enabled

**Bit 9 CC3DE:** Channel 0 DMA request enable.

- 0: Channel 0 DMA request disabled
- 1: Channel 0 DMA request enabled

**Bit 8 UDE:** Update DMA request enable.

- 0: Update DMA request disabled
- 1: Update DMA request enabled

**Bit 7 RESERVED:** Reserved.

**Bit 6 TIE:** Trigger interrupt request enable.

- 0: Trigger interrupt request disabled
- 1: Trigger interrupt request enabled

**Bit 5 RESERVED:** Reserved.

**Bit 4 CC3IE:** Channel 3 interrupt request enable.

- 0: Channel 3 interrupt request disabled
- 1: Channel 3 interrupt request enabled

**Bit 3 CC2IE:** Channel 2 interrupt request enable.

- 0: Channel 2 interrupt request disabled
- 1: Channel 2 interrupt request enabled

**Bit 2 CC1IE:** Channel 1 interrupt request enable.

- 0: Channel 1 interrupt request disabled
- 1: Channel 1 interrupt request enabled

**Bit 1 CC0IE:** Channel 0 interrupt request enable.

- 0: Channel 0 interrupt request disabled
- 1: Channel 0 interrupt request enabled

**Bit 0 UIE:** Update interrupt request enable.

- 0: Update interrupt request disabled
- 1: Update interrupt request enabled

## 20.17.5 GPTIM\_SR

Address Offset: 0x10

Reset Value: 0x0000

| 15-13    |          | 12    | 11    | 10    | 9     | 8-7      |
|----------|----------|-------|-------|-------|-------|----------|
| RESERVED |          | CC3OF | CC2OF | CC1OF | CC0OF | RESERVED |
| r-0h     |          | rw-0h | rw-0h | rw-0h | rw-0h | r-0h     |
| 6        | 5        | 4     | 3     | 2     | 1     | 0        |
| TIF      | RESERVED | CC3IF | CC2IF | CC1IF | CC0IF | UIF      |
| rw-0h    | r-0h     | rw-0h | rw-0h | rw-0h | rw-0h | rw-0h    |

**Bit 15-13 RESERVED:** Reserved.

**Bit 12 CC3OF:** Channel 3 overcapture flag (cleared by writing it to 0).

- 0: No overcapture occurred
- 1: At least one overcapture occurred

**Bit 11 CC2OF:** Channel 2 overcapture flag (cleared by writing it to 0).

- 0: No overcapture occurred
- 1: At least one overcapture occurred

**Bit 10 CC1OF:** Channel 1 overcapture flag (cleared by writing it to 0).

- 0: No overcapture occurred
- 1: At least one overcapture occurred

**Bit 9 CC0OF:** Channel 0 overcapture flag (cleared by writing it to 0).

- 0: No overcapture occurred
- 1: At least one overcapture occurred

**Bit 8-7 RESERVED:** Reserved.

**Bit 6 TIF:** Trigger interrupt flag (cleared by writing it to 0).

- 0: No trigger event occurred
- 1: Trigger event occurred

**Bit 5 RESERVED:** Reserved.

**Bit 4 CC3IF:** Channel 3 capture/compare flag (compare mode: cleared by writing it to 0; capture mode: cleared by reading the ccrx register or writing it to 0).

- 0: No event occurred
- 1: Capture or compare occurred

**Bit 3 CC2IF:** Channel 2 capture/compare flag (compare mode: cleared by writing it to 0; capture mode: cleared by reading the ccrx register or writing it to 0).

- 0: No event occurred
- 1: Capture or compare occurred

**Bit 2 CC1IF:** Channel 1 capture/compare flag (compare mode: cleared by writing it to 0; capture mode: cleared by reading the ccrx register or writing it to 0).

- 0: No event occurred

- 1: Capture or compare occurred

**Bit 1 CC0IF:** Channel 0 capture/compare flag (compare mode: cleared by writing it to 0; capture mode: cleared by reading the ccrx register or writing it to 0).

- 0: No event occurred
- 1: Capture or compare occurred

**Bit 0 UIF:** Update flag (cleared by reading SR or writing it to 0).

- 0: No event occurred
- 1: Update occurred

## 20.17.6 GPTIM\_EGR

Address Offset: 0x14

Reset Value: 0x0000

| 15-7     | 6    | 5        | 4    | 3    | 2    | 1    | 0    |
|----------|------|----------|------|------|------|------|------|
| RESERVED | TG   | RESERVED | CC3G | CC2G | CC1G | CC0G | UG   |
| r-0h     | w-0h | r-0h     | w-0h | w-0h | w-0h | w-0h | w-0h |

**Bit 15-7 RESERVED:** Reserved.

**Bit 6 TG:** Trigger generation.

- 0: No action
- 1: A trigger event is generated and TIF is set

**Bit 5 RESERVED:** Reserved.

**Bit 4 CC3G:** Channel 3 event generation

- 0: No action
- 1: Capture is generated in the input mode and compare is generated in the output mode. CC3IF is set in both modes.

**Bit 3 CC2G:** Channel 2 event generation

- 0: No action
- 1: Capture is generated in the input mode and compare is generated in the output mode. CC2IF is set in both modes.

**Bit 2 CC1G:** Channel 1 event generation

- 0: No action
- 1: Capture is generated in the input mode and compare is generated in the output mode. CC1IF is set in both modes.

**Bit 1 CC0G:** Channel 0 event generation

- 0: No action
- 1: Capture is generated in the input mode and compare is generated in the output mode. CC1IF is set in both modes.

**Bit 0 UG:** Update event generation.

- 0: No action
- 1: An update event generated

### 20.17.7 GPTIM\_CCMR1

Address Offset: 0x18

Reset Value: 0x0000

**The structure for output mode is as follows:**

| 15    | 14-12 | 11    | 10    | 9-8   | 7     | 6-4   | 3     | 2     | 1-0   |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| OC1CE | OC1M  | OC1PE | OC1FE | CC1S  | OC0CE | OC0M  | OC0PE | OC0FE | CC0S  |
| rw-0h |

**Bit 15 OC1CE:** Channel 1 output compare clear enable.

- 0: Clear disabled
- 1: Clear enabled, ETRF high level can clear the channel output

**Bit 14-12 OC1M:** Channel 1 output compare mode selection.

- 000: Frozen mode- the channel output does not change with the comparison result
- 001: Active mode- the channel outputs active level after matching
- 010: Inactive mode- the channel outputs inactive level after matching
- 011: Flip mode- the channel output toggles after matching
- 100: Forced active mode- the active level is output directly in this mode
- 101: Forced inactive mode- the inactive level is output directly in this mode.
- 110: PWM1 mode - when counting up, the channel outputs active level if CNT<CCR, otherwise it outputs inactive level; when counting down, the channel outputs inactive level if CNT>CCR, otherwise it outputs active level (When counting up, OCxREF always outputs high level if CCRx>ARR, and low level If CCRx==0; when counting down, OCxREF always outputs high level if CCRx>ARR, and 0% PWM is not possible in this mode)
- 111: PWM2 mode - when counting up, the channel outputs inactive level if CNT<CCR, otherwise it outputs active level; when counting down, the channel outputs active level if CNT>CCR, otherwise it outputs inactive level. 0% and 100% waveforms are the same as in PWM1 mode.

**Bit 11 OC1PE:** Channel 1 output compare shadow register enable.

- 0: Shadow register disabled
- 1: Shadow register enabled

**Bit 10 OC1FE:** Channel 1 fast output enable.

- 0: Fast mode disabled- Output changes only when matched
- 1: Fast mode enabled- Trigger input is equivalent to a match event and directly affects the channel output, independent of the comparison of the counter with the CCR

**Bit 9-8 CC1S:** Capture compare selection.

- 00: The channel is configured in output mode
- 01: The channel is configured in input mode, and capture channel input is mapped on channel 1
- 10: The channel is configured in input mode, and capture channel input is mapped on channel 0
- 11: The channel is configured in input mode, and capture channel input is mapped on trigger input TRC

**Bit 7 OC0CE:** Channel 0 output compare clear enable.

- 0: Clear disabled
- 1: Clear enabled, ETRF high level can clear the channel output

**Bit 6-4 OC0M:** Channel 0 output compare mode selection.

- 000: Frozen mode- the channel output does not change with the comparison result
- 001: Active mode- the channel outputs active level after matching
- 010: Inactive mode- the channel outputs inactive level after matching
- 011: Toggle mode- the channel output toggles after matching
- 100: Forced active mode- the active level is output directly in this mode
- 101: Forced inactive mode, the inactive level is output directly in this mode
- 110: PWM1 mode- when counting up, the channel outputs active level if CNT<CCR, otherwise it outputs inactive level; when counting down, the channel outputs inactive level if CNT>CCR, otherwise it outputs active level (when counting up, OCxREF always outputs high level if CCRx>ARR, and low level if CCRx==0; when counting down, OCxREF always outputs high level if CCRx>ARR, and 0% PWM is not possible)
- 111: PWM2 mode- when counting up, the channel outputs inactive level if CNT<CCR, otherwise it outputs active level; when counting down, the channel outputs active level if CNT>CCR, otherwise it outputs inactive level. 0% and 100% waveforms are the same as in PWM1 mode.

**Bit 3 OC0PE:** Channel 0 output compare shadow register enable.

Channel 0 output compare shadow register enable.

- 0: shadow register disabled
- 1: shadow register enabled

**Bit 2 OC0FE:** Channel 0 fast output enable.

- 0: Fast mode disabled- Output changes only when matched
- 1: Fast mode enabled- Trigger input is equivalent to a match event, which directly affects the channel output and is not affected by the comparison of the counter with the CCR

**Bit 1-0 CC0S:** Capture compare selection.

- 00: The channel is configured in output mode
- 01: The channel is configured in input mode, and capture channel input is mapped on channel 0
- 10: The channel is configured in input mode, and capture channel input is mapped on channel 1
- 11: 11: The channel is configured in input mode, and capture channel input is mapped on trigger input TRC

The structure for input mode is as follows:

| 15-12 | 11-10  | 9-8   | 7-4   | 3-2    | 1-0   |
|-------|--------|-------|-------|--------|-------|
| IC1F  | IC1PSC | CC1S  | IC0F  | IC0PSC | CC0S  |
| rw-0h | rw-0h  | rw-0h | rw-0h | rw-0h  | rw-0h |

**Bit 15-12 IC1F:** Channel 1 input filter configuration (only effective when CCxS!=0x0 is configured)

- 0000: Filter disabled
- 0001: fsampling=fclk, N=2
- 0010: fsampling=fclk, N=4
- 0011: fsampling=fclk, N=8

- 0100: fsampling=fDTS/2, N=6
- 0101: fsampling=fDTS/2, N=8
- 0110: fsampling=fDTS/4, N=6
- 0111: fsampling=fDTS/4, N=8
- 1000: fsampling=fDTS/8, N=6
- 1001: fsampling=fDTS/8, N=8
- 1010: fsampling=fDTS/16, N=5
- 1011: fsampling=fDTS/16, N=6
- 1100: fsampling=fDTS/16, N=8
- 1101: fsampling=fDTS/32, N=5
- 1110: fsampling=fDTS/32, N=6
- 1111: fsampling=fDTS/32, N=8

**Bit 11-10 IC1PSC:** Channel 1 division (only effective when CCxS!=0x0 is configured).

- 00: no division
- 01: division by 2
- 10: division by 4
- 11: division by 8

**Bit 9-8 CC1S:** Capture compare selection.

- 00: The channel is configured in output mode
- 01: The channel is configured in input mode, and capture channel input is mapped on channel 1
- 10: The channel is configured in input mode, and capture channel input is mapped on channel 0
- 11: The channel is configured in input mode, and capture channel input is mapped on trigger input TRC

**Bit 7-4 IC0F:** Channel 0 input filter configuration (only effective when CCxS!=0x0)

- 0000: Filter disabled
- 0001: fsampling=fpclk, N=2
- 0010: fsampling=fpclk, N=4
- 0011: fsampling=fpclk, N=8
- 0100: fsampling=fDTS/2, N=6
- 0101: fsampling=fDTS/2, N=8
- 0110: fsampling=fDTS/4, N=6
- 0111: fsampling=fDTS/4, N=8
- 1000: fsampling=fDTS/8, N=6
- 1001: fsampling=fDTS/8, N=8
- 1010: fsampling=fDTS/16, N=5
- 1011: fsampling=fDTS/16, N=6
- 1100: fsampling=fDTS/16, N=8
- 1101: fsampling=fDTS/32, N=5
- 1110: fsampling=fDTS/32, N=6
- 1111: fsampling=fDTS/32, N=8

**Bit 3-2 IC0PSC:** Channel 0 division (only effective when CCxS!=0x0 is configured)

- 00: no division
- 01: division by 2

- 10: division by 4
- 11: division by 8

**Bit 1-0 CC0S:** Capture compare selection.

- 00: The channel is configured in output mode
- 01: The channel is configured in input mode, and capture channel input is mapped on channel 0
- 10: The channel is configured in input mode, and capture channel input is mapped on channel 1
- 11: The channel is configured in input mode, and capture channel input is mapped on trigger input TRC

## 20.17.8 GPTIM\_CCMR2

Address Offset: 0x1C

Reset Value: 0x0000

The structure for output mode is as follows:

| 15    | 14-12 | 11    | 10    | 9-8   | 7     | 6-4   | 3     | 2     | 1-0   |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| OC3CE | OC3M  | OC3PE | OC3FE | CC3S  | OC2CE | OC2M  | OC2PE | OC2FE | CC2S  |
| rw-0h |

**Bit 15 OC3CE:** Channel 3 output compare clear enable.

- 0: Clear disabled
- 1: Clear enabled, ETRF high level can clear the channel output

**Bit 14-12 OC3M:** Channel 3 output compare mode selection.

- 000: Frozen mode- the channel output does not change with the comparison result
- 001: Active mode- the channel outputs active level after matching
- 010: Inactive mode- the channel outputs inactive level after matching
- 011: Toggle mode- the channel output toggles after matching
- 100: Forced active mode- the active level is output directly in this mode
- 101: Forced inactive mode- the inactive level is output directly in this mode.
- 110: PWM1 mode - when counting up, the channel outputs active level if CNT<CCR, otherwise it outputs inactive level; when counting down, the channel outputs inactive level if CNT>CCR, otherwise it outputs active level (When counting up, OCxREF always outputs high level if CCRx>ARR, and low level If CCRx==0; when counting down, OCxREF always outputs high level if CCRx>ARR, and 0% PWM is not possible)
- 111: PWM2 mode - when counting up, the channel outputs inactive level if CNT<CCR, otherwise it outputs active level; when counting down, the channel outputs active level if CNT>CCR, otherwise it outputs inactive level. 0% and 100% waveforms are the same as in PWM1 mode.

**Bit 11 OC3PE:** Channel 3 output compare shadow register enable.

- 0: shadow register disabled
- 1: shadow register enabled

**Bit 10 OC3FE:** Channel 3 fast output enable.

- 0: Fast mode disabled- Output changes only when matched
- 1: Fast mode enabled- Trigger input is equivalent to a match event, which directly affects the channel

output and is not affected by the comparison of the counter with the CCR

**Bit 9-8 CC3S:** Capture compare selection.

- 00: The channel is configured in output mode
- 01: The channel is configured in input mode, and capture channel input is mapped on channel 3
- 10: The channel is configured in input mode, and capture channel input is mapped on channel 2
- 11: The channel is configured in input mode, and capture channel input is mapped on trigger input TRC

**Bit 7 OC2CE:** Channel 2 output compare clear enable.

- 0: Clear disabled
- 1: Clear enabled, ETRF high level can clear the channel output

**Bit 6-4 OC2M:** Channel 2 output compare mode selection.

- 000: Frozen mode- the channel output does not change with the comparison result
- 001: Active mode- the channel outputs active level after matching
- 010: Inactive mode- the channel outputs inactive level after matching
- 011: Toggle mode- the channel output toggles after matching
- 100: Forced active mode- the active level is output directly in this mode
- 101: Forced inactive mode- the inactive level is output directly in this mode.
- 110: PWM1 mode - when counting up, the channel outputs active level if CNT<CCR, otherwise it outputs inactive level; when counting down, the channel outputs inactive level if CNT>CCR, otherwise it outputs active level (When counting up, OCxREF always outputs high level if CCRx>ARR, and low level If CCRx==0; when counting down, OCxREF always outputs high level if CCRx>ARR, and 0% PWM is not possible)
- 111: PWM2 mode - when counting up, the channel outputs inactive level if CNT<CCR, otherwise it outputs active level; when counting down, the channel outputs active level if CNT>CCR, otherwise it outputs inactive level. 0% and 100% waveforms are the same as in PWM1 mode.

**Bit 3 OC2PE:** Channel 2 output compare shadow register enable.

- 0: shadow register disabled
- 1: shadow register enabled

**Bit 2 OC2FE:** Channel 2 fast output enable.

- 0: Fast mode disabled- Output changes only when matched
- 1: Fast mode enabled- Trigger input is equivalent to a match event, which directly affects the channel output and is not affected by the comparison of the counter with the CCR

**Bit 1-0 CC2S:** Capture compare selection.

- 00: The channel is configured in output mode
- 01: The channel is configured in input mode, and capture channel input is mapped on channel 2
- 10: The channel is configured in input mode, and capture channel input is mapped on channel 3
- 11: The channel is configured in input mode, and capture channel input is mapped on trigger input TRC

The structure for input mode is as follows:

| 15-12 | 11-10  | 9-8   | 7-4   | 3-2    | 1-0   |
|-------|--------|-------|-------|--------|-------|
| IC3F  | IC3PSC | CC3S  | IC2F  | IC2PSC | CC2S  |
| rw-0h | rw-0h  | rw-0h | rw-0h | rw-0h  | rw-0h |

**Bit 15-12 IC3F:** Channel 3 input filter configuration (only effective when CCxS!=0x0 is configured).

- 0000: Filter disabled
- 0001: fsampling=fpclk, N=2
- 0010: fsampling=fpcclk, N=4
- 0011: fsampling=fpcclk, N=8
- 0100: fsampling=fDTS/2, N=6
- 0101: fsampling=fDTS/2, N=8
- 0110: fsampling=fDTS/4, N=6
- 0111: fsampling=fDTS/4, N=8
- 1000: fsampling=fDTS/8, N=6
- 1001: fsampling=fDTS/8, N=8
- 1010: fsampling=fDTS/16, N=5
- 1011: fsampling=fDTS/16, N=6
- 1100: fsampling=fDTS/16, N=8
- 1101: fsampling=fDTS/32, N=5
- 1110: fsampling=fDTS/32, N=6
- 1111: fsampling=fDTS/32, N=8

**Bit 11-10 IC3PSC:** Channel 3 division (only effective when CCxS!=0x0 is configured)

- 00: no division
- 01: division by 2
- 10: division by 4
- 11: division by 8

**Bit 9-8 CC3S:** Capture compare selection.

- 00: The channel is configured in output mode
- 01: The channel is configured in input mode, and capture channel input is mapped on channel 3
- 10: The channel is configured in input mode, and capture channel input is mapped on channel 2
- 11: The channel is configured in input mode, and capture channel input is mapped on trigger input TRC

**Bit 7-4 IC2F:** Channel 2 input filter configuration (only effective when CCxS!=0x0 is configured).

- 0000: Filter disabled
- 0001: fsampling=fpcclk, N=2
- 0010: fsampling=fpcclk, N=4
- 0011: fsampling=fpcclk, N=8
- 0100: fsampling=fDTS/2, N=6
- 0101: fsampling=fDTS/2, N=8
- 0110: fsampling=fDTS/4, N=6
- 0111: fsampling=fDTS/4, N=8
- 1000: fsampling=fDTS/8, N=6

- 1001: fsampling=fDTS/8, N=8
- 1010: fsampling=fDTS/16, N=5
- 1011: fsampling=fDTS/16, N=6
- 1100: fsampling=fDTS/16, N=8
- 1101: fsampling=fDTS/32, N=5
- 1110: fsampling=fDTS/32, N=6
- 1111: fsampling=fDTS/32, N=8

**Bit 3-2 IC2PSC:** Channel 2 division (only effective when CCxS!=0x0 is configured).

- 00: no division
- 01: division by 2
- 10: division by 4
- 11: division by 8

**Bit 1-0 CC2S:** Capture compare selection.

- 00: The channel is configured in output mode
- 01: The channel is configured in input mode, and capture channel input is mapped on channel 2
- 10: The channel is configured in input mode, and capture channel input is mapped on channel 3
- 11: The channel is configured in input mode, and capture channel input is mapped on trigger input TRC

## 20.17.9 GPTIM\_CCER

Address Offset: 0x20

Reset Value: 0x0000

| 15    | 14       | 13    | 12    | 11    | 10       | 9     | 8     |
|-------|----------|-------|-------|-------|----------|-------|-------|
| CC3NP | RESERVED | CC3P  | CC3E  | CC2NP | RESERVED | CC2P  | CC2E  |
| rw-0h | r-0h     | rw-0h | rw-0h | rw-0h | r-0h     | rw-0h | rw-0h |
| 7     | 6        | 5     | 4     | 3     | 2        | 1     | 0     |
| CC1NP | RESERVED | CC1P  | CC1E  | CC0NP | RESERVED | CC0P  | CC0E  |
| rw-0h | r-0h     | rw-0h | rw-0h | rw-0h | r-0h     | rw-0h | rw-0h |

**Bit 15 CC3NP:** Output inverted polarity- which must be bit 0 for output mode, refer to CC3P for input mode.

**Bit 14 RESERVED:** Reserved.

**Bit 13 CC3P:** Output polarity- which must work in conjunction with CC3NP (Configure polarity preferably before mode selection to prevent unknown errors triggered by internal signal toggle).

### Output mode:

- 0: Output active polarity bit high level
- 1: Output active polarity bit low level

### Input mode, {CC3NP, CC3P}:

- 00: Valid Channel input rising edge (capture mode, trigger mode, reset mode and clock mode), active high (gated mode and encoding mode)
- 01: Valid channel input falling edge (capture mode, trigger mode, reset mode, and clock mode), active

- low (gated mode and encoding mode)
- 10: Reserved
- 11: Valid channel input rising and falling edges (capture mode, trigger mode, reset mode, and clock mode), active high (gated mode and encoding mode)

**Bit 12 CC3E:** Channel enable.

**Input mode:**

- 0: Capture disabled
- 1: Capture enabled

**Output mode:**

- 0: Output disabled
- 1: Output enabled

**Bit 11 CC2NP:** Output inverted polarity- which must be bit 0 for output mode, refer to CC2P for input mode.

**Bit 10 RESERVED:** Reserved.

**Bit 9 CC2P:** Output polarity- which must work in conjunction with CC2NP (Configure polarity preferably before mode selection to prevent unknown errors triggered by internal signal toggle).

**Output mode:**

- 0: Output active polarity bit high level
- 1: Output active polarity bit low level

**Input mode, {CC2NP, CC2P}:**

- 00: Valid Channel input rising edge (capture mode, trigger mode, reset mode and clock mode), active high (gated mode and encoding mode)
- 01: Valid channel input falling edge (capture mode, trigger mode, reset mode, and clock mode), active low (gated mode and encoding mode)
- 10: Reserved
- 11: Valid channel input rising and falling edges (capture mode, trigger mode, reset mode, and clock mode), active high (gated mode and encoding mode)

**Bit 8 CC2E:** Channel enable.

**Input mode:**

- 0: Capture disabled
- 1: Capture enabled

**Output mode:**

- 0: Output disabled
- 1: Output enabled

**Bit 7 CC1NP:** Output inverted polarity- which must be bit 0 for output mode, refer to CC1P for input mode.

**Bit 6 RESERVED:** Reserved.

**Bit 5 CC1P:** Output polarity- which must work in conjunction with CC1NP (Configure polarity preferably before mode selection to prevent unknown errors triggered by internal signal toggle).

**Output mode:**

- 0: Output active polarity bit high level
- 1: Output active polarity bit low level

**Input mode, {CC1NP, CC1P}:**

- 00: Valid Channel input rising edge (capture mode, trigger mode, reset mode and clock mode), active high (gated mode and encoding mode)
- 01: Valid channel input falling edge (capture mode, trigger mode, reset mode, and clock mode), active low (gated mode and encoding mode)
- 10: Reserved
- 11: Valid channel input rising and falling edges (capture mode, trigger mode, reset mode, and clock mode), active high (gated mode and encoding mode)

**Bit 4 CC1E:** Channel enable.

**Input mode:**

- 0: Capture disabled
- 1: Capture enabled

**Output mode:**

- 0: Output disabled
- 1: Output enabled

**Bit 3 CC0NP:** Output inverted polarity- which must be bit 0 for output mode, refer to CC0P for input mode.

**Bit 2 RESERVED:** Reserved.

**Bit 1 CC0P:** Output polarity- which must work in conjunction with CC0NP (Configure polarity preferably before mode selection to prevent unknown errors triggered by internal signal toggle).

**Output mode:**

- 0: Output active polarity bit high level
- 1: Output active polarity bit low level

**Input mode, {CC0NP, CC0P}:**

- 00: Valid Channel input rising edge (capture mode, trigger mode, reset mode and clock mode), active high (gated mode and encoding mode)
- 01: Valid channel input falling edge (capture mode, trigger mode, reset mode, and clock mode), active low (gated mode and encoding mode)
- 10: Reserved
- 11: Valid channel input rising and falling edges (capture mode, trigger mode, reset mode, and clock mode), active high (gated mode and encoding mode)

**Bit 0 CC0E:** Channel enable.

**Input mode:**

- 0: Capture disabled
- 1: Capture enabled

**Output mode:**

- 0: Output disabled
- 1: Output enabled

### 20.17.10 GPTIM\_CNT

Address Offset: 0x24

Reset Value: 0x0000

|       |
|-------|
| 15-0  |
| CNT   |
| rw-0h |

**Bit 15-0 CNT:** Counter value.

### 20.17.11 GPTIM\_PSC

Address Offset: 0x28

Reset Value: 0x0000

|       |
|-------|
| 15-0  |
| PSC   |
| rw-0h |

**Bit 15-0 PSC:** The clock division value is PSC+1.

### 20.17.12 GPTIM\_ARR

Address Offset: 0x2C

Reset Value: 0xFFFF

|          |
|----------|
| 15-0     |
| PSC      |
| rw-FFFFh |

**Bit 15-0 ARR:** Counter reload value.

### 20.17.13 GPTIM\_CCR0

Address Offset: 0x34

Reset Value: 0x0000

|       |
|-------|
| 15-0  |
| CCR0  |
| rw-0h |

**Bit 15-0 CCR0:** In output mode, this register holds the compare value written by the user for comparison with CNT. In input mode, this register holds the captured value and is read-only.

### 20.17.14 GPTIM\_CCR1

Address Offset: 0x38

Reset Value: 0x0000

| 15-0  |
|-------|
| CCR1  |
| rw-0h |

**Bit 15-0 CCR1:** In output mode, this register holds the compare value written by the user for comparison with CNT. In input mode, this register holds the captured value and is read-only.

### 20.17.15 GPTIM\_CCR2

Address Offset: 0x3C

Reset Value: 0x0000

| 15-0  |
|-------|
| CCR2  |
| rw-0h |

**Bit 15-0 CCR2:** In output mode, this register holds the compare value written by the user for comparison with CNT. In input mode, this register holds the captured value and is read-only.

### 20.17.16 GPTIM\_CCR3

Address Offset: 0x40

Reset Value: 0x0000

| 15-0  |
|-------|
| CCR3  |
| rw-0h |

**Bit 15-0 CCR3:** In output mode, this register holds the compare value written by the user for comparison with CNT. In input mode, this register holds the captured value and is read-only.

### 20.17.17 GPTIM\_DCR

Address Offset: 0x48

Reset Value: 0x0000

| 15-13    | 12-8  | 7-5      | 4-0   |
|----------|-------|----------|-------|
| RESERVED | DBL   | RESERVED | DBA   |
| r-0h     | rw-0h | r-0h     | rw-0h |

**Bit 15-13 RESERVED:** Reserved.

**Bit 12-8 DBL:** DMA consecutive read/write length.

- 00000: 1 transfer
- 00001: 2 transfers
- 00010: 3 transfers
- 00011: 4 transfers
- 00100: 5 transfers
- 00101: 6 transfers
- 00110: 7 transfers
- 00111: 8 transfers
- 01000: 9 transfers
- 01001: 10 transfers
- 01010: 11 transfers
- 01011: 12 transfers
- 01100: 13 transfers
- 01101: 14 transfers
- 01110: 15 transfers
- 01111: 16 transfers
- 10000: 17 transfers
- 10001: 18 transfers

**Bit 7-5 RESERVED:** Reserved,

**Bit 4-0 DBA:** DMA consecutive read/write base address.

- 00000: CR1 register
- 00001: CR2 register
- 00010: SMCR register
- 00011: DIER register
- 00100: SR register
- 00101: EGR register
- 00110: CCMR1 register
- 00111: CCMR2 register
- 01000: CCER register
- 01001: CNT register
- 01010: PSC register
- 01011: ARR register
- 01100: Reserved register with address offset 0X30
- 01101: CCR0 register
- 01110: CCR1 register
- 01111: CCR2 register
- 10000: CCR3 register
- 10001: Reserved register with address offset 0X44
- 10010: DCR register
- 10011: DMAR register
- 10100: OR register
- 10101: reserved
- 10110: reserved

- 10111: reserved
- 11000: reserved
- 11001: reserved
- 11010: reserved
- 11011: reserved
- 11100: reserved
- 11101: reserved
- 11110: reserved
- 11111: reserved

### 20.17.18 GPTIM\_DMAR

Address Offset: 0x4C

Reset Value: 0x0000

| 15-0  |
|-------|
| DMAR  |
| rw-0h |

**Bit 15-0 DMAR:** This register holds the value of the register currently being operated by the DMA. For example, if the DMA needs to operate the TIM\_CR2 register, then directly operating this address is equivalent to operating the TIM\_CR2 register. As for which register it is, the values of DSTEP, DBL and DBA are to be referenced.

### 20.17.19 GPTIM\_OR

Address Offset: 0x50

Reset Value: 0x0000

The structure of this register for GPTIMER0 is as follows:

| 15-11    | 10-7    | 6-4     | 3-0     |
|----------|---------|---------|---------|
| RESERVED | ETR_RMP | TI3_RMP | TI0_RMP |
| r-0h     | rw-0h   | rw-0h   | rw-0h   |

**Bit 15-11 RESERVED:** Reserved.

**Bit 10-7 ETR\_RMP:** ETR remapping

- 0000: iom
- 0001: comp0
- 0010: comp1
- 0011: xo32k
- 0100: rco48m
- 0101: adcctrl\_awd0
- 0110: adcctrl\_awd1
- 0111: adcctrl\_awd2
- 1000: uart\_rx[0]

- 1001: uart\_rx[1]
- 1010: uart\_rx[2]
- 1011: uart\_rx[3]
- 1100: uart\_rx[4]
- 1101: reserved
- 1110: reserved
- 1111: reserved

**Bit 6-4 TI3\_RMP:** Channel 3 remapping.

- 000: iom
- 001: comp0
- 010: comp1
- 011: reserved
- 100: reserved
- 101: reserved
- 110: reserved
- 111: reserved

**Bit 3-0 TI0\_RMP:** Channel 0 remapping.

- 0000: iom
- 0001: uart\_rx[0]
- 0010: uart\_rx[1]
- 0011: uart\_rx[2]
- 0100: uart\_rx[3]
- 0101: uart\_rx[4]
- 0110: reserved
- 0111: reserved
- 1000: reserved
- 1001: reserved
- 1010: reserved
- 1011: reserved
- 1100: reserved
- 1101: reserved
- 1110: reserved
- 1111: reserved

The structure of this register for GPTIMER1 is as follows:

| 15-2     | 1-0     |
|----------|---------|
| RESERVED | TI2_RMP |
| r-0h     | rw-0h   |

**Bit 15-2 RESERVED:** Reserved.

**Bit 1-0 TI2\_RMP:** Channel 2 remapping.

- 00: iom
- 01: TIM3\_CH1

- 10: reserved
- 11: reserved

The structure of this register for GPTIMER2 is as follows:

| 15-10    | 9-7     | 6-5     | 4-0     |
|----------|---------|---------|---------|
| RESERVED | ETR_RMP | TI1_RMP | TI0_RMP |
| r-0h     | rw-0h   | rw-0h   | rw-0h   |

**Bit 15-10 RESERVED:** Reserved.

**Bit 9-7 ETR\_RMP:** ETR remapping.

- 0000: iom
- 0001: comp0
- 0010: comp1
- 0011: xo32k
- 0100: reserved
- 0101: reserved
- 0110: reserved
- 0111: reserved
- 1000: reserved
- 1001: reserved
- 1010: reserved
- 1011: reserved
- 1100: reserved
- 1101: reserved
- 1110: reserved
- 1111: reserved

**Bit 6-5 TI1\_RMP:** Channel 1 remapping.

- 00: iom
- 01: comp1
- 10: reserved
- 11: reserved

**Bit 4-0 TI0\_RMP:** Channel 0 remapping.

- 00000: iom
- 00001: xo24m
- 00010: xo32m
- 00011: rco48m
- 00100: xo32k
- 00101: rco32k
- 00110: mco
- 00111: comp0
- 01000: rco3.6m
- 01001: rtc\_alarm1\_happen\_pulse
- 01010: rtc\_alarm0\_happen\_pulse

- 01011: rtc\_cyc\_counter\_pulse
- 01100: reserved
- 01101: reserved
- 01110: reserved
- 01111: reserved
- 10000: reserved
- 10001: reserved
- 10010: reserved
- 10011: reserved
- 10100: reserved
- 10101: reserved
- 10110: reserved
- 10111: reserved
- 11000: reserved
- 11001: reserved
- 11010: reserved
- 11011: reserved
- 11100: reserved
- 11101: reserved
- 11110: reserved
- 11111: reserved

The structure of this register for GPTIMER3 is as follows:

| 15-7     | 6-3     | 2-0     |
|----------|---------|---------|
| RESERVED | ETR_RMP | TIO_RMP |
| r-0h     | rw-0h   | rw-0h   |

**Bit 15-7 RESERVED:** Reserved.

**Bit 6-3 ETR\_RMP:** ETR remapping.

- 0000: iom
- 0001: comp0
- 0010: comp1
- 0011: xo32k
- 0100: uart\_rx[0]
- 0101: uart\_rx[1]
- 0110: uart\_rx[2]
- 0111: uart\_rx[3]
- 1000: uart\_rx[4]
- 1001: reserved
- 1010: reserved
- 1011: reserved
- 1100: reserved
- 1101: reserved
- 1110: reserved

- 1111: reserved

**Bit 2-0 TI0\_RMP:** Channel 0 remapping.

- 000: iom
- 001: comp0
- 010: comp1
- 011: uart\_rx[0]
- 100: uart\_rx[1]
- 101: uart\_rx[2]
- 110: uart\_rx[3]
- 111: uart\_rx[4]

# 21.

# I2S

The Inter-IC Sound (I2S) Bus is a simple three-wire serial bus protocol that only handles the transfer of audio data. It supports configurable data bit width. When the data bit width changes, the corresponding data rate is reconfigured.

## 21.1 Main Features

1. I2S transmitter and/or receiver based on the Philips I2S serial protocol
2. Full duplex communication
3. Master or slave mode of operation
4. Audio data resolutions of 12, 16, 20, 24, and 32 bits
5. FIFO configurable number of stereo channels (up to 4) for both transmitter and receiver
6. Configurable support for software DMA
7. Supports interrupt
8. The generation of TX empty and RX available data interrupts can be configured by FIFO trigger threshold level.

The following figure illustrates the block diagram of I2S:



## 21.2 Data Reception and Transmission

The external pins of I2S are mclk, sclk, ws and data, where mclk is valid only in master mode and is the output signal. The slave can get its clock from the master's mclk pin if it does not have a stable one. Sclk and ws pins are output signals in master mode and input signals in slave mode. When they are input signals, sclk, ws, and data are represented by sclk\_in, ws\_in, and di respectively, and when they are output signals, they are represented by sclk\_out, ws\_out, and do respectively.

### 21.2.1 Pin Connections

The pin connections between I2S master and slave is shown in the figure below:



The pin for transmitting data consists of two pins, di and do, allowing for full duplex communication.

### 21.2.2 Transmission waveform

The I2S transmission waveform is as follows:



Data must be transmitted and received from the left channel first, otherwise it will lead to interruption and invalid data. The master must generate the clock, i.e. sclk and ws signals before transmitting and receiving data in slave mode, otherwise it will cause failure.

## 21.3 Clock Configuration

The following interface clocks are available for I2S: 0: pclk0, 1: xo24m, 2: pll, 3: xo32m, >3: external clock. In slave mode, only external clock can be selected as the I2S interface clock. The interface clock can be changed before it is enabled, but not afterwards.

## 21.4 Software DMA

Unlike general DMA, for software DMA, every time a block size of data is transferred, the DMA status is queried by I2S interrupt or polling to see if the data transfer is complete, and when the transfer is complete, the DMA should be triggered again for the next data transfer. If the block size is set to N, then the DMA status should be queried for N times and N DMA transfers should be triggered.

### I2S DMA Transmission Process:

- (1) Configure the [I2S\\_TXDMA](#) register address as the destination address of DMA;
- (2) Configure the memory address of transmitted data as the source address of DMA;
- (3) Configure the DATA\_WIDTH of DMA to 2 (32-bit data width);
- (4) Configure the SRC\_MSIZE and DEST\_MSIZE of DMA to 0 (burst length of 1) in the [DMA\\_CTLx register](#);
- (5) Configure the total data transmission length of DMA to N;
- (6) Configure the handshake of DMA to 0, i.e., an invalid value;
- (7) Enable the DMA channel;
- (8) Configure the [DMA\\_CFGx register](#) according to the DMA channel to enable software DMA;
- (9) Configure the destination request to trigger DMA transmissions, with the number of triggers being the total transmission length N configured above.

### I2S DMA Receiving Process:

- (1) Configure the [I2S\\_RXDMA](#) register address as the source address of DMA;
- (2) Configure the memory address of transmitted data as the destination address of DMA;
- (3) Configure the DATA\_WIDTH of DMA to 2 (32-bit data width);

- (4) Configure the SRC\_MSIZE and DEST\_MSIZE of DMA to 0 (burst length of 1) in the [DMA\\_CTLx register](#);
- (5) Configure the total data transmission length of DMA to N;
- (6) Configure the handshake of DMA to 0, i.e., an invalid value;
- (7) Enable the DMA channel;
- (8) Configure the [DMA\\_CFGx register](#) according to the DMA channel to enable software DMA;
- (9) Configure the source request to trigger DMA transmissions, with the number of triggers being the total transmission length N configured above.

## 21.5 Interrupt

I2S has 4 interrupt sources, TX overflow, TX empty, RX overflow, and RX available data, each of which can be enabled or disabled by independent interrupt mask bits. The TX empty and RX available data interrupts can be generated by configuring the FIFO trigger threshold level. The TX empty interrupt is generated when the number of used FIFOs in the TX FIFO is less than or equal to the threshold level, and the RX available data interrupt is generated when the number of used FIFOs in the RX FIFO is greater than or equal to the threshold level. The FIFO trigger threshold levels for the TX empty and RX available data interrupts are configured through [TFCR and RFCR registers](#) respectively. The I2S interrupt signals are listed below:

| Interrupt         | Description            |
|-------------------|------------------------|
| TX overflow       | TX FIFO overflow       |
| TX empty          | TX FIFO empty          |
| RX overflow       | RX FIFO overflow       |
| RX available data | RX FIFO available data |

The above interrupts are enabled by configuring the [IMR register](#).

## 21.6 I2S Register

I2S base address: 0x40002000

| Register         | Offset | Description                            |
|------------------|--------|----------------------------------------|
| IER              | 0x00   | Enable Register                        |
| IRER             | 0x04   | Receiver Block Enable Register         |
| ITER             | 0x08   | Transmitter Block Enable Register      |
| CER              | 0x0C   | Clock Enable Register                  |
| CCR              | 0x10   | Clock Configuration Register           |
| RXFFR            | 0x14   | Receiver Block FIFO Register           |
| TXFFR            | 0x18   | Transmitter Block FIFO Register        |
| LRBR_LTHR        | 0x20   | Left Receive Transmit Buffer Register  |
| RRBR_RTHR        | 0x24   | Right Receive Transmit Buffer Register |
| RER              | 0x28   | Receive Enable Register                |
| TER              | 0x2C   | Transmit Enable Register               |
| RCR              | 0x30   | Receive Configuration Register         |
| TCR              | 0x34   | Transmit Configuration Register        |
| ISR              | 0x38   | Interrupt Status Register              |
| IMR              | 0x3C   | Interrupt Mask Register                |
| ROR              | 0x40   | Receive Overrun Register               |
| TOR              | 0x44   | Transmit Overrun Register              |
| RFCR             | 0x48   | Receive FIFO Configuration Register    |
| TFCR             | 0x4C   | Transmit FIFO Configuration Register   |
| RFF              | 0x50   | Receive FIFO Flush Register            |
| TFF              | 0x54   | Transmit FIFO Flush Register           |
| RXDMA            | 0x1C0  | Receiver Block DMA Register            |
| RRXDMA           | 0x1C4  | Reset Receiver Block DMA Register      |
| TXDMA            | 0x1C8  | Transmitter Block DMA Register         |
| RTXDMA           | 0x1CC  | Reset Transmitter Block DMA Register   |
| I2S_COMP_PARM_2  | 0x1F0  | Component Parameter 2 Register         |
| I2S_COMP_PARM_1  | 0x1F4  | Component Parameter 1 Register         |
| I2S_COMP_VERSION | 0x1F8  | Component Version Register             |
| I2S_COMP_TYPE    | 0x1FC  | Component Type Register                |

### 21.6.1 IER

Address Offset: 0x00

Reset Value: 0x00000000

|             |          |
|-------------|----------|
| <b>31-1</b> | <b>0</b> |
| RESERVED    | IEN      |
| r-0h        | rw-0h    |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 IEN:** I2S enable.

- 0: Disabled
- 1: Enabled

## 21.6.2 IRER

Address Offset: 0x04

Reset Value: 0x00000000

| 31-1     | 0     |
|----------|-------|
| RESERVED | RXEN  |
| r-0h     | rw-0h |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 RXEN:** Receive block enable.

- 0: Disabled
- 1: Enabled

## 21.6.3 ITER

Address Offset: 0x08

Reset Value: 0x00000000

| 31-1     | 0     |
|----------|-------|
| RESERVED | TXEN  |
| r-0h     | rw-0h |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 TXEN:** Transmitter block enable.

- 0: Disabled
- 1: Enabled

## 21.6.4 CER

Address Offset: 0x0C

Reset Value: 0x00000000

| 31-1     | 0     |
|----------|-------|
| RESERVED | CLKEN |
| r-0h     | rw-0h |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 CLKEN:** Clock enable.

- 0: Disabled
- 1: Enabled

### 21.6.5 CCR

Address Offset: 0x10

Reset Value: 0x00000000

| 31-5     | 4-3   | 2-0   |
|----------|-------|-------|
| RESERVED | WSS   | SCLKG |
| r-0h     | rw-0h | rw-0h |

**Bit 31-5 RESERVED:** Reserved.

**Bit 4-3 WSS:** WS length.

- 0: 16 clock cycles
- 1: 24 clock cycles
- 2: 32 clock cycles

**Bit 2-0 SCLKG:** Sclk gating.

- 0: No gating
- 1: 12 clock cycles
- 2: 16 clock cycles
- 3: 20 clock cycles
- 4: 24 clock cycles

### 21.6.6 RXFFR

Address Offset: 0x14

Reset Value: 0x00000000

| 31-1     | 0     |
|----------|-------|
| RESERVED | RXFFR |
| r-0h     | w-0h  |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 RXFFR:** Receiver block FIFO reset.

- 0: Disabled
- 1: Enabled

### 21.6.7 TXFFR

Address Offset: 0x18

Reset Value: 0x00000000

| 31-1     | 0     |
|----------|-------|
| RESERVED | TXFFR |
| r-0h     | w-0h  |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 TXFFR:** Transmitter block FIFO reset.

- 0: Disabled
- 1: Enabled

### 21.6.8 LRBR\_LTHR

Address Offset: 0x20

Reset Value: 0x00000000

| 31-0      |
|-----------|
| LRBR_LTHR |
| rw-0h     |

**Bit 31-0 LRBR\_LTHR:** Left receive transmit buffer.

### 21.6.9 RRBR\_RTHR

Address Offset: 0x24

Reset Value: 0x00000000

| 31-0      |
|-----------|
| RRBR_RTHR |
| rw-0h     |

**Bit 31-0 RRBR\_RTHR:** Right receive transmit buffer.

### 21.6.10 RER

Address Offset: 0x28

Reset Value: 0x00000001

| 31-1     | 0      |
|----------|--------|
| RESERVED | RXCHEN |
| r-0h     | w-1h   |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 RXCHEN:** Receive channel enable control.

- 0: Disabled
- 1: Enabled

### 21.6.11 TER

Address Offset: 0x2C

Reset Value: 0x00000001

| 31-1     | 0      |
|----------|--------|
| RESERVED | TXCHEN |
| r-0h     | w-1h   |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 TXCHEN:** Transmit channel enable control.

- 0: Disabled
- 1: Enabled

### 21.6.12 RCR

Address Offset: 0x30

Reset Value: 0x00000000

| 31-3     | 2-0  |
|----------|------|
| RESERVED | WLEN |
| r-0h     | w-0h |

**Bit 31-3 RESERVED:** Reserved.

**Bit 2-0 WLEN:** Word length.

- 000: Ignore word length
- 001: 12 bits
- 010: 16 bits
- 011: 20 bits
- 100: 24 bits
- 101: 32 bits

### 21.6.13 TCR

Address Offset: 0x34

Reset Value: 0x00000000

| 31-3     | 2-0  |
|----------|------|
| RESERVED | WLEN |
| r-0h     | w-0h |

**Bit 31-3 RESERVED:** Reserved.

**Bit 2-0 WLEN:** Word length.

- 000: Ignore word length
- 001: 12 bits
- 010: 16 bits
- 011: 20 bits
- 100: 24 bits
- 101: 32 bits

### 21.6.14 ISR

Address Offset: 0x38

Reset Value: 0x00000010

| <b>31-6</b> | <b>5</b> | <b>4</b> | <b>3-2</b> | <b>1</b> | <b>0</b> |
|-------------|----------|----------|------------|----------|----------|
| RESERVED    | TXFO     | TXFE     | RESERVED   | RXFO     | RXDA     |
| r-0h        | r-0h     | r-1h     | r-0h       | r-0h     | r-0h     |

**Bit 31-6 RESERVED:** Reserved.

**Bit 5 TXFO:** Status of data overrun interrupt for the TX channel.

- 0: No overrun
- 1: Overrun

**Bit 4 TXFE:** Status of transmit empty trigger interrupt.

- 0: No empty
- 1: Empty

**Bit 3-2 RESERVED:** Reserved.

**Bit 1 RXFO:** Status of data overrun interrupt for the RX channel.

- 0: No overrun
- 1: Overrun

**Bit 0 RXDA:** Status of receive data available interrupt.

- 0: No data
- 1: Data

### 21.6.15 IMR

Address Offset: 0x3C

Reset Value: 0x00000033

| <b>31-6</b> | <b>5</b> | <b>4</b> | <b>3-2</b> | <b>1</b> | <b>0</b> |
|-------------|----------|----------|------------|----------|----------|
| RESERVED    | TXFOM    | TXFEM    | RESERVED   | RXFOM    | RXDAM    |
| r-0h        | rw-1h    | rw-1h    | r-0h       | rw-1h    | rw-1h    |

**Bit 31-6 RESERVED:** Reserved.

**Bit 5 TXFOM:** Masks TX FIFO overrun interrupt.

- 0: Unmasks
- 1: Masks

**Bit 4 TXFEM:** Masks TX FIFO empty interrupt

- 0: Unmasks
- 1: Masks

**Bit 3-2 RESERVED:** Reserved.

**Bit 1 RXFOM:** Masks RX FIFO overrun interrupt.

- 0: Unmasks
- 1: Masks

**Bit 0 RXDAM:** Masks RX FIFO data available interrupt.

- 0: Unmasks
- 1: Masks

### 21.6.16 ROR

Address Offset: 0x40

Reset Value: 0x00000000

| 31-1     | 0     |
|----------|-------|
| RESERVED | RXCHO |
| r-0h     | r-0h  |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 RXCHO:** Receive channel overrun status. Read this bit to clear the RX FIFO data overrun interrupt.

- 0: No overrun
- 1: Overrun

### 21.6.17 TOR

Address Offset: 0x44

Reset Value: 0x00000000

| 31-1     | 0     |
|----------|-------|
| RESERVED | TXCHO |
| r-0h     | r-0h  |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 TXCHO:** Transmit channel overrun status. Read this bit to clear the TX FIFO data overrun interrupt.

- 0: No overrun
- 1: Overrun

### 21.6.18 RFCR

Address Offset: 0x48

Reset Value: 0x00000000

| 31-4     | 3-0    |
|----------|--------|
| RESERVED | RXCHDT |
| r-0h     | rw-0h  |

**Bit 31-4 RESERVED:** Reserved.

**Bit 3-0 RXCHDT:** These bits program the trigger level in the RX FIFO at which the received data available interrupt is generated.

- 0000: FIFO trigger threshold is 1.
- 0001: FIFO trigger threshold is 2
- 0010: FIFO trigger threshold is 3
- 0011: FIFO trigger threshold is 4
- 0100: Reserved
- 0101: Reserved
- 0110: Reserved
- 0111: Reserved
- 1000: Reserved
- 1001: Reserved
- 1010: Reserved
- 1011: Reserved
- 1100: Reserved
- 1101: Reserved
- 1110: Reserved
- 1111: Reserved

### 21.6.19 TFCR

Address Offset: 0x4C

Reset Value: 0x00000000

| 31-4     | 3-0    |
|----------|--------|
| RESERVED | TXCHET |
| r-0h     | rw-0h  |

**Bit 31-4 RESERVED:** Reserved.

**Bit 3-0 TXCHET:** These bits program the trigger level in the TX FIFO at which the Empty Threshold Reached Interrupt is generated.

- 0000: FIFO trigger threshold is 0
- 0001: FIFO trigger threshold is 1

- 0010: FIFO trigger threshold is 2
- 0011: FIFO trigger threshold is 3
- 0100: Reserved
- 0101: Reserved
- 0110: Reserved
- 0111: Reserved
- 1000: Reserved
- 1001: Reserved
- 1010: Reserved
- 1011: Reserved
- 1100: Reserved
- 1101: Reserved
- 1110: Reserved
- 1111: Reserved

### 21.6.20 RFF

Address Offset: 0x50

Reset Value: 0x00000000

| 31-1     | 0      |
|----------|--------|
| RESERVED | RXCHFR |
| r-0h     | w-0h   |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 RXCHFR:** Receive channel FIFO reset.

- 0: Disabled
- 1: Enabled

### 21.6.21 TFF

Address Offset: 0x54

Reset Value: 0x00000000

| 31-1     | 0      |
|----------|--------|
| RESERVED | TXCHFR |
| r-0h     | w-0h   |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 TXCHFR:** Transmit channel FIFO reset.

- 0: Disabled
- 1: Enabled

### 21.6.22 RXDMA

Address Offset: 0x1C0

Reset Value: 0x00000000

| 31-0  |
|-------|
| RXDMA |
| r-0h  |

**Bit 31-0 RXDMA:** Receiver Block DMA Register.

### 21.6.23 RRXDMA

Address Offset: 0x1C4

Reset Value: 0x00000000

| 31-1     | 0      |
|----------|--------|
| RESERVED | RRXDMA |
| r-0h     | w-0h   |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 RRXDMA:** Reset Receiver Block DMA Register.

- 0: Disabled
- 1: Enabled

### 21.6.24 TXDMA

Address Offset: 0x1C8

Reset Value: 0x00000000

| 31-0  |
|-------|
| TXDMA |
| w-0h  |

**Bit 31-0 TXDMA:** Transmitter Block DMA Register.

### 21.6.25 RTXDMA

Address Offset: 0x1CC

Reset Value: 0x00000000

| 31-1     | 0      |
|----------|--------|
| RESERVED | RTXDMA |
| r-0h     | w-0h   |

**Bit 31-1 RESERVED:** Reserved.

**Bit 0 RTXDMA:** Reset Transmitter Block DMA Register.

- 0: Disabled
- 1: Enabled

### 21.6.26 I2S\_COMP\_PARAM\_2

Address Offset: 0x1F0

Reset Value: 0x0000048C

| 31-13    | 12-10             | 9-7               |
|----------|-------------------|-------------------|
| RESERVED | I2S_RX_WORDSIZE_3 | I2S_RX_WORDSIZE_2 |
| r-0h     | r-1h              | r-1h              |
| 6        | 5-3               | 2-0               |
| RESERVED | I2S_RX_WORDSIZE_1 | I2S_RX_WORDSIZE_0 |
| r-0h     | r-1h              | r-4h              |

**Bit 31-13 RESERVED:** Reserved.

**Bit 12-10 I2S\_RX\_WORDSIZE\_3:** Bit width of receive channel 3.

- 000: 12 bits
- 001: 16 bits
- 010: 20 bits
- 011: 24 bits
- 100: 32 bits

**Bit 9-7 I2S\_RX\_WORDSIZE\_2:** Bit width of receive channel 2.

- 000: 12 bits
- 001: 16 bits
- 010: 20 bits
- 011: 24 bits
- 100: 32 bits

**Bit 6 RESERVED:** Reserved.

**Bit 5-3 I2S\_RX\_WORDSIZE\_1:** Bit width of receive channel 1.

- 000: 12 bits

- 001: 16 bits
- 010: 20 bits
- 011: 24 bits
- 100: 32 bits

**Bit 2-0 I2S\_RX\_WORDSIZE\_0:** Bit width of receive channel 0.

- 000: 12 bits
- 001: 16 bits
- 010: 20 bits
- 011: 24 bits
- 100: 32 bits

### 21.6.27 I2S\_COMP\_PARAM\_1

Address Offset: 0x1F4

Reset Value: 0x24C0066

| 31-28                 | 27-25             | 24-22                 |
|-----------------------|-------------------|-----------------------|
| RESERVED              | I2S_TX_WORDSIZE_3 | I2S_TX_WORDSIZE_2     |
| r-0h                  | r-0h              | r-0h                  |
| <b>21-19</b>          | <b>18-16</b>      | <b>15-11</b>          |
| I2S_TX_WORDSIZE_1     | I2S_TX_WORDSIZE_0 | RESERVED              |
| r-0h                  | r-4h              | r-0h                  |
| <b>10-9</b>           | <b>8-7</b>        | <b>6</b>              |
| I2S_TX_CHANNELS       | I2S_RX_CHANNELS   | I2S_RECEIVER_BLOCK    |
| r-0h                  | r-0h              | r-1h                  |
| <b>5</b>              | <b>4</b>          | <b>3-2</b>            |
| I2S_TRANSMITTER_BLOCK | I2S_MODE_EN       | I2S_FIFO_DEPTH_GLOBAL |
| r-1h                  | r-0h              | r-1h                  |
| <b>1-0</b>            |                   |                       |
| APB_DATA_WIDTH        |                   |                       |
| r-2h                  |                   |                       |

**Bit 31-28 RESERVED:** Reserved.

**Bit 27-25 I2S\_TX\_WORDSIZE\_3:** Bit width of transmit channel 3.

- 000: 12 bits
- 001: 16 bits
- 010: 20 bits
- 011: 24 bits
- 100: 32 bits

**Bit 24-22 I2S\_TX\_WORDSIZE\_2:** Bit width of transmit channel 2.

- 000: 12 bits
- 001: 16 bits

- 010: 20 bits
- 011: 24 bits
- 100: 32 bits

**Bit 21-19 I2S\_TX\_WORDSIZE\_1:** Bit width of transmit channel 1.

- 000: 12 bits
- 001: 16 bits
- 010: 20 bits
- 011: 24 bits
- 100: 32 bits

**Bit 18-16 I2S\_TX\_WORDSIZE\_0:** Bit width of transmit channel 0.

- 000: 12 bits
- 001: 16 bits
- 010: 20 bits
- 011: 24 bits
- 100: 32 bits

**Bit 15-11 RESERVED:** Reserved.

**Bit 10-9 I2S\_TX\_CHANNELS:** Channel number of transmitter block.

- 00: 1 channel
- 01: 2 channels
- 10: 3 channels
- 11: 4 channels

**Bit 8-7 I2S\_RX\_CHANNELS:** Channel number of receiver block.

- 00: 1 channel
- 01: 2 channels
- 10: 3 channels
- 11: 4 channels

**Bit 6 I2S\_RECEIVER\_BLOCK:** Receiver block.

- 0: No receiver block
- 1: Receiver block

**Bit 5 I2S\_TRANSMITTER\_BLOCK:** Transmitter block.

- 0: No transmitter block
- 1: Transmitter block

**Bit 4 I2S\_MODE\_EN:** MASTER or not.

- 0: No
- 1: Yes

**Bit 3-2 I2S\_FIFO\_DEPTH\_GLOBAL:** FIFO depth.

- 00: 2
- 01: 4
- 10: 8
- 11: 16

**Bit 1-0 APB\_DATA\_WIDTH:** APB bus data bit width.

- 00: 8 bits
- 01: 16 bits
- 10: 32 bits
- 11: Reserved

### 21.6.28 I2S\_COMP\_VERSION

Address Offset: 0x1F8

Reset Value: 0x3130392A

| 31-0             |
|------------------|
| I2S_COMP_VERSION |
| r-3130392ah      |

**Bit 31-0 I2S\_COMP\_VERSION:** Version number.

### 21.6.29 I2S\_COMP\_TYPE

Address Offset: 0x1FC

Reset Value: 0x445701a0

| 31-0          |
|---------------|
| I2S_COMP_TYPE |
| r-445701a0h   |

**Bit 31-0 I2S\_COMP\_TYPE:** Component type.

# 22.

# LCD

LCD (Liquid Crystal Display) is a display controller that supports display at low power consumption and supports multiple COMs and SEGs.

## 22.1 Main Features

1. Bias configuration
2. Duty control
3. Automatic switching of high and low currents and high current duration cycle control
4. Blink position and frequency control
5. Dead state duration configuration
6. Frequency division and prescale control
7. LCD drive mode configuration
8. Even frame transmission completion interrupt

## 22.2 COM and SEG

The LCD supports up to 4 COMs and 24 SEGs or 8 COMs and 20 SEGs. 8 COMs are currently not developed for use due to the poor display. One SEG and one COM form a pixel, and each SEG can form a pixel with each COM. For example, to light up the pixel composed of SEG 0 and COM 0, the bit 0 of the [DR0 register](#) should be set to 1, and the bit 0 to bit 23 of the [DR0 register](#) correspond to the pixel status of SEG 0 to SEG 23 on COM 0. The correspondence between COMs and DRx registers is as follows.

| COM   | DRx |
|-------|-----|
| COM 0 | DR0 |
| COM 1 | DR1 |
| COM 2 | DR2 |
| COM 3 | DR3 |
| COM 4 | DR4 |
| COM 5 | DR5 |
| COM 6 | DR6 |
| COM 7 | DR7 |

The following are the corresponding connections of COMs and SEGs to GPIOs:

| SEG or COM   | GPIO   | Remark                        |
|--------------|--------|-------------------------------|
| SEG 0        | GPIO16 |                               |
| SEG 1        | GPIO17 |                               |
| SEG 2        | GPIO23 |                               |
| SEG 3        | GPIO24 |                               |
| SEG 4        | GPIO25 |                               |
| SEG 5        | GPIO26 |                               |
| SEG 6        | GPIO08 |                               |
| SEG 7        | GPIO27 |                               |
| SEG 8        | GPIO28 |                               |
| SEG 9        | GPIO29 |                               |
| SEG 10       | GPIO30 |                               |
| SEG 11       | GPIO31 |                               |
| SEG 12       | GPIO13 |                               |
| SEG 13       | GPIO12 |                               |
| SEG 14       | GPIO09 |                               |
| SEG 15       | GPIO45 |                               |
| SEG 16       | GPIO44 |                               |
| SEG 17       | GPIO36 |                               |
| SEG 18       | GPIO35 |                               |
| SEG 19       | GPIO34 |                               |
| SEG 20/COM 7 | GPIO14 | SEG 20 and COM 7 share a GPIO |
| SEG 21/COM 6 | GPIO15 | SEG 21 and COM 6 share a GPIO |
| SEG 22/COM 5 | GPIO05 | SEG 22 and COM 5 share a GPIO |
| SEG 23/COM 4 | GPIO04 | SEG 23 and COM 4 share a GPIO |
| SEG 24/COM 3 | GPIO10 | SEG 24 and COM 3 share a GPIO |
| SEG 25/COM 2 | GPIO42 | SEG 25 and COM 2 share a GPIO |
| SEG 26/COM 1 | GPIO41 | SEG 26 and COM 1 share a GPIO |
| COM 0        | GPIO40 |                               |

When SEG and COM share a GPIO, only one of them can be used.

## 22.3 Bias and Duty

Both bias and duty controls are set by the [CR0 register](#). Bias supports 4 modes of control: 1/4, 1/3, 1/2, and static bias. Duty supports 5 modes of control: static duty, 1/2, 1/3, 1/4, and 1/8. When two COMs are used, the duty is configured as 1/2 and only COM 0 and COM 1 can be used. When three COMs are used, the duty is configured as 1/3, and only COM 0, COM 1 and COM 2 can be used. The same is true when four and eight COMs are used.

## 22.4 High and Low Current Switching Control

The high and low current switching and the high current duration cycle, controlled via the [CR1 register](#), are to reduce power consumption. The automatic high and low current switching can be enabled or disabled. The high current duration cycle can be configured as 0, 1, 2, 3, 4, 5, 6, or 7, which is based on the prescaled frequency as a reference.

## 22.5 Blink Control

The blink position and blink frequency control are configured via the [CR1 register](#). It is possible to disable the blink function, or to configure the blinking of one pixel of SEG 0 and COM 0, blinking of 8 pixels of SEG 0 and all COMs, or blinking of all pixels. For the blink frequency control, see the description of the [CR1 register](#).

## 22.6 Frequency Division and Prescale Control

Prescale and divide the LCD module clock frequency. See the description of the [CR1 register](#) for the specific frequency division value and prescaler value.

## 22.7 Dead Control

It is possible not to enable the dead state, if enabled, the number of cycles can be configured, referring to the clock frequency of the LCD module that is prescaled and divided. The number of cycles can be 1, 2, 3, 4, 5, 6 or 7.

## 22.8 LCD Drive Mode

Different drive modes show different contrast with different power consumption. There are four modes as follows:

1. low current mode
2. high current mode
3. low current + buffer mode
4. high current + buffer mode

The drive mode is configured by bit 3 and bit 4 of the analog register 0xB.

## 22.9 LCD Screen Software Control Process

The interface clock source of the LCD module can be XO32K or RCO32K. After the clock source is selected, the clock of the LCD module should be enabled. The software control process is as follows:

1. Set the GPIO corresponding to the SEG and COM to be used to ANALOG mode.
2. Configure bias, duty, prescale and frequency division.
3. Configure blink function and dead state
4. Configure the high and low current switching and high current duration cycle
5. Clear the status values of all DRx registers
6. Enable the LCD controller via the [CR0 register](#)
7. Control the state of the DRx register according to the display content. First, determine the connection between the GPIOs of the ASR6601 chip and the pins of the LCD screen. There is no need for a one-to-one correspondence between the SEG and COM of the chip and that of the LCD screen, that is, there is no need for SEG 0 of the ASR6601 to correspond to SEG 0 of the LCD screen, SEG 1 of the ASR6601 to correspond to SEG 1 of the LCD screen, and COM 0 of the ASR6601 to correspond to COM 0 of the LCD screen. They can be connected randomly. However, the SEG of the chip must be connected to the SEG of the LCD screen, and the COM of the chip must be connected to the COM of the LCD screen. In addition, for the convenience of software processing, the COM of the chip and the COM of the LCD screen generally correspond to each other, that is, the COM 0 of the chip is connected to the COM 0 of the LCD screen, and the COM 1 of the chip is connected to the COM 1 of the LCD screen, and so on. Then determine whether the pixel needs to be lit according to the display format of the LCD screen. Taking the display format of the VN-2646 LCD screen as an example as follows:

A

-----

| |

F| |B

| |

--G--

| |

E| |C

| |

-----

D

Then convert the display format to a list, as follows:

|           | COM0  | COM1 | COM2 | COM3 |
|-----------|-------|------|------|------|
| SEG (n)   | { D , | E ,  | G ,  | F }  |
| SEG (n+1) | { 0 , | C ,  | B ,  | A }  |

A, B, C, D, E, F, and G represent one pixel each. For example, if the number "0" is displayed, pixels A, B, C, D, E, and F should be lit. The lit pixel is indicated by 1., as shown below:

|           | COM0  | COM1 | COM2 | COM3 |
|-----------|-------|------|------|------|
| SEG (n)   | { 1 , | 1 ,  | 0 ,  | 1 }  |
| SEG (n+1) | { 0 , | 1 ,  | 1 ,  | 1 }  |

Next, replace the SEG and COM of the chip with the SEG and COM in the list above, for example, SEG (n) is actually connected to SEG 2 of the chip, SEG (n+1) is actually connected to SEG 5 of the chip, and the COM of the chip corresponds to the COM of the LCD screen one by one. The final list is as follows:

|       | COM0  | COM1 | COM2 | COM3 |
|-------|-------|------|------|------|
| SEG 2 | { 1 , | 1 ,  | 0 ,  | 1 }  |
| SEG 5 | { 0 , | 1 ,  | 1 ,  | 1 }  |

Finally, the state of the pixel of COM 0 and SEG 2 is set to active, i.e., the bit corresponding to SEG 2 in the [DR0 register](#) is set to 1, the bits corresponding to SEG 2 and SEG 5 in the [DR1 register](#) are set to 1, the bit corresponding to SEG 5 in the [DR2 register](#) is set to 1, and the bits corresponding to SEG 2 and SEG 5 in the [DR3 register](#) are set to 1.

8. Enable the SEG and COM of the LCD analog module. First, configure the number of COMs to be used through bit 1 to bit 3 of analog register 0x9. The configured values can be 0, 1, 2, 3, or 7, which means 1 COM, 2 COMs, 3 COMs, 4 COMs, and 8 COMs are used respectively. Then enable the needed COM of COM 1, COM 2, COM 3, COM 4, COM 5, COM 6, and COM 7 through analog register 0xb, and COM 0 through analog register 0xa. For SEG configuration, the SEG to be used is enabled by analog register 0xb. Finally, configure the analog register 0x6 to enable the LCD analog module.

## 22.10 Interrupt

The even frame transmission completion interrupt is enabled by bit 1 of the [CR2 register](#). The function of this interrupt is to make the display smoother when updating the display content. To update the display content via this interrupt, i.e., to update the value of register DRx, [DR0](#) is written first, then [DR1](#), and so on.

## 22.11 LCD Register

LCD base address: 0x40018000

| Register | Offset | Description            |
|----------|--------|------------------------|
| CR0      | 0x00   | Control Register 0     |
| CR1      | 0x04   | Control Register 1     |
| DR0      | 0x08   | COM 0 Control Register |
| DR1      | 0x0C   | COM 1 Control Register |
| DR2      | 0x10   | COM 2 Control Register |
| DR3      | 0x14   | COM 3 Control Register |
| DR4      | 0x18   | COM 4 Control Register |
| DR5      | 0x1C   | COM 5 Control Register |
| DR6      | 0x20   | COM 6 Control Register |
| DR7      | 0x24   | COM 7 Control Register |
| SR       | 0x28   | Status Register        |
| CR2      | 0x2C   | Control Register 2     |

### 22.11.1 CR0

Address Offset: 0x00

Reset Value: 0x00000000

| 31-6     | 5      | 4-3   | 2-0   |
|----------|--------|-------|-------|
| RESERVED | LCD_EN | BIAS  | DUTY  |
| r-0h     | rw-0h  | rw-0h | rw-0h |

**Bit31-6 RESERVED:** Reserved.

**Bit 5 LCD\_EN:** Enable control of the LCD controller. Before being enabled, both COM and SEG voltages are 0 V. After being enabled, the lcdctrl internal state machine starts to work and controls the lcddriver to generate waveforms.

- 0: disabled
- 1: enabled

**Bit 4-3 BIAS:** bias control.

- 0: bias 1/4
- 1: bias 1/3
- 2: bias 1/2
- 3: static bias

**Bit 2-0 DUTY:** duty control.

- 0: static duty

- 1: 1/2 duty
- 2: 1/3 duty
- 3: 1/4 duty
- 4-6: configuration is not allowed
- 7: 1/8 duty

## 22.11.2 CR1

Address Offset: 0x04

Reset Value: 0x00000000

| 31-20        | 19-17       | 16         | 15-13      |
|--------------|-------------|------------|------------|
| RESERVED     | RES_SEL_NUM | RES_SEL_EN | DEAD_CYCLE |
| r-0h         | rw-0h       | rw-0h      | rw-0h      |
| <b>12-11</b> | <b>10-8</b> | <b>7-4</b> | <b>3-0</b> |
| BLINK_SEL    | BLINK_FREQ  | DIV_NUM    | PRE_SCALER |
| rw-0h        | rw-0h       | rw-0h      | rw-0h      |

**Bit 31-20 RESERVED:** Reserved.

**Bit 19-17 RES-SEL-NUM:** LCD high current duration cycle (ps\_clk).

- 0: 0 ps\_clk
- 1: 1 ps\_clk
- 2: 2 ps\_clk
- 3: 3 ps\_clk
- 4: 4 ps\_clk
- 5: 5 ps\_clk
- 6: 6 ps\_clk
- 7: 7 ps\_clk

**Bit 16 RES\_SEL\_EN:** LCD high and low current automatic switching enable.

- 0: disabled
- 1: enabled

**Bit 15-13 DEAD\_CYCLE:** dead state duration cycle.

- 0: dead state disabled
- 1: 1 div\_clk cycle
- 2: 2 div\_clk cycles
- 3: 3 div\_clk cycles
- 4: 4 div\_clk cycles
- 5: 5 div\_clk cycles
- 6: 6 div\_clk cycles
- 7: 7 div\_clk cycles

**Bit 12-11 BLINK\_SEL:** blink position selection.

- 0: blink function disabled

- 1: 1 pixel of SEG 0 and COM 0 blinks
- 2: 8 pixels of SEG 0 and all COMs blink
- 3: all pixels of SEGs and COMs blink

**Bit 10-8 BLINK\_FREQ:** blink frequency control. Blink frequency= $\text{div\_clk}/(2^{(3+\text{BLINK\_FR EQ})})$ .

- 0:  $\text{div\_clk}/8$
- 1:  $\text{div\_clk}/16$
- 2:  $\text{div\_clk}/32$
- 3:  $\text{div\_clk}/64$
- 4:  $\text{div\_clk}/128$
- 5:  $\text{div\_clk}/256$
- 6:  $\text{div\_clk}/512$
- 7:  $\text{div\_clk}/1024$

**Bit 7-4 DIV\_NUM:** ps\_clk frequency division control.  $\text{div\_clk}=\text{ps\_clk}/(16+\text{DIV\_NUM})$ .

- 0:  $\text{div\_clk}=\text{ps\_clk}/16$
- 1:  $\text{div\_clk}=\text{ps\_clk}/17$
- 2:  $\text{div\_clk}=\text{ps\_clk}/18$
- 3:  $\text{div\_clk}=\text{ps\_clk}/19$
- 4:  $\text{div\_clk}=\text{ps\_clk}/20$
- 5:  $\text{div\_clk}=\text{ps\_clk}/21$
- 6:  $\text{div\_clk}=\text{ps\_clk}/22$
- 7:  $\text{div\_clk}=\text{ps\_clk}/23$
- 8:  $\text{div\_clk}=\text{ps\_clk}/24$
- 9:  $\text{div\_clk}=\text{ps\_clk}/25$
- 10:  $\text{div\_clk}=\text{ps\_clk}/26$
- 11:  $\text{div\_clk}=\text{ps\_clk}/27$
- 12:  $\text{div\_clk}=\text{ps\_clk}/28$
- 13:  $\text{div\_clk}=\text{ps\_clk}/29$
- 14:  $\text{div\_clk}=\text{ps\_clk}/30$
- 15:  $\text{div\_clk}=\text{ps\_clk}/31$

**Bit 3-0 PRE\_SCALER:** LCD interface clock (lcd\_clk) prescale control.  $\text{ps\_clk}=\text{lcd\_clk}/(2^{\text{PRE\_SCALER}})$ .

- 0:  $\text{ps\_clk}=\text{lcd\_clk}$
- 1:  $\text{ps\_clk}=\text{lcd\_clk}/2$
- 2:  $\text{ps\_clk}=\text{lcd\_clk}/4$
- 3:  $\text{ps\_clk}=\text{lcd\_clk}/8$
- 4:  $\text{ps\_clk}=\text{lcd\_clk}/16$
- 5:  $\text{ps\_clk}=\text{lcd\_clk}/32$
- 6:  $\text{ps\_clk}=\text{lcd\_clk}/64$
- 7:  $\text{ps\_clk}=\text{lcd\_clk}/128$
- 8:  $\text{ps\_clk}=\text{lcd\_clk}/256$
- 9:  $\text{ps\_clk}=\text{lcd\_clk}/512$
- 10:  $\text{ps\_clk}=\text{lcd\_clk}/1024$

- 11: ps\_clk= lcd\_clk/2048
- 12: ps\_clk= lcd\_clk/4096
- 13: ps\_clk= lcd\_clk/8192
- 14: ps\_clk= lcd\_clk/16384
- 15: ps\_clk= lcd\_clk/32768

### 22.11.3 DR0

Address Offset:0x08

Reset Value: 0x00000000

| 31-27    | 26-0           |
|----------|----------------|
| RESERVED | COM0_SEG_STATE |
| r-0h     | rw-0h          |

**Bit 31-27 RESERVED:** Reserved.

**Bit 26-0 COM0\_SEG\_STATE:** COM 0 corresponds to the active state of the SEG. Bit 0 corresponds to SEG 0, and bit 1 corresponds to SEG 1, and so on.

- 0: inactive
- 1: active

### 22.11.4 DR1

Address Offset:0x0C

Reset Value: 0x00000000

| 31-26    | 25-0           |
|----------|----------------|
| RESERVED | COM1_SEG_STATE |
| r-0h     | rw-0h          |

**Bit 31-26 RESERVED:** Reserved.

**Bit 25-0 COM1\_SEG\_STATE:** COM 1 corresponds to the active state of the SEG. Bit 0 corresponds to SEG 0, and bit 1 corresponds to SEG 1, and so on.

- 0: inactive
- 1: active

### 22.11.5 DR2

Address Offset: 0x10

Reset Value: 0x00000000

| 31-25    | 24-0           |
|----------|----------------|
| RESERVED | COM2_SEG_STATE |

|      |       |
|------|-------|
| r-0h | rw-0h |
|------|-------|

**Bit 31-25 RESERVED:** reserved.

**Bit 24-0 COM2\_SEG\_STATE:** COM 2 corresponds to the active state of the SEG. Bit 0 corresponds to SEG 0, and bit 1 corresponds to SEG 1, and so on.

- 0: inactive
- 1: active

#### 22.11.6 DR3

Address Offset: 0x14

Reset Value: 0x00000000

| 31-24    | 23-0           |
|----------|----------------|
| RESERVED | COM3_SEG_STATE |
| r-0h     | rw-0h          |

**Bit 31-24 RESERVED:** reserved.

**Bit 23-0 COM3\_SEG\_STATE:** COM 3 corresponds to the active state of the SEG. Bit 0 corresponds to SEG 0, and bit 1 corresponds to SEG 1, and so on.

- 0: inactive
- 1: active

#### 22.11.7 DR4

Address Offset: 0x18

Reset Value: 0x00000000

| 31-20    | 19-0           |
|----------|----------------|
| RESERVED | COM4_SEG_STATE |
| r-0h     | rw-0h          |

**Bit 31-20 RESERVED:** reserved.

**Bit 19-0 COM4\_SEG\_STATE:** COM 4 corresponds to the active state of the SEG. Bit 0 corresponds to SEG 0, and bit 1 corresponds to SEG 1, and so on.

- 0: inactive
- 1: active

### 22.11.8 DR5

Address Offset: 0x1C

Reset Value: 0x00000000

| 31-20    | 19-0           |
|----------|----------------|
| RESERVED | COM5_SEG_STATE |
| r-0h     | rw-0h          |

**Bit 31-20 RESERVED:** reserved.

**Bit 19-0 COM5\_SEG\_STATE:** COM 5 corresponds to the active state of the SEG. Bit 0 corresponds to SEG 0, and bit 1 corresponds to SEG 1, and so on.

- 0: inactive
- 1: active

### 22.11.9 DR6

Address Offset: 0x20

Reset Value: 0x00000000

| 31-20    | 19-0           |
|----------|----------------|
| RESERVED | COM6_SEG_STATE |
| r-0h     | rw-0h          |

**Bit 31-20 RESERVED:** reserved.

**Bit 19-0 COM6\_SEG\_STATE:** COM 6 corresponds to the active state of the SEG. Bit 0 corresponds to SEG 0, and bit 1 corresponds to SEG 1, and so on.

- 0: inactive
- 1: active

### 22.11.10 DR7

Address Offset: 0x24

Reset Value: 0x00000000

| 31-20    | 19-0           |
|----------|----------------|
| RESERVED | COM7_SEG_STATE |
| r-0h     | rw-0h          |

**Bit 31-20 RESERVED:** reserved.

**Bit 19-0 COM7\_SEG\_STATE:** COM 7 corresponds to the active state of the SEG. Bit 0 corresponds to SEG 0, and bit 1 corresponds to SEG 1, and so on.

- 0: inactive
- 1: active

### 22.11.11 SR

Address Offset: 0x28

Reset Value: 0x00000003

| 31-2     | 1              | 0              |
|----------|----------------|----------------|
| RESERVED | WRITE_CR1_DONE | WRITE_CR0_DONE |
| r-0h     | r-1h           | r-1h           |

**Bit 31-2 RESERVED:** reserved.

**Bit 1 WRITE\_CR1\_DONE:** CR1 operation completion status. This bit is set and cleared by hardware.

- 0: operation to be done
- 1: operation completed

**Bit 0 WRITE\_CR0\_DONE:** CR0 operation completion status. This bit is set and cleared by hardware.

- 0: operation to be done
- 1: operation completed

### 22.11.12 CR2

Address Offset: 0x2C

Reset Value: 0x00000000

| 31-2     | 1                      | 0                  |
|----------|------------------------|--------------------|
| RESERVED | EVEN_FRAME_DONE_INT_EN | EVEN_FRAME_DONE_SR |
| r-0h     | rw-0h                  | r-0h               |

**Bit 31-2 RESERVED:** reserved.

**Bit 1 EVEN\_FRAME\_DONE\_INT\_EN:** EVEN\_FRAME\_DONE interrupt enable.

- 0: interrupt disabled
- 1: interrupt enabled

**Bit 0 EVEN\_FRAME\_DONE\_SR:** EVEN\_FRAME\_DONE interrupt status. This bit is set by hardware, and cleared by software by writing 1.

- 0: no interrupt occurred
- 1: interrupt occurred