

# A31G324, A31G323 User's Manual

# 32-bit Cortex-M0+ based General Purpose Microcontroller

Version 1.07

## Introduction

This user's manual contains complete information for application developers who use A31G324 or A31G323 for their specific needs.

A31G32x devices are 32-bit general purpose microcontrollers for various USB appliances. To meet the requirements for the complexity and high performance in consumer and portable electronics, A31G32x incorporate ARM's high-speed 32-bit Cortex-M0+ Cores, USB full speed interface, high speed ADC, various power mode for power consumption reduction, plentiful analog functions, and high resolution PWM for precision control and data processing.

Building on the very successful Cortex-M0+ processor, the ARM® Cortex®-M0+ retains full instruction set and tool compatibility, while further reducing energy consumption and increasing performance.



## **Reference document**

• Document 'DDI 0484C' is provided by ARM and contains information of Cortex-M0+.

## Contents

| Intro | ntroduction1 |                |                                                                        |     |  |
|-------|--------------|----------------|------------------------------------------------------------------------|-----|--|
| Refe  | rence o      | documei        | nt                                                                     | 1   |  |
| 1     | Descr        | iption         |                                                                        | .19 |  |
|       | 1.1          | Device         | overview                                                               | .19 |  |
|       | 1.2          |                | liagram                                                                |     |  |
| 2     | Pinout       | ts and p       | in descriptions                                                        | .23 |  |
|       | 2.1          |                | 5                                                                      |     |  |
|       |              | 2.1.1          | A31G323RLN, A31G324RLN (64 LQFP)                                       | .23 |  |
|       |              | 2.1.2          | A31G323CLN, A31G324CLN (48 LQFP)                                       |     |  |
|       |              | 2.1.3          | A31G323CUN, A31G324CUN (48 QFN)                                        |     |  |
|       | 2.2          |                | scription                                                              |     |  |
| 3     | Syster       |                | nemory overview                                                        |     |  |
|       | 3.1          | System         | n architecture                                                         |     |  |
|       |              | 3.1.1          | Cortex-M0+ Core                                                        |     |  |
|       |              | 3.1.2          | Interrupt controller                                                   |     |  |
|       | 3.2          |                | y organization                                                         |     |  |
|       |              | 3.2.1          | Register boundary address                                              |     |  |
|       |              | 3.2.2          | Memory map                                                             |     |  |
|       |              | 3.2.3          | Embedded SRAM                                                          |     |  |
|       |              | 3.2.4          | Flash memory overview                                                  |     |  |
|       |              | 3.2.5          | Boot mode                                                              |     |  |
| 4     | •            |                | bl unit                                                                |     |  |
|       | 4.1          |                | ock diagram                                                            |     |  |
|       | 4.2          |                | system                                                                 |     |  |
|       |              | 4.2.1          | HCLK clock domain                                                      |     |  |
|       |              | 4.2.2          | PCLK clock domain                                                      |     |  |
|       |              | 4.2.3          | Clock configuration procedure                                          |     |  |
|       | 4.3          |                | domain                                                                 |     |  |
|       | 4.4          |                |                                                                        |     |  |
|       |              | 4.4.1          | Cold reset                                                             |     |  |
|       |              | 4.4.2          | Warm reset                                                             |     |  |
|       |              | 4.4.3          | LVR reset                                                              |     |  |
|       |              | 4.4.4          | Reset tree                                                             |     |  |
|       | 4.5          | •              | ion mode                                                               |     |  |
|       |              | 4.5.1          | RUN mode                                                               |     |  |
|       |              | 4.5.2          | SLEEP mode                                                             |     |  |
|       |              | 4.5.3          | Power-down mode                                                        |     |  |
|       |              | 4.5.4          | STOP mode                                                              |     |  |
|       |              | 4.5.5          | STANDBY mode                                                           |     |  |
|       | 16           | 4.5.6          | BACKUP POWER mode                                                      |     |  |
|       | 4.6          | 4.6.1          | ers                                                                    |     |  |
|       |              | 4.6.1          | SCUCC_VENDORID: vendor ID register                                     |     |  |
|       |              | 4.6.2<br>4.6.3 | SCUCC_CHIPID: chip ID register                                         |     |  |
|       |              | 4.6.3<br>4.6.4 | SCUCC_REVNR: revision number register<br>SCU_SMR: system mode register |     |  |
|       |              | 4.6.4<br>4.6.5 | SCU_SMR. system mode register                                          |     |  |
|       |              | 4.6.5<br>4.6.6 | SCU_WUER: wakeup source enable register                                |     |  |
|       |              | 4.6.6<br>4.6.7 |                                                                        |     |  |
|       |              | 4.0.7          | SCU_WUSR: wakeup source status register                                | 09  |  |



|       | 4.6.8  | SCU_RSER: reset source enable register                     | 71  |
|-------|--------|------------------------------------------------------------|-----|
|       | 4.6.9  | SCU_RSSR: reset source status register                     |     |
|       |        | SCU_PRER1: peripheral reset enable register 1              |     |
|       |        | SCU_PRER2: peripheral reset enable register 2              |     |
|       |        | SCU_PER1: peripheral enable register1                      |     |
|       |        | SCU_PER2: peripheral enable register 2                     |     |
|       | 4.6.14 | SCU_PCER1: peripheral clock enable register 1              | 77  |
|       |        | SCU_PCER2: peripheral clock register 2                     |     |
|       | 4.6.16 | SCU_PPCLKSR: peripheral clock selection register           | 79  |
|       |        | SCU_CSCR: clock source control register                    |     |
|       | 4.6.18 | SCU_SCCR: system clock control register                    | 81  |
|       | 4.6.19 | SCU_CMR: clock monitoring register                         | 81  |
|       | 4.6.20 | SCU_NMIR: NMI control register                             | 83  |
|       | 4.6.21 | SCU_COR: clock output register                             | 84  |
|       | 4.6.22 | SCU_PLLCON: PLL control register                           | 85  |
|       | 4.6.23 | SCU_VDCCON: VDC control register                           | 87  |
|       | 4.6.24 | SCU_PDRCON: PDR control register                           | 88  |
|       | 4.6.25 | SCU_LSICON: Low speed internal OSC control register        | 89  |
|       | 4.6.26 | SCU_EOSCR: External oscillator control register            | 89  |
|       | 4.6.27 | SCU_EMODR: External mode status register                   | 90  |
|       | 4.6.28 | SCU_RSTDBCR: pin reset debounce control register           | 91  |
|       | 4.6.29 | SCU_MCCR1: Miscellaneous clock control register 1          | 92  |
|       | 4.6.30 | SCU_MCCR2: Miscellaneous clock control register 2          | 93  |
|       |        | SCU_MCCR3: Miscellaneous clock control register 3          |     |
|       |        | SCU_MCCR4: Miscellaneous clock control register 4          |     |
|       |        | SCU_MCCR5: Miscellaneous clock control register 5          |     |
|       |        | SCU_MCCR6: Miscellaneous clock control register 6          |     |
|       |        | SCULV_LVICR: Low voltage indicator control register        |     |
|       |        | SCULV_LVRCR: Low voltage reset control register            |     |
|       |        | SCULV_LVRCNFIG: Configuration for low voltage reset        |     |
| PCU a |        | 0                                                          |     |
| 5.1   |        | nd GPIO Block diagram                                      |     |
| 5.2   |        | Itiplexing                                                 |     |
| 5.3   |        | ۲۰۰۶                                                       |     |
|       | 5.3.1  | Pn_MOD: PORT n mode register                               |     |
|       | 5.3.2  | Pn_TYP: Port n output type selection register              |     |
|       | 5.3.3  | Pn_AFSR1: Port n alternative function selection register 1 |     |
|       | 5.3.4  | Pn_AFSR2: Port n alternative function selection register 2 |     |
|       | 5.3.5  | Pn_PUPD: Port n pull-up/down resistor selection register   |     |
|       | 5.3.6  | Pn_INDR: Port n input data register                        |     |
|       | 5.3.7  | Pn_OUTDR: Port n output data register                      |     |
|       | 5.3.8  | Pn_BSR: Port n output bit set register                     |     |
|       | 5.3.9  | Pn_BCR: Port n output bit clear register                   |     |
|       | 5.3.10 | Pn_OUTDMSK: Port n output data mask register               |     |
|       |        | Pn_DBCR: Port n debounce control register                  |     |
|       |        | Pn_IER: Port n interrupt enable register                   |     |
|       |        | Pn_ISR: Port n interrupt status register                   |     |
|       |        | Pn_ICR: Port n interrupt control register                  |     |
|       |        | PCU_USBCON: USB control register                           |     |
|       |        |                                                            |     |
|       | 5.5.10 | PCU_PORTEN: Port access enable                             | 115 |



5

|    | 5.4    | Functio  | nal description                                     | . 116 |
|----|--------|----------|-----------------------------------------------------|-------|
| 6  | Flash  | memory   | <i>i</i> controller                                 | . 118 |
|    | 6.1    | Registe  | ers                                                 | . 120 |
|    |        | 6.1.1    | FMC_MR: Flash memory mode register                  | . 121 |
|    |        | 6.1.2    | FMC_CR: Flash memory control register               | . 121 |
|    |        | 6.1.3    | FMC_AR: Flash memory address register               | . 122 |
|    |        | 6.1.4    | FMC_DR: Flash data input register                   | . 122 |
|    |        | 6.1.5    | FMC_BUSY: Flash write busy status register          | . 123 |
|    |        | 6.1.6    | FMC_CRC: Flash CRC check register                   | . 123 |
|    |        | 6.1.7    | FMC_CFG: Flash memory configuration register        | . 124 |
|    |        | 6.1.8    | FMC_WPROT: Write protection register                | . 124 |
|    |        | 6.1.9    | FMC_LOCK: Flash lock register                       | . 125 |
|    | 6.2    | Functio  | nal description                                     | . 126 |
|    |        | 6.2.1    | Flash erase and program examples                    | . 126 |
| 7  | Direct | Memory   | y Access Controller (DMAC)                          | . 129 |
|    | 7.1    | Block d  | liagram                                             | . 129 |
|    | 7.2    | Registe  | -<br>Prs                                            | . 130 |
|    |        | 7.2.1    | DCn.CR: DMA controller configuration register       | . 130 |
|    |        | 7.2.2    | DCn.SR: DMA controller status register              | . 132 |
|    |        | 7.2.3    | DCn.PAR: DMA controller peripheral address register | . 132 |
|    |        | 7.2.4    | DCn.MAR: DMA controller memory address register     | . 133 |
|    | 7.3    | Functio  | nal description                                     | . 134 |
|    |        | 7.3.1    | DMA operation                                       | . 135 |
| 8  | Static | memory   | / controller (EBI)                                  | . 138 |
|    | 8.1    | Block d  | liagram                                             | . 139 |
|    | 8.2    | Registe  | -<br>Prs                                            | . 139 |
|    |        | 8.2.1    | SMIBCRn: Memory area configuration register n       | . 140 |
|    | 8.3    | Functio  | nal description                                     | . 141 |
|    |        | 8.3.1    | Chip select signal                                  | . 141 |
|    |        | 8.3.2    | Byte lane control and control signal                | . 141 |
|    |        | 8.3.3    | Bus control signal in read operation                | . 144 |
|    |        | 8.3.4    | Bus control signal in write operation               | . 147 |
|    |        | 8.3.5    | Timing change of control signals                    | . 150 |
|    |        | 8.3.6    | Wait control while accessing memory                 | . 151 |
| 9  | Watch  | ndog tim | er (WDT)                                            | . 152 |
|    | 9.1    | WDT b    | lock diagram                                        | . 152 |
|    | 9.2    | Registe  | ers                                                 | . 153 |
|    |        | 9.2.1    | WDT_CR: Watchdog timer control register             | . 154 |
|    |        | 9.2.2    | WDT_SR: Watchdog timer status register              | . 155 |
|    |        | 9.2.3    | WDT_DR: Watchdog timer data register                | . 155 |
|    |        | 9.2.4    | WDT_CNT: Watchdog timer counter register            | . 156 |
|    |        | 9.2.5    | WDT_WINDR: Watchdog timer window data register      | . 156 |
|    |        | 9.2.6    | WDT_CNTR: Watchdog timer counter reload register    | . 157 |
|    | 9.3    | Functio  | nal description                                     | . 157 |
|    |        | 9.3.1    | Timing diagram                                      | . 158 |
|    |        | 9.3.2    | Prescale table                                      | . 158 |
| 10 | Watch  | n timer  |                                                     | . 159 |
|    | 10.1   | WT blo   | ck diagram                                          | . 159 |
|    | 10.2   | Registe  | ers                                                 | . 160 |
|    |        | 10.2.1   | WT_CR: Watch timer control register                 | . 161 |
|    |        |          |                                                     |       |



|    |        | 10.2.2   | WT_DR: Watch timer data register                                      | 162 |
|----|--------|----------|-----------------------------------------------------------------------|-----|
|    |        | 10.2.3   | WT_CNT: Watch timer counter register                                  | 162 |
| 11 | 16-bit | timer    |                                                                       | 163 |
|    | 11.1   | 16-bit t | imer block diagram                                                    | 164 |
|    | 11.2   | Registe  | ers                                                                   | 164 |
|    |        | 11.2.1   | TIMER1n_CR: Timer/counter 1n control register                         | 165 |
|    |        | 11.2.2   | TIMER1n_ADR: Timer/counter 1n A data register                         | 167 |
|    |        | 11.2.3   | TIMER1n_BDR: Timer/counter n B data register                          | 167 |
|    |        | 11.2.4   | TIMER1n_CAPDR: Timer/counter 1n capture data register                 | 168 |
|    |        | 11.2.5   | TIMER1n_PREDR: Timer/counter 1n prescaler data register               | 168 |
|    |        | 11.2.6   | TIMER1n_CNT: Timer/counter n counter register                         | 168 |
|    | 11.3   |          | onal description                                                      |     |
|    |        | 11.3.1   | Timer counter 10/11/12/13                                             | 169 |
|    |        | 11.3.2   | 16-bit timer/counter mode                                             | 170 |
|    |        | 11.3.3   | 16-bit capture mode                                                   | 172 |
|    |        |          | 16-bit PPG mode                                                       |     |
| 12 | 32-bit |          |                                                                       |     |
|    | 12.1   |          | imer block diagram                                                    |     |
|    | 12.2   |          | ərs                                                                   |     |
|    |        | 0        | TIMER2n_CR: Timer/counter 2n control register                         |     |
|    |        |          | TIMER2n_ADR: Timer/counter 2n A data register                         |     |
|    |        |          | TIMER2n_BDR: Timer/counter 2n B data register                         |     |
|    |        |          | TIMER2n_CAPDR: Timer/counter 2n capture data register                 |     |
|    |        |          | TIMER2n_PREDR: Timer/counter 2n prescaler data register               |     |
|    |        |          | TIMER2n_CNT: Timer/counter 2n counter register                        |     |
|    | 12.3   |          | onal description                                                      |     |
|    | 12.0   |          | Timer counter 2n                                                      |     |
|    |        |          | 32-bit timer/counter mode                                             |     |
|    |        |          | 32-bit capture mode                                                   |     |
|    |        |          | 32-bit PPG mode                                                       |     |
| 13 | Timor  |          | 32-bit FFG mode                                                       |     |
| 15 | 13.1   |          | counter 30 block diagram                                              |     |
|    | 13.1   |          | ers                                                                   |     |
|    | 13.2   |          | TIMER30_CR: Timer/counter 30 control register                         |     |
|    |        |          |                                                                       |     |
|    |        |          | TIMER30_PDR: Timer/counter 30 period data register                    |     |
|    |        |          | TIMER30_ADR: Timer/counter 30 A data register                         |     |
|    |        |          | TIMER30_BDR: Timer/counter 30 B data register                         |     |
|    |        |          | TIMER30_CDR: Timer/counter 30 C data register                         |     |
|    |        |          | TIMER30_CAPDR: Timer/counter 30 capture data register                 |     |
|    |        |          | TIMER30_PREDR: Timer/counter 30 prescaler data register               |     |
|    |        |          | TIMER30_CNT: Timer/counter 30 counter register                        |     |
|    |        |          | TIMER30_OUTCR: Timer/counter 30 output control register               |     |
|    |        |          | OTIMER30_DLY: Timer/counter 30 PWM output delay data register         |     |
|    |        |          | I TIMER30_INTCR: Timer/counter 30 interrupt control register          |     |
|    |        |          | 2 TIMER30_INTFLAG: Timer/counter 30 interrupt flag register           |     |
|    |        |          | 3TIMER30_HIZCR: Timer/counter 30 high-impedance control register      |     |
|    |        |          | Image: Timer Timer Counter 30 A/DC trigger control register           |     |
|    |        |          | 5TIMER30_ADTDR: Timer/counter 30 A/DC trigger generator data register |     |
|    | 13.3   |          | onal description                                                      |     |
|    |        | 13.3.1   | Timer counter 30                                                      | 208 |



|    |        |          | Timer 30 capture mode                                      |     |
|----|--------|----------|------------------------------------------------------------|-----|
|    |        | 13.3.3   | Timer 30 interval mode                                     | 211 |
| 14 | Timer  | counter  | 40                                                         | 223 |
|    | 14.1   | Timer c  | counter 40 block diagram                                   | 224 |
|    | 14.2   | Registe  | ers                                                        | 225 |
|    |        | 14.2.1   | TIMER40_CR: Timer/counter 40 control register              | 226 |
|    |        | 14.2.2   | TIMER40_ADR: Timer/counter 40 A data register              | 227 |
|    |        | 14.2.3   | TIMER40 BDR: Timer/counter 40 B data register              | 228 |
|    |        | 14.2.4   | TIMER40 CAPDR: Timer/counter 40 capture data register      | 228 |
|    |        | 14.2.5   | TIMER40 PREDR: Timer/counter 40 prescaler data register    | 228 |
|    |        | 14.2.6   | TIMER40_PREDR2: Timer/counter 40 prescaler data register 2 | 229 |
|    |        | 14.2.7   | TIMER40_CNT: Timer/counter 40 counter register             | 229 |
|    | 14.3   | Functio  | nal description                                            | 230 |
|    |        | 14.3.1   | Timer counter 40                                           | 230 |
|    |        | 14.3.2   | 16-bit timer/counter mode                                  | 230 |
|    |        | 14.3.3   | 16-bit capture mode                                        | 233 |
|    |        | 14.3.4   | 16-bit PPG mode                                            | 236 |
| 15 | Unive  | rsal syn | chronous/asynchronous receiver/transmitter                 | 239 |
|    | 15.1   | USART    | ۲<br>block diagram                                         | 240 |
|    | 15.2   |          | ers                                                        |     |
|    |        | 15.2.1   | USARTn_CR1: USARTn control register 1                      | 242 |
|    |        |          | USARTn_CR2: USARTn control register 2                      |     |
|    |        | 15.2.3   | USARTn_ST: USARTn status register                          | 245 |
|    |        | 15.2.4   | USARTn_BDR: USARTn baud rate generation register           | 246 |
|    |        | 15.2.5   | USARTn_DR: USARTn data register                            | 247 |
|    |        | 15.2.6   | USARTn_FPCR: USARTn floating point count register          | 247 |
|    |        | 15.2.7   | USARTn_RTO: USARTn RTO register                            | 248 |
|    | 15.3   | Functio  | nal description                                            | 248 |
|    |        | 15.3.1   | USART clock generation                                     | 249 |
|    |        | 15.3.2   | External clock (SCKn)                                      | 250 |
|    |        | 15.3.3   | Synchronous mode operation                                 | 250 |
|    |        | 15.3.4   | UART data format                                           | 251 |
|    |        | 15.3.5   | UART parity bit                                            | 252 |
|    |        | 15.3.6   | UART transmitter                                           | 252 |
|    |        | 15.3.7   | UART receiver                                              | 254 |
|    |        | 15.3.8   | SPI mode                                                   | 257 |
|    |        | 15.3.9   | SPI clock formats and timing                               | 257 |
|    |        | 15.3.10  | )Baud rate settings (example)                              | 260 |
|    |        | 15.3.11  | 0% error baud rate                                         | 261 |
|    |        | 15.3.12  | Receive time out (RTO)                                     | 261 |
| 16 | I2C in | terface. |                                                            | 262 |
|    | 16.1   | I2C blo  | ck diagram                                                 | 263 |
|    | 16.2   | Registe  | ers                                                        | 263 |
|    |        | 16.2.1   | I2Cn_CR: I2Cn control register                             | 264 |
|    |        | 16.2.2   | I2Cn_ST: I2Cn status register                              | 265 |
|    |        |          | I2Cn_SAR1: I2Cn slave address register 1                   |     |
|    |        |          | I2Cn_SAR2: I2Cn slave address register 2                   |     |
|    |        |          | I2Cn_DR: I2Cn data register                                |     |
|    |        |          | I2Cn_SDAHR: I2Cn SDA hold time register                    |     |
|    |        | 16.2.7   | I2Cn_SCLLR: I2Cn SCL low period register                   | 268 |
|    |        |          |                                                            |     |



|    |        | 16.2.8  | I2Cn_SCLHR: I2Cn SCL high period register                                           | . 269 |
|----|--------|---------|-------------------------------------------------------------------------------------|-------|
|    |        | 16.2.9  | I2Cn_MR: I2Cn mode control register                                                 | . 269 |
|    | 16.3   | Functio | nal description                                                                     | .270  |
|    |        | 16.3.1  | I2C bit transfer                                                                    | .270  |
|    |        | 16.3.2  | START/repeated START/STOP                                                           | .270  |
|    |        | 16.3.3  | Data transfer                                                                       | .271  |
|    |        | 16.3.4  | Acknowledge                                                                         | .271  |
|    |        | 16.3.5  | Synchronization/Arbitration                                                         | .272  |
|    |        | 16.3.6  | I2C operation                                                                       | .273  |
| 17 | Serial | periphe | ral interface (SPI)                                                                 | . 280 |
|    | 17.1   | SPI blo | ck diagram                                                                          | . 281 |
|    | 17.2   | -       | ers                                                                                 |       |
|    |        |         | SPIn.TDR: SPI transmit data register                                                |       |
|    |        |         | SPIn.RDR: SPI receive data register                                                 |       |
|    |        |         | SPIn.CR: SPI control register                                                       |       |
|    |        |         | SPIn.SR: SPI status register                                                        |       |
|    |        |         | SPIn.BR: SPI baud rate register                                                     |       |
|    |        |         | SPIn.EN: SPI enable register                                                        |       |
|    |        |         | SPIn.LR: SPI delay length register                                                  |       |
|    | 17.3   |         | nal description                                                                     |       |
|    |        |         | SPI timing                                                                          |       |
|    |        |         | DMA handshake                                                                       |       |
| 18 |        |         |                                                                                     |       |
|    | 18.1   |         | ADC block diagram                                                                   |       |
|    | 18.2   | •       |                                                                                     |       |
|    |        |         | ADC_MR: ADC mode register                                                           |       |
|    |        |         | ADC_CSCR: ADC current sequence/channel register                                     |       |
|    |        |         | ADC_CCR: ADC clock control register                                                 |       |
|    |        |         | ADC_TRG: ADC trigger selection register                                             |       |
|    |        |         | ADC_SCSR1: ADC channel selection 1 register                                         |       |
|    |        |         | ADC_SCSR2: ADC channel selection 2 register                                         |       |
|    |        |         | ADC_CR: ADC control register                                                        |       |
|    |        |         | ADC_SR: ADC state register<br>ADC_IER: ADC interrupt enable register                |       |
|    |        |         |                                                                                     |       |
|    |        |         | ADC_DDR: ADC DMA data register                                                      |       |
|    |        |         | ADC_DR: ADC sequence 0 to 7 data register<br>ADC_CMPR: ADC channel compare register |       |
|    | 18.3   |         | nal description                                                                     |       |
|    | 10.5   |         | ADC single mode timing diagram                                                      |       |
|    |        |         | ADC single mode timing diagram                                                      |       |
|    |        |         | ADC sequential mode timing diagram                                                  |       |
|    |        |         | ADC multiple mode timing diagram                                                    |       |
| 19 | 10-hit |         |                                                                                     |       |
| 10 | 19.1   |         | DAC block diagram and analog power pin                                              |       |
|    | 19.2   |         | ers                                                                                 |       |
|    | 10.2   | -       | DAC_DR: DAC data register                                                           |       |
|    |        |         | DAC_BR: DAC buffer register                                                         |       |
|    |        |         | DAC_CR: DAC control register                                                        |       |
|    |        |         | DAC_PGSR: Programmable gain control register                                        |       |
|    |        |         | DAC_OFSCR: DAC offset control register                                              |       |
|    |        |         |                                                                                     |       |



|    | 19.3   | Functional description                                             | 313 |
|----|--------|--------------------------------------------------------------------|-----|
|    |        | 19.3.1 DAC data buffer register                                    |     |
|    |        | 19.3.2 Automatic DAC data increment/decrement                      | 313 |
|    |        | 19.3.3 Programmable gain controller                                | 314 |
| 20 | Comp   | parator                                                            |     |
|    | 20.1   | Comparator block diagram                                           |     |
|    | 20.2   | Registers                                                          |     |
|    |        | 20.2.1 COMP0CR: Comparator 0 control register                      |     |
|    |        | 20.2.2 COMP1CR: Comparator 1 control register                      |     |
|    |        | 20.2.3 COMPDBNC: Comparator debounce register                      |     |
|    |        | 20.2.4 COMPICON: Comparator Interrupt control register             |     |
|    |        | 20.2.5 COMPIEN: Comparator interrupt enable register               |     |
|    |        | 20.2.6 COMPIST: Comparator interrupt status register               |     |
|    |        | 20.2.7 COMPICLR: Comparator interrupt clear register               |     |
| 21 | Cyclic | c redundancy check and checksum (CRC checksum)                     |     |
|    | 21.1   | CRC and checksum block diagram                                     |     |
|    | 21.2   | Registers                                                          |     |
|    |        | 21.2.1 CRC_CR: CRC control register                                |     |
|    |        | 21.2.2 CRC_IN: CRC input data register                             |     |
|    |        | 21.2.3 CRC_RLT: CRC result data register                           |     |
|    |        | 21.2.4 CRC_INIT: CRC initial data register                         |     |
|    | 21.3   | Functional description                                             |     |
|    |        | 21.3.1 CRC polynomial structure                                    |     |
|    |        | 21.3.2 CRC operation procedure in DMA mode                         |     |
|    |        | 21.3.3 CRC operation procedure in user CRC and checksum mode       |     |
| 22 |        | full speed device interface                                        |     |
|    | 22.1   | USB block diagram                                                  |     |
|    | 22.2   | Registers                                                          |     |
|    |        | 22.2.1 GOTGCTL: Control and status register                        |     |
|    |        | 22.2.2 GOTGINT: Interrupt register                                 |     |
|    |        | 22.2.3 GAHBCFG: AHB configuration register                         |     |
|    |        | 22.2.4 GUSBCFG: USB configuration register                         |     |
|    |        | 22.2.5 GRSTCTL: Reset register                                     |     |
|    |        | 22.2.6 GINTSTS: Interrupt register                                 |     |
|    |        | 22.2.7 GINTMSK: Interrupt mask register                            |     |
|    |        | 22.2.8 GRXSTSR: Receive status debug read register                 |     |
|    |        | 22.2.9 GRXSTSP: Receive status read/pop register                   |     |
|    |        | 22.2.10 GRXFSIZ: Receive FIFO size register                        |     |
|    |        | 22.2.11 GNPTXFSIZ: Non-periodic transmit FIFO size register        |     |
|    |        | 22.2.12 GHWCFG1: User HW config1 register                          |     |
|    |        | 22.2.13 GHWCFG2: User HW config2 register                          |     |
|    |        | 22.2.14 GHWCFG3: User HW config2 register                          |     |
|    |        | 22.2.15 GHWCFG4: User hardware config4 register                    |     |
|    |        | 22.2.16 GLPMCFG: LPM config register                               |     |
|    |        | 22.2.17 GPWRDN: Global power down register                         |     |
|    |        | 22.2.18 GDFIFOCFG: Global DFIFO configuration register             |     |
|    |        | 22.2.19 DIEPTXFi: Device IN endpoint transmit FIFO size register i |     |
|    |        | 22.2.20 DCFG: Device configuration register                        |     |
|    |        | 22.2.21 DCTL: Device control register                              |     |
|    |        | 22.2.22 DSTS: Device status register                               |     |



|        | 22.2.23 DIEPMSK: Device IN endpoint common interrupt mask register        | 369 |
|--------|---------------------------------------------------------------------------|-----|
|        | 22.2.24 DOEPMSK: Device OUT endpoint common interrupt mask register       | 370 |
|        | 22.2.25 DAINT: Device all endpoints interrupt register                    | 372 |
|        | 22.2.26 DAINTMSK: Device all endpoints interrupt mask register            | 373 |
|        | 22.2.27 DTHRCTL: Device threshold control register                        | 374 |
|        | 22.2.28 DIEPEMPMSK: Device IN endpoint FIFO empty interrupt mask register | 376 |
|        | 22.2.29 DIEPCTL0: Device control IN endpoint 0 control register           | 376 |
|        | 22.2.30 DIEPINT0: Device IN endpoint 0 interrupt register                 | 378 |
|        | 22.2.31 DIEPDMA0: Device IN endpoint 0 DMA address register               | 380 |
|        | 22.2.32 DTXFSTS0: Device IN endpoint transmit FIFO status register 0      | 381 |
|        | 22.2.33 DIEPDMAB0: Device IN endpoint 16 buffer address register          | 381 |
|        | 22.2.34 DIEPCTLi : Device control IN endpoint i control register          | 382 |
|        | 22.2.35 DIEPINTi: Device IN endpoint I interrupt register                 | 385 |
|        | 22.2.36 DIEPDMAi: Device IN endpoint I DMA address register               | 387 |
|        | 22.2.37 DTXFSTSi: Device IN endpoint transmit FIFO status register i      | 388 |
|        | 22.2.38 DIEPDMABi: Device IN endpoint I buffer address register           | 388 |
|        | 22.2.39 DOEPCTL0: Device control OUT endpoint 0 control register          | 389 |
|        | 22.2.40 DOEPINT0: Device OUT endpoint 0 interrupt register                | 391 |
|        | 22.2.41 DOEPDMA0: Device OUT endpoint 0 DMA address register              |     |
|        | 22.2.42 DOEPDMAB0: Device OUT Endpoint 16 Buffer Address Register         |     |
|        | 22.2.43 DOEPCTLi: Device control OUT endpoint I control register          |     |
|        | 22.2.44 DOEPINTi: Device OUT endpoint I interrupt register                |     |
|        | 22.2.45 DOEPDMAi: Device OUT Endpoint I DMA Address Register              |     |
|        | 22.2.46 DOEPDMABi: Device OUT Endpoint I Buffer Address Register          |     |
|        | 22.2.47 PCGCCTL: Power and Clock Gating Control Register                  |     |
| 22.3   | Functional description                                                    | 403 |
|        | 22.3.1 USB device                                                         | 403 |
|        | 22.3.2 USB descriptors                                                    | 405 |
|        | 22.3.3 USB operation                                                      |     |
|        | 22.3.4 USB transfer                                                       |     |
|        | 22.3.5 USB software example                                               | 409 |
| Real-t | ime clock (RTC)                                                           | 413 |
| 23.1   | RTC block diagram                                                         |     |
| 23.2   | Registers                                                                 | 415 |
|        | 23.2.1 RTCCR: RTC control register                                        |     |
|        | 23.2.2 ERRCOR: Error correction register                                  |     |
|        | 23.2.3 SEC: Second counter register                                       |     |
|        | 23.2.4 MIN: Minute counter register                                       |     |
|        | 23.2.5 HOUR: Hour counter register                                        |     |
|        | 23.2.6 DAY: Day counter register                                          |     |
|        | 23.2.7 WEEK: Week counter register                                        |     |
|        | 23.2.8 MONTH: Month counter register                                      |     |
|        | 23.2.9 YEAR: Year counter register                                        |     |
|        | 23.2.10 ALARMW: Alarm register                                            |     |
|        | 23.2.11 SUBDR: Sub-second counter compare register                        |     |
|        | 23.2.12 TIME_TS: TimeStamp time register                                  |     |
|        | 23.2.13 DATE_TS: TimeStamp date register                                  |     |
|        | 23.2.14 BKUPDR: Backup register 1 to 4                                    |     |
|        | 23.2.15 RTCPFCR: RTC pin function configuration register                  |     |
| 23.3   | Functional description                                                    |     |



23

|          |              | 23.3.1 Starting the RTC Operation                               |     |
|----------|--------------|-----------------------------------------------------------------|-----|
|          |              | 23.3.2 RTC RW mode (read and write mode)                        | 428 |
|          |              | 23.3.3 RTC alarm setting                                        | 431 |
|          |              | 23.3.4 RTC Constant-period matching                             | 432 |
|          |              | 23.3.5 RTC Timestamp                                            |     |
|          |              | 23.3.6 RTC 1Hz output                                           |     |
|          |              | 23.3.7 Error correction of RTC                                  |     |
|          |              | 23.3.8 BKUPDR and RTCPFCR registers                             |     |
| 24       | Temp         | sensor                                                          |     |
|          | 24.1         | Temp sensor block diagram                                       | 437 |
|          | 24.2         | Registers                                                       |     |
|          |              | 24.2.1 TSENSECON: Temp sensor control register                  |     |
|          |              | 24.2.2 TSREFPEROID: Temp sensor reference clock period register |     |
|          |              | 24.2.3 TSSENSECNT: Temp sensor sense clock count register       | 439 |
|          | 24.3         | Functional discription                                          |     |
|          |              | 24.3.1 How to calculate and convert to temperature              |     |
| 25       |              | ical characteristics                                            |     |
|          | 25.1         | Absolute maximum ratings                                        |     |
|          | 25.2         | Recommended operating conditions                                |     |
|          | 25.3         | ADC characteristics                                             |     |
|          | 25.4         | DAC characteristics                                             |     |
|          | 25.5         | Power on reset characteristics                                  |     |
|          | 25.6         | Low voltage reset/indicator characteristics                     |     |
|          | 25.7         | High frequency internal RC oscillator characteristics           |     |
|          | 25.8         | Low frequency internal RC oscillator characteristics            |     |
|          | 25.9         | DC electrical characteristics                                   |     |
|          |              | Supply current characteristics                                  |     |
|          |              | AC characteristics                                              |     |
|          |              | USART SPI characteristics                                       |     |
|          |              | I2C characteristics                                             |     |
|          |              | USART UART timing characteristics                               |     |
|          |              | Data retention voltage in STOP mode                             |     |
|          |              | Internal Flash ROM characteristics                              |     |
|          |              | Main oscillator characteristics                                 |     |
|          |              | Sub oscillator characteristics                                  |     |
|          |              | Operating voltage range                                         |     |
|          |              | PLL electrical characteristics                                  |     |
|          |              | Comparator characteristics                                      |     |
|          |              | USB characteristics                                             |     |
| 26       |              | Temperature Sensor characteristics<br>opment tools              |     |
| 20       | 26.1         | •                                                               |     |
|          | 26.1         | Compiler                                                        |     |
|          | 26.2         | Debugger                                                        |     |
| 27       |              | Programmer                                                      |     |
| 27<br>28 |              | t Design Guide<br>age information                               |     |
| 20       | 28.1         | 64 LQFP package information                                     |     |
|          | 20.1<br>28.2 | 48 LQFP package information                                     |     |
|          | 20.2<br>28.3 | 48 QFN package information                                      |     |
| 29       |              | ing information                                                 |     |
| 23       | Ordel        |                                                                 | +/0 |



| evision history471 |
|--------------------|
|--------------------|



## List of figures

| Figure 1. A31G32x Block diagram                                      | 22  |
|----------------------------------------------------------------------|-----|
| Figure 2. LQFP 64 Pinouts                                            | 23  |
| Figure 3. LQFP 48 Pinouts                                            | 24  |
| Figure 4. QFN 48 Pinouts                                             | 25  |
| Figure 5. Interrupt Block Diagram                                    | 37  |
| Figure 6. Memory Map                                                 | 39  |
| Figure 7. Connection Diagram of UART10 Boot                          | 41  |
| Figure 8. Connection Diagram of UART11 Boot                          | 41  |
| Figure 9. Connection Diagram of I2C Boot                             | 42  |
| Figure 10. Connection Diagram of E-PGM+ and SWD Port                 | 42  |
| Figure 11. SCU Block diagram                                         | 43  |
| Figure 12. Clock Tree Configuration                                  | 44  |
| Figure 13. Clock Change Procedure                                    | 46  |
| Figure 14. Peripheral Clock Select (n: 1, 2, 3, 4, 5, and 6)         | 47  |
| Figure 15. Power Domain Diagram                                      | 49  |
| Figure 16. Power up Procedure                                        | 50  |
| Figure 17. Warm Reset Diagram                                        | 51  |
| Figure 18. LVR Reset Timing Diagram                                  | 51  |
| Figure 19. Reset Tree Configuration                                  | 52  |
| Figure 20. Transition between Operation Modes                        | 53  |
| Figure 21. SLEEP Mode Operation Sequence                             | 54  |
| Figure 22. Power down Mode Block Diagram                             | 55  |
| Figure 23. STOP Mode Sequence                                        | 58  |
| Figure 24. STOP Mode Timing Diagram                                  | 58  |
| Figure 25. STANDBY Mode Sequence                                     | 59  |
| Figure 26. STANDBY Mode Timing Diagram                               | 60  |
| Figure 27. BACKUP POWER Mode Sequence                                | 61  |
| Figure 28. BACKUP POWER Mode Timing Diagram                          | 62  |
| Figure 29. LVI Block Diagram                                         | 99  |
| Figure 30. LVR Block Diagram                                         | 99  |
| Figure 31. PCU Block Diagram                                         | 101 |
| Figure 32. GPIO Block Diagram(Except PC13, PC14, PC15)               | 102 |
| Figure 33. PC13, PC14, PC15 Block Diagram                            | 102 |
| Figure 34. I/O Port Block Diagram (External Interrupt I/O Pins)      | 102 |
| Figure 35. Port Diagram                                              | 116 |
| Figure 36. Debounce Function Timing Diagram                          | 117 |
| Figure 37. GPIO Diagram                                              | 117 |
| Figure 38. Flash Memory Map (128 KB Code Flash)                      | 119 |
| Figure 39. DMAC Block Diagram                                        | 129 |
| Figure 40. DMAC Functional Block Diagram                             | 135 |
| Figure 41. DMAC Operation Sequence                                   | 136 |
| Figure 42. Timing Diagram of DMAC Transfer from Peripheral to Memory | 137 |
| Figure 43. Timing Diagram of DMAC Transfer from Memory to Peripheral | 137 |
| Figure 44. Timing Diagram Example of N DMAC Transfer                 |     |
| Figure 45. Static Memory Controller Block Diagram                    |     |
| Figure 46. Bus Configuration with 8-bit Memory                       | 142 |
| Figure 47. Bus Configuration with 16-bit Memory                      | 143 |
|                                                                      |     |



| Figure 48. | Word Read Operation with 8-bit Memory and 8-bit Bus                     | . 144 |
|------------|-------------------------------------------------------------------------|-------|
| Figure 49. | Half Word Read Operation with 8-bit Memory and 8-bit Bus                | . 144 |
| Figure 50. | Word Read Operation with 8-bit Memory and 16-bit Bus                    | . 145 |
| Figure 51. | Half Word Read Operation with 8-bit Memory and 16-bit Bus               | . 145 |
| Figure 52. | Word Read Operation with 16-bit Memory and 16-bit Bus                   | . 146 |
| Figure 53. | Half Word Read Operation with 16-bit Memory and 16-bit Bus              | . 146 |
|            | Word Write Operation with 8-bit Memory and 8-bit Bus                    |       |
| Figure 55. | Half Word Write Operation with 8-bit Memory and 8-bit Bus               | . 147 |
| Figure 56. | Word Write Operation with 8-bit Memory and 16-bit Bus                   | . 148 |
| Figure 57. | Half Word Write Operation with 8-bit Memory and 16-bit Bus              | . 148 |
| Figure 58. | Word Write Operation with 16-bit Memory and 16-bit Bus                  | . 149 |
|            | Half Word Write Operation with 16-bit Memory and 16-bit Bus             |       |
|            | Read Timing Changing by IDLE = 1'                                       |       |
|            | Write Timing Changing by 'PREIDL = 1'                                   |       |
|            | Write Operation with External Wait (nWAIT), 'EXP = 0'                   |       |
|            | WDT Block Diagram                                                       |       |
| -          | WDT Interrupt and WDT Reset Timing Diagram                              |       |
| •          | Watch Timer Block Diagram                                               |       |
|            | 16-bit Timer Block Diagram                                              |       |
|            | TIMER 1n Block Diagram in Timer/Counter Mode (n = 0, 1, 2, and 3)       |       |
|            | Timer/Counter Mode Timing Example of TIMER 1n (n = 0, 1, 2, and 3)      |       |
| -          | Timer/Counter Mode Operation Sequence of TIMER 1n (n = 0, 1, 2, and 3)  |       |
| •          | TIMER 1n Block Diagram in Capture Mode ( $n = 0, 1, 2, and 3$ )         |       |
| -          | Capture Mode Timing Example of TIMER 1n ( $n = 0, 1, 2, and 3$ )        |       |
| -          | Express Timer Overflow in Capture Mode of TIMER 1n (n = 0, 1, 2, and 3) |       |
| -          | Capture Mode Operation Sequence of TIMER 1n ( $n = 0, 1, 2, and 3$ )    |       |
| -          | TIMER 1n Block Diagram in PPG Mode ( $n = 0, 1, 2, and 3$ )             |       |
| -          | PPG Mode Timing Example of TIMER 1n (n = 0, 1, 2, and 3)                |       |
| -          | PPG Mode Operation Sequence of TIMER 1n (n = 0, 1, 2, and 3)            |       |
| -          | 16-bit Timer Block Diagram                                              |       |
| -          | TIMER 2n Block Diagram in Timer/Counter Mode                            |       |
|            | Timer/Counter Mode Timing Example of TIMER 2n                           |       |
| -          | Timer/Counter Mode Operation Sequence of TIMER 2n (n = 0 or 1)          |       |
| 0          | TIMER 2n Block Diagram in Capture Mode                                  |       |
| -          | Capture Mode Timing Example of TIMER 2n (n = 0 and 1)                   |       |
| -          | Express Timer Overflow in Capture Mode of TIMER 2n (T2nCNCLR = 1'b1)    |       |
|            | Express Timer Overflow in Capture Mode of TIMER 2n (T2nCNCER = 1'b0)    |       |
| -          |                                                                         |       |
| -          | Capture Mode Operation Sequence of TIMER 2n (n = 0 or 1)                |       |
| -          | TIMER 2n Block Diagram in PPG Mode                                      |       |
| -          | PPG Mode Timing Example of TIMER 2n (n = 0 or 1)                        |       |
| -          | PPG Mode Operation Sequence of TIMER 2n (n = 0 or 1)                    |       |
| •          | Timer Counter 30 Block Diagram                                          |       |
| -          | 16-bit Capture Mode of Timer 30                                         |       |
|            | Capture Mode Operation Sequence of TIMER 30                             |       |
| •          | Example of PWM at 4MHZ                                                  |       |
| -          | Example of Changing the Period in Absolute Duty Cycle at 4MHz           |       |
| -          | Interval Mode Timing Chart With "DLYPOS = 0"                            |       |
| -          | Interval Mode Timing Chart With "DLYPOS = 1                             |       |
| -          | Back-to-Back Mode Timing Chart                                          |       |
| Figure 97. | Example of PWM External Synchronization with BLNK Input (x: A, B and C) | .218  |



| Figure 00 Everyna of Ferrer A. Chennel Mede                                                | 040   |
|--------------------------------------------------------------------------------------------|-------|
| Figure 98. Example of Force A-Channel Mode                                                 |       |
| Figure 99. Force A-Channel Mode Block Diagram<br>Figure 100. Example of 6-Channel Mode     |       |
| •                                                                                          |       |
| Figure 101. 6-Channel Mode Block Diagram                                                   |       |
| Figure 102. Timer Counter 40 Block Diagram                                                 |       |
| Figure 103. TIMER 40 Block Diagram in 16-bit Timer/Counter Mode                            |       |
| Figure 104. 16-bit Timer/Counter Mode Timing Example of TIMER 40                           |       |
| Figure 105. 16-bit Timer/Counter Mode Operation Sequence of TIMER 40                       |       |
| Figure 106. 16-bit Capture Mode of Timer 40                                                |       |
| Figure 107. Capture Mode Timing Example of TIMER 40                                        |       |
| Figure 108. Express Timer Overflow in Capture Mode of TIMER 40                             |       |
| Figure 109. Capture Mode Operation Sequence of TIMER 40                                    |       |
| Figure 110. TIMER 40 Block Diagram in PPG Mode                                             |       |
| Figure 111. PPG Mode Timing Example of TIMER 40                                            |       |
| Figure 112. PPG Mode Operation Sequence of TIMER 40                                        |       |
| Figure 113. UART Block Diagram (n = 10, 11, 12, and 13)                                    |       |
| Figure 114. SPIN Block Diagram (n = 10, 11, 12, and 13)                                    |       |
| Figure 115. Clock Generation Block Diagram (USARTn, n = 10, 11, 12, and 13)                |       |
| Figure 116. Synchronous Mode SCKn Timing (USARTn, n = 10, 11, 12, and 13)                  |       |
| Figure 117. Frame Format (USART)                                                           |       |
| Figure 118. Asynchronous Start Bit Sampling (n = 10, 11, 12 and 13)                        |       |
| Figure 119. Asynchronous Data and Parity Bit Sampling (n = 10, 11, 12 and 13)              | 256   |
| Figure 120. Stop Bit Sampling and Next Start Bit Sampling (n = 10, 11, 12 and 13)          | 257   |
| Figure 121. USART SPIn Clock Formats when CPHAn = 0 (n = 10, 11, 12 and 13)                |       |
| Figure 122. USART SPIn Clock Formats when CPHAn=1 (n = 10, 11, 12 and 13)                  |       |
| Figure 123. 0% Error Baud Rate Diagram                                                     |       |
| Figure 124. I2C Block Diagram                                                              | 263   |
| Figure 125. I2C Bus Bit Transfer (n = 0 and 1)                                             | 270   |
| Figure 126. START and STOP Condition (n = 0 and 1)                                         |       |
| Figure 127. I2C Bus Data Transfer (n = 0 and 1)                                            | 271   |
| Figure 128. I2C Bus Acknowledge (n = 0 and 1)                                              | 272   |
| Figure 129. Clock Synchronization during the Arbitration Procedure (n = 0 and 1)           | 272   |
| Figure 130. Arbitration Procedure between Two Masters (n = 0 and 1)                        | 273   |
| Figure 131. SPI Block Diagram                                                              | 281   |
| Figure 132. SPI wave form (STL, BTL and SPL)                                               | 287   |
| Figure 133. SPI Transfer Timing 1/4 (CPHA=0, CPOL=0, MSBF=0)                               | 288   |
| Figure 134. SPI Transfer Timing 2/4 (CPHA=0, CPOL=1, MSBF=1)                               | 288   |
| Figure 135. SPI Transfer Timing 3/4 (CPHA=1, CPOL=0, MSBF=0)                               | 289   |
| Figure 136. SPI Transfer Timing 4/4 (CPHA=1, CPOL=1, MSBF=1)                               | 289   |
| Figure 137. DMA Handshake Flow Chart                                                       | 290   |
| Figure 138. 12-bit ADC Block Diagram                                                       | 292   |
| Figure 139. ADC Single Mode Timing (When ADC.MR.AMOD = '0')                                | 304   |
| Figure 140. ADC Burst Mode Timing (When ADC.MR.AMOD = '1')                                 | 305   |
| Figure 141. ADC Trigger Timing in Burst Mode (SEQCNT = 3'b111, 8 Sequential Conversion)    |       |
| Figure 142. ADC Sequential Mode Timing (When MR.AMOD = '0' and MR.SEQCNT ≠ '0')            |       |
| Figure 143. ADC Trigger Timing in Sequential Mode (SEQCNT = 3'b111, 8 Sequential Conversio | n)306 |
| Figure 144. ADC Multiple Mode Timing (When MR.AMOD = '2' and MR.SEQCNT ≠ '0')              | -     |
| Figure 145. ADC Trigger Timing in Multiple Mode (SEQCNT = 3'b111, 8 Multiple Conversion)   |       |
| Figure 146. 10-bit DAC Block Diagram                                                       |       |
| Figure 147. Analog Power (AVREF) Pin with a Capacitor                                      |       |
|                                                                                            |       |



| Figure 148.  | DACBR[15:0] Value by a Selected Gain                    | 315 |
|--------------|---------------------------------------------------------|-----|
| Figure 149.  | Comparator Block Diagram                                | 316 |
| Figure 150.  | CRC and Checksum Block Diagram                          | 323 |
| Figure 151.  | CRC Polynomial Structure                                | 327 |
| Figure 152.  | USB Interface Block Diagram                             | 328 |
| Figure 153.  | USB Packet Field                                        | 404 |
| Figure 154.  | USB Descriptor Hierarchy                                | 405 |
| Figure 155.  | USB Communication using Software                        | 409 |
| Figure 156 A | Application Example: Open Windows OS                    | 410 |
| -            | Application Example: Check COM Port                     |     |
| Figure 158.  | Application Example: Printing Characters                | 410 |
|              | HID Block Diagram                                       |     |
| Figure 160.  | USB HID PIPE Example GUI                                | 411 |
| Figure 161.  | Crystal Design Guide                                    | 412 |
| -            | RTC Block Diagram                                       |     |
| -            | Start Operation Sequence of RTC                         |     |
| Figure 164.  | Read Operation Sequence of RTC                          | 429 |
| Figure 165.  | Sub-second Counter Match in RW Mode                     | 430 |
| Figure 166.  | Sub-second Counter Match in RW Mode when Writing to SEC | 430 |
| Figure 167.  | Alarm Operation Sequence of RTC                         | 431 |
| Figure 168.  | Configuring Sequence of BKUPDR Register                 | 435 |
| Figure 169.  | PC13 wakeup in Standby Mode                             | 436 |
| Figure 170.  | Temp Sensor Block Diagram                               | 437 |
| Figure 171.  | AC Timing                                               | 448 |
| Figure 172.  | SPI Timing                                              | 450 |
| Figure 173.  | I2C Timing                                              | 451 |
| Figure 174.  | Waveform of UART Timing Characteristics                 | 452 |
|              | UART Module Timing                                      |     |
| Figure 176.  | Crystal/Ceramic Oscillator                              | 455 |
| Figure 177.  | External Clock                                          | 455 |
|              | Clock Timing Measurement at XIN                         |     |
| Figure 179.  | Crystal Oscillator                                      | 456 |
|              | Clock Timing Measurement at SXIN                        |     |
| Figure 181.  | Operating Voltage Range                                 | 457 |
| Figure 182.  | A-Link and Pin Descriptions                             | 461 |
| Figure 183.  | E-PGM+ (Single Writer) and Pin Descriptions             | 462 |
| Figure 184.  | E-Gang4 and E-Gang6 (for Mass Production)               | 462 |
| Figure 185.  | PCB Design Guide for On-Board Programming               | 463 |
| -            | 64 LQFP Package Outline                                 |     |
| Figure 187.  | 48 LQFP Package Outline                                 | 466 |
| Figure 187.  | 48 QFN Package Outline                                  | 468 |
| Figure 188.  | A31G32x Device Numbering Nomenclature                   | 470 |
|              |                                                         |     |



## List of tables

| Table 1. A31G324 and A31G323 Device Features and Peripheral Counts | 19    |
|--------------------------------------------------------------------|-------|
| Table 2. Pin Description                                           |       |
| Table 3. Interrupt Vector Map                                      |       |
| Table 4. A31G32x Memory Boundary Addresses                         |       |
| Table 5. Boot Mode Pin List                                        | 40    |
| Table 6. SCU Pins                                                  | 43    |
| Table 7. Clock Sources                                             | 45    |
| Table 8. Flash Wait Control Recommendation                         | 47    |
| Table 9. Peripheral Clock Select                                   |       |
| Table 10. Reset Sources of Cold Reset and Warm Reset               | 49    |
| Table 11. Operation Mode                                           |       |
| Table 12. Oscillator Control in Power down Mode                    | 56    |
| Table 13. Peripheral Operation in Power down Mode                  | 56    |
| Table 14. STOP Mode Configuration                                  |       |
| Table 15. STANDBY Mode Configuration                               |       |
| Table 16. BACKUP POWER Mode Configuration                          | 61    |
| Table 17. Base Address of SCU (Chip Configuration)                 | 62    |
| Table 18. SCU Register Map (Chip Configuration)                    |       |
| Table 19. Base Address of SCU                                      |       |
| Table 20. SCU Register Map                                         | 63    |
| Table 21. Base Address of LVI/LVR                                  |       |
| Table 22. LVI/LVR Register Map                                     |       |
| Table 23. VDC33 Mode Description                                   |       |
| Table 24. PCU and GPIO pins                                        | . 101 |
| Table 25. GPIO Alternative Function                                | . 103 |
| Table 26. Base Address of PCU                                      |       |
| Table 27. PCU and GPIO Register Map                                |       |
| Table 28. Flash Memory Controller Features                         | . 118 |
| Table 29. Base Address of Flash Memory Controller                  |       |
| Table 30. FMC Register Map                                         |       |
| Table 31. Base Address of DMAC                                     | . 130 |
| Table 32. DMAC Register Map                                        |       |
| Table 33. DMAC PERISEL Selection                                   |       |
| Table 34. Pin Assignment of Static Memory Controller               | . 138 |
| Table 35. Base Address of Static Memory Controller                 | . 139 |
| Table 36. SMIF Register Map                                        | . 139 |
| Table 37. Memory Region Selection and nCS Output by Address        | . 141 |
| Table 38. Data Sort for 8-bit Memory Bus                           | . 141 |
| Table 39. Data Sort for 16-bit Memory Bus                          |       |
| Table 40. Config Signal by A[0]                                    |       |
| Table 41. Base Address of WDT                                      | . 153 |
| Table 42. WDT Register Map                                         | . 153 |
| Table 43. Pre-scaled WDT Counter Clock Frequency                   |       |
| Table 44. Base Address of WT                                       | . 160 |
| Table 45. WT Register Map                                          | . 160 |
| Table 46. Pin Assignment of 16-bit Timer: External Pins            | . 163 |
| Table 47. Base Address of 16-bit Timer                             | . 164 |
| Table 48. TIMER 1n Register Map                                    | . 165 |



| Table 49. | TIMER 1n Operating Modes                                    | . 169 |
|-----------|-------------------------------------------------------------|-------|
| Table 50. | Pin Assignment of 32-bit Timer: External Pins               | . 178 |
| Table 51. | Base Address of 32-bit Timer                                | . 180 |
| Table 52. | TIMER 2n Register Map                                       | . 180 |
| Table 53. | TIMER 2n Operating Modes                                    | . 185 |
| Table 54. | Pin Assignment of Timer Counter 30: External Pins           | . 194 |
| Table 55. | Base Address of Timer Counter 30                            | . 196 |
| Table 56. | Timer Counter 30 Register Map                               | . 196 |
|           | Timer 30 Operating Modes                                    |       |
|           | PWM Channel Polarity                                        |       |
| Table 59. | Pin Assignment of Timer Counter 40: External Pins           | .223  |
| Table 60. | Base Address of Timer Counter 40                            | .225  |
| Table 61. | Timer Counter 30 Register Map                               | .225  |
|           | Timer 40 Operating Modes                                    |       |
|           | Pin Assignment of USART: External Pins                      |       |
|           | Base Address of USART                                       |       |
| Table 65. | USART Register Map                                          | .242  |
|           | Equations for Calculating USART Baud Rate Register Settings |       |
|           | CPOL Functionality                                          |       |
|           | Baud Rate Settings Example                                  |       |
|           | Pin Assignment of I2C: External Pins                        |       |
|           | Base Address of I2C Interface.                              |       |
|           | I2C Register Map                                            |       |
|           | Pin Assignment of SPI: External Pins                        |       |
|           | Base Address of SPI                                         |       |
|           | SPI Register Map                                            |       |
|           | Pin Assignment of ADC: External Signal                      |       |
|           | Base Address of 12-bit ADC                                  |       |
|           | 12-bit ADC Register Map                                     |       |
|           | Trigger Source of ADC                                       |       |
|           | Base Address of DAC                                         |       |
|           | 10-bit DAC Register Map                                     |       |
|           | Base Address of Comparator                                  |       |
|           | Comparator Register Map                                     |       |
|           | Base Address of CRC                                         |       |
|           | CRC Register Map                                            |       |
|           | Base Address of USB Interface                               |       |
|           | USB Interface Register Map                                  |       |
|           | USB Packet PID                                              |       |
|           | Base Address of RTC Interface                               |       |
|           | RTC Register Map                                            |       |
|           | Specified time system by AMPM                               |       |
|           | SUBDR and RTC Clock Combination for 1Hz.                    |       |
|           | WEEK and ALARMWW Registers                                  |       |
|           | Example of Setting the Alarm                                |       |
|           | Correction Resolution by Frequency                          |       |
|           | PC13, PC14, PC15 Function in RTCPFCR register               |       |
|           | Base Address of TSENSE Interface                            |       |
|           | TSENSE Register Map                                         |       |
|           | Specific temperature value in the region of OTP             |       |
| 10010 30. |                                                             | . ++0 |



| Table 99. A | Absolute maximum rating                                       | 441 |
|-------------|---------------------------------------------------------------|-----|
| Table 100.  | Recommended Operating Condition                               | 442 |
| Table 101.  | ADC Electrical Characteristics                                | 442 |
| Table 102.  | DAC Electrical Characteristics                                | 443 |
|             | POR Electrical Characteristics                                |     |
| Table 104.  | Low Voltage Reset/Indicator Characteristics                   | 444 |
| Table 105.  | High Frequency Internal RC Oscillator Characteristics         | 445 |
| Table 106.  | Low Frequency (750KHz) Internal RC Oscillator Characteristics | 445 |
| Table 107.  | Low Frequency (40KHz) Internal RC Oscillator Characteristics  | 445 |
|             | DC Electrical Characteristics                                 |     |
| Table 109.  | Supply Current Characteristics                                | 447 |
| Table 110.  | AC Characteristics                                            | 448 |
| Table 111.  | SPI Characteristics with High Voltage                         | 449 |
| Table 112.  | SPI Characteristics with Low Voltage                          | 449 |
|             | I2C Characteristics                                           |     |
| Table 114.  | UART Timing Characteristics                                   | 452 |
| Table 115.  | Data Retention Voltage in STOP mode                           | 453 |
| Table 116.  | Internal Flash ROM Characteristics                            | 453 |
| Table 117.  | Main Oscillator Characteristics                               | 454 |
| Table 118.  | Sub Oscillator Characteristics                                | 456 |
| Table 119.  | PLL Electrical Characteristics                                | 457 |
| Table 120.  | Comparator Characteristics                                    | 458 |
| Table 121.  | Interanal Voltage Reference Characteristics(For comparator)   | 459 |
| Table 122.  | USB Characteristics                                           | 460 |
| Table 123.  | Temperature Sensor Characteristics                            | 460 |
| Table 124.  | 64 LQFP Package Mechanical Data                               | 465 |
| Table 125.  | 48 LQFP Package Mechanical Data                               | 467 |
| Table 125.  | 48 QFN Package Mechanical Data                                | 469 |
| Table 126.  | A31G32x Device Ordering Information                           | 470 |
|             |                                                               |     |



## 1 **Description**

A31G32x lines are 32-bit general purpose microcontrollers with up to 128 Kbytes of flash memory. They are powerful microcontrollers which provide effective solutions to various electrical appliances which require both low power consumption and high performance.

#### 1.1 Device overview

In this section, features of A31G32x and peripheral counts are introduced.

| Peripherals           |                     | Description                                                                             |  |  |
|-----------------------|---------------------|-----------------------------------------------------------------------------------------|--|--|
| Core                  | CPU                 | High Performance Low-Power Cortex-M0+ Core<br>32-bit ARM Cortex-M0+ CPU                 |  |  |
|                       | Interrupt           | NVIC (Nested-Vectored Interrupt Controller)                                             |  |  |
|                       |                     | Up to 32 peripheral interrupts supported.                                               |  |  |
| Memory                | Code flash          | A31G324: 128Kbytes code flash memory                                                    |  |  |
|                       |                     | A31G323: 64Kbytes code flash memory                                                     |  |  |
|                       |                     | Flash access wait                                                                       |  |  |
|                       |                     | 0 clock wait: up to 20MHz                                                               |  |  |
|                       |                     | 1 clock wait: up to 40MHz                                                               |  |  |
|                       |                     | 2 clock wait: up to 48MHz                                                               |  |  |
|                       | SRAM                | 16 Kbytes SRAM (0 wait)                                                                 |  |  |
|                       | Endurance           | 10,000 times at room temperature                                                        |  |  |
|                       |                     | Retention for 10 years                                                                  |  |  |
| System                | Operating frequency | Up to 48 MHz                                                                            |  |  |
| Control Unit<br>(SCU) | Clock               | High speed internal oscillator (HSI)                                                    |  |  |
|                       |                     | 48MHz (±3% @-40℃ to +85℃)                                                               |  |  |
|                       |                     | Low speed internal oscillator (LSI)                                                     |  |  |
|                       |                     | 750KHz (±20% @-40℃ to +85℃)                                                             |  |  |
|                       |                     | 40KHz (±50% @-40℃ to +85℃)                                                              |  |  |
|                       |                     | External main oscillator (HSE): 2MHz to 16MHz                                           |  |  |
|                       |                     | External sub-oscillator (LSE): 32.768KHz                                                |  |  |
|                       |                     | Phase-locked loop (PLL) frequency generator generates a high-speed clock (up to 144MHz) |  |  |
|                       | Clock monitoring    | System Fail-Safe function by Clock Monitoring                                           |  |  |
|                       |                     | External main oscillator(HSE)                                                           |  |  |
|                       |                     | External sub oscillator(LSE)                                                            |  |  |
|                       |                     | Main system clock (MCLK)                                                                |  |  |

 Table 1. A31G324 and A31G323 Device Features and Peripheral Counts



| Peripherals                              |                | Description                                                                                                                                                                 |  |  |
|------------------------------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Operating<br>mode<br>Reset               |                | RUN mode<br>SLEEP mode<br>STOP mode<br>STANDBY mode<br>Backup Power mode                                                                                                    |  |  |
|                                          |                | nRESET pin reset<br>Core reset<br>Software reset<br>POR (Power On Reset)<br>LVR (Low Voltage Reset)<br>WDTR (Watch Dog Timer Reset)<br>Reset due to clock oscillating error |  |  |
| General Purpo                            | ose I/O (GPIO) | 51 Ports (PA[15:0], PB[15:0], PC[15:0], PF[2:0]): 64-Pin<br>37 Ports (PA[15:0], PB[15:0], PC[15:13], PF[1:0]): 48-Pin                                                       |  |  |
| Direct Memory Access<br>Controller (DMA) |                | 4-ch direct memory access (DMA) support peripherals<br>SPI20, SPI21, USART10, USART11, USART12, USART13,<br>CRC, ADC                                                        |  |  |
| Watch Timer (                            | WT)            | 14-bit divider with extended 12-bit counter 1-ch                                                                                                                            |  |  |
| Watchdog Tim                             | ner (WDT)      | 24-bit down counter timer: 1-ch<br>Reset and periodic interrupts are supported                                                                                              |  |  |
| TIMER Timer1x<br>Timer2x                 |                | 16bit: 4-ch<br>Periodic timer mode, One-shot timer mode, PWM pulse mode,<br>Capture mode                                                                                    |  |  |
|                                          |                | 32bit : 2-ch<br>Periodic timer mode, One-shot timer mode, PWM pulse mode,<br>Capture mode                                                                                   |  |  |
|                                          | Timer40        | 16bit : 1-ch<br>Periodic timer mode, One-shot timer mode, PWM pulse mode, 3-<br>Phase Capture mode                                                                          |  |  |
| PWM Timer30                              |                | 16bit : 6-ch<br>Periodic timer mode, Back-to-Back mode, Capture mode                                                                                                        |  |  |

Table 1. A31G324 and A31G323 Device Features and Peripheral Counts (continued)



| Peripherals                  |          | Description                                              |  |  |
|------------------------------|----------|----------------------------------------------------------|--|--|
| Communication USART          |          | 4-ch                                                     |  |  |
| function                     | SPI      | 2-ch                                                     |  |  |
|                              | I2C      | 2-ch                                                     |  |  |
|                              | USB      | Full speed 2.0 device                                    |  |  |
|                              |          | 12-bit ADC : 1Msps                                       |  |  |
| ADC                          |          | 64-pin : 16-ch                                           |  |  |
|                              |          | 48-pin : 10-ch                                           |  |  |
| DAC                          |          | 10-bit DAC 1-ch                                          |  |  |
| DAC                          |          | PA4, PA5: output pin                                     |  |  |
| External Bus Interface (EBI) |          | 20-bit address size, 16-bit multiplexed address/data bus |  |  |
| CRC calculator (CRC)         |          | CRC-CCITT, CRC-16                                        |  |  |
|                              |          | 8-ch reference input                                     |  |  |
| Comparator                   |          | 2-ch output comparator                                   |  |  |
|                              |          | Window mode                                              |  |  |
| Operating Voltage            | <b>)</b> | 1.8V to 5.5V                                             |  |  |
| Operating temperature        |          | Commercial grade (-40℃ to +85℃)                          |  |  |
|                              |          | Three types of package options                           |  |  |
| Deskare                      |          | 48-pin QFN                                               |  |  |
| Package                      |          | 48-pin LQFP                                              |  |  |
|                              |          | 64-pin LQFP                                              |  |  |

Table 1. A31G324 and A31G323 Device Features and Peripheral Counts (continued)



#### 1.2 Block diagram

In this section, A31G32x devices with peripherals are described in block diagram.



Figure 1. A31G32x Block diagram



### 2. Pinouts and pin descriptions

In this chapter, A31G32x devices' pinouts and pin descriptions are introduced.

#### 2.1 Pinouts

#### 2.1.1 A31G323RLN, A31G324RLN (64 LQFP)



Figure 2. LQFP 64 Pinouts



#### 2.1.2 A31G323CLN, A31G324CLN (48 LQFP)



Figure 3. LQFP 48 Pinouts



#### 2.1.3 A31G323CUN, A31G324CUN (48 QFN)



Figure 4. QFN 48 Pinouts



#### 2.2 Pin description

Pin configuration information in Table 2 contains two pairs of power/ground and other dedicated pins. These multi-function pins have up to ten selections of functions including GPIO. Configuration including pin ordering can be changed without notice.

| Pin no. |        | Pin name   | Туре  | Description                              | Remark  |
|---------|--------|------------|-------|------------------------------------------|---------|
| 64-pin  | 48-pin |            |       |                                          |         |
| 1       | 1      | VBAT       | Р     | Backup Power Supply                      |         |
| 2       | 2      | PC13*      | IOUDS | PORT C Bit 13 Input/Output               |         |
|         |        | RTC_TAMP1  | 1     | RTC TimeStamp Input                      |         |
|         |        | RTC_OUT    | 0     | RTC Output                               |         |
| 3       | 3      | PC14*      | IOUDS | PORT C Bit 14 Input/Output               |         |
|         |        | SXIN       | 1     | Sub Oscillator Input                     |         |
| 4       | 4      | PC15*      | IOUDS | PORT C Bit 15 Input/Output               |         |
|         |        | SXOUT      | 0     | Sub Oscillator Output                    |         |
| 5       | 5      | PF0*       | IOUDS | PORT F Bit 0 Input/Output                |         |
|         |        | XIN        | 1     | Main Oscillator Input                    |         |
|         |        | CLKO       | 0     | Clock Output                             |         |
| 6       | 6      | PF1*       | IOUDS | PORT F Bit 1 Input/Output                |         |
|         |        | XOUT       | 0     | Main Oscillator Output                   |         |
| 7       | 7      | nReset     | IU    | Reset Pin                                | Pull-up |
| 8       | _      | PC0*       | IOUDS | PORT C Bit 0 Input/Output                |         |
|         |        | AN10       | IA    | ADC Input 10                             |         |
|         |        | LWR        | 0     | EBI Lower byte write signal              |         |
|         |        | CP0_P1     | IA    | Comparator 0 Positive 1 Input            |         |
| 9       | _      | PC1*       | IOUDS | PORT C Bit 1 Input/Output                |         |
|         |        | AN11       | IA    | ADC Input 11                             |         |
|         |        | AD00       | I/O   | EBI Address/Data bus bit 0               |         |
|         |        | CP1_P1     | IA    | Comparator 1 Positive 1 Input            |         |
| 10      | _      | PC2*       | IOUDS | PORT C Bit 2 Input/Output                |         |
|         |        | SPI21_MISO | I/O   | SPI Channel 21 Master Input/Slave Output |         |
|         |        | AN12       | IA    | ADC Input 12                             |         |
|         |        | AD01       | I/O   | EBI Address/Data bus bit 1               |         |
| 11      | _      | PC3*       | IOUDS | PORT C Bit 3 Input/Output                |         |
|         |        | SPI21_MOSI | I/O   | SPI Channel 21 Master Out / Slave In     |         |
|         |        | AN13       | IA    | ADC Input 13                             |         |
|         |        | AD02       | I/O   | EBI Address/Data bus bit 2               |         |
|         |        | EC13       | 1     | Timer 13 Event Count Input               |         |
|         |        | T13CAP     | 1     | Timer 13 Capture Input                   |         |
|         |        | T13OUT     | 0     | Timer 13 Output                          |         |
| 12      | 8      | AVSS       | Р     | Power supply for ADC, DAC, Comparator    |         |

| Table | 2. | Pin | Description | ı |
|-------|----|-----|-------------|---|
|       |    |     |             | • |



| Pin no. |        | Pin name     | Туре  | Description                                | Remark |
|---------|--------|--------------|-------|--------------------------------------------|--------|
| 64-pin  | 48-pin |              |       |                                            |        |
| 13      | 9      | AVDD         | Р     | Power supply for ADC, DAC, Comparator      |        |
| 14 10   | 10     | PA0*         | IOUDS | PORT A Bit 0 Input/Output                  |        |
|         |        | CP0_OUT      | 0     | Comparator 0 Output                        |        |
|         |        | USART13_TXD  | 0     | USART Channel 13 TXD Output                |        |
|         |        | USART13_MOSI | I/O   | USART Channel 13 Master Out / Slave In     |        |
|         |        | AN0          | IA    | ADC Input 0                                |        |
|         |        | CP0_N2       | IA    | Comparator 0 Negative 2 Input              |        |
|         |        | RTC_TAMP2    | 1     | RTC TimeStamp Input                        |        |
|         |        | EC20         | 1     | Timer 20 External Clock Input              |        |
| 15      | 11     | PA1*         | IOUDS | PORT A Bit 1 Input/Output                  |        |
|         |        | USART11_SS   | I/O   | USART Channel 11 Slave Select Signal       |        |
|         |        | USART13_RXD  | I     | USART Channel 13 RXD Input                 |        |
|         |        | USART13_MISO | I/O   | USART Channel 13 Master Input/Slave Output |        |
|         |        | AN1          | IA    | ADC Input 1                                |        |
|         |        | CP0_P0       | IA    | Comparator 0 Positive 0 Input              |        |
|         |        | T20OUT       | 0     | Timer 20 Output                            |        |
|         |        | T20CAP       | I     | Timer 20 Capture Input                     |        |
|         |        | T13OUT       | 0     | Timer 13 Output                            |        |
|         |        | T13CAP       | I     | Timer 13 Capture Input                     |        |
|         |        | EC13         | I     | Timer 13 External Clock Input              |        |
| 16      | 12     | PA2*         | IOUDS | PORT A Bit 2 Input/Output                  |        |
|         |        | USART11_TXD  | 0     | USART Channel 11 TXD Output                |        |
|         |        | USART11_MOSI | I/O   | USART Channel 11 Master Output/Slave Input |        |
|         |        | CP1_OUT      | 0     | Comparator 1 Output                        |        |
|         |        | AN2          | IA    | ADC Input 2                                |        |
|         |        | CP1_N2       | IA    | Comparator 1 Negative 2 Input              |        |
|         |        | T20OUT       | 0     | Timer 20 Output                            |        |
|         |        | T20CAP       | I     | Timer 20 Capture Input                     |        |
|         |        | T10OUT       | 0     | Timer 10 Output                            |        |
|         |        | T10CAP       | 1     | Timer 10 Capture Input                     |        |
|         |        | EC10         | 1     | Timer 10 External Clock Input              |        |
| 17      | 13     | PA3*         | IOUDS | PORT A Bit 3 Input/Output                  |        |
|         |        | USART11_RXD  | 1     | USART Channel 11 RXD Input                 |        |
|         |        | USART11_MISO | I/O   | USART Channel 11 Master Input/Slave Output |        |
|         |        | AN3          | IA    | ADC Input 3                                |        |
|         |        | CP1_P0       | IA    | Comparator 1 Positive 0 Input              |        |
|         |        | T20OUT       | 0     | Timer 20 Output                            |        |
|         |        | T20CAP       | 1     | Timer 20 Capture Input                     |        |
|         |        | T10OUT       | 0     | Timer 10 Output                            |        |
|         |        | T10CAP       | 1     | Timer 10 Capture Input                     |        |
|         |        | EC10         | 1     | Timer 10 External Clock Input              |        |



| Pin no. |        | Pin name    | Туре  | Description                              | Remark |
|---------|--------|-------------|-------|------------------------------------------|--------|
| 64-pin  | 48-pin |             |       |                                          |        |
| 18      | _      | VSS         | Р     | VSS                                      |        |
| 19      | _      | VDD         | Р     | VDD                                      |        |
| 20      | 14     | PA4*        | IOUDS | PORT A Bit 4 Input/Output                |        |
|         |        | SPI20_SS    | I/O   | SPI Channel 20 Slave Select Signal       |        |
|         |        | CP0_N0      | IA    | Comparator 0 Negative 0 Input            |        |
|         |        | CP1_N0      | IA    | Comparator 1 Negative 0 Input            |        |
|         |        | AN4         | IA    | ADC Input 4                              |        |
|         |        | USART11_SCK | I/O   | USART Channel 11 Clock Input/Output      |        |
|         |        | DAC_OUT1    | 0     | DAC Output                               |        |
| 21      | 15     | PA5*        | IOUDS | PORT A Bit 5 Input/Output                |        |
|         |        | SPI20_SCK   | I/O   | SPI Channel 20 Clock Input/Output        |        |
|         |        | CP0_N1      | IA    | Comparator 0 Negative 1 Input            |        |
|         |        | CP1_N1      | IA    | Comparator 1 Negative 1 Input            |        |
|         |        | AN5         | IA    | ADC Input 5                              |        |
|         |        | EC20        | I     | Timer 20 External Clock Input            |        |
|         |        | DAC_OUT2    | 0     | DAC Output                               |        |
| 22      | 16     | PA6*        | IOUDS | PORT A Bit 6 Input/Output                |        |
|         |        | SPI20_MISO  | I/O   | SPI Channel 20 Master-Input/Slave-Output |        |
|         |        | CP0_OUT     | 0     | Comparator 0 Output                      |        |
|         |        | AN6         | IA    | ADC Input 6                              |        |
|         |        | BLNK30      | I     | External Sync Signal Input for T30 PWM   |        |
|         |        | T40OUT      | 0     | Timer 40 Output                          |        |
|         |        | T40CAP_CH1  | I     | Timer 40 CH1 Capture Input               |        |
|         |        | T11OUT      | 0     | Timer 11 Output                          |        |
|         |        | T11CAP      | I     | Timer 11 Capture Input                   |        |
|         |        | EC11        | I     | Timer 11 External Clock Input            |        |
|         |        | RD          | 0     | EBI Read signal                          |        |
| 23      | 17     | PA7*        | IOUDS | PORT A Bit 7 Input/Output                |        |
|         |        | SPI20_MOSI  | I/O   | SPI Channel 20 Master Out / Slave In     |        |
|         |        | CP1_OUT     | 0     | Comparator 1 Output                      |        |
|         |        | AN7         | IA    | ADC Input 7                              |        |
|         |        | PWM30AB     | 0     | Timer 30 PWM Output                      |        |
|         |        | T40OUT      | 0     | Timer 40 Output                          |        |
|         |        | T40CAP_CH2  | I     | Timer 40 CH2 Capture Input               |        |
|         |        | T12OUT      | 0     | Timer 12 Output                          |        |
|         |        | T12CAP      | 1     | Timer 12 Capture Input                   |        |
|         |        | EC12        | 1     | Timer 12 External Clock Input            |        |
|         |        | A19         | 0     | EBI Address 19 bus signal                |        |

 Table 2. Pin Description (continued)



| Pin no. |        | Pin name     | Туре  | Description                                | Remark |
|---------|--------|--------------|-------|--------------------------------------------|--------|
| 64-pin  | 48-pin |              |       |                                            |        |
| 24      | _      | PC4*         | IOUDS | PORT C Bit 4 Input/Output                  |        |
|         |        | USART12_TXD  | 0     | USART Channel 12 TXD Input                 |        |
|         |        | USART12_MOSI | I/O   | USART Channel 12 Master Output/Slave Input |        |
|         |        | AN14         | IA    | ADC Input 14                               |        |
|         |        | EC40         | 1     | Timer 40 External Clock Input              |        |
|         |        | A18          | 0     | EBI Address 18 bus signal                  |        |
| 25      | _      | PC5*         | IOUDS | PORT C Bit 5 Input/Output                  |        |
|         |        | USART12_RXD  | I     | USART Channel 12 RXD Input                 |        |
|         |        | USART12_MISO | I/O   | USART Channel 12 Master Input/Slave Output |        |
|         |        | AN15         | IA    | ADC Input 15                               |        |
|         |        | T21CAP       | I     | Timer 21 Capture Input                     |        |
|         |        | T21OUT       | 0     | Timer 21 Output                            |        |
|         |        | A17          | 0     | EBI Address 17 bus signal                  |        |
| 26      | 18     | PB0*         | IOUDS | PORT B Bit 0 Input/Output                  |        |
|         |        | AN8          | IA    | ADC Input 8                                |        |
|         |        | PWM30BB      | 0     | Timer 30 PWM Output                        |        |
|         |        | T21CAP       | 1     | Timer 21 Capture Input                     |        |
|         |        | T21OUT       | 0     | Timer 21 Output                            |        |
|         |        | T40OUT       | 0     | Timer 40 Output                            |        |
|         |        | T40CAP_CH3   | I     | Timer 40 CH3 Capture Input                 |        |
|         |        | USART12_SCK  | I/O   | USART Channel 12 Clock Input/Output        |        |
|         |        | A16          | 0     | EBI Address 16 bus signal                  |        |
| 27      | 19     | PB1*         | IOUDS | PORT B Bit 1 Input/Output                  |        |
|         |        | AN9          | IA    | ADC Input 9                                |        |
|         |        | PWM30CB      | 0     | Timer 30 PWM Output                        |        |
|         |        | USART12_SS   | I/O   | USART Channel 12 Slave Select Signal       |        |
|         |        | T13OUT       | 0     | Timer 13 Output                            |        |
|         |        | T13CAP       | I     | Timer 13 Capture Input                     |        |
|         |        | EC13         | I     | Timer 13 External Clock Input              |        |
|         |        | AD15         | I/O   | EBI Address or Data 15 bus signal          |        |
| 28      | 20     | PB2*         | IOUDS | PORT B Bit 2 Input/Output                  |        |
|         |        | T13OUT       | 0     | Timer 13 Output                            |        |
|         |        | T13CAP       | 1     | Timer 13 Capture Input                     |        |
|         |        | EC13         | I     | Timer 13 External Clock Input              |        |
|         |        | AD14         | I/O   | EBI Address or Data 14 bus signal          |        |

Table 2. Pin Description (continued)



| Pin no. |        | Pin name     | Туре  | Description                                | Remark |
|---------|--------|--------------|-------|--------------------------------------------|--------|
| 64-pin  | 48-pin |              |       |                                            |        |
| 29      | 21     | PB10*        | IOUDS | PORT B Bit 10 Input/Output                 |        |
|         |        | SPI21_SCK    | I/O   | SPI Channel 21 Clock Input/Output          |        |
|         |        | I2C1_SCL     | I/O   | I2C Channel 1 SCL In/Output                |        |
|         |        | USART12_TXD  | 0     | USART Channel 12 TXD Input                 |        |
|         |        | USART12_MOSI | I/O   | USART Channel 12 Master Output/Slave Input |        |
|         |        | T20OUT       | 0     | Timer 20 Output                            |        |
|         |        | T20CAP       | 1     | Timer 20 Capture Input                     |        |
|         |        | AD13         | I/O   | EBI Address or Data 13 bus signal          |        |
| 30      | 22     | PB11*        | IOUDS | PORT B Bit 11 Input/Output                 |        |
|         |        | USART12_RXD  | 1     | USART Channel 12 RXD Input                 |        |
|         |        | USART12_MISO | I/O   | USART Channel 12 Master Input/Slave Output |        |
|         |        | I2C1_SDA     | I/O   | I2C Channel 1 SDA In/Output                |        |
|         |        | T20OUT       | 0     | Timer 20 Output                            |        |
|         |        | T20CAP       | I     | Timer 20 Capture Input                     |        |
|         |        | AD12         | I/O   | EBI Address or Data 12 bus signal          |        |
| 31      | 23     | VSS          | Р     | VSS                                        |        |
| 32      | 24     | VDD          | Р     | VDD                                        |        |
| 33      | 25     | PB12*        | IOUDS | PORT B Bit 12 Input/Output                 |        |
|         |        | SPI21_SS     | I/O   | SPI Channel 21 Slave Select Signal         |        |
|         |        | BLNK30       | 1     | External Sync Signal Input for T30 PWM     |        |
|         |        | USART12_SCK  | I/O   | USART Channel 12 Clock Input/Output        |        |
|         |        | EC13         | I     | Timer 13 External Clock Input              |        |
|         |        | T13CAP       | 1     | Timer 13 Capture Input                     |        |
|         |        | T13OUT       | 0     | Timer 13 Output                            |        |
|         |        | AD11         | I/O   | EBI Address or Data 11 bus signal          |        |
| 34      | 26     | PB13*        | IOUDS | PORT B Bit 13 Input/Output                 |        |
|         |        | SPI21_SCK    | I/O   | SPI Channel 21 Clock Input/Output          |        |
|         |        | I2C1_SCL     | I/O   | I2C Channel 1 SCL In/Output                |        |
|         |        | PWM30AB      | 0     | Timer 30 PWM Output                        |        |
|         |        | AD10         | I/O   | EBI Address or Data 10 bus signal          |        |
| 35      | 27     | PB14*        | IOUDS | PORT B Bit 14 Input/Output                 |        |
|         |        | SPI21_MISO   | I/O   | SPI Channel 21 Master-Input/Slave-Output   |        |
|         |        | I2C1_SDA     | I/O   | I2C Channel 1 SDA In/Output                |        |
|         |        | PWM30BB      | 0     | Timer 30 PWM Output                        |        |
|         |        | T10OUT       | 0     | Timer 10 Output                            |        |
|         |        | T10CAP       | 1     | Timer 10 Capture Input                     |        |
|         |        | EC10         | 1     | Timer 10 External Clock Input              |        |
|         |        | USART12_SS   | I/O   | USART Channel 12 Slave Select Signal       |        |
|         |        | <br>AD09     | I/O   | EBI Address or Data 9 bus signal           |        |

| Table 2. | Pin | Descriptio | on (contir | nued) |
|----------|-----|------------|------------|-------|
|          |     |            |            |       |



| Pin no. |        | Pin name     | Туре  | Description                                | Remark |
|---------|--------|--------------|-------|--------------------------------------------|--------|
| 64-pin  | 48-pin |              |       |                                            |        |
| 36      | 28     | PB15*        | IOUDS | PORT B Bit 15 Input/Output                 |        |
|         |        | SPI21_MOSI   | I/O   | SPI Channel 21 Master Out / Slave In       |        |
|         |        | PWM30CB      | 0     | Timer 30 PWM Output                        |        |
|         |        | T10OUT       | 0     | Timer 10 Output                            |        |
|         |        | T10CAP       | 1     | Timer 10 Capture Input                     |        |
|         |        | EC10         | 1     | Timer 10 External Clock Input              |        |
|         |        | T21CAP       | 1     | Timer 21 Capture Input                     |        |
|         |        | T21OUT       | 0     | Timer 21 Output                            |        |
|         |        | AD08         | I/O   | EBI Address or Data 8 bus signal           |        |
| 37      | _      | PC6*         | IOUDS | PORT C Bit 6 Input/Output                  |        |
|         |        | T21CAP       | I     | Timer 21 Capture Input                     |        |
|         |        | T21OUT       | 0     | Timer 21 Output                            |        |
|         |        | T40OUT       | 0     | Timer 40 Output                            |        |
|         |        | T40CAP_CH1   | 1     | Timer 40 CH1 Capture Input                 |        |
|         |        | nWAIT        | 0     | EBI External Wait signal                   |        |
| 38      | _      | PC7*         | IOUDS | PORT C Bit 7 Input/Output                  |        |
|         |        | T40OUT       | 0     | Timer 40 Output                            |        |
|         |        | T40CAP CH2   | 1     | Timer 40 CH2 Capture Input                 |        |
|         |        |              | 0     | EBI Upper Data select signal               |        |
| 39      |        | PC8*         | IOUDS | PORT C Bit 8 Input/Output                  |        |
|         |        | T40OUT       | 0     | Timer 40 Output                            |        |
|         |        | T40CAP_CH3   | 1     | Timer 40 CH3 Capture Input                 |        |
|         |        | UWR          | 0     | EBI Upper Byte write signal                |        |
| 40      |        | PC9*         | IOUDS | PORT C Bit 9 Input/Output                  |        |
|         |        | EC40         | 1     | Timer 40 External Clock Input              |        |
|         |        | CS3          | 0     | EBI memory selection signal 3              |        |
| 41      | 29     | PA8*         | IOUDS | PORT A Bit 8 Input/Output                  |        |
|         |        | USART10_SCK  | I/O   | USART Channel 10 Clock Input/Output        |        |
|         |        | PWM30AA      | 0     | Timer 30 PWM Output                        |        |
|         |        | AD07         | I/O   | EBI Address or Data 7 bus signal           |        |
| 42      | 30     | PA9*         | IOUDS | PORT A Bit 9 Input/Output                  |        |
|         |        | USART10 TXD  | 0     | USART Channel 10 TXD Input                 |        |
|         |        | USART10_MOSI | I/O   | USART Channel 10 Master Output/Slave Input |        |
|         |        | PWM30BA      | 0     | Timer 30 PWM Output                        |        |
|         |        | AD06         | I/O   | EBI Address or Data 6 bus signal           |        |
| 43      | 31     | PA10*        | IOUDS | PORT A Bit 10 Input/Output                 |        |
| -       |        | USART10 RXD  | 1     | USART Channel 10 RXD Input                 |        |
|         |        | USART10_MISO | I/O   | USART Channel 10 Master Input/Slave Output |        |
|         |        | PWM30CA      | 0     | Timer 30 PWM Output                        |        |
|         |        | EC21         |       | Timer 21 External Clock Input              |        |
|         |        | AD05         | I/O   | EBI Address or Data 5 bus signal           |        |

#### Table 2. Pin Description (continued)



| Pin no. |        | Pin name     | Туре  | Description                                | Remark  |
|---------|--------|--------------|-------|--------------------------------------------|---------|
| 64-pin  | 48-pin |              |       |                                            |         |
| 44      | 32     | PA11*        | IOUDS | PORT A Bit 11 Input/Output                 |         |
|         |        | CP0_OUT      | 0     | Comparator 0 Output                        |         |
|         |        | USBDM        | I/O   | USB Data Line Minus                        |         |
|         |        | AD04         | I/O   | EBI Address or Data 4 bus signal           |         |
| 45      | 33     | PA12*        | IOUDS | PORT A Bit 12 Input/Output                 |         |
|         |        | CP1_OUT      | 0     | Comparator 2 Output                        |         |
|         |        | USBDP        | I/O   | USB Data Line Plus                         |         |
|         |        | EC30         | 1     | Timer 30 External Clock Input              |         |
|         |        | USART10_SS   | I/O   | USART Channel 10 Slave Select Signal       |         |
|         |        | T30CAP       | 1     | Timer 30 Capture Input                     |         |
|         |        | AD03         | I/O   | EBI Address or Data 3 bus signal           |         |
| 46      | 34     | PA13         | IOUDS | PORT A Bit 13 Input/Output                 |         |
|         |        | SWDIO*       | I/OU  | SWD Data Input/Output                      | Pull-up |
| 47      | 35     | VSS          | Р     | VSS                                        |         |
| 48      | 36     | VDDIO2       | Р     | VDD                                        |         |
| 49      | 37     | PA14         | IOUDS | PORT A Bit 14 Input/Output                 |         |
|         |        | USART11_TXD  | 0     | USART Channel 11 TXD Output                |         |
|         |        | USART11_MOSI | I/O   | USART Channel 11 Master Output/Slave Input |         |
|         |        | SWCLK*       | IU    | SWD Clock Input                            | Pull-up |
| 50      | 38     | PA15*        | IOUDS | PORT A Bit 15 Input/Output                 |         |
|         |        | USART13_SS   | I/O   | USART Channel 13 Slave Select Signal       |         |
|         |        | USART11_RXD  | 1     | USART Channel 11 RXD Input                 |         |
|         |        | USART11_MISO | I/O   | USART Channel 11 Master Input/Slave Output |         |
|         |        | SPI20_SS     | I/O   | SPI Channel 20 Slave Select Signal         |         |
|         |        | EC21         | 1     | Timer 21 External Clock Input              |         |
|         |        | ALE          | 0     | EBI Address Latch signal                   |         |
| 51      | _      | PC10*        | IOUDS | PORT C Bit 10 Input/Output                 |         |
|         |        | USART12_TXD  | 0     | USART Channel 12 TXD Output                |         |
|         |        | USART12_MOSI | I/O   | USART Channel 12 Master Output/Slave Input |         |
|         |        | USART13_TXD  | 0     | USART Channel 13 TXD Output                |         |
|         |        | USART13_MOSI | I/O   | USART Channel 13 Master Output/Slave Input |         |
|         |        | LDS          | 0     | EBI Lower Data select signal               |         |
| 52      | _      | PC11*        | IOUDS | PORT C Bit 11 Input/Output                 |         |
|         |        | USART12_RXD  | 1     | USART Channel 12 RXD Input                 |         |
|         |        | USART12_MISO | I/O   | USART Channel 12 Master Input/Slave Output |         |
|         |        | USART13_RXD  | 1     | USART Channel 13 RXD Input                 |         |
|         |        | USART13_MISO | I/O   | USART Channel 13 Master Input/Slave Output |         |
|         |        | EC21         | 1     | Timer 21 External Clock Input              |         |
|         |        | RD           | 0     | EBI Read signal                            |         |

#### Table 2. Pin Description (continued)



| Pin no. |        | Pin name     | Туре  | Description                                | Remark |
|---------|--------|--------------|-------|--------------------------------------------|--------|
| 64-pin  | 48-pin |              |       |                                            |        |
| 53      | _      | PC12*        | IOUDS | PORT C Bit 12 Input/Output                 |        |
|         |        | USART12_SCK  | I/O   | USART Channel 12 Clock Input/Output        |        |
|         |        | USART13_SCK  | I/O   | USART Channel 13 Clock Input/Output        |        |
|         |        | CS2          | 0     | EBI memory selection signal 2              |        |
| 54      | _      | PF2*         | IOUDS | PORT F Bit 2 Input/Output                  |        |
|         |        | USART12_SS   | I/O   | USART Channel 12 Slave Select Signal       |        |
|         |        | EC40         | 1     | Timer 40 External Clock Input              |        |
|         |        | T21CAP       | I     | Timer 21 Capture Input                     |        |
|         |        | T21OUT       | 0     | Timer 21 Output                            |        |
|         |        | CS1          | 0     | EBI memory selection signal 1              |        |
| 55      | 39     | PB3*         | IOUDS | PORT B Bit 3 Input/Output                  |        |
|         |        | SPI20_SCK    | I/O   | SPI Channel 20 Clock Input/Output          |        |
|         |        | T20OUT       | 0     | Timer 20 Output                            |        |
|         |        | T20CAP       | I     | Timer 20 Capture Input                     |        |
|         |        | AD02         | I/O   | EBI Address or Data 2 bus signal           |        |
| 56      | 40     | PB4*         | IOUDS | PORT B Bit 4 Input/Output                  |        |
|         |        | SPI20_MISO   | I/O   | SPI Channel 20 Master-Input/Slave-Output   |        |
|         |        | T40OUT       | 0     | Timer 40 Output                            |        |
|         |        | T40CAP_CH1   | I     | Timer 40 CH1 Capture Input                 |        |
|         |        | AD01         | I/O   | EBI Address or Data 1 bus signal           |        |
| 57      | 41     | PB5*         | IOUDS | PORT B Bit 5 Input/Output                  |        |
|         |        | SPI20_MOSI   | I/O   | SPI Channel 20 Master Out / Slave In       |        |
|         |        | T40OUT       | 0     | Timer 40 Output                            |        |
|         |        | T40CAP_CH2   | I     | Timer 40 CH2 Capture Input                 |        |
|         |        | T21CAP       | 1     | Timer 21 Capture Input                     |        |
|         |        | T21OUT       | 0     | Timer 21 Output                            |        |
|         |        | AD00         | I/O   | EBI Address or Data 0 bus signal           |        |
| 58      | 42     | PB6*         | IOUDS | PORT B Bit 6 Input/Output                  |        |
|         |        | I2C0_SCL     | 0     | I2C Channel 0 SCL In/Output                |        |
|         |        | USART10_TXD  | 0     | USART Channel 10 TXD Output                |        |
|         |        | USART10_MOSI | I/O   | USART Channel 10 Master Output/Slave Input |        |
|         |        | T11OUT       | 0     | Timer 11 Output                            |        |
|         |        | T11CAP       | 1     | Timer 11 Capture Input                     | 1      |
|         |        | EC11         | 1     | Timer 11 External Clock Input              |        |
|         |        | T40CAP_CH3   | 1     | Timer 40 CH3 Capture Input                 | 1      |
|         |        | T40OUT       | 0     | Timer 40 Output                            | 1      |
|         |        | LWR          | 0     | EBI Lower Byte Write signal                | 1      |

#### Table 2. Pin Description (continued)



| Pin no. |        | Pin name     | Туре  | Description                                | Remark  |
|---------|--------|--------------|-------|--------------------------------------------|---------|
| 64-pin  | 48-pin |              |       |                                            |         |
| 59      | 43     | PB7*         | IOUDS | PORT B Bit 7 Input/Output                  |         |
|         |        | I2C0_SDA     | I/O   | I2C Channel 0 SDA In/Output                |         |
|         |        | USART10_RXD  | 1     | USART Channel 10 RXD Input                 |         |
|         |        | USART10_MISO | I/O   | USART Channel 10 Master Input/Slave Output |         |
|         |        | T12OUT       | 0     | Timer 12 Output                            |         |
|         |        | T12CAP       | 1     | Timer 12 Capture Input                     |         |
|         |        | EC12         | 1     | Timer 12 External Clock Input              |         |
|         |        | CS0          | 0     | EBI memory selection signal 0              |         |
| 60      | 44     | BOOT0        | IU    | Boot Mode Selection Input                  | Pull-up |
| 61      | 45     | PB8*         | IOUDS | PORT B Bit 8 Input/Output                  | Pull-up |
|         |        | I2C0_SCL     | I/O   | I2C Channel 0 SCL In/Output                |         |
|         |        | T11OUT       | 0     | Timer 11 Output                            |         |
|         |        | T11CAP       | I     | Timer 11 Capture Input                     |         |
|         |        | EC11         | 1     | Timer 11 External Clock Input              |         |
| 62      | 46     | PB9*         | IOUDS | PORT B Bit 9 Input/Output                  | Pull-up |
|         |        | SPI21_SS     | I/O   | SPI Channel 21 Slave Select Signal         |         |
|         |        | I2C0_SDA     | I/O   | I2C Channel 0 SDA In/Output                |         |
|         |        | T12OUT       | 0     | Timer 12 Output                            |         |
|         |        | T12CAP       | I     | Timer 12 Capture Input                     |         |
|         |        | EC12         | I     | Timer 12 External Clock Input              |         |
| 63      | 47     | VSS          | Р     | VSS                                        |         |
| 64      | 48     | VDD          | Р     | VDD                                        |         |

| Table 2 | 2 Pin    | Description | (continued) |
|---------|----------|-------------|-------------|
| Table 1 | <u> </u> | Description | (continueu) |

NOTES:

1. I=Input, O=Output, U=Pull-up, D=Pull-down, S=Schmitt-Trigger Input Type, C=CMOS Input Type, A=Analog, P=Power

2. The \* means 'selected pin function after reset condition'.

3. Pin order may be changed with revision notice.

4. BOOT0, nRESET, PA13 (SWDIO), PA14 (SWCLK), PB8, and PB9 are the default pull-up pins.



#### 3. System and memory overview

#### 3.1 System architecture

Main system of A31G32x series consists of the followings:

- ARM<sup>®</sup> Cortex<sup>®</sup> -M0+ core
- General purpose DMA
- Internal SRAM
- Internal Flash memory
- Two AHB buses

#### 3.1.1 Cortex-M0+ Core

The ARM<sup>®</sup> Cortex<sup>®</sup>-M0+ processor is the most energy-efficient ARM processor available. It builds on the very successful Cortex-M0+ processor, retaining full instruction set and tool compatibility, while further reducing energy consumption and increasing performance. Document "DDI 0484C" from ARM provides detail information of Cortex-M0+.

#### 3.1.2 Interrupt controller

| Priority | Vector Address | Interrupt Source   |
|----------|----------------|--------------------|
| -16      | 0x0000_0000    | Stack Pointer      |
| -15      | 0x0000_0004    | Reset Address      |
| -14      | 0x0000_0008    | NMI Handler        |
| -13      | 0x0000_000C    | Hard Fault Handler |
| -12      | 0x0000_0010    | Reserved           |
| -11      | 0x0000_0014    |                    |
| -10      | 0x0000_0018    |                    |
| -9       | 0x0000_001C    |                    |
| -8       | 0x0000_0020    |                    |
| -7       | 0x0000_0024    |                    |
| -6       | 0x0000_0028    |                    |
| -5       | 0x0000_002C    | SVCall Handler     |
| -4       | 0x0000_0030    | Reserved           |
| -3       | 0x0000_0034    |                    |
| -2       | 0x0000_0038    | PenSV Handler      |
| -1       | 0x0000_003C    | SysTick Handler    |

#### Table 3. Interrupt Vector Map



| Priority | Vector Address | Interrupt Source |
|----------|----------------|------------------|
| 0        | 0x0000_0040    | LVR              |
| 1        | 0x0000_0044    | SYSCLKFAIL       |
| 2        | 0x0000_0048    | WDT              |
| 3        | 0x0000_004C    | GPIOA, GPIOB     |
| 4        | 0x0000_0050    | GPIOC, GPIOF     |
| 5        | 0x0000_0054    | Reserved         |
| 6        | 0x0000_0058    | Reserved         |
| 7        | 0x0000_005C    | TIMER10          |
| 8        | 0x0000_0060    | TIMER11          |
| 9        | 0x0000_0064    | TIMER12          |
| 10       | 0x0000_0068    | 12C0             |
| 11       | 0x0000_006C    | USART10          |
| 12       | 0x0000_0070    | WT               |
| 13       | 0x0000_0074    | TIMER30          |
| 14       | 0x0000_0078    | I2C1             |
| 15       | 0x0000_007C    | TIMER20          |
| 16       | 0x0000_0080    | TIMER21          |
| 17       | 0x0000_0084    | USART11          |
| 18       | 0x0000_0088    | ADC              |
| 19       | 0x0000_008C    | SPI20            |
| 20       | 0x0000_0090    | SPI21            |
| 21       | 0x0000_0094    | TIMER13          |
| 22       | 0x0000_0098    | TIMER40          |
| 23       | 0x0000_009C    | RTC              |
| 24       | 0x0000_00A0    | Reserved         |
| 25       | 0x0000_00A4    | Reserved         |
| 26       | 0x0000_00A8    | USART12          |
| 27       | 0x0000_00AC    | USART13          |
| 28       | 0x0000_00B0    | TEMP-Sensor      |
| 29       | 0x0000_00B4    | COMP             |
| 30       | 0x0000_00B8    | USB              |
| 31       | 0x0000_00BC    | CRC              |

| Table 3. Interrupt Vector Map (continued) |
|-------------------------------------------|
|-------------------------------------------|

NOTES:

1. Each interrupt has an associated priority-level register. Each of them is 2 bits wide, occupying the two MSBs of the Interrupt Priority Level Registers.



Each Interrupt Priority Level Register occupies 1 byte (8 bits).NVIC registers in the Cortex-M0+ processor can only be accessed using word-size transfers, so for each access, four Interrupt Priority Level Registers are accessed at the same time. \*\*

NVIC PRIO BITS = 2

2. Figure 5 is a caution when using Peripheral Interrupts. Interrupt don't work if only peripheral interrupts are enabled. Enable the function in core to enable interrupt. \* \_\_enable\_irq > NVCI\_EnableIRQ(Peripheral) > Each Peripheral Interrupt



Figure 5. Interrupt Block Diagram



## 3.2 Memory organization

Program memory, data memory, registers and I/O ports are organized in the same address space.

#### 3.2.1 Register boundary address

Table 4 gives the boundary addresses of peripherals in A31G32x series.

| Boundary address           | Memory area              |
|----------------------------|--------------------------|
| 0x4000_0000                | SCU                      |
| 0x4000_5100                | LVI/LVR                  |
| 0x4000_1000/1100/1200/1500 | PCU A/B/C/F              |
| 0x4000_0100                | Flash controller         |
| 0x2000_0000                | Internal SRAM            |
| 0x4000_0400/0410/0420/0430 | DMACH0/1/2/3             |
| 0x4000_6200                | Static memory controller |
| 0x4000_1A00                | WDT                      |
| 0x4000_2000                | WT                       |
| 0x4000_2100/2200/2300/2700 | Timer 10/11/12/13        |
| 0x4000_2500/2600           | Timer 20/21              |
| 0x4000_2400/2800           | Timer 30/40              |
| 0x4000_3800/3900/3A00/3B00 | USART 10/11/12/13        |
| 0x4000_4800/4900           | I2C 0/1                  |
| 0x4000_4C00/4D00           | SPI 20/21                |
| 0x4000_3000                | 12-bit ADC               |
| 0x4000_3500                | 10-bit DAC               |
| 0x4000_3420                | Comparator               |
| 0x4000_0300                | CRC                      |
| 0x5000_0000                | USB                      |
| 0x4000_6100                | RTC                      |
| 0x4000_6300                | Temp sensor              |

Table 4. A31G32x Memory Boundary Addresses



#### 3.2.2 Memory map

Figure 6 shows addressable memory space in memory map.



Figure 6. Memory Map



### 3.2.3 Embedded SRAM

A31G32x series have a block of 0-wait on-chip SRAM. The size of SRAM is 16KB and its base address is 0x2000\_0000.

SRAM memory area is usually used for data memory and stack memory. Sometimes the code is dumped into the SRAM memory for fast operation or flash erase/programming operation. This device does not support memory remap strategy. So jump and return are required to perform the code in SRAM memory area.

#### 3.2.4 Flash memory overview

A31G32x series provides internal 128KB code flash memory and its controller. This is enough to control the general system. Self-programming is available and ISP and SWD programming is also supported in boot or debugging mode.

Instruction and data cache buffer are present and overcome the low bandwidth flash memory. CPU can access flash memory with one wait state up to 48MHz bus frequency.

#### 3.2.5 Boot mode

#### Boot mode pins

A31G32x series has a boot mode option to program internal flash memory. Boot mode can be entered by setting BOOT pin to 'L' at reset timing (Normal state is 'H').

Boot mode supports both of UART boot and I2C boot:

- UART boot uses USART10\_TXD/USART10\_RXD port or USART11\_TXD/USART11\_RXD.
- I2C boot uses I2C0\_SCL/I2C0\_SDA1 port.

The pins for boot mode are listed in Table 5.

| Block                | Pin Name         | Dir | Description                 |  |
|----------------------|------------------|-----|-----------------------------|--|
| SYSTEM               | nRESET           | I   | Reset Input signal          |  |
|                      | nBOOT            | I   | 'Low' to enter Boot mode    |  |
| UART mode of USART10 | USART10_RXD/PA10 | I   | USART10 Boot Receive Data   |  |
|                      | USART10_TXD/PA9  | 0   | USART10 Boot Transmit Data  |  |
| UART mode of USART11 | USART11_RXD/PA15 | I   | USART11 Boot Receive Data   |  |
|                      | USART11_TXD/PA14 | 0   | USART11 Boot Transmit Data  |  |
| 12C                  | I2C0_SDA/PB7     | 1/0 | I2C0 Boot Data Input/Output |  |
|                      | I2C0_SCL/PB6     | I   | I2C0 Boot Clock Input       |  |

#### Table 5. Boot Mode Pin List



#### **Boot mode connections**

User can design a target board using any of boot mode ports such as I2C or UART mode of USART10, USART11. Sample connection diagrams of boot mode are introduced in the following figures:



Figure 7. Connection Diagram of UART10 Boot



Figure 8. Connection Diagram of UART11 Boot





Figure 9. Connection Diagram of I2C Boot

### SWD mode connections

A user can use SWD mode for writing with E-PGM+. This mode can be used for writing & debugging.



Figure 10. Connection Diagram of E-PGM+ and SWD Port



# 4. System control unit

A31G32x series have a built-in intelligent power control block which manages system analog blocks and operating modes. System control unit (SCU) block controls an internal reset and clock signals to maintain optimize system performance and power dissipation.

Four pins in Table 6 are assigned for SCU block.

| Pin name   | Туре | Description                     |
|------------|------|---------------------------------|
| nRESET     | I    | External Reset Input            |
| XIN/XOUT   | OSC  | External Crystal Oscillator     |
| SXIN/SXOUT | OSC  | External sub-Crystal Oscillator |
| CLKO       | 0    | Clock Output Monitoring Signal  |

| Table | 6  | SCU | Pins   |
|-------|----|-----|--------|
| Iabic | υ. | 000 | 1 1113 |

## 4.1 SCU block diagram

In this subsection, SCU block diagram is introduced in Figure 11.



#### Figure 11. SCU Block diagram



## 4.2 Clock system

A31G32x series have two main operating clocks. One is HCLK which produces a clock signal both for CPU and AHB bus system. The other is PCLK which produces a clock signal for peripheral systems.

A user can keep the clock system variation under software control. Through Figure 12 and Table 7, users learn about the clock system of A31G32x devices and clock sources.



Figure 12. Clock Tree Configuration



All multiplexers switching clock sources have a glitch-free circuit in each. So a clock can be switched without glitch risks. When a user tries to change a clock mux control, both of clock sources must be alive. If one of them is not alive, clock change operation is stopped and system will be halted and not be recovered.

| Clock name | Frequency  | Description                    |
|------------|------------|--------------------------------|
| HSE        | 2-16 MHz   | High Speed External Oscillator |
| LSE        | 32.768 kHz | Low Speed External Oscillator  |
| HSI        | 48 MHz     | High Speed Internal OSC        |
| LSI750K    | 750 kHz    | Low Speed Internal OSC         |
| LSI40K     | 40 kHz     | Low Speed Internal OSC         |
| LSITS      | _          | Internal OSC for temp sensor   |

| Table | 7. | Clock | Sources |
|-------|----|-------|---------|
|-------|----|-------|---------|

#### 4.2.1 HCLK clock domain

HCLK clock feeds the clock to the CPU and the AHB bus. Cortex-M0+ CPU requires 2 clocks related with FCLK and HCLK. FCLK is free running clock and it is always running except in power down mode. HCLK can be stopped in SLEEP mode and power down mode.

BUS system and memory systems are operated by MCLK clock. Maximum bus operating clock speed is 48MHz.

### 4.2.2 PCLK clock domain

PCLK is the master clock of all peripherals. Each peripheral clock is enabled by SCU\_PCER1, and SCU\_PCER2 registers can be used by each peripheral. Before enabling the PCLK input clock of each block, it can't be accessible even reading its registers. It can be stopped in power down mode.

### 4.2.3 Clock configuration procedure

After powering up, the default system clock is fed by LSI750K (750KHz) clock. By default LSI750K is enabled at power up sequence. The other clock sources will be enabled by user controls with the LSI750K system clock.

HSI48M (48MHz) clock can be enabled by SCU\_CSCR register.

HSE (2-16MHz) clock can be enabled by SCU\_CSCR register. Prior to enable the HSE block, the pin mux configuration should be set for XIN, XOUT function. PF0 and PF1 pins are shared with HSE's XIN and XOUT function – PF\_MOD and PF\_AFSR0 registers should be configured properly. After enabling the HSE block, you must wait for more than 2ms time to ensure stable operation of crystal oscillation.

LSE (32.768KHz) clock can be enabled by SCU\_CSCR register. Prior to enable the LSE block, the pin mux configuration should be set for SXIN, SXOUT function. PC14 and PC15 pins are shared with LSE's SXIN and SXOUT function – PC\_MOD and PC\_AFSR1 registers should be configured properly.



After enabling the LSE block, you must wait for more than 2s time to ensure stable operation of crystal oscillation. You can change an MCLK by using the SCU\_SCCR register.

You can find an example flow chart configuring the system clock in Figure 13.



Figure 13. Clock Change Procedure



When you speed up the system clock to the maximum operating frequency, you should check flash wait control configuration. Flash read access time is one of limitation factor for performance. The wait control recommendation is suggested in Table 8.

| FM.CFG.WAIT | FLASH Access Wait         Available Max System clock frequency |        |
|-------------|----------------------------------------------------------------|--------|
| 00          | 0 clock wait                                                   | ~20MHz |
| 01          | 1 clock wait                                                   | ~40MHz |
| 10          | 2 clock wait                                                   | ~48MHz |

Table 8. Flash Wait Control Recommendation

Figure 14 shows how to set the peripheral clock. Selecting a peripheral clock is a typical method of MCCRn and PCLK. Exceptionally WT, WDT, RTC use other clocks besides MCCRn and PCLK. (n = 1, 2, 3, 4, 5 and 6).



Figure 14. Peripheral Clock Select (n: 1, 2, 3, 4, 5, and 6)



### 4. System control unit

|            | Clock Selection | Clock Selection |                      |  |  |
|------------|-----------------|-----------------|----------------------|--|--|
| Peripheral | MCCRn           | PCLK            | Another              |  |  |
| Systick    | MCCD4           | N/A             | N/A                  |  |  |
| Timer1n    | MCCR1           | 0               | N/A                  |  |  |
| Timer20    | MCCD2           | 0               | N/A                  |  |  |
| Timer30    | MCCR2           | 0               | N/A                  |  |  |
| WT         | MCCR3           | N/A             | WDTRC, LSE, LSI40kHz |  |  |
| WDT        | MCCR3           | N/A             | LSI40kHz             |  |  |
| DBCLK      | MCCR4           | N/A             | N/A                  |  |  |
| RTC        |                 | N/A             | LSI40kHz             |  |  |
| TSREF      | F MCCR5 N/A     |                 | N/A                  |  |  |
| TSSENSE    | N/A             |                 | N/A                  |  |  |
| USB        |                 | 0               | N/A                  |  |  |
| Timer40    | er40 MCCR6      |                 | N/A                  |  |  |
| Timer21    | 0               |                 | N/A                  |  |  |

## 4.3 Power domain

A31G32x series have two VDCs supplying internal 1.5V power to digital circuit: one for VDD15 domain and one for backup domain.

VDD is the main power supply and VBAT is the backup power supply. A power supply switch determines which power is to be supplied (VPWRSW). In initial state, this switch selects VDD as power supply, so it isn't booted by VBAT but is booted only by VDD. To retain the contents of the backup domain when VDD is off during operation, the power supply switch selects VBAT and uses the optional STANDBY voltage provided by the battery or other source.

To improve conversion accuracy and to extend the supply flexibility, the ADC, the DAC and Comparator have an independent power supply VDDA and VSSA which can be separately filtered and shielded from noise on the PCB. The VDDA supply voltage must be greater or equal to VDD.





Figure 15. Power Domain Diagram

Another regulator VDC33 is embedded to supply 3.3V power to a USB. When power to the USB is supplied from outside, output of the VDC33 must be floating. VDD33\_PD of SCU\_VDCCON register must be set to 1 to make it floating.

## 4.4 Reset

A31G32x series have two system reset options. One is to cold reset that is effective during power up or down sequence. The other is warm reset which is generated by several reset sources. A reset event makes a chip to turn to an initial state. Reset sources of the cold reset and the warm reset are listed in Table 10.

|               | Cold reset | Warm reset        |
|---------------|------------|-------------------|
| Reset sources | VPWRSW POR | nRESET Pin        |
|               | VDD15 POR  | WDT reset         |
|               | LVR reset  | MCLK Fail reset   |
|               |            | HSE Fail reset    |
|               |            | S/W reset         |
|               |            | CPU request reset |

Table 10. Reset Sources of Cold Reset and Warm Reset



## 4.4.1 Cold reset

Cold reset is an important feature of a chip when power is up. This characteristic will affect overall system boot.

Internal VDC is enabled when VDD power is turn on. Internal POR trigger level is 1.2V of VDD voltage out level. At this time, boot operation is started. The LSI750K clock is enabled and counts 2.73msec time for internal VDC level stabilizing. In this time, VDD voltage level should be over than initial LVR level (1.63V). After 2.73msec counting, the cold reset is released and counts 0.27msec time for warm reset synchronizing. After releasing both cold and warm reset, BOOTROM and CPU are running.



Figure 16 shows power up sequence and internal reset waveforms.

Figure 16. Power up Procedure

The VDD15 POR in the cold reset source senses the VDC output voltage in the VDD15 domain and generates a reset signal. The VDD15 POR reset signal initializes only the VDD15 domain. The backup domain is initialized only by VPWRSW POR or LVR reset.

In STANDBY mode and BACKUP POWER mode, VDD15 domain VDC is turned off and VDD15 POR occurs. Because core exists in VDD15 domain, wakeup in STANDBY mode or BACKUP POWER mode will execute BOOTROM and jump to start address.



#### 4.4.2 Warm reset

Warm reset event has several reset sources and some parts of chip returns to an initial state when the warm reset condition is occurred.

The warm reset source is controlled by SCU\_RSER register and the status is appeared in SCU\_RSSR register. The reset for each peripheral blocks is controlled by SCU\_PRER register. The reset can be masked independently.



Figure 17. Warm Reset Diagram

### 4.4.3 LVR reset

Voltage level of LVR is set by low voltage reset configuration register (SCULV\_LVRCNFG). Reset status of the LVR is shown in SCU\_RSSR register. The LVR reset is controlled by SCULV\_LVRCR register, which is cleared to "0x00" by VPWRSW POR reset.



Figure 18. LVR Reset Timing Diagram



#### 4.4.4 Reset tree



Figure 19. Reset Tree Configuration



### 4.5 Operation mode

INIT mode is an initial state of the chip when a reset is asserted. In RUN mode, CPU shows the maximum performance with high-speed clock system. SLEEP mode and three Power Down modes (STOP, STANDBY, and BACKUP POWER) can be used as a low power consumption mode. In the low power consumption mode, power is effectively managed to reduce power consumption by halting processor core and unused peripherals. Figure 20 describes transition between the operation modes.



Figure 20. Transition between Operation Modes



| MODE         | Condition                                                                | After Wake<br>up Event | After Reset<br>Event |
|--------------|--------------------------------------------------------------------------|------------------------|----------------------|
| RUN          | POWER ON                                                                 | N/A                    | INIT                 |
| SLEEP        | WFI (Wait for Interrupt): SCB.SCR[2]*=0                                  | RUN                    | INIT                 |
| STOP         | WFI (Wait for Interrupt): SCB.SCR[2]*=1                                  | RUN                    | INIT                 |
| STANDBY      | WFI (Wait for Interrupt): SCB.SCR[2]*=1,<br>VDDCON[18]=1                 | INIT                   | INIT                 |
| BACKUP POWER | VDD <pdr level:="" pdrcon[7]="1&lt;/td"><td>INIT</td><td>INIT</td></pdr> | INIT                   | INIT                 |

### 4.5.1 RUN mode

In RUM mode, CPU and the peripheral hardware operate with a high-speed clock. After a reset followed by INIT state, the system enters in the RUN mode.

### 4.5.2 SLEEP mode

Only CPU is stopped in this mode. Each peripheral function can be enabled by the function enable and clock enable bit in the PER and PCER register.



Figure 21. SLEEP Mode Operation Sequence



### 4.5.3 Power-down mode

The A31G32x series have three power down modes: STOP mode, STANDBY mode, and BACKUP POWER mode.

In STOP mode, 1.5V VDC is off and backup domain VDC is supplied to 1.5V domain. All peripherals in the 1.5V domain are switched to STOP state and CPU goes under deepsleep state. In STANDBY mode, 1.5V VDC is off and power is not supplied to 1.5V domain. Therefore, all peripherals of the 1.5V domain are initialized by VDD15 POR. In BACKUP POWER mode, VDD is turned off and the power switch selects VBAT instead of VDD. 1.5V VDC is off and no power is supplied and initialized by VDD15 POR.



Figure 22. Power down Mode Block Diagram

LVI operates in STOP mode and STANDBY mode but is ignored in BACKUP POWER mode. LVR operation is not recommended in STOP mode and STANDBY mode. To use it, set BGRAON = 1 in SCU\_SMR. LVR is not supported in BACKUP POWER mode. LVI and LVR are set using the SCULV\_LVRCNFIG, SCULV\_LVRCR and SCULV\_LVICR registers. Initially the LVR is on. When LVR occurs, both backup domain and 1.5V domain are reset.



In power down mode, LSE, and LSI40K can operate in backup domain. To operate the LSE in power down mode, set SCU\_CSCR [14] = 1. LSI40K does not turn off automatically in power down mode, so if you want LSI40K not to work in power down mode, you have to turn it off before entering power down mode.

|        | Operation enable  | Power down operation                                                                  |
|--------|-------------------|---------------------------------------------------------------------------------------|
| LSE    | SCU_CSCR[15] = 1  | If SCU_CSCR[14] = 1, RUN mode state is maintained<br>If SCU_CSCR[14] = 0, turned off. |
| LSI40K | SCU_MCCR3[11] = 1 | RUN mode state is maintained.                                                         |

Table 12. Oscillator Control in Power down Mode

Table 13 lists peripheral's operation in each power down mode.

| Mode                                 | Stop mode                                              | Standby mode | Backup power mode |
|--------------------------------------|--------------------------------------------------------|--------------|-------------------|
| HSI48M                               | Stop                                                   | Power off    | Power off         |
| FLASH                                | Stop                                                   | Power off    | Power off         |
| Tempsensor                           | Stop                                                   | Power off    | Power off         |
| USB                                  | Stop                                                   | Power off    | Power off         |
| HSE                                  | Stop                                                   | Power off    | Power off         |
| PLL                                  | Stop                                                   | Power off    | Power off         |
| ADC                                  | Stop                                                   | Power off    | Power off         |
| DAC                                  | Stop                                                   | Power off    | Power off         |
| Comparator                           | Operates                                               | Power off    | Power off         |
| CPU                                  | Deepsleep                                              | Power off    | Power off         |
| SRAM                                 | Retain                                                 | Power off    | Power off         |
| SPI20,21                             | Stop                                                   | Power off    | Power off         |
| I2C0,1                               | Operates only slave mode                               | Power off    | Power off         |
| USART10,11,12,13                     | Operates as only wakeup source                         | Power off    | Power off         |
| TIMER10,11,12,13<br>TIMER20,21,30,40 | Operates only when the<br>TIMER clock is<br>oscillates | Power off    | Power off         |

### Table 13. Peripheral Operation in Power down Mode



| Mode                                        | Stop mode                                      | Standby mode                                   | Backup power mode                              |  |
|---------------------------------------------|------------------------------------------------|------------------------------------------------|------------------------------------------------|--|
| WT                                          | Operates only when the WT clock is oscillates  | Power off                                      | Power off                                      |  |
| PA,PB,PC,PF<br>(except PC13, PC14,<br>PC15) | Retain                                         | Power off                                      | Power off                                      |  |
| PC13                                        | Retain                                         | GPIO or wakeup Pin                             | GPIO or wakeup Pin                             |  |
| PC14                                        | Retain                                         | GPIO or SXIN                                   | GPIO or SXIN                                   |  |
| PC15                                        | Retain                                         | GPIO or SXOUT                                  | GPIO or SXOUT                                  |  |
| LSI750K                                     | Off Off                                        |                                                | Off                                            |  |
| LSI40K                                      | Operates                                       | Operates                                       | Operates                                       |  |
| LSE                                         | Operates                                       | Operates                                       | Operates                                       |  |
| LVI                                         | Operates                                       | Operates                                       | Discard                                        |  |
| LVR                                         | Operates                                       | Operates                                       | No support                                     |  |
| RTC                                         | Operates only when the RTC clock is oscillates | Operates only when the RTC clock is oscillates | Operates only when the RTC clock is oscillates |  |
| WDT                                         | Operates only when the WDT clock is oscillates | Operates only when the WDT clock is oscillates | Operates only when the WDT clock is oscillates |  |
| SCU(Partially)                              | Operates                                       | Operates                                       | Operates                                       |  |

Table 13. Peripheral Operation in Power down Mode (continued)

### 4.5.4 STOP mode

When the core goes under deepsleep state using WFI instruction, the chip enters in STOP mode. In STOP mode, all peripherals of 1.5V domain are stopped. Once power is supplied, internal SRAM and registers maintain their values.

The backup domain operates regardless of the STOP mode. To wake up in STOP mode, an interrupt request must be generated and can be selected in the SCU\_WUER register. Stabilization time is 2.73ms after wakeup event occurs.

When entering in STOP mode, HSE is selected as the PLL input clock. These are maintained after wakeup.

Table 14. STOP Mode Configuration

| Mode | Condition       | Wakeup source           |
|------|-----------------|-------------------------|
| STOP | WFI             | Source included in WUER |
|      | SCB.SCR[2]* = 1 |                         |
|      | VDCCON[18] = 0  |                         |





Figure 23. STOP Mode Sequence



Figure 24. STOP Mode Timing Diagram



### 4.5.5 STANDBY mode

When the core goes under deepsleep state using WFI instruction with VDCCON[18] = 1, the chip enters in STANDBY mode. In STANDBY mode, VDC is turned off in 1.5V domain and all peripherals of 1.5V domain are in power off state. Therefore, the 1.5V domain is initialized as a whole by the VDD15 POR in STANDBY mode. The backup domain operates regardless of the STANDBY mode.

When selected in the SCU\_WUER register, the LVI, WDT, and RTC interrupt flags in the backup domain can be used to wake up in STANDBY mode. If you set PC13 as wakeup pin by setting the RTCPFCR register, the chip can wake up from STANDBY mode with rising edge of PC13. When a pin reset occurs in STANDBY mode, the chip exits STANDBY mode. Pin reset can be enabled in SCU\_RSER. Stabilization time is 2.73ms after wakeup event occurs.

When entering in STANDBY mode, HSE is selected as the PLL input clock. These are maintained after wake-up.

| Mode                       | Condition                                                                                                                                                                   | Wakeup source                                                                       |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
| STANDBY                    | WFI                                                                                                                                                                         | RTC                                                                                 |
|                            | SCB.SCR[2]* = 1                                                                                                                                                             | WDT                                                                                 |
|                            | VDCCON[18] = 1                                                                                                                                                              | PC13 (Wakeup pin)                                                                   |
|                            |                                                                                                                                                                             | Pin reset                                                                           |
| <b>NOTES:</b><br>1. SCB.SC | STAR<br>-SETUP WAKE U<br>-SCU_SMR[9:8<br>SCB.SCR[2<br>VDCCON[1<br>WFI<br>WFI<br>Standby<br>Wakeup e<br>Wakeup from St<br>END<br>CR is System Control Register in System Con | JP SOURCE<br>B] CONFIG<br>J * = 1<br>B] = 1<br>state<br>vent ?<br>Yes<br>andby mode |
| 1. SCB.SC                  | R is System Control Register in System Con                                                                                                                                  |                                                                                     |

### Table 15. STANDBY Mode Configuration

Figure 25. STANDBY Mode Sequence





Figure 26. STANDBY Mode Timing Diagram

### 4.5.6 BACKUP POWER mode

By connecting the VBAT pin to an optional standby voltage from a battery or other source, you can maintain the contents of the backup register and power the entire backup domain when VDD is turned off.

BACKUP POWER mode can be entered from all operation modes (RUN, SLEEP and STOP, STANDBY). If a PDR reset occurs when Power down reset (PDR) is enabled through the PDRCON register, the chip enters in BACKUP POWER mode. In BACKUP POWER mode, 1.5V VDC is turned off and all peripherals are in power off state. If VDD rises again and becomes higher than PDR, it exits BACKUP POWER mode and 1.5V domain restarts in initial state. For more information about BACKUP POWER mode, please refer to 4.3 Power domain.



| Mode            | Condition     | Wakeup source      |
|-----------------|---------------|--------------------|
| BACKUP<br>POWER | PDRCON[7] = 1 | (VDD rising) > PDR |

**NOTE**: It is recommended that VBAT is higher than PDR voltage.



Figure 27. BACKUP POWER Mode Sequence





Figure 28. BACKUP POWER Mode Timing Diagram

## 4.6 Registers

Base address of SCU (chip configuration) and register map are introduced in the followings:

Table 17. Base Address of SCU (Chip Configuration)

| Name                     | Base address |  |
|--------------------------|--------------|--|
| SCU (Chip Configuration) | 0x4000_F000  |  |

Table 18. SCU Register Map (Chip Configuration)

| Name           | Offset | Туре   | Descriptio           | on             | Reset value | Reference    |
|----------------|--------|--------|----------------------|----------------|-------------|--------------|
| SCUCC_VENDORID | 0x0000 | RONOTE | Vendor<br>Register   | Identification | 0x4142_4F56 | <u>4.6.1</u> |
| SCUCC_CHIPID   | 0x0004 | RONOTE | Chip<br>Register.    | Identification | 0x4D31_A00x | 4.6.2        |
| SCUCC_REVNR    | 0x0008 | RONOTE | Revision<br>Register | Number         | 0x0000_00xx | 4.6.3        |

NOTE:

1. 'RO' means 'Read Only'.

Base address of SCU and register map are introduced in the followings:



| Name | Base address |
|------|--------------|
| SCU  | 0x4000_0000  |

### Table 19. Base Address of SCU

## Table 20. SCU Register Map

| Name            | Offset | Туре | Description                           | Reset value | Reference     |
|-----------------|--------|------|---------------------------------------|-------------|---------------|
| SCU_SMR         | 0x0004 | RW   | System Mode Register                  | 0x0000_0000 | 4.6.4         |
| SCU_SCR         | 8000x0 | RW   | System Control Register               | 0x0000_0000 | 4.6.5         |
| SCU_WUER        | 0x0010 | RW   | Wake up source enable<br>register     | 0x0000_0000 | <u>4.6.6</u>  |
| SCU_WUSR        | 0x0014 | RO   | Wake up source status<br>register     | 0x0000_0000 | <u>4.6.7</u>  |
| SCU_RSER        | 0x0018 | RW   | Reset source enable register          | 0x0000_0069 | 4.6.8         |
| SCU_RSSR        | 0x001C | RW   | Reset source status register          | 0x0000_0080 | 4.6.9         |
| SCU_PRER1       | 0x0020 | RW   | Peripheral reset enable<br>register 1 | 0x871F_273B | <u>4.6.10</u> |
| SCU_PRER2       | 0x0024 | RW   | Peripheral reset enable register 2    | 0x88D1_0F3C | <u>4.6.11</u> |
| SCU_PER1        | 0x0028 | RW   | Peripheral enable register 1          | 0x0000_000F | <u>4.6.12</u> |
| SCU_PER2        | 0x002C | RW   | Peripheral enable register 2          | 0x2000_0000 | <u>4.6.13</u> |
| SCU_PCER1       | 0x0030 | RW   | Peripheral clock enable<br>register 1 | 0x0000_000F | <u>4.6.14</u> |
| SCU_PCER2       | 0x0034 | RW   | Peripheral clock enable<br>register 2 | 0x2000_0000 | <u>4.6.15</u> |
| SCU_PPCLKS<br>R | 0x0038 | RW   | Peripheral clock selection register   | 0x0000_0000 | <u>4.6.16</u> |
| SCU_CSCR        | 0x0040 | RW   | Clock Source Control register         | 0x0000_0800 | <u>4.6.17</u> |
| SCU_SCCR        | 0x0044 | RW   | System Clock Control register         | 0x0000_0000 | <u>4.6.18</u> |
| SCU_CMR         | 0x0048 | RW   | Clock Monitoring register             | 0x0000_0090 | <u>4.6.19</u> |
| SCU_NMIR        | 0x004C | RW   | NMI control register                  | 0x0000_0000 | 4.6.20        |
| SCU_COR         | 0x0050 | RW   | Clock Output Control register         | 0x0000_000F | 4.6.21        |
| SCU_PLLCON      | 0x0060 | RW   | PLL Control register                  | 0x0000_0000 | 4.6.22        |



| Name            | Offset | Туре | Description                            | Reset value | Reference     |  |  |
|-----------------|--------|------|----------------------------------------|-------------|---------------|--|--|
| SCU_VDCCON      | 0x0064 | RW   | VDC Control register                   | 0x0402_887F | 4.6.23        |  |  |
| SCU_PDRCON      | 0x0068 | RW   | PDR Control register                   | 0x0000_0000 | 4.6.24        |  |  |
| SCU_LSICON      | 0x006C | RW   | Internal Ring OSC Control Register     | 0x0000_0001 | 4.6.25        |  |  |
| SCU_EOSCR       | 0x0080 | RW   | External Oscillator control register   | 0x0000_1014 | <u>4.6.26</u> |  |  |
| SCU_EMODR       | 0x0084 | RW   | External mode pin read register        | 0x0000_0000 | <u>4.6.27</u> |  |  |
| SCU_RSTDBC<br>R | 0x0088 | RW   | Pin Reset Debounce Control<br>Register | 0x0000_0000 | <u>4.6.28</u> |  |  |
| SCU_MCCR1       | 0x0090 | RW   | Misc. Clock Control register 1         | 0x0000_0000 | 4.6.29        |  |  |
| SCU_MCCR2       | 0x0094 | RW   | Misc. Clock Control register 2         | 0x0000_0000 | 4.6.30        |  |  |
| SCU_MCCR3       | 0x0098 | RW   | Misc. Clock Control register 3         | 0x0000_0000 | <u>4.6.31</u> |  |  |
| SCU_MCCR4       | 0x009C | RW   | Misc. Clock Control register 4         | 0x0000_0000 | 4.6.32        |  |  |
| SCU_MCCR5       | 0x00A0 | RW   | Misc. Clock Control register 5         | 0x0000_0000 | 4.6.33        |  |  |
| SCU_MCCR6       | 0x00A4 | RW   | Misc. Clock Control register 6         | 0x0000_0000 | 4.6.34        |  |  |

Table 20. SCU Register Map (continued)

NOTES:

1. 'RO' means 'Read Only'.

2. 'RW' means 'Read and Write'.

Base address of LVI/LVR unit and register map are introduced in the followings:

#### Table 21. Base Address of LVI/LVR

| NAME           | BASE ADDRESS |
|----------------|--------------|
| SCULV(LVI/LVR) | 0x4000_5100  |

#### Table 22. LVI/LVR Register Map

| Name               | Offset | Туре | Description                               | Reset value | Reference     |
|--------------------|--------|------|-------------------------------------------|-------------|---------------|
| SCULV_LVICR        | 0x0000 | RW   | Low Voltage Indicator<br>Control Register | 0x0000_0000 | 4.6.35        |
| SCULV_LVRCR        | 0x0004 | RW   | Low Voltage Reset Control Register        | 0x0000_0000 | <u>4.6.36</u> |
| SCULV_LVRCN<br>FIG | 0x0008 | RW   | Configuration for Low Voltage Reset       | 0x0000_000F | 4.6.37        |

#### NOTES:

1. 'RO' means 'Read Only' and 'RW' means 'Read and Write'.

2. 'RC' means 'Read and Write 1 Clear'.



#### 4.6.1 SCUCC\_VENDORID: vendor ID register

SCUCC\_VENDORID register shows the vendor identification information. This is a 32-bit read-only register.

#### SCUCC\_VENDORID=0x4000\_F000

| 31 | 30     | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  | 15   | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|--------|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|------|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |        |    |    |    |    |    |    |    |    |    |    |    |    |     |     |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    | VENDID |    |    |    |    |    |    |    |    |    |    |    |    |     |     |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |        |    |    |    |    |    |    |    |    |    |    |    |    |     |     |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |        |    |    |    |    |    |    |    |    |    |    |    |    | 0x4 | 114 | 2_41 | -56 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |        |    |    |    |    |    |    |    |    |    |    |    |    |     | F   | RO   |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |        |    |    |    |    |    |    |    |    |    |    |    |    |     |     |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| 31VENDIDVendor Identification bits.00x4142_4F56 |  |  |
|-------------------------------------------------|--|--|
|-------------------------------------------------|--|--|

### 4.6.2 SCUCC\_CHIPID: chip ID register

SCUCC\_CHIPID register shows chip identification information. This is a 32-bit read-only register.

|    |        | SCUCC_CHIPID=0x4000_F004<br>30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |    |    |    |    |    |    |    |    |    |     |     |     |      |       |     |             |     |    |    |   |   |   |   |   |   |   |   |   |   |
|----|--------|----------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|-----|-----|-----|------|-------|-----|-------------|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30     | 29                                                                                                             | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18  | 17  | 16   | 15    | 14  | 13          | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |        |                                                                                                                |    |    |    |    |    |    |    |    |    |     |     |     |      |       |     |             |     |    |    |   |   |   |   |   |   |   |   |   |   |
|    | CHIPID |                                                                                                                |    |    |    |    |    |    |    |    |    |     |     |     |      |       |     |             |     |    |    |   |   |   |   |   |   |   |   |   |   |
|    | CHIPID |                                                                                                                |    |    |    |    |    |    |    |    |    |     |     |     |      |       |     |             |     |    |    |   |   |   |   |   |   |   |   |   |   |
|    |        |                                                                                                                |    |    |    |    |    |    |    |    | (  | )x4 | D31 | A0( | )6 c | or Ox | x4D | 31 <i>A</i> | 100 | 7  |    |   |   |   |   |   |   |   |   |   |   |
|    |        |                                                                                                                |    |    |    |    |    |    |    |    |    |     |     |     | F    | 20    |     |             |     |    |    |   |   |   |   |   |   |   |   |   |   |

| 31 | CHIPID | Chip Identificatio | n bits.                             |
|----|--------|--------------------|-------------------------------------|
| 0  |        | 0x4D31A006         | 128k bytes flash memory for program |
|    |        | 0x4D31A007         | 64k bytes flash memory for program  |



#### 4.6.3 SCUCC\_REVNR: revision number register

Revision Number register is a 32-bit read-only register. This Register is available at 32/16/8-bit access.

|                   |        |       |       |       |    |    |      |      |      |      |     |      |     |      |        |       | -    |      |     |      |       | _   |   |
|-------------------|--------|-------|-------|-------|----|----|------|------|------|------|-----|------|-----|------|--------|-------|------|------|-----|------|-------|-----|---|
| 31 30 29 28 27 26 | 25 24  | 23 22 | 21 20 | ) 19  | 18 | 17 | 16   | 15   | 14   | 13   | 12  | 11   | 10  | 9    | 8      | 7     | 6    | 5    | 4   | 3    | 2     | 1   | 0 |
|                   |        |       | Res   | serve | ed |    |      |      |      |      |     |      |     |      |        |       |      | ł    | RE\ | /NC  | )     |     |   |
|                   |        |       | 0x0   | 0000  | 00 |    |      |      |      |      |     |      |     |      |        |       |      |      | х   | х    |       |     |   |
|                   |        |       |       | •     |    |    |      |      |      |      |     |      |     |      |        |       |      |      | R   | 0    |       |     |   |
|                   | 7<br>0 | REVN  | 10    |       |    |    | Chip | o Re | visi | on N | Num | ber. | The | se l | oits a | are f | ixed | l by | mar | nufa | cture | er. |   |

#### SCUCC\_REVNR=0x4000\_F008

### 4.6.4 SCU\_SMR: system mode register

Current operating mode is shown in this SCU mode register. The previous operating mode will be saved in this register after reset event. There is a VDC On/Off control bit in power down mode.

|                                                                   |        | ;      | SCI      | U_SM     | R=0 | x4( | 000_ | 000  | )4 |
|-------------------------------------------------------------------|--------|--------|----------|----------|-----|-----|------|------|----|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 | 9      | 8      | 7        | 65       | 4   | 3   | 2    | 1    | 0  |
| Reserved                                                          | BGRAON | VDCAON | Reserved | PREVMODE |     | R   | ese  | rved | ł  |
| -                                                                 | 0      | 0      | -        | 00       | )   |     | -    |      |    |
| _                                                                 | RW     | RW     | -        | RC       |     |     | -    |      |    |

| 9 | BGRAON   | BGR Always on select bit in power down mode            |
|---|----------|--------------------------------------------------------|
|   |          | 0 BGR is automatically off entering power down mode    |
|   |          | 1 BGR isn't automatically off entering power down mode |
| 8 | VDCAON   | VDC Always on select bit in power down mode            |
|   |          | 0 VDC is automatically off entering power down mode    |
|   |          | 1 VDC isn't automatically off entering power down mode |
| 6 | PREVMODE | Previous operating mode before current reset event     |
| 4 |          | 000 Previous operating mode was RUN mode               |
|   |          | 001 Previous operating mode was SLEEP mode             |
|   |          | 011 Previous operating mode was INIT mode              |
|   |          | 110 Previous operating mode was Back-up Power mode     |
|   |          | 111 Previous operating mode was Standby or Stop mode   |

NOTE:

1. Power down modes: STOP, STANDBY, and BACKUP POWER



#### 4.6.5 SCU\_SCR: system control register

It is possible to reset MCU as SWRST bit set. System Mode Register is a 32-bit register.

|    |        |    |    |    |    |    |      |     |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |   | 5 | SCL | J_S | CR | =0x | 400   | 0_0 | 800 |
|----|--------|----|----|----|----|----|------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-----|---|---|-----|-----|----|-----|-------|-----|-----|
| 31 | 30     | 29 | 28 | 27 | 26 | 25 | 5 24 | 4 2 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9   | 8 | 7 | 6   | 5   | 4  | 3   | 2     | 1   | 0   |
|    | WTIDKY |    |    |    |    |    |      |     |    |    |    |    |    |    |    |    |    |    |    |    | Re | serv | ved |   |   |     |     |    |     | SWRST |     |     |
|    |        |    |    |    |    |    | 0x0  | 00  | 00 |    |    |    |    |    |    |    |    |    |    |    |    |      |     | - |   |     |     |    |     |       |     | 0   |
|    |        |    |    |    |    |    | ١    | W0  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     | - |   |     |     |    |     |       |     | RW  |

| 31<br>16 | WTIDKY | Write Identification Key                                               |
|----------|--------|------------------------------------------------------------------------|
| 10       |        | On writes, write 0x9EB3 to these bits, otherwise the write is ignored. |
| 0        | SWRST  | Internal soft reset activation bit (check RSER[4] for reset)           |
|          |        | 0 Normal operation                                                     |
|          |        | 1 Internal soft reset generated and auto cleared                       |

#### 4.6.6 SCU\_WUER: wakeup source enable register

Enable wakeup source when the chip is in the Power Down mode. Wakeup sources which will be used the source of chip wakeup should be enabled in each bit field. If the source is used as a wakeup source, the corresponding bit should be written with '1'. If the source is not used as a wakeup source, the bit should be written with '0'.

|                                                |         |         |          |                   |                   |      |          | •        | 500      | _•      |        | IX         | ·V74              | 1000  | _0     | 10     |
|------------------------------------------------|---------|---------|----------|-------------------|-------------------|------|----------|----------|----------|---------|--------|------------|-------------------|-------|--------|--------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 1 | 6 15    | 14      | 13       | 12                | 11                | 10   | 9        | 8        | 7        | 6       | 5      | 4          | 3                 | 2     | 1      | 0      |
| Reserved                                       | I2C1WUE | 12C0WUE | GPIOFWUE | <b>USART13WUE</b> | <b>USART12WUE</b> | PIOC | GPIOBWUE | GPIOAWUE | Reserved | COMPWUE | RTCWUE | USART11WUE | <b>USART10WUE</b> | WTWUE | WDTWUE | LVRWUE |
| -                                              | 0       | 0       | 0        | 0                 | 0                 | 0    | 0        | 0        | -        | 0       | 0      | 0          | 0                 | 0     | 0      | 0      |
|                                                | RW      | RW      | RW       | RW                | RW                | RW   | RW       | RW       | -        | RW      | RW     | RW         | RW                | RW    | RW     | RW     |





|    |            | 1 Enable the wakeup event generation                                                 |
|----|------------|--------------------------------------------------------------------------------------|
|    | -          | 0 Not used for wakeup source                                                         |
| 1  | WDTWUE     | Enable wakeup source of watchdog timer event                                         |
|    |            | 1         Enable the wakeup event generation                                         |
|    |            | 0 Not used for wakeup source                                                         |
| 2  | WTWUE      | Enable wakeup source of watch timer event                                            |
|    |            | 1         Enable the wakeup event generation                                         |
| 0  | UGANTIOWOL | 0 Not used for wakeup source                                                         |
| 3  | USART10WUE | Enable the wakeup event generation     Enable wakeup source of USART10 change event  |
|    |            |                                                                                      |
| 4  | USARTTWUE  | Enable wakeup source of USART11 change event 0 Not used for wakeup source            |
| 4  | USART11WUE | Enable the wakeup event generation     Enable wakeup source of LISAPT11 change event |
|    |            | 0 Not used for wakeup source                                                         |
| 5  | RTCWUE     | Enable wakeup source of RTC change event                                             |
| F  |            | 1 Enable the wakeup event generation                                                 |
|    |            | 0 Not used for wakeup source                                                         |
| 6  | COMPWUE    | Enable wakeup source of COMP change event                                            |
|    | 00151415   | 1 Enable the wakeup event generation                                                 |
|    |            | 0 Not used for wakeup source                                                         |
| 8  | GPIOAWUE   | Enable wakeup source of GPIOA port pin change event                                  |
|    |            | 1 Enable the wakeup event generation                                                 |
|    |            | 0 Not used for wakeup source                                                         |
| 9  | GPIOBWUE   | Enable wakeup source of GPIOB port pin change event                                  |
|    |            | 1 Enable the wakeup event generation                                                 |
|    |            | 0 Not used for wakeup source                                                         |
| 10 | GPIOCWUE   | Enable wakeup source of GPIOC port pin change event                                  |
|    |            | 1 Enable the wakeup event generation                                                 |
|    |            | 0 Not used for wakeup source                                                         |
| 11 | USART12WUE | Enable wakeup source of USART12 change event                                         |
|    |            | 1 Enable the wakeup event generation                                                 |
|    |            | 0 Not used for wakeup source                                                         |
| 12 | USART13WUE | Enable wakeup source of USART13 change event                                         |
|    |            | 1 Enable the wakeup event generation                                                 |
|    |            | 0 Not used for wakeup source                                                         |
| 13 | GPIOFWUE   | Enable wakeup source of GPIOF port pin change event                                  |
|    |            | 1 Enable the wakeup event generation                                                 |
|    |            | 0 Not used for wakeup source                                                         |
| 14 | I2C0WUE    | Enable wakeup source of I2C0 change event                                            |
|    |            | 1 Enable the wakeup event generation                                                 |
|    |            | 0 Not used for wakeup source                                                         |
|    |            |                                                                                      |

#### NOTE :

RTCWUE, WDTWUE, LVRWUE are no reset in STANDBY mode and BACKUP POWER 1. mode.



#### 4.6.7 SCU\_WUSR: wakeup source status register

When the system is waked up by any wakeup source, the wakeup source is identified by reading SCU\_WUSR register. When the bit is set to 1, the corresponding wakeup source issues the wake-up signal to SCU. The bit will be cleared when the event source is cleared by the software.

#### SCU\_WUSR=0x4000\_0014

| 31 30 29 28 27 26 25 24 23 22 21 20 19 | 18 17 16 15 | 5 14 | 13      | 12        | 11        | 10      | 9       | 8       | 7      | 6      | 5     | 4         | 3         | 2    | 1     | 0     |
|----------------------------------------|-------------|------|---------|-----------|-----------|---------|---------|---------|--------|--------|-------|-----------|-----------|------|-------|-------|
| Reserved                               | 13C1WL      |      | GPIOFWU | USART13WU | USART12WU | GPIOCWU | GPIOBWU | GPIOAWU | PC13WU | COMPWU | RTCWU | USART11WU | USART10WU | WTWU | WDTWU | LVRWU |
| -                                      | 0           | 0 0  | 0       | 0         | 0         | 0       | 0       | 0       | 0      | 0      | 0     | 0         | 0         | 0    | 0     | 0     |
| -                                      | RC          | 0 R0 | RO      | RO        | RO        | RO      | RO      | RO      | RO     | RO     | RO    | RO        | RO        | RO   | RO    | RO    |

| 45 | 100414/11 | Chatus of walks an accuracy of 1904 shares avant                        |
|----|-----------|-------------------------------------------------------------------------|
| 15 | I2C1WU    | Status of wakeup source of I2C1 change event                            |
|    |           | 0 No wakeup event                                                       |
|    |           | 1 Wakeup event was generated                                            |
| 14 | I2C0WU    | Status of wakeup source of I2C0 change event                            |
|    |           | 0 No wakeup event                                                       |
|    |           | 1 Wakeup event was generated                                            |
| 13 | GPIOFWU   | Status of wakeup source of GPIOF port pin change event                  |
|    |           | 0 No wakeup event                                                       |
|    |           | 1 Wakeup event was generated                                            |
| 12 | USART13WU | Status of wakeup source of USART13 change event                         |
|    |           | 0 No wakeup event                                                       |
|    |           | 1 Wakeup event was generated                                            |
| 11 | USART12WU | Status of wakeup source of USART12 change event                         |
|    |           | 0 No wakeup event                                                       |
|    |           | 1 Wakeup event was generated                                            |
| 10 | GPIOCWU   | Status of wakeup source of GPIOC port pin change event                  |
|    |           | 0 No wakeup event                                                       |
|    |           | 1 Wakeup event was generated                                            |
| 9  | GPIOBWU   | Status of wakeup source of GPIOB port pin change event                  |
|    |           | 0 No wakeup event                                                       |
|    |           | 1 Wakeup event was generated                                            |
| 8  | GPIOAWU   | Status of wakeup source of GPIOA port pin change event                  |
|    |           | 0 No wakeup event                                                       |
|    |           | 1 Wakeup event was generated                                            |
| 7  | PC13WU    | Status of wakeup source of PC13 pin change event<br>(Only Standby Mode) |
|    |           | 0 No wakeup event                                                       |
|    |           | 1 Wakeup event was generated                                            |



| 6 | COMPWU    | Status of wakeup source of COMP change event    |
|---|-----------|-------------------------------------------------|
|   |           | 0 No wakeup event                               |
|   |           | 1 Wakeup event was generated                    |
| 5 | RTCWU     | Status of wakeup source of RTC change event     |
|   |           | 0 No wakeup event                               |
|   |           | 1 Wakeup event was generated                    |
| 4 | USART11WU | Status of wakeup source of USART11 change event |
|   |           | 0 No wakeup event                               |
|   |           | 1 Wakeup event was generated                    |
| 3 | USART10WU | Status of wakeup source of USART10 change event |
|   |           | 0 No wakeup event                               |
|   |           | 1 Wakeup event was generated                    |
| 2 | WTWU      | Status of wakeup source of watch timer event    |
|   |           | 0 No wakeup event                               |
|   |           | 1 Wakeup event was generated                    |
| 1 | WDTWU     | Status of wakeup source of watchdog timer event |
|   |           | 0 No wakeup event                               |
|   |           | 1 Wakeup event was generated                    |
| 0 | LVRWU     | Status of wakeup source of LVR event            |
|   |           | 0 No wakeup event                               |
|   |           | 1 Wakeup event was generated                    |
|   |           |                                                 |



#### 4.6.8 SCU\_RSER: reset source enable register

A reset source to CPU can be selected by SCU\_RSER register. When writing '1' in the bit field of each reset source, the reset source event will be transferred to reset generator. When writing '0' in the bit field of each reset source, the reset source event will be masked and not generate the reset event.

#### SCU\_RSER=0x4000\_0018

| 31 30 29 28 27 26 25 24 23 22 | 21 20 19 18 <sup>-</sup> | 17 16 | 15 1 | 4 13 | 12 11 | 10 | 9 | 8 | 7 | 6      | 5      | 4     | 3      | 2       | 1      | 0      |
|-------------------------------|--------------------------|-------|------|------|-------|----|---|---|---|--------|--------|-------|--------|---------|--------|--------|
|                               | Reserved                 |       |      |      |       |    |   |   |   | PINRST | CPURST | SWRST | WDTRST | MCKFRST | MOFRST | LVRRST |
|                               | -                        |       |      |      |       |    |   |   |   | 1      | 1      | 0     | 1      | 0       | 0      | 1      |
|                               | -                        |       |      |      |       |    |   |   |   | RW     | RW     | RW    | RW     | RW      | RW     | RW     |

| 6 | PINRST  | External pin reset enable bit      |
|---|---------|------------------------------------|
|   |         | 0 Reset from this event is masked  |
|   |         | 1 Reset from this event is enabled |
| 5 | CPURST  | CPU request reset enable bit       |
|   |         | 0 Reset from this event is masked  |
|   |         | 1 Reset from this event is enabled |
| 4 | SWRST   | Software reset enable bit          |
|   |         | 0 Reset from this event is masked  |
|   |         | 1 Reset from this event is enabled |
| 3 | WDTRST  | Watchdog Timer reset enable bit    |
|   |         | 0 Reset from this event is masked  |
|   |         | 1 Reset from this event is enabled |
| 2 | MCKFRST | MCLK Clock fail reset enable bit   |
|   |         | 0 Reset from this event is masked  |
|   |         | 1 Reset from this event is enabled |
| 1 | MOFRST  | HSE Clock fail reset enable bit    |
|   |         | 0 Reset from this event is masked  |
|   |         | 1 Reset from this event is enabled |
| 0 | LVRRST  | LVR reset enable bit               |
|   |         | 0 Reset from this event is masked  |
|   |         | 1 Reset from this event is enabled |

NOTE:

1. PINRST, WDTRST, LVRRST are reset only by LVR reset and VPWRSW POR.



### 4.6.9 SCU\_RSSR: reset source status register

SCU\_RSSR register shows reset source information when reset event is occurred. '1' means reset event was exist and '0' means reset event is not exist for the corresponding reset source.

#### SCU\_RSSR=0x4000\_001C

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 | 8 | 7     | 6      | 5      | 4     | 3      | 2       | 1      | 0      |
|---------------------------------------------------------------------|---|-------|--------|--------|-------|--------|---------|--------|--------|
| Reserved                                                            |   | PORST | PINRST | CPURST | SWRST | WDTRST | MCKFRST | MOFRST | LVDRST |
| -                                                                   |   | 1     | 0      | 0      | 0     | 0      | 0       | 0      | 0      |
|                                                                     |   | RW    | RW     | RW     | RW    | RW     | RW      | RW     | RW     |

| 7 | PORST   | Power on reset status bit                                               |
|---|---------|-------------------------------------------------------------------------|
|   |         | 0 Read : Reset from this event was not exist<br>Write : no effect       |
|   |         | 1 Read : Reset from this event was occurred<br>Write : Clear the status |
| 6 | PINRST  | External pin reset status bit                                           |
|   |         | 0 Read : Reset from this event was not exist<br>Write : no effect       |
|   |         | 1 Read : Reset from this event was occurred<br>Write : Clear the status |
| 5 | CPURST  | CPU request reset status bit                                            |
|   |         | 0 Read : Reset from this event was not exist<br>Write : no effect       |
|   |         | 1 Read : Reset from this event was occurred<br>Write : Clear the status |
| 4 | SWRST   | Software reset status bit                                               |
|   |         | 0 Read : Reset from this event was not exist<br>Write : no effect       |
|   |         | 1 Read : Reset from this event was occurred<br>Write : Clear the status |
| 3 | WDTRST  | Watchdog Timer reset status bit                                         |
|   |         | 0 Read : Reset from this event was not exist<br>Write : no effect       |
|   |         | 1 Read : Reset from this event was occurred<br>Write : Clear the status |
| 2 | MCKFRST | MCLK Clock fail reset status bit                                        |
|   |         | 0 Read : Reset from this event was not exist<br>Write : no effect       |
|   |         | 1 Read : Reset from this event was occurred<br>Write : Clear the status |



| MOFRST | HSE Clock fail reset status bit                                         |
|--------|-------------------------------------------------------------------------|
|        | 0 Read : Reset from this event was not exist<br>Write : no effect       |
|        | 1 Read : Reset from this event was occurred<br>Write : Clear the status |
| LVRRST | LVR reset status bit                                                    |
|        | 0 Read : Reset from this event was not exist<br>Write : no effect       |
|        | 1 Read : Reset from this event was occurred<br>Write : Clear the status |
|        |                                                                         |

# 4.6.10 SCU\_PRER1: peripheral reset enable register 1

The reset of each peripheral by event reset, can be masked by user setting. SCU\_PRER1/SCU\_PRER2 register will control the enable of the event reset. If the corresponding bit is '1', the peripheral corresponded with this bit, accepts the reset event. Otherwise, the peripheral is protected from reset event and maintain current operation.

|    |             |         |         |         |    |          |    |         |         |         |         |         |          |       |          |       |       | 9     | SCI | J_P      | RE  | R1= | 0x4 | 1000     | 0_0 | 020 |
|----|-------------|---------|---------|---------|----|----------|----|---------|---------|---------|---------|---------|----------|-------|----------|-------|-------|-------|-----|----------|-----|-----|-----|----------|-----|-----|
| 31 | 30 29 28 27 | 26      | 25      | 24      | 23 | 22       | 21 | 20      | 19      | 18      | 17      | 16      | 15 14    | 13    | 12 11    | 10    | 9     | 8     | 7   | 6        | 5   | 4   | 3   | 2        | 1   | 0   |
| WT | Reserved    | TIMER21 | TIMER20 | TIMER30 |    | Reserved |    | TIMER40 | TIMER13 | TIMER12 | TIMER11 | TIMER10 | Reserved | GPIOF | Reserved | GPIOC | GPIOB | GPIOA | -   | Keserved | EBI | AMD |     | Doconiod |     |     |
| 1  | -           | 1       | 1       | 1       |    | -        |    | 1       | 1       | 1       | 1       | 1       | -        | 1     | -        | 1     | 1     | 1     |     | -        | 1   | 1   |     | -        | •   |     |
| RW | -           | RW      | RW      | RW      |    | -        |    | RW      | RW      | RW      | RW      | RW      | -        | RW    | -        | RW    | RW    | RW    |     | •        | RW  | RW  |     |          |     |     |

| 31 | WT      | WT reset mask      |
|----|---------|--------------------|
| 26 | TIMER21 | TIMER21 reset mask |
| 25 | TIMER20 | TIMER20 reset mask |
| 24 | TIMER30 | TIMER30 reset mask |
| 20 | TIMER40 | TIMER40 reset mask |
| 19 | TIMER13 | TIMER13 reset mask |
| 18 | TIMER12 | TIMER12 reset mask |
| 17 | TIMER11 | TIMER11 reset mask |
| 16 | TIMER10 | TIMER10 reset mask |
| 13 | GPIOF   | GPIOF reset mask   |
| 10 | GPIOC   | GPIOC reset mask   |
| 9  | GPIOB   | GPIOB reset mask   |
| 8  | GPIOA   | GPIOA reset mask   |
| 5  | EBI     | EBI reset mask     |
| 4  | DMA     | DMA reset mask     |
|    |         |                    |



# 4.6.11 SCU\_PRER2: peripheral reset enable register 2

SCU\_PRER2 is a 32-bit register.

# SCU\_PRER2=0x4000\_0024

| 31  | 30       | 29  | 28       | 27     | 26 2 | 25       | 24 | 23   | 22  | 21       | 20  | 19 | 18       | 17 | 16  | 15 | 14     | 13 | 12 | 11      | 10      | 9       | 8       | 7 | 6        | 5    | 4    | 3     | 2     | 1 0      |
|-----|----------|-----|----------|--------|------|----------|----|------|-----|----------|-----|----|----------|----|-----|----|--------|----|----|---------|---------|---------|---------|---|----------|------|------|-------|-------|----------|
| CRC | Reserved | RTC | Reserved | TSENSE |      | Reserved |    | COMP | DAC | Reserved | ADC |    | Reserved |    | USB |    | Docord | 5  |    | USART13 | USART12 | USART11 | USART10 |   | Reserved | 12C1 | 12C0 | SPI21 | SPI20 | Reserved |
| 1   | -        | 0   | -        | 1      |      | -        |    | 1    | 1   | -        | 1   |    | -        |    | 1   |    | -      |    |    | 1       | 1       | 1       | 1       |   | -        | 1    | 1    | 1     | 1     | -        |
| RW  | -        | RW  | -        | RW     |      | -        |    | RW   | RW  | -        | RW  |    | -        |    | RW  |    |        |    |    | RW      | RW      | RW      | RW      |   |          | RW   | RW   | RW    | RW    | -        |

| 31 | CRC     | CRC reset mask     |
|----|---------|--------------------|
| 29 | RTC     | RTC reset mask     |
| 27 | TSENSE  | TSENSE reset mask  |
| 23 | COMP    | COMP reset mask    |
| 22 | DAC     | DAC reset mask     |
| 20 | ADC     | ADC reset mask     |
| 16 | USB     | USB reset mask     |
| 11 | USART13 | USART13 reset mask |
| 10 | USART12 | USART12 reset mask |
| 9  | USART11 | USART11 reset mask |
| 8  | USART10 | USART10 reset mask |
| 5  | I2C1    | I2C1 reset mask    |
| 4  | I2C0    | I2C0 reset mask    |
| 3  | SPI21   | SPI21 reset mask   |
| 2  | SPI20   | SPI20 reset mask   |
|    |         |                    |



#### 4.6.12 SCU\_PER1: peripheral enable register1

Before using a peripheral unit, it must be activated by writing '1' to a corresponding bit in SCU\_PER1/ SCU\_PER2 register. Before the activation, the peripheral will stay in reset state.

All peripherals are enabled by default. To disable the peripheral unit, write '0' to the corresponding bit in the SCU\_PER1/ SCU\_PER2 register, and then the peripheral goes under reset state.

|    |       |          |                                                |         |                |         |  |          |  |         |         |         |         |         |          |       |          |       |       |      | S | CU_      | PE  | R1= | =0x4 | 4000     | 0_0 | 028 |
|----|-------|----------|------------------------------------------------|---------|----------------|---------|--|----------|--|---------|---------|---------|---------|---------|----------|-------|----------|-------|-------|------|---|----------|-----|-----|------|----------|-----|-----|
| 31 | 30 29 | 28       | 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 1 |         |                |         |  |          |  |         |         | 13      | 12 11   | 10      | 9        | 8     | 7        | 6     | 5     | 4    | 3 | 2        | 1   | 0   |      |          |     |     |
| ΜT |       | Reserved |                                                | TIMER21 | <b>TIMER20</b> | TIMER30 |  | Reserved |  | TIMER40 | TIMER13 | TIMER12 | TIMER11 | TIMER10 | Reserved | GPIOF | Reserved | GPIOC | GPIOB | ROID | - | Keserved | EBI | AMD |      | Doconiod |     |     |
| 0  |       | -        |                                                | 0       | 0              | 0       |  | 0        |  | 0       | 0       | 0       | 0       | 0       | -        | 0     | -        | 0     | 0     | 0    |   | -        | 0   | 0   |      | -        | •   |     |
| RW |       | •        |                                                | RW      | RW             | RW      |  | RW       |  | RW      | RW      | RW      | RW      | RW      | -        | RW    | -        | RW    | RW    | RW   |   | -        | RW  | RW  |      |          |     |     |

| 31 | WT      | WT function enable      |
|----|---------|-------------------------|
| 26 | TIMER21 | TIMER21 function enable |
| 25 | TIMER20 | TIMER20 function enable |
| 24 | TIMER30 | TIMER30 function enable |
| 20 | TIMER40 | TIMER40 function enable |
| 19 | TIMER13 | TIMER13 function enable |
| 18 | TIMER12 | TIMER12 function enable |
| 17 | TIMER11 | TIMER11 function enable |
| 16 | TIMER10 | TIMER10 function enable |
| 13 | GPIOF   | GPIOF function enable   |
| 10 | GPIOC   | GPIOC function enable   |
| 9  | GPIOB   | GPIOB function enable   |
| 8  | GPIOA   | GPIOA function enable   |
| 5  | EBI     | EBI function enable     |
| 4  | DMA     | DMA function enable     |



# 4.6.13 SCU\_PER2: peripheral enable register 2

Peripheral enable register 2 is a 32-bit register.

# SCU\_PER2=0x4000\_002C

| 31  | 30       | 29  | 28       | 27     | 26 2 | 25 2     | 24 | 23   | 22  | 21       | 20  | 19 | 18       | 17 | 16  | 15 | 14 | 13        | 12 | 11      | 10      | 9       | 8       | 7 | 6        | 5    | 4    | 3     | 2     | 1 (      | 0 |
|-----|----------|-----|----------|--------|------|----------|----|------|-----|----------|-----|----|----------|----|-----|----|----|-----------|----|---------|---------|---------|---------|---|----------|------|------|-------|-------|----------|---|
| CRC | Reserved | RTC | Reserved | TSENSE |      | Reserved |    | COMP | DAC | Reserved | ADC |    | Reserved |    | USB |    |    | Lesel veu |    | USART13 | USART12 | USART11 | USART10 |   | naviacan | 12C1 | 12C0 | SPI21 | SPI20 | Reserved |   |
| 0   | -        | 1   | -        | 0      |      | -        |    | 0    | 0   | -        | 0   |    | -        |    | 0   |    |    | -         |    | 0       | 0       | 0       | 0       | - | -        | 0    | 0    | 0     | 0     | -        |   |
| RW  | -        | RW  | -        | RW     |      | -        |    | RW   | RW  | -        | RW  |    | -        |    | RW  |    |    | -         |    | RW      | RW      | RW      | RW      | - |          | RW   | RW   | RW    | RW    | -        |   |

| 31 | CRC     | CRC function enable     |
|----|---------|-------------------------|
| 29 | RTC     | RTC function enable     |
| 27 | TSENSE  | TSENSE function enable  |
| 23 | COMP    | COMP function enable    |
| 22 | DAC     | DAC function enable     |
| 20 | ADC     | ADC function enable     |
| 16 | USB     | USB function enable     |
| 11 | USART13 | USART13 function enable |
| 10 | USART12 | USART12 function enable |
| 9  | USART11 | USART11 function enable |
| 8  | USART10 | USART10 function enable |
| 5  | I2C1    | I2C1 function enable    |
| 4  | I2C0    | I2C0 function enable    |
| 3  | SPI21   | SPI21 function enable   |
| 2  | SPI20   | SPI20 function enable   |
|    |         |                         |



# 4.6.14 SCU\_PCER1: peripheral clock enable register 1

To use peripheral unit, its clock should be activated by writing '1' to the corresponding bit in the SCU\_PCER1 register. Without enabling the clock, the peripheral won't operate properly.

To stop the clock of the peripheral, write '0' to the corresponding bit in the SCU\_PCER1/ SCU\_PCER2 register, then the clock will be stopped.

|    |    |          |    |    |         |                |         |    |          |    |         |         |         |         |         |          |       |          |       |       | 9    | SCL | J_P      | CE  | R1= | 0x4 | 1000     | _0 | )30 |
|----|----|----------|----|----|---------|----------------|---------|----|----------|----|---------|---------|---------|---------|---------|----------|-------|----------|-------|-------|------|-----|----------|-----|-----|-----|----------|----|-----|
| 31 | 30 | 29       | 28 | 27 | 26      | 25             | 24      | 23 | 22       | 21 | 20      | 19      | 18      | 17      | 16      | 15 14    | 13    | 12 11    | 10    | 9     | 8    | 7   | 6        | 5   | 4   | 3   | 2        | 1  | 0   |
| WT |    | Reserved |    |    | TIMER21 | <b>TIMER20</b> | TIMER30 |    | Reserved |    | TIMER40 | TIMER13 | TIMER12 | TIMER11 | TIMER10 | Reserved | GPIOF | Reserved | GPIOC | GPIOB | ROID |     | Keserved | EBI | DMA |     | Pacaniad |    |     |
| 0  |    | -        |    |    | 0       | 0              | 0       |    | -        |    | 0       | 0       | 0       | 0       | 0       | -        | 0     | -        | 0     | 0     | 0    |     | -        | 0   | 0   |     | -        |    |     |
| RW |    | -        |    |    | RW      | RW             | RW      |    | •        |    | RW      | RW      | RW      | RW      | RW      | -        | RW    | -        | RW    | RW    | RW   |     | •        | RW  | RW  |     |          |    |     |

| 31 | WT      | WT clock enable      |
|----|---------|----------------------|
| 26 | TIMER21 | TIMER21 clock enable |
| 25 | TIMER20 | TIMER20 clock enable |
| 24 | TIMER30 | TIMER30 clock enable |
| 20 | TIMER40 | TIMER40 clock enable |
| 19 | TIMER13 | TIMER13 clock enable |
| 18 | TIMER12 | TIMER12 clock enable |
| 17 | TIMER11 | TIMER11 clock enable |
| 16 | TIMER10 | TIMER10 clock enable |
| 13 | GPIOF   | GPIOF clock enable   |
| 10 | GPIOC   | GPIOC clock enable   |
| 9  | GPIOB   | GPIOB clock enable   |
| 8  | GPIOA   | GPIOA clock enable   |
| 5  | EBI     | EBI clock enable     |
| 4  | DMA     | DMA clock enable     |



# 4.6.15 SCU\_PCER2: peripheral clock register 2

To use peripheral unit, its clock should be activated by writing '1' to the corresponding bit in the SCU\_PCER2 register.

#### SCU\_PCER2=0x4000\_0034

| 31  | 30       | 29  | 28       | 27     | 26 | 25       | 24 | 23   | 22  | 21       | 20  | 19 18    | 17 | 16  | 15 | 14       | 13 | 12 | 11      | 10      | 9       | 8       | 7         | 6        | 5    | 4    | 3     | 2     | 1        | 0 |
|-----|----------|-----|----------|--------|----|----------|----|------|-----|----------|-----|----------|----|-----|----|----------|----|----|---------|---------|---------|---------|-----------|----------|------|------|-------|-------|----------|---|
| CRC | Reserved | RTC | Reserved | TSENSE |    | Reserved |    | COMP | DAC | Reserved | ADC | Reserved |    | USB |    | Reserved | •  |    | USART13 | USART12 | USART11 | USART10 | Docomicad | Reserved | 12C1 | 12C0 | SPI21 | SPI20 | Reserved |   |
| 0   | -        | 1   | 1        | 0      |    | -        |    | 0    | 0   | I        | 0   | -        |    | 0   |    | -        |    |    | 0       | 0       | 0       | 0       |           | -        | 0    | 0    | 0     | 0     | -        |   |
| RW  | -        | RW  | -        | RW     |    | •        |    | RW   | RW  | -        | RW  | -        |    | RW  |    | -        |    |    | RW      | RW      | RW      | RW      |           | •        | RW   | RW   | RW    | RW    | -        |   |

| 31 | CRC     | CRC clock enable     |
|----|---------|----------------------|
| 29 | RTC     | RTC clock enable     |
| 27 | TSENSE  | TSENSE clock enable  |
| 23 | COMP    | COMP clock enable    |
| 22 | DAC     | DAC clock enable     |
| 20 | ADC     | ADC clock enable     |
| 16 | USB     | USB clock enable     |
| 11 | USART13 | USART13 clock enable |
| 10 | USART12 | USART12 clock enable |
| 9  | USART11 | USART11 clock enable |
| 8  | USART10 | USART10 clock enable |
| 5  | I2C1    | I2C1 clock enable    |
| 4  | I2C0    | I2C0 clock enable    |
| 3  | SPI21   | SPI21 clock enable   |
| 2  | SPI20   | SPI20 clock enable   |
|    |         |                      |



# 4.6.16 SCU\_PPCLKSR: peripheral clock selection register

SCU\_PPCLKSR register is a 32-bit register. This register is available at 32/16/8-bit access.

#### SCU\_PPCLKSR=0x4000\_0038

| 3 | 31 | 3 | 80 | 29 | 2 | 8 | 27       | 26 | 6 2 | 25 | 24 | 23 | 3 2 | 22     | 21       | 20     | 19     | 18       | 17     | 16     | 15 14 | 13 12    | 2 11 | 10 | 9      | 8 | 7        | 6 | 5      | 4 | 3        | 2 | 1        | 0      |
|---|----|---|----|----|---|---|----------|----|-----|----|----|----|-----|--------|----------|--------|--------|----------|--------|--------|-------|----------|------|----|--------|---|----------|---|--------|---|----------|---|----------|--------|
|   |    |   |    |    |   |   | Reserved |    |     |    |    |    |     | T1xCLK | Reserved | T20CLK | T21CLK | Reserved | T30CLK | T40CLK |       | Reserved |      |    | USBCLK |   | Reserved |   | RTCCLK |   | VV I CLA |   | Reserved | WDTCLK |
|   |    |   |    |    |   |   | -        |    |     |    |    |    |     | 0      | -        | 0      | 0      | -        | 0      | 0      |       | -        |      |    | 0      |   | -        |   | 0      | 0 | 0        |   | -        | 0      |
|   |    |   |    |    |   |   | •        |    |     |    |    |    |     | RW     | -        | RW     | RW     |          | RW     | RW     |       | •        |      |    | RW     |   | •        |   | RW     | R | W        |   | -        | RW     |

| 22 | T1xCLK | Timer 1x Clock Selection bit                                                                             |
|----|--------|----------------------------------------------------------------------------------------------------------|
|    |        | 0 SCU_MCCR1 Timer1x clock                                                                                |
|    |        | 1 PCLK clock                                                                                             |
| 20 | T20CLK | Timer 20 Clock Selection bit                                                                             |
|    |        | 0 SCU_MCCR2 Timer20 clock                                                                                |
|    |        | 1 PCLK clock                                                                                             |
| 19 | T21CLK | Timer 21 Clock Selection bit                                                                             |
|    |        | 0 SCU_MCCR6 Timer21 clock                                                                                |
|    |        | 1 PCLK clock                                                                                             |
| 17 | T30CLK | Timer 30 Clock Selection bit                                                                             |
|    |        | 0 SCU_MCCR2 Timer30 clock                                                                                |
|    |        | 1 PCLK clock                                                                                             |
| 16 | T40CLK | Timer 40 Clock Selection bit                                                                             |
|    |        | 0 SCU_MCCR6 Timer40 bit                                                                                  |
|    |        | 1 PCLK clock                                                                                             |
| 9  | USBCLK | USB Clock Selection bit                                                                                  |
|    |        | 0 SCU_MCCR5 USB clock                                                                                    |
|    |        | 1 PCLK clock                                                                                             |
| 5  | RTCCLK | RTC Clock Selection bit                                                                                  |
|    |        | 0 LSI40K clock                                                                                           |
|    |        | 1 SCU_MCCR5 RTC clock                                                                                    |
| 4  | WTCLK  | Watch Timer Clock Selection bit                                                                          |
| 3  |        | 00 SCU_MCCR3 WT clock                                                                                    |
|    |        | 01 LSE clock                                                                                             |
|    |        | 10 WDTRC clock                                                                                           |
|    |        | 11 LSI40K clock                                                                                          |
|    |        | NOTE: These bits should be changed during the WTEN bit of watch time<br>control register (WTCR) is "0b". |
| 0  | WDTCLK | Watch-dog Timer Clock Selection bit                                                                      |
|    |        | 0 LSI40K clock                                                                                           |
|    |        | 1 SCU_MCCR3 WDT clock                                                                                    |

#### NOTE:

1. RTCCLK and WDTCLK can be reset only by LVR reset and VPWRSW POR.



# 4.6.17 SCU\_CSCR: clock source control register

A31G32x series have multiple clock sources to generate internal operating clocks. Each clock source can be controlled by SCU\_CSCR register.

# SCU\_CSCR=0x4000\_0040

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 | 11 10 9 8 | 7 6 5 4 | 3 2 1 0 |
|-------------------------------------------------|-------------|-----------|---------|---------|
| WTIDKY                                          | LSECON      | LSICON    | HSICON  | HSECON  |
| 0x0000                                          | 0000        | 1000      | 0000    | 0000    |
| WO                                              | RW          | RW        | RW      | RW      |

| 31 | WTIDKY | Write Identification Key                                                |                  |
|----|--------|-------------------------------------------------------------------------|------------------|
| 16 |        | On writes, write 0xA507 to these bits, otherwise the                    | write is ignored |
| 15 | LSECON | External crystal sub oscillator control                                 |                  |
| 12 |        | 0XXX Disable external sub crystal oscillator                            |                  |
|    |        | 1000 Enable external sub crystal oscillator                             |                  |
|    |        | 1001 Enable external sub crystal oscillator divid                       | le by 2          |
|    |        | 1010 Enable external sub crystal oscillator divid                       | le by 4          |
|    |        | 1100 Enable external sub crystal oscillator in Po                       | wer Down mod     |
|    |        | 1101 Enable external sub crystal oscillator divid<br>in Power Down mode | le by 2          |
|    |        | 1110 Enable external sub crystal oscillator divid<br>in Power Down mode | le by 4          |
|    |        | Other Reserved                                                          |                  |
| 11 | LSICON | Low speed internal oscillator control                                   |                  |
| 8  |        | 0XXX Disable low speed internal oscillator                              |                  |
|    |        | 1000 Enable low speed internal oscillator                               |                  |
|    |        | 1001 Enable low speed internal oscillator divide                        | e by 2           |
|    |        | 1010 Enable low speed internal oscillator divide                        | e by 4           |
|    |        | Other Reserved                                                          |                  |
| 7  | HSICON | High speed internal oscillator control                                  |                  |
| 4  |        | 0XXX Disable high speed internal oscillator                             |                  |
|    |        | 1000 Enable high speed internal oscillator                              |                  |
|    |        | 1001 Enable high speed internal oscillator divid                        | e by 2           |
|    |        | 1010 Enable high speed internal oscillator divid                        | e by 4           |
|    |        | 1011 Enable high speed internal oscillator divid                        | e by 8           |
|    |        | 1100 Enable high speed internal oscillator divid                        | e by 16          |
|    |        | 1101 Enable high speed internal oscillator divid                        | e by 32          |
|    |        | 1111 Reserved                                                           |                  |
| 3  | HSECON | External crystal main oscillator control                                |                  |
| 0  |        | 0XXX Disable external main crystal oscillator                           |                  |
|    |        | 1000 Enable external main crystal oscillator                            |                  |
|    |        | 1001 Enable external main crystal oscillator di                         | vide by 2        |
|    |        | 1010 Enable external main crystal oscillator di                         | vide by 4        |
|    |        | Other Reserved                                                          |                  |

1. SCU\_CSCR[15:12] are reset only by LVR reset and VPWRSW POR.

2. To use LSE in Power down Mode, Select 1100b' in SCU\_CSCR[15:12].



# 4.6.18 SCU\_SCCR: system clock control register

Selected system clock source in SCU\_SCCR becomes MCLK. Before changing clock, clock sources have to be alive by SCU\_CSCR register.

| SCU  | SCCR=0x4000    | 0044   |
|------|----------------|--------|
| 000_ | _00011 074000_ | 00-1-1 |

|                                                | —                               | _          |
|------------------------------------------------|---------------------------------|------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 1 | 15 14 13 12 11 10 9 8 7 6 5 4 3 | 2 1 0      |
| WTIDKY                                         | Reserved                        | PLLINCLKSE |
| 0x0000                                         | -                               | 0 00       |
| WO                                             |                                 | RW RW      |

| 31<br>16 | WTIDKY      | Write Identification Key                                               |
|----------|-------------|------------------------------------------------------------------------|
| 10       |             | On writes, write 0x570A to these bits, otherwise the write is ignored. |
| 2        | PLLINCLKSEL | PLL input source select register                                       |
|          |             | 0 HSI clock is used as PLLINCLK clock                                  |
|          |             | 1 HSE clock is used as PLLINCLK clock                                  |
| 1        | MCLKSEL     | System clock select register                                           |
| 0        |             | 00 Internal ring oscillator(750kHz)                                    |
|          |             | 01 LSE XTAL (32kHz)                                                    |
|          |             | 10 PLL bypassed clock                                                  |
|          |             | 11 PLL output clock                                                    |

1. When change MCLKSEL, both clock sources should be alive. Ex) Both of HSI and HSE should be alive, otherwise the chip will malfunction.

# 4.6.19 SCU\_CMR: clock monitoring register

Clock can be monitored by LSI for security purpose.

|                                                 |         |          |        |       |         |        |         | 30     | <u></u>  |         | (-UX   | 400   | 0_0     | 040    |
|-------------------------------------------------|---------|----------|--------|-------|---------|--------|---------|--------|----------|---------|--------|-------|---------|--------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15      | 14 13 12 | 11     | 10    | 9       | 8      | 7       | 6      | 5        | 4       | 3      | 2     | 1       | 0      |
| Reserved                                        | MCLKREC | Reserved | LNMASL | LSEIE | LSEFAIL | LSESTS | MCLKMNT | MCLKIE | MCLKFAIL | MCLKSTS | HSEMNT | JIJSH | HSEFAIL | HSESTS |
| -                                               | 0       | -        | 0      | 0     | 0       | 0      | 1       | 0      | 0        | 1       | 0      | 0     | 0       | 0      |
|                                                 | RW      | -        | RW     | RW    | RC      | RO     | RW      | RW     | RC       | RO      | RW     | RW    | RC      | RO     |

## SCU\_CMR=0x4000\_0048



| 15 | MCLKREC  | MCLK fail auto recovery                                                                        |
|----|----------|------------------------------------------------------------------------------------------------|
|    |          | 0 MCLK is changed to LSI by default when MCLKFAIL issued                                       |
|    |          | 1 MCLK auto recovery is disabled                                                               |
| 11 | LSEMNT   | External sub oscillator monitoring enable                                                      |
|    |          | 0 External sub oscillator monitoring disabled                                                  |
|    |          | 1 External sub oscillator monitoring enabled                                                   |
| 10 | LSEIE    | External sub oscillator fail interrupt enable                                                  |
|    |          | 0 External sub oscillator fail interrupt disabled                                              |
|    |          | 1 External sub oscillator fail interrupt enabled                                               |
| 9  | LSEFAIL  | External sub oscillator fail interrupt                                                         |
|    |          | 0 External sub oscillator fail interrupt not occurred                                          |
|    |          | 1 Read : External sub oscillator fail interrupt is pending<br>Write : Clear pending interrupt  |
| 8  | LSESTS   | External sub oscillator status                                                                 |
|    |          | 0 Not oscillate                                                                                |
|    |          | 1 External sub oscillator is working normally                                                  |
| 7  | MCLKMNT  | MCLK monitoring enable                                                                         |
|    |          | 0 MCLK monitoring disabled                                                                     |
|    |          | 1 MCLK monitoring enabled                                                                      |
| 6  | MCLKIE   | MCLK fail interrupt enable                                                                     |
|    |          | 0 MCLK fail interrupt disabled                                                                 |
|    |          | 1 MCLK fail interrupt enabled                                                                  |
| 5  | MCLKFAIL | MCLK fail interrupt                                                                            |
|    |          | 0 MCLK fail interrupt not occurred                                                             |
|    |          | 1 Read : MCLK fail interrupt is pending<br>Write : Clear pending interrupt                     |
| 4  | MCLKSTS  | MCLK clock status                                                                              |
|    |          | 0 No clock is present on MCLK                                                                  |
|    |          | 1 Clock is present on MCLK                                                                     |
| 3  | HSEMNT   | External main oscillator monitoring enable                                                     |
|    |          | 0 External main oscillator monitoring disabled                                                 |
|    |          | 1 External main oscillator monitoring enabled                                                  |
| 2  | HSEIE    | External main oscillator fail interrupt enable                                                 |
|    |          | 0 External main oscillator fail interrupt disabled                                             |
|    |          | 1 External main oscillator fail interrupt enabled                                              |
| 1  | HSEFAIL  | External main oscillator fail interrupt                                                        |
|    |          | 0 External main oscillator fail interrupt not occurred                                         |
|    |          | 1 Read : External main oscillator fail interrupt is pending<br>Write : Clear pending interrupt |
| 0  | HSESTS   | External main oscillator status                                                                |
|    |          | 0 Not oscillate                                                                                |
|    |          | 1 External main oscillator is working normally                                                 |



# 4.6.20 SCU\_NMIR: NMI control register

SCU\_NMIR is a non-maskable interrupt configuration register which can be set by software. There are three types of interrupt sources from WDT and SCU.

It will jump to NMI handler if a selected NMI event occurred and it must check event status. For clearing occurred status, it should clear the interrupt flags of that peripheral occurred.

Write access key is required 0xA32C on SCU\_NMIR[31:16] when write register.

| 31 30 29 28 27 26 25 | 24 | 23 22 21 20 19 18 17                   | 16                              | 15 14 13 12 11                                                                                                                                                                      | 10                                | 9                       | 8                      | 7     | 6     | 5     | 4 3 | 3 | 2        | 1          | 0     |
|----------------------|----|----------------------------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-------------------------|------------------------|-------|-------|-------|-----|---|----------|------------|-------|
| ACC                  | ES | SCODE                                  |                                 | Reserved                                                                                                                                                                            | WDTINTSTS                         | MCLKFAILSTS             | LVRSTS                 |       | Res   | serve | ed  |   | WDTINTEN | MCLKFAILEN | LVREN |
|                      |    | -                                      |                                 | -                                                                                                                                                                                   | 0                                 | 0                       | 0                      |       |       | -     |     |   | 0        | 0          | 0     |
|                      | V  | VO                                     |                                 |                                                                                                                                                                                     | RO                                | RO                      | RO                     |       |       | •     |     | F | RW       | RW         | RW    |
| 3<br>10<br>10<br>9   | 6  | ACCESSCODE<br>WDTINTSTS<br>MCLKFAILSTS | Wr<br>WE<br>Thi<br>0<br>1<br>MC | is field enables writi<br>iting 0xA32C is to e<br>DT Interrupt conditio<br>is bit can't invoke N<br>Not occurred<br>Event occurred<br>CLK Fail condition s<br>is bit can't invoke N | enabl<br>on sta<br>MI ir<br>tatus | e wri<br>atus<br>iterru | iting.<br>bit<br>ıpt w | itho  | ut er | nable |     |   |          |            |       |
|                      |    |                                        | 0                               | Not occurred<br>Event occurred                                                                                                                                                      |                                   | lient                   | ipt w                  |       |       |       | DIL |   |          |            |       |
| 8                    |    | LVRSTS                                 |                                 | R condition status b<br>s bit can't invoke N<br>Not occurred<br>Event occurred                                                                                                      | MI ir                             | iterru                  | ıpt w                  | ritho | ut er | nable | bit |   |          |            |       |
| 2                    |    | WDTINTEN                               | WE<br>0<br>1                    | DT Interrupt condition<br>Disable<br>Enable                                                                                                                                         | on er                             | able                    | for I                  | NMI   | inte  | rrupt |     |   |          |            |       |

0

1

0

1

Disable

Enable

Disable

Enable

MCLK Fail condition enable for NMI interrupt

LVR Fail condition enable for NMI interrupt

SCU\_NMIR=0x4000\_004C



1

0

MCLKFAILEN

LVREN

# 4.6.21 SCU\_COR: clock output register

A31G32x series can drive a clock from internal MCLK clock with a dedicated post divider. To use CLKO output function, it should be set as CLKO that has output mode in PF0 Pin Mux. SCU\_COR register is an 8-bit register.

# SCU\_COR=0x4000\_0050

| 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 3 22 | 21 | 20 | 19 | 18   | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4      | 3 | 2   | 1   | 0 |
|---|----|----|----|----|----|----|----|----|------|----|----|----|------|-----|----|----|----|----|----|----|----|---|---|---|---|---|--------|---|-----|-----|---|
|   |    |    |    |    |    |    |    |    |      |    |    | Re | serv | ved |    |    |    |    |    |    |    |   |   |   |   |   | CLKOEN | С | CLK | וסכ | V |
|   |    |    |    |    |    |    |    |    |      |    |    |    | -    |     |    |    |    |    |    |    |    |   |   |   |   |   | 0      |   | 11  | 11  |   |
|   |    |    |    |    |    |    |    |    |      |    |    |    | •    |     |    |    |    |    |    |    |    |   |   |   |   |   | RW     |   | R   | W   |   |

| 4      | CLKOEN  | Clock output enable                                    |
|--------|---------|--------------------------------------------------------|
|        |         | 0 CLKO is disabled and stay "L" output                 |
|        |         | 1 CLKO Is enabled                                      |
| 3<br>0 | CLKODIV | Clock output divider value                             |
| Ū      |         | CLKO = MCLK ( $CLKODIV = 0$ )                          |
|        |         | $CLKO = \frac{MCLK}{2 * (CLKODIV + 1)}  (CLKODIV > 0)$ |



#### SCU\_PLLCON: PLL control register 4.6.22

Integrated PLL will synthesize high speed clock for extremely high performance of CPU. The PLL is controlled by setting the register. PLL Control Register is 32-bit register.

| 31      | 30 29 | 28 2 | 7 26  | 25 | 24 | 23      | 22    | 21      | 20 19    | 18 17 | 16     | 15 | 14 | 13 | 12  | 11   | 10 | 9 | 8 | 7 | 6   | 5    | 4  | 3 | 2   | 1   | 0 |
|---------|-------|------|-------|----|----|---------|-------|---------|----------|-------|--------|----|----|----|-----|------|----|---|---|---|-----|------|----|---|-----|-----|---|
| PLLLOCK |       | Rese | erved |    |    | PLLRSTB | PLLEN | BYPASSB | Reserved | PREI  | JIV    |    |    | PC | SSI | [RI\ | /1 |   |   | P | SSI | ۲DIN | √2 | C | JUT | DIV | / |
| 0       |       | -    |       |    |    | 0       | 0     | 0       | -        | 00    | כ<br>כ |    |    | 0  | 000 | 000  | 0  |   |   |   | 00  | 00   |    |   | 000 | 00  |   |
| RO      |       |      |       |    |    | RW      | RW    | RW      | -        | RW    |        |    |    |    | R   | W    |    |   |   |   | R   | W    |    |   | RV  | V   |   |

| Reserved | PLLR | PLLI | ВҮРА | Resel | PREDIV | POSTRIV1          | POSTDIV2 | OUTDIV |
|----------|------|------|------|-------|--------|-------------------|----------|--------|
| -        | 0    | 0    | 0    | -     | 000    | 0000000           | 0000     | 0000   |
|          | RW   | RW   | RW   | -     | RW     | RW                | RW       | RW     |
|          |      |      |      |       |        |                   |          |        |
| 31       | Ρ    | LLLC | CK   |       | PLLI   | _OCK status       |          |        |
|          |      |      |      |       | 0      | PLL is not locked |          |        |

| 51   | FLLLOCK  | FLELOCK Status                                                   |
|------|----------|------------------------------------------------------------------|
|      |          | 0 PLL is not locked                                              |
|      |          | 1 PLL is locked                                                  |
| 23   | PLLRSTB  | PLL reset                                                        |
|      |          | 0 PLL reset is asserted                                          |
|      |          | 1 PLL reset is negated                                           |
| 22   | PLLEN    | PLL enable                                                       |
|      |          | 0 PLL is disabled                                                |
|      |          | 1 PLL is enabled                                                 |
| 21   | BYPASSB  | PLLINCLK bypass                                                  |
|      |          | 0 FOUT is bypassed as PLLINCLK                                   |
|      |          | 1 FOUT is PLL output                                             |
| 18   | PREDIV   | PLLINCLK predivider (R)                                          |
| 16   |          | 0~7 PLLINCLK divided by (PREDIV + 1), (PLLINCLK/1 to PLLINCLK/8) |
| 15   | POSTDIV1 | Feedback control 1 (N1)                                          |
| 8    |          | 0x00 N1 = 0 (N1 + 1)                                             |
|      |          | 0xFF N1 = 255 (N1 + 1)                                           |
| 7    | POSTDIV2 | Feedback control 2 (N2)                                          |
| 4    |          | 0x0 N2 = 0 (N2 + 1)                                              |
|      |          | 0xF N2 = 15 (N2 + 1)                                             |
| 3    | OUTDIV   | Output divider control (P)                                       |
| 0    |          | 0x0 P = 0 (P+1)                                                  |
|      |          | 0xF P = 15 (P+1)                                                 |
| NOTE |          |                                                                  |

#### NOTES:

Bit 20 of PLLCON must be kept at 0.

When PLLEN is set to '1', PLLRSTB is set to '1' and PLL Divider count after at least 1us. Wait more than 190us for PLL Lock Time, then check the PLL Lock flag(Bit 31). At power down(Stop/Standby) mode, set PLLRSTB to '0', PLLEN to '0' Bits of OUTDIV is not recommended to set to '1'.

Output calculat

| ation form | nula is as fol | PLLINCLK $\times$ (N <sub>1</sub> + 1)                                       |
|------------|----------------|------------------------------------------------------------------------------|
| -          | 1 01           | $J_{T} = \frac{(R+1) \times (N_2 + 1) \times (P + 1)}{(R+1) \times (P + 1)}$ |
|            | R              | Pre Divider Counter Value                                                    |
|            | N <sub>1</sub> | Post Divider1 Counter Value                                                  |
|            | N <sub>2</sub> | Post Divider2 Counter Value                                                  |
|            | Р              | Output Divider Counter Value                                                 |



# Calculating PLL output frequency value

PLL of A31G32x series can accurately set the output frequency,  $F_{OUT}$ , in 1MHz increments. The formula for the  $F_{IN}$  input to the  $F_{VCO}$  input of the PLL is as follows, and the input range of the  $F_{IN}$  frequency is between 1MHz and 3MHz. However, it is recommended to set the input frequency (FIN) to 2MHz as much as possible.

$$FIN = \frac{PLLINCLK}{(R+1)}$$
, Where  $1MHz \le FIN \le 3MHz$  (Recommanded  $FIN = 2MHz$ )

At this time, the range of  $F_{VCO}$  output frequency should be set to 288MHz or less, and the calculation formula is as follows.

$$F_{VCO} = FIN \times (N_1 + 1), VCO \le 288MHz$$

As a result, the final frequency of PLL, F<sub>OUT</sub>, can be obtained from the formula below using the formula above.

$$F_{OUT} = \frac{PLLINCLK \times (N_1 + 1)}{(R + 1) \times (N_2 + 1) \times (P + 1)} = \frac{FIN \times (N_1 + 1)}{(N_2 + 1) \times (P + 1)}$$



# 4.6.23 SCU\_VDCCON: VDC control register

On chip VDC control register. VDCTRIM is used for the trim value of VDC output. VDCWDLY value can be written with writing '1' to VDCWDLY\_WEN bit simultaneously.

|    |                     |    |             |            |              |            |    |              |    |          |            |    |    |    |          |    |    |    |    | S        | cu_         | VD | cc | ON | =0> | (400 | 00_ | 00 | 64 |
|----|---------------------|----|-------------|------------|--------------|------------|----|--------------|----|----------|------------|----|----|----|----------|----|----|----|----|----------|-------------|----|----|----|-----|------|-----|----|----|
| 31 | 30 29               | 28 | 27          | 26         | 25           | 24         | 23 | 22 21        | 20 | 19       | 18         | 17 | 16 | 15 | 14       | 13 | 12 | 11 | 10 | 9        | 8           | 7  | 6  | 5  | 4   | 3    | 2   | 1  | 0  |
|    | <b>VDC33 WTIDKY</b> |    | VDC33_PDBGR | VDC33_STOP | VDC33_BYPSBS | VDC33_LOCK |    | VDC15 WTIDKY |    | Reserved | VDC15_STBY |    |    |    | Recented |    |    |    |    | VDC33_PD | VDCWDLY_WEN |    |    |    |     |      |     |    |    |
|    | 0000                |    | 0           | 1          | 0            | 0          |    | 0000         |    | -        | 0          |    |    |    | -        |    |    |    |    | 0        | 0           |    |    |    | 0x  | 7F   |     |    |    |
|    | WO                  |    | RW          | RW         | RW           | RW         |    | WO           |    | -        | RW         |    |    |    |          |    |    |    |    | RW       | WO          |    |    |    | R   | N    |     |    |    |

| 31<br>28 | VDC33 WTIDKY             | VDC33 Write Identification Key<br>On writes, write 0xA to these bits, otherwise the write is ignored.                                                                                                                    |
|----------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27       | VDC33_PDBGR              | VDC33 BGR Power Down Signal                                                                                                                                                                                              |
|          |                          | 0 BGR Alive                                                                                                                                                                                                              |
|          |                          | 1 BGR Power Down                                                                                                                                                                                                         |
| 26       | VDC33_STOP               | VDC33 STOP Mode Enable Signal                                                                                                                                                                                            |
|          |                          | 0 RUN mode                                                                                                                                                                                                               |
|          |                          | 1 STOP mode                                                                                                                                                                                                              |
| 25       | VDC33_BYPASS             | VDC33 Bypass Mode Enable Signal                                                                                                                                                                                          |
|          |                          | 0 5V Bypass Enable                                                                                                                                                                                                       |
|          |                          | 1 Disable                                                                                                                                                                                                                |
| 24       | VDC33_LOCK               | VDC Control signal for *BGR stabilization                                                                                                                                                                                |
|          |                          | 0 Select BMR when BGR off                                                                                                                                                                                                |
|          |                          | 1 Select BGR after stabilization time when BGR is on                                                                                                                                                                     |
| 23<br>20 | VDC15 WTIDKY             | VDC15 Write Identification Key<br>On writes, write 0x5 to these bits, otherwise the write is ignored.                                                                                                                    |
| 18       | VDC15_STBY               | Power down mode selection signal when CPU enters deepsleep<br>mode                                                                                                                                                       |
|          |                          | 0 Stop Mode                                                                                                                                                                                                              |
|          |                          | 1 Standby Mode                                                                                                                                                                                                           |
| 9        | VDC33_PD                 | VDC33 Power Down Signal                                                                                                                                                                                                  |
|          |                          | 0 VDC33 is not Power Down Mode                                                                                                                                                                                           |
|          |                          | 1 VDC33 is Power Down Mode                                                                                                                                                                                               |
| 8        | VDCWDLY_WEN              | VDCWDLY value write enable. VDCWDLY value can be written with<br>writing '1' to VDCWDLY_WEN bit simultaneously.                                                                                                          |
| 7<br>0   | VDCWDLY                  | VDC warm-up delay count value.<br>When SCU is waked up from power down mode, the warm-up dela<br>is inserted for VDC output being stabilized.<br>The amount of delay can be defined with this register value 7F<br>4msec |
| NOTE     | : Reserved bits should n | ever be modified.                                                                                                                                                                                                        |



| _      | VDC33_PDBGR | VDC33_STOP | VDC33_BYPSB | VDC33_LOCK | VDC33_PD | Output   |
|--------|-------------|------------|-------------|------------|----------|----------|
| RUN    | 0           | 0          | 1           | 1          | 0        | 3.3V     |
| STOP   | 1           | 1          | 1           | 0          | 0        | 3.3V     |
| BYPASS | 1           | х          | 0           | 0          | 0        | VDD      |
| PD     | 1           | 0          | 1           | x          | 1        | Floating |

# Table 23. VDC33 Mode Description

NOTES:

1. In power down mode, VDC33 must be configured in STOP or BYPASS mode to reduce current consumption.

2. When supplying external power 3.3V to USB, VDC33 must be configured in PD mode.

3. When VDC33 BGR is used as a single ended receiver hysteresis reference voltage in VDC33 PD mode, PDBGR should be set to 1.

# 4.6.24 SCU\_PDRCON: PDR control register

#### SCU\_VDCCON=0x4000\_0064

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 | 11 10 9 8        | 7     | 6 5 | 54  | 3 2   | 1 0 |
|-------------------------------------------------------------|------------------|-------|-----|-----|-------|-----|
| Reserved                                                    | PDRCON<br>WTIDKY | PDREN |     | Res | erved |     |
| -                                                           | 0x0              | 0     |     |     | -     |     |
|                                                             | WO               | RW    |     |     |       |     |

| 11<br>8 | PDRCON WTIDKY | PDRCON Write Identification Key<br>On writes, write 0xA to these bits, otherwise the write is ignored. |
|---------|---------------|--------------------------------------------------------------------------------------------------------|
| 7       | PDREN         | PDR Enable                                                                                             |
|         |               | 0 PDR Disable                                                                                          |
|         |               | 1 PDR Enable                                                                                           |

NOTE:

1. When using the backup power mode, disable LVR (SCU\_LVRCR, SCU\_LVRCNFIG) and LVR reset (SCU\_RSER).



SCU LSICON=0x4000 006C

#### SUL I SICONI I . . . . . . 4.6.25

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 2 | 23 | 22 | 21 | 20 | 19 | 18 | 3 17 | 71  | 6 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0    |
|----|----|----|----|----|----|----|----|---|----|----|----|----|----|----|------|-----|------|----|----|----|----|----|---|---|---|---|---|---|---|---|--------|------|
|    |    |    |    |    |    |    |    |   |    |    |    |    |    | I  | Res  | er\ | /ed  |    |    |    |    |    |   |   |   |   |   |   |   |   | EN_LDO | SKIP |
|    |    |    |    |    |    |    |    |   |    |    |    |    |    |    |      | -   |      |    |    |    |    |    |   |   |   |   |   |   |   |   | 0      | 1    |
|    |    |    |    |    |    |    |    |   |    |    |    |    |    |    |      | -   |      |    |    |    |    |    |   |   |   |   |   |   |   |   | RW     | RW   |

| 25 | SCU_LSICON: Low sp | eed internal OSC | control register |
|----|--------------------|------------------|------------------|
|    |                    |                  |                  |

| 1 | EN_LDO  | Internal LDO On/Off                   |
|---|---------|---------------------------------------|
|   |         | 0 Disable                             |
|   |         | 1 Enable                              |
| 0 | SKIP_LS | Internal Level Shifter control signal |
|   |         | 0 Enable                              |
|   |         | 1 Disable                             |

#### 4.6.26 SCU\_EOSCR: External oscillator control register

External main crystal oscillator has two characteristics. For the noise immunity, NMOS amp type is recommended and for the low power characteristic, INV amp type is recommended. SCU\_EOSCR register is a 16-bit register.

#### SCU\_EOSCR=0x4000\_0080

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 | 7 16 1 | 15 14 | 4 13 12 | 11 10 9  | 8     | 7    | 6        | 54   | 32    | 1        | 0      |
|----------------------------------------------|--------|-------|---------|----------|-------|------|----------|------|-------|----------|--------|
| Reserved                                     |        | ESEN  | ESISEL  | Reserved | ESSMT | EMEN | Reserved | ISEL | NCOPT | Reserved | NCSKIP |
| -                                            |        | 0 -   | 01      | -        | 0     | 0    | -        | 01   | 01    | -        | 0      |
|                                              |        | W -   | RW      | -        | RW    | W    | -        | RW   | RW    | -        | RW     |

| 15 | ESEN   | Write enable for External LSE   |
|----|--------|---------------------------------|
| 15 | ESEN   | While enable for External LSE   |
|    |        | 0 Write access disabled         |
|    |        | 1 Write access enabled          |
| 13 | ESISEL | Select current for External LSE |
| 12 |        | 00 High                         |
|    |        | 01 Mid-High (default)           |
|    |        | 10 Mid-Low                      |
|    |        | 11 Low                          |
| 8  | ESSMT  | Select Schmitt trigger          |
|    |        | 0 Schmitt trigger bypass        |
|    |        | 1 Schmitt trigger turn on       |



| 7 | EMEN   | Write enable for External HSE                                                                                                                                                 |
|---|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |        | 0 Write access disabled                                                                                                                                                       |
|   |        | 1 Write access enabled                                                                                                                                                        |
| 5 | ISE    | Select current for External HSE                                                                                                                                               |
| 4 |        | 00 High                                                                                                                                                                       |
|   |        | 01 Mid-High (default)                                                                                                                                                         |
|   |        | 10 Mid-Low                                                                                                                                                                    |
|   |        | 11 Low                                                                                                                                                                        |
| 3 | NCOPT  | Noise Cancel delay Option for External HSE                                                                                                                                    |
| 2 |        | <ul> <li>25ns (12MHz &lt; HSE &lt; 16MHz)</li> <li>20ns (8MHz &lt; HSE &lt; 12MHz)</li> <li>15ns (4MHz &lt; HSE &lt; 8MHz)</li> <li>10ns (2MHz &lt; HSE &lt; 4MHz)</li> </ul> |
| 0 | NCSKIP | Noise Cancel SKIP enable for External HSE                                                                                                                                     |
|   |        | 0 Disable                                                                                                                                                                     |
|   |        | 1 Enable (Noise Cancel skipped)                                                                                                                                               |

# 4.6.27 SCU\_EMODR: External mode status register

SCU\_EMODR register shows external mode pin status while booting. This register is an 8-bit register.

|                         |                            |                |    | _  |   |     |    | — |      |
|-------------------------|----------------------------|----------------|----|----|---|-----|----|---|------|
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 | 14 13 12 11 10 | 98 | 76 | 5 | 4 3 | 32 | 1 | 0    |
|                         | Reserved                   |                |    |    |   |     |    |   | BOOT |
|                         | -                          |                |    |    |   |     |    |   | -    |
|                         |                            |                |    |    |   |     |    |   | R    |
|                         |                            |                |    |    |   |     |    |   |      |

#### SCU\_EMODR=0x4000\_0084

| 0 | BOOT | BOOT pin level     |
|---|------|--------------------|
|   |      | 0 BOOT pin is low  |
|   |      | 1 BOOT pin is high |



# 4.6.28 SCU\_RSTDBCR: pin reset debounce control register

## SCU\_RSTDBCR=0x4000\_0088

|                                                 |          |                 | —           | _   |
|-------------------------------------------------|----------|-----------------|-------------|-----|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 5 15 14  | 13 12 11 10 9 8 | 7 6 5 4 3 2 | 1 0 |
| WTIDKY                                          | Reserved | CLKCNT          | Reserved    | EN  |
| 0x0000                                          | -        | 0x00            | -           | 0   |
| WO                                              | -        | RW              | -           | RW  |

| 31   | WTIDKY | Write Identification Key                                                                              |  |  |  |  |  |  |  |  |
|------|--------|-------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 16   |        | On writes, write 0x0514 to these bits, otherwise the write is ignored.                                |  |  |  |  |  |  |  |  |
| 13   | CLKCNT | Noise Cancel delay Option for LSI 750kHz                                                              |  |  |  |  |  |  |  |  |
| 8    |        | N N clock checking for debounce by LSI (750kHz)                                                       |  |  |  |  |  |  |  |  |
| 0    | EN     | Pin reset debounce enable bit                                                                         |  |  |  |  |  |  |  |  |
|      |        | 0 Disable                                                                                             |  |  |  |  |  |  |  |  |
|      |        | 1 Enable                                                                                              |  |  |  |  |  |  |  |  |
| NOTE |        | If a user wants to operate pi<br>st enable LSI (750kHz). Because pin reset debource uses LSI for cloc |  |  |  |  |  |  |  |  |

reset debounce, the user must enable LSI (750kHz). Because pin reset debounce uses LSI for clock source.

The port debounce should be disabled before Power Down mode.



# 4.6.29 SCU\_MCCR1: Miscellaneous clock control register 1

A31G32x series can drive a clock from internal MCLK clock with dedicated post divider. STCSEL bits and STCDIV bits of MCCR1 are used as SYSTICK external clock source. TEXT1CSEL bits and TEXT1DIV bits of SCU\_MCCR1 are used as TIMER1n external clock source. Register SCU\_MCCR1 is a 32-bit register.

| SCU | MCCR | 1=0x4000 | 0090 |
|-----|------|----------|------|
|     |      |          |      |

| 3 | 1 | 30 | 29   | ) 2 | 28 | 27 | 7 | 26 | 2  | 5  | 24 | 2 | 3 2 | 22 | 21 | 20 | 1              | 9  | 18 | 17 | 1( | 6 | 15 | 14 | 13  | 3  | 12 | 11 | 10 | 9  | 8   | 7 | 6 | 5 | ;  | 4   | 3   | 2   | 1 | 0 |
|---|---|----|------|-----|----|----|---|----|----|----|----|---|-----|----|----|----|----------------|----|----|----|----|---|----|----|-----|----|----|----|----|----|-----|---|---|---|----|-----|-----|-----|---|---|
|   |   | Re | esei | rve | ∍d |    | Т | Ē× | (T | 1C | SE | L |     |    | т  | EX | T1             | DI | V  |    |    |   |    | Re | sei | rv | ed |    | ST | CS | SEL |   |   | S | YS | STI | СКІ | JIV |   |   |
|   |   |    | -    |     |    |    |   |    | 0: | x0 |    |   |     |    |    | 0) | <b>&lt;</b> 00 | )  |    |    |    |   |    |    | -   |    |    |    |    | 0x | C   |   |   |   |    | 0x  | 00  |     |   |   |
|   |   |    | -    |     |    |    |   |    | R  | W  |    |   |     |    |    |    | RW             |    |    |    |    |   |    |    | •   |    |    |    |    | RW |     |   |   |   |    | R   | N   |     |   |   |

| 26 | TEXT1CSEL | TIMER1n EXT Clock source select bit                          |    |
|----|-----------|--------------------------------------------------------------|----|
| 24 |           | 0xx LSI 750kHz                                               |    |
|    |           | 011 LSE(32kHz)                                               |    |
|    |           | 100 MCLK ( bus clock )                                       |    |
|    |           | 101 HSI 48MHz                                                |    |
|    |           | 110 HSE                                                      |    |
|    |           | 111 PLL Clock                                                |    |
| 23 | TEXT1DIV  | TIMER1n EXT Clock N divider                                  |    |
| 16 |           | 8'h0 disabled                                                |    |
|    |           | 8'hN (selected clock) / N                                    |    |
|    |           | To change the value, set 0x0 first without changing TEXT1CSE | EL |
| 10 | STCSEL    | SYSTIC Clock source select bit                               |    |
| 8  |           | 0xx LSI 750kHz                                               |    |
|    |           | 011 LSE(32kHz)                                               |    |
|    |           | 100 MCLK ( bus clock )                                       |    |
|    |           | 101 HSI 48MHz                                                |    |
|    |           | 110 HSE                                                      |    |
|    |           | 111 PLL Clock                                                |    |
| 7  | STDIV     | SYSTICK Clock N divider                                      |    |
| 0  |           | 8'h0 disabled                                                |    |
|    |           | 8'hN (selected clock) / N                                    |    |
|    |           | To change the value, set 0x0 first without changing STCSEL.  |    |



### 4.6.30 SCU\_MCCR2: Miscellaneous clock control register 2

A31G32x series can drive a clock from internal MCLK clock with a dedicated post divider. TEXT2CSEL bits and TEXT2DIV bits of MCCR2 are used as a TIMER20 external clock source. TEXT3CSEL bits and TEXT3DIV bits of SCU\_MCCR2 are used as a TIMER30 external clock source. Register SCU\_MCCR2 is a 32-bit register.

#### SCU\_MCCR2=0x4000\_0094

| 31 30 29 28 2 | 7 26 25 24 | 23 22 21 20 19 18 17 16 | 15 14 13 12 11 | 10 9 8     | 7 6 5 4 3 2 1 0 |
|---------------|------------|-------------------------|----------------|------------|-----------------|
| Reserved      | TEXT3CSEL  | TEXT3DIV                | Reserved       | TEXT20CSEL | TEXT20DIV       |
| -             | 0x0        | 0x00                    | -              | 0x0        | 0x00            |
| -             | RW         | RW                      | •              | RW         | RW              |

| 26 | TEXT3CSEL  | TIMER   | 30 EXT Clock source select bit                           |
|----|------------|---------|----------------------------------------------------------|
| 24 |            | 0xx     | LSI 750kHz                                               |
|    |            | 011     | LSE(32kHz)                                               |
|    |            | 100     | MCLK ( bus clock )                                       |
|    |            | 101     | HSI 48MHz                                                |
|    |            | 110     | HSE                                                      |
|    |            | 111     | PLL Clock                                                |
| 23 | TEXT3DIV   | TIMER   | 30 EXT Clock N divider                                   |
| 16 |            | 8'h0    | disabled                                                 |
|    |            | 8'hN    | (selected clock) / N                                     |
|    |            | To chan | ge the value, set 0x0 first without changing TEXT3DIV    |
| 10 | TEXT20CSEL | TIMER 2 | 20 EXT Clock source select bit                           |
| 8  |            | 0xx     | LSI 750kHz                                               |
|    |            | 011     | LSE(32kHz)                                               |
|    |            | 100     | MCLK ( bus clock )                                       |
|    |            | 101     | HSI 48MHz                                                |
|    |            | 110     | HSE                                                      |
|    |            | 111     | PLL Clock                                                |
| 7  | TEXT20DIV  | TIMER 2 | 20 EXT Clock N divider                                   |
| 0  |            | 8'h0    | disabled                                                 |
|    |            | 8'hN    | (selected clock)/N                                       |
|    |            | To chan | ge the value, set 0x0 first without changing TEXT20CSEL. |



# 4.6.31 SCU\_MCCR3: Miscellaneous clock control register 3

A31G32x series can drive a clock from an internal MCLK clock with a dedicated post divider. WDTCSEL bits and WDTDIV bits of a MCCR3 are used as WDT external clock source. WTEXTCSEL bits and WTEXTCDIV bits of SCU\_MCCR3 are used as a WT external clock source. This register is a 32-bit register.

| SCU | MCCR3=0x4000 | 0098  |
|-----|--------------|-------|
| 000 |              | _0000 |

| 31 | 30 | 29   | 28  | 27 | 26  | 25   | 24  | 23 | 22 | 21 | 20 | 19  | 18  | 17 | 16 | 15 | 14   | 13   | 12 | 11       | 10 | 9   | 8   | 7      | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|----|----|------|-----|----|-----|------|-----|----|----|----|----|-----|-----|----|----|----|------|------|----|----------|----|-----|-----|--------|---|---|----|----|---|---|---|
|    | Re | serv | red |    | WTE | EXTC | SEL |    |    | WT | ΈX | TCI | JIV |    |    | F  | lese | erve | ed | LSI40kHz | WD | TCS | SEL | WDTDIV |   |   |    |    |   |   |   |
|    |    |      |     |    |     | 0x0  |     |    |    |    | 0x | 00  |     |    |    |    |      |      |    | 0        |    | 0x0 |     |        |   |   | 0x | 00 |   |   |   |
|    |    |      |     |    |     | RW   |     |    |    |    | R  | W   |     |    |    |    |      |      |    | RW       |    | RW  |     |        |   |   | R  | N  |   |   |   |

| 26 | WTEXTCSEL | WT Exte  | rnal Clock source select bit                           |
|----|-----------|----------|--------------------------------------------------------|
| 24 |           | 0xx      | LSI 750kHz                                             |
|    |           | 011      | LSE (32kHz)                                            |
|    |           | 100      | MCLK ( bus clock )                                     |
|    |           | 101      | HSI 48MHz                                              |
|    |           | 110      | HSE                                                    |
|    |           | 111      | PLL Clock                                              |
| 23 | WTEXTCDIV | WT Exte  | rnal Clock N divider                                   |
| 16 |           | 8'h0     | disabled                                               |
|    |           | 8'hN     | (selected clock) / N                                   |
|    |           | To chang | ge the value, set 0x0 first without changing WTEXTCSEL |
| 11 | LSI40kHz  | LSI40kH  | z Enable                                               |
|    |           | 0        | Disable                                                |
|    |           | 1        | Enable                                                 |
| 10 | WDTCSEL   | WDT Clo  | ock source select bit                                  |
| 8  |           | 0xx      | LSI 750kHz                                             |
|    |           | 011      | LSE(32kHz)                                             |
|    |           | 100      | MCLK ( bus clock )                                     |
|    |           | 101      | HSI 48MHz                                              |
|    |           | 110      | HSE                                                    |
|    |           | 111      | PLL Clock                                              |
| 7  | WDTDIV    | WDT Clo  | ock N divider                                          |
| 0  |           | 8'h0     | disabled                                               |
|    |           | 8'hN     | ( selected clock ) / N                                 |
|    |           | To chan  | ge the value, set 0x0 first without changing WDTCSEL.  |



# 4.6.32 SCU\_MCCR4: Miscellaneous clock control register 4

A31G32x series can drive a clock from an internal MCLK clock with a dedicated post divider. PD0CSEL bits and PD0DIV bits of SCU\_MCCR4 are used as PA, PB, PC, PF Debounce Clock source. This register is a 32-bit register.

#### SCU\_MCCR4=0x4000\_009C

|                                                                |         | • • • • • <b>-</b> • • • |
|----------------------------------------------------------------|---------|--------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 | 10 9 8  | 7 6 5 4 3 2 1 0          |
| Reserved                                                       | PD0CSEL | PD0DIV                   |
| -                                                              | 0x0     | 0x00                     |
|                                                                | RW      | RW                       |

| 10 | PD0CSEL | Debounce Clock for PORT source select bit (PA,PB,PC,PF)      |
|----|---------|--------------------------------------------------------------|
| 8  |         | 0xx LSI 750kHz                                               |
|    |         | 011 LSE(32kHz)                                               |
|    |         | 100 MCLK (bus clock)                                         |
|    |         | 101 HSI 48MHz                                                |
|    |         | 110 HSE                                                      |
|    |         | 111 PLL Clock                                                |
| 7  | PD0DIV  | PORT Debounce Clock N divider (PA,PB,PC,PF)                  |
| 0  |         | 8'h0 disabled                                                |
|    |         | 8'hN (selected clock) / N                                    |
|    |         | To change the value, set 0x0 first without changing PD0CSEL. |



# 4.6.33 SCU\_MCCR5: Miscellaneous clock control register 5

A31G32x series can drive a clock from an internal MCLK clock with a dedicated post divider. PD0CSEL bits and PD0DIV bits of MCCR5 are used as PA, PB, PC Debounce Clock source. USBCSEL bits and USBCDIV bits of MCCR5 are used as a USB Clock source. This register is a 32-bit register.

# SCU\_MCCR5=0x4000\_00A0

| 31 | 30 29 | 28  | 27 | 26 | 6 25    | 24 | 23 | 22 | 21 | 20  | 19  | 18 | 17 | 16          | 15 14        | 13 12          | 2 11      | ' | 10 | 9       | 8 | 7 | 6 | 5 | 4   | 3   | 2 | 1 | 0 |
|----|-------|-----|----|----|---------|----|----|----|----|-----|-----|----|----|-------------|--------------|----------------|-----------|---|----|---------|---|---|---|---|-----|-----|---|---|---|
|    | Reser | ved |    |    | USBCSEL |    |    |    | Re | ser | ved |    |    | USBEXTCLKEN | TSREFCLK_SEL | TSSENSECLK_SEL | I SITS FN |   |    | RTCCSEL |   |   |   | F | RTC | DI∿ | / |   |   |
|    | -     |     |    |    | 0x0     | )  |    |    |    | -   |     |    |    |             | 0x0          | 0x0            |           |   | C  | )x0     |   |   |   |   | 0x  | 00  |   |   |   |
|    | •     |     |    |    | RW      |    |    |    |    | -   |     |    |    | RW          | RW           | RW             | RW        | 1 |    | RW      |   |   |   |   | R   | W   |   |   |   |

| 26       | USBCSEL        | USB C   | lock source select bit                                                                                                  |
|----------|----------------|---------|-------------------------------------------------------------------------------------------------------------------------|
| 24       |                | 0xx     | Reserved                                                                                                                |
|          |                | 100     | MCLK ( bus clock )                                                                                                      |
|          |                | 101     | HSI 48MHz                                                                                                               |
|          |                | 110     | Reserved                                                                                                                |
|          |                | 111     | PLL Clock                                                                                                               |
| 16       | USBEXTCLKEN    | USB E   | xternal clock enable                                                                                                    |
|          |                | 0       | Disable                                                                                                                 |
|          |                | 1       | Enable                                                                                                                  |
|          |                | To cha  | inge the value, set 0x0 first without changing USBCSEL                                                                  |
| 15<br>14 | TSREFCLK_SEL   | Note) \ | Sensor Reference clock select bit<br>When reference clock is sub-osc, reference and sense clock<br>anged to each other. |
|          |                | 00      | HSI_I (Output clock set by CSCR from HSI)                                                                               |
|          |                | 01      | MCLK                                                                                                                    |
|          |                | 10      | HSE                                                                                                                     |
|          |                | 11      | LSE                                                                                                                     |
| 13       | TSSENSECLK_SEL | Temp    | Sensor Sense clock select bit                                                                                           |
| 12       |                | 00      | LSITS                                                                                                                   |
|          |                | 01      | LSI750kHz                                                                                                               |
|          |                | 10      | LSI40kHz                                                                                                                |
|          |                | 11      | HSI_I (Output clock set by CSCR from HSI)                                                                               |
| 11       | LSITS_EN       | LSITS   | Enable                                                                                                                  |
|          |                | 0       | Disable                                                                                                                 |
|          |                | 1       | Enable                                                                                                                  |
| 10       | RTCCSEL        | RTC C   | lock source select bit                                                                                                  |
| 8        |                | 0xx     | LSI 750kHz                                                                                                              |
|          |                | 011     | LSE (32kHz)                                                                                                             |
|          |                | 100     | MCLK ( bus clock )                                                                                                      |
|          |                | 101     | HSI 48MHz                                                                                                               |
|          |                | 110     | HSE                                                                                                                     |
|          |                | 111     | PLL Clock                                                                                                               |



| 7 | RTCDIV | RTC Clock N divider        |  |
|---|--------|----------------------------|--|
| 0 |        | 8'h0 disabled              |  |
|   |        | 8'hN (selected clock ) / N |  |

# 4.6.34 SCU\_MCCR6: Miscellaneous clock control register 6

A31G32x series can drive a clock from an internal MCLK clock with a dedicated post divider. TEXT21CSEL bits and TEXT21DIV bits of MCCR6 are used as a TIMER21 external clock source. TEXT4CSEL bits and TEXT4DIV bits of SCU\_MCCR6 are used as a TIMER40 external clock source. This register is a 32-bit register.

|                |            |                         |                | 000        |                 |
|----------------|------------|-------------------------|----------------|------------|-----------------|
| 31 30 29 28 27 | 26 25 24   | 23 22 21 20 19 18 17 16 | 15 14 13 12 11 | 10 9 8     | 7 6 5 4 3 2 1 0 |
| Reserved       | TEXT21CSEL | TEXT21DIV               | Reserved       | TEXT40CSEL | TEXT40DIV       |
| -              | 0x0        | 0x00                    | -              | 0x0        | 0x00            |
| -              | RW         | RW                      | -              | RW         | RW              |

| 26 | TEXT21CSEL | TIMER 21 EXT Clock source select bit                   |          |
|----|------------|--------------------------------------------------------|----------|
| 24 |            | 0xx LSI 750kHz                                         |          |
|    |            | 011 LSE(32kHz)                                         |          |
|    |            | 100 MCLK ( bus clock )                                 |          |
|    |            | 101 HSI 48MHz                                          |          |
|    |            | 110 HSE                                                |          |
|    |            | 111 PLL Clock                                          |          |
| 23 | TEXT21DIV  | TIMER 21 EXT Clock N divider                           |          |
| 16 |            | 8'h0 disabled                                          |          |
|    |            | 8'hN (selected clock) / N                              |          |
|    |            | To change the value, set 0x0 first without changing TE | XT2DIV   |
| 10 | TEXT4CSEL  | TIMER 40 EXT Clock source select bit                   |          |
| 8  |            | 0xx LSI 750kHz                                         |          |
|    |            | 011 LSE(32kHz)                                         |          |
|    |            | 100 MCLK ( bus clock )                                 |          |
|    |            | 101 HSI 48MHz                                          |          |
|    |            | 110 HSE                                                |          |
|    |            | 111 PLL Clock                                          |          |
| 7  | TEXT4DIV   | TIMER 40 EXT Clock N divider                           |          |
| 0  |            | 8'h0 disabled                                          |          |
|    |            | 8'hN (selected clock) / N                              |          |
|    |            | To change the value, set 0x0 first without changing TE | XT40CSEL |



# SCU\_MCCR2=0x4000\_00A4

# 4.6.35 SCULV\_LVICR: Low voltage indicator control register

SCULV\_LVICR is a 32-bit register, and available at 32/16/8-bit access.

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7     | 6        | 5       | 4       | 3 2 1 0 |
|-----------------------------------------------------------------------|-------|----------|---------|---------|---------|
| Reserved                                                              | LVIEN | Reserved | LVINTEN | LVIFLAG | LVIVS   |
| -                                                                     | 0     | -        | 0       | 0       | 0000    |
|                                                                       | RW    | •        | RW      | RW      | RW      |

| 7 | LVIEN   | LVI Enab   | le bit.                                                      |
|---|---------|------------|--------------------------------------------------------------|
|   |         | 0          | Disable low voltage indicator.                               |
|   |         | 1          | Enable low voltage indicator.                                |
| 5 | LVINTEN | LVI Interr | upt Enable bit.                                              |
|   |         | 0          | Disable low voltage indicator interrupt.                     |
|   |         | 1          | Enable low voltage indicator interrupt.                      |
| 4 | LVIFLAG | LVI Interr | upt Flag bit.                                                |
|   |         | 0          | No request occurred.                                         |
|   |         | 1          | Request occurred, This bit is cleared to '0' when write '1'. |
| 3 | LVIVS   | LVI Volta  | ge Selection bits.                                           |
| 0 |         | 0000       | 1.63V                                                        |
|   |         | 0001       | 1.72V                                                        |
|   |         | 0010       | 1.82V                                                        |
|   |         | 0011       | 1.94V                                                        |
|   |         | 0100       | 2.03V                                                        |
|   |         | 0101       | 2.16V                                                        |
|   |         | 0110       | 2.35V                                                        |
|   |         | 0111       | 2.52V                                                        |
|   |         | 1000       | 2.72V                                                        |
|   |         | 1001       | 3.10V                                                        |
|   |         | 1010       | 3.24V                                                        |
|   |         | 1011       | 3.66V                                                        |
|   |         | 1100       | 3.79V                                                        |
|   |         | 1101       | 4.11V                                                        |
|   |         | 1110       | 4.28V                                                        |
|   |         | 1111       | 4.57V                                                        |







Figure 29. LVI Block Diagram

# 4.6.36 SCULV\_LVRCR: Low voltage reset control register

SCULV\_LVRCR is a 32-bit register, and available at 32/16/8-bit access.

|                                                                  |    |   |   | -  |    |     |     |   | - |   |
|------------------------------------------------------------------|----|---|---|----|----|-----|-----|---|---|---|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 1 | 09 | 8 | 7 | 6  | 5  | 4   | 3   | 2 | 1 | 0 |
| Reserved                                                         |    |   |   |    |    | LVF | REN |   |   |   |
| -                                                                |    |   |   | 0x | 00 |     |     |   |   |   |
|                                                                  |    |   |   | R  | N  |     |     |   |   |   |

| SCULV | LVRCR=0x4000 | 5104 |
|-------|--------------|------|
| 000-1 |              |      |





Figure 30. LVR Block Diagram



# 4.6.37 SCULV\_LVRCNFIG: Configuration for low voltage reset

Low voltage indicator control register is a 32-bit register, and available at 32/16/8-bit access.

|    | SCULV_LVRCNFIG =0x4000_5108 |    |    |    |    |    |    |        |      |    |    |    |    | 08 |      |      |    |    |     |     |    |   |   |   |   |   |   |   |   |   |   |
|----|-----------------------------|----|----|----|----|----|----|--------|------|----|----|----|----|----|------|------|----|----|-----|-----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30                          | 29 | 28 | 27 | 26 | 25 | 24 | 23     | 22   | 21 | 20 | 19 | 18 | 17 | 16   | 15   | 14 | 13 | 12  | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    | WTIDKY                      |    |    |    |    |    |    | LVRENM |      |    |    |    |    | F  | Rese | erve | ed |    | LVF | RVS | ;  |   |   |   |   |   |   |   |   |   |   |
|    | 0x0000                      |    |    |    |    |    |    |        |      |    | 0x | 00 |    |    |      | -    |    |    |     |     | 0> | ٢ |   |   |   |   |   |   |   |   |   |
|    | WO                          |    |    |    |    |    |    |        | RW - |    |    |    |    |    |      | R    | N  |    |     |     |    |   |   |   |   |   |   |   |   |   |   |

| 31 | WTIDKY | Write Iden | tification Key                                              |
|----|--------|------------|-------------------------------------------------------------|
| 24 |        | On writes, | write 0x72A5 to these bits, otherwise the write is ignored. |
| 15 | LVRENM | LVR Rese   | t Operation Control Master Configuration                    |
| 8  |        | 0xAA       | LVR operation is decided by the LVREN of LVRCR register     |
|    |        | Others     | Master enable LVR operation                                 |
| 3  | LVRVS  | LVR Volta  | ge Selection bits.                                          |
| 0  |        | 1111       | 1.63V                                                       |
|    |        | 1110       | 1.72V                                                       |
|    |        | 1101       | 1.82V                                                       |
|    |        | 1100       | 1.94V                                                       |
|    |        | 1011       | 2.03V                                                       |
|    |        | 1010       | 2.16V                                                       |
|    |        | 1001       | 2.35V                                                       |
|    |        | 1000       | 2.52V                                                       |
|    |        | 0111       | 2.72V                                                       |
|    |        | 0110       | 3.10V                                                       |
|    |        | 0101       | 3.24V                                                       |
|    |        | 0100       | 3.66V                                                       |
|    |        | 0011       | 3.79V                                                       |
|    |        | 0010       | 4.11V                                                       |
|    |        | 0001       | 4.28V                                                       |
|    |        | 0000       | 4.57V                                                       |



# 5. PCU and GPIO

Port Control Unit (PCU) configures and controls external I/Os as listed in the followings:

- External signal directions of each pins
- Interrupt trigger mode for each pins
- Internal pull-up/down register control and open drain control

General Purpose Input/Output (GPIO) is corresponding to the most pins except dedicated-function pins. GPIO ports are controlled by GPIO block as listed in the followings:

- Output signal level (H/L) select
- External interrupt interface
- Pull up/down enable or disable

Four pins in Table 24 are assigned for PCU and GPIO blocks.

| Pin name | Туре | Description |
|----------|------|-------------|
| PA       | 10   | PA0 to PA15 |
| РВ       | 10   | PB0 to PB15 |
| PC       | 10   | PC0 to PC15 |
| PF       | 10   | PF0 to PF2  |

#### Table 24. PCU and GPIO pins

# 5.1 PCU and GPIO Block diagram

Figure 31 describes PCU in block diagram.



Figure 31. PCU Block Diagram



Figure 32 and Figure 33 describes GPIO in block diagram, and Figure 34 introduces external interrupt I/O pins.



Figure 32. GPIO Block Diagram(Except PC13, PC14, PC15)



Figure 33. PC13, PC14, PC15 Block Diagram



Figure 34. I/O Port Block Diagram (External Interrupt I/O Pins)



# 5.2 Pin multiplexing

GPIO pins have alternative function pins. Table 25 shows pin multiplexing information.

| Pin  | Alternative function |                  |                  |                |        |        |        |                |        |      |                                         |  |  |  |
|------|----------------------|------------------|------------------|----------------|--------|--------|--------|----------------|--------|------|-----------------------------------------|--|--|--|
| name | AF0                  | AF1              | AF2              | AF3            | AF4    | AF5    | AF6    | AF7            | AF8    | AF9  | AF10                                    |  |  |  |
| PA0  | USART13<br>_TXD      | USART13<br>_MOSI |                  | CP0_OU<br>T    | EC20   |        |        | RTC_TA<br>MP2  |        |      | AN0<br>CP0_N2                           |  |  |  |
| PA1  | USART13<br>_RXD      | USART13<br>_MISO | USART11<br>_SS   |                | EC13   | T13CAP | T13OUT | T20CAP         | T20OUT |      | AN1<br>CP0_P0                           |  |  |  |
| PA2  | USART11<br>_TXD      |                  | USART11<br>_MOSI | CP1_OU<br>T    | EC10   | T10CAP | T10OUT | T20CAP         | T20OUT |      | AN2<br>CP1_N2                           |  |  |  |
| PA3  | USART11<br>_RXD      |                  | USART11<br>_MISO |                | EC10   | T10CAP | T10OUT | T20CAP         | T20OUT |      | AN3<br>CP1_P0                           |  |  |  |
| PA4  | SPI20_S<br>S         |                  | USART11<br>_SCK  |                |        |        |        |                |        |      | AN4<br>CP0_N0<br>CP1_N0<br>DAC_OU<br>T1 |  |  |  |
| PA5  | SPI20_S<br>CK        |                  |                  |                | EC20   |        |        |                |        |      | AN5<br>CP0_N1<br>CP1_N1<br>DAC_OU<br>T2 |  |  |  |
| PA6  | SPI20_MI<br>SO       | CP0_OU<br>T      |                  | BLNK30         | EC11   | T11CAP | T11OUT | T40CAP_<br>CH1 | T40OUT | RD   | AN6                                     |  |  |  |
| PA7  | SPI20_M<br>OSI       | CP1_OU<br>T      |                  | PWM30A<br>B    | EC12   | T12CAP | T12OUT | T40CAP_<br>CH2 | T40OUT | A19  | AN7                                     |  |  |  |
| PA8  |                      | USART10<br>_SCK  |                  | PWM30A<br>A    |        |        |        |                |        | AD07 |                                         |  |  |  |
| PA9  | USART10<br>_TXD      | USART10<br>_MOSI |                  | PWM30B<br>A    |        |        |        |                |        | AD06 |                                         |  |  |  |
| PA10 | USART10<br>_RXD      | USART10<br>_MISO |                  | PWM30C<br>A    | EC21   |        |        |                |        | AD05 |                                         |  |  |  |
| PA11 | CP0_OU<br>T          |                  |                  |                |        |        |        |                |        | AD04 | USBDM                                   |  |  |  |
| PA12 | CP1_OU<br>T          | USART10<br>_SS   |                  | EC30           | T30CAP |        |        |                |        | AD03 | USBDP                                   |  |  |  |
| PA13 |                      | SWDIO            |                  |                |        |        |        |                |        |      |                                         |  |  |  |
| PA14 | USART11<br>_TXD      | SWCLK            | USART11<br>_MOSI |                |        |        |        |                |        |      |                                         |  |  |  |
| PA15 | USART11<br>_RXD      | USART13<br>_SS   | USART11<br>_MISO | SPI20_S<br>S   | EC21   |        |        |                |        | ALE  |                                         |  |  |  |
| PB0  |                      | USART12<br>_SCK  |                  | PWM30B<br>B    |        | T21CAP | T21OUT | T40CAP_<br>CH3 | T40OUT | A16  | AN8                                     |  |  |  |
| PB1  |                      | USART12<br>_SS   |                  | PWM30C<br>B    | EC13   | T13CAP | T13OUT |                |        | AD15 | AN9                                     |  |  |  |
| PB2  |                      |                  |                  |                | EC13   | T13CAP | T13OUT |                |        | AD14 |                                         |  |  |  |
| PB3  |                      |                  |                  | SPI20_S<br>CK  |        | T20CAP | T20OUT |                |        | AD02 |                                         |  |  |  |
| PB4  |                      |                  |                  | SPI20_MI<br>SO |        |        |        | T40CAP_<br>CH1 | T40OUT | AD01 |                                         |  |  |  |
| PB5  |                      |                  |                  | SPI20_M<br>OSI |        | T21CAP | T21OUT | T40CAP_<br>CH2 | T40OUT | AD00 |                                         |  |  |  |
| PB6  | USART10<br>_TXD      | USART10<br>_MOSI | I2C0_SC<br>L     |                | EC11   | T11CAP | T11OUT | T40CAP_<br>CH3 | T40OUT | LWR  |                                         |  |  |  |
| PB7  | USART10<br>_RXD      | USART10<br>_MISO | I2C0_SD<br>A     |                | EC12   | T12CAP | T12OUT |                |        | CS0  |                                         |  |  |  |

## Table 25. GPIO Alternative Function



| Pin  | Alternative function |                  |                 |                  |      |        |        |                |        |       |                |  |  |  |
|------|----------------------|------------------|-----------------|------------------|------|--------|--------|----------------|--------|-------|----------------|--|--|--|
| name | AF0                  | AF1              | AF2             | AF3              | AF4  | AF5    | AF6    | AF7            | AF8    | AF9   | AF10           |  |  |  |
| PB8  |                      | I2C0_SC<br>L     |                 |                  | EC11 | T11CAP | T11OUT |                |        |       |                |  |  |  |
| PB9  |                      | I2C0_SD<br>A     |                 | SPI21_S<br>S     | EC12 | T12CAP | T12OUT |                |        |       |                |  |  |  |
| PB10 | USART12<br>_TXD      | USART12<br>_MOSI | I2C1_SC<br>L    | SPI21_S<br>CK    |      | T20CAP | T20OUT |                |        | AD13  |                |  |  |  |
| PB11 | USART12<br>_RXD      | USART12<br>_MISO | I2C1_SD<br>A    |                  |      | T20CAP | T20OUT |                |        | AD12  |                |  |  |  |
| PB12 | SPI21_S<br>S         | USART12<br>_SCK  |                 | BLNK30           | EC13 | T13CAP | T13OUT |                |        | AD11  |                |  |  |  |
| PB13 | SPI21_S<br>CK        | _                | I2C1_SC<br>L    | PWM30A<br>B      |      |        |        |                |        | AD10  |                |  |  |  |
| PB14 | SPI21_MI<br>SO       | USART12<br>_SS   | I2C1_SD<br>A    | PWM30B<br>B      | EC10 | T10CAP | T10OUT |                |        | AD09  |                |  |  |  |
| PB15 | SPI21_M<br>OSI       | _                |                 | PWM30C<br>B      | EC10 | T10CAP | T10OUT | T21CAP         | T21OUT | AD08  |                |  |  |  |
| PC0  |                      |                  |                 |                  |      |        |        |                |        | LWR   | AN10<br>CP0_P1 |  |  |  |
| PC1  |                      |                  |                 |                  |      |        |        |                |        | AD00  | AN11<br>CP1_P1 |  |  |  |
| PC2  | SPI21_MI<br>SO       |                  |                 |                  |      |        |        |                |        | AD01  | AN12           |  |  |  |
| PC3  | SPI21_M<br>OSI       |                  |                 |                  | EC13 | T13CAP | T13OUT |                |        | AD02  | AN13           |  |  |  |
| PC4  | USART12<br>_TXD      | USART12<br>_MOSI |                 |                  |      |        |        | EC40           |        | A18   | AN14           |  |  |  |
| PC5  | USART12<br>_RXD      | USART12<br>_MISO |                 |                  |      | T21CAP | T21OUT |                |        | A17   | AN15           |  |  |  |
| PC6  |                      |                  |                 |                  |      | T21CAP | T21OUT | T40CAP_<br>CH1 | T40OUT | NWAIT |                |  |  |  |
| PC7  |                      |                  |                 |                  |      |        |        | T40CAP_<br>CH2 | T40OUT | UDS   |                |  |  |  |
| PC8  |                      |                  |                 |                  |      |        |        | T40CAP_<br>CH3 | T40OUT | UWR   |                |  |  |  |
| PC9  |                      |                  |                 |                  |      |        |        | EC40           |        | CS3   |                |  |  |  |
| PC10 | USART13<br>_TXD      | USART13<br>_MOSI | USART12<br>_TXD | USART12<br>_MOSI |      |        |        |                |        | LDS   |                |  |  |  |
| PC11 | USART13<br>_RXD      | USART13<br>_MISO | USART12<br>_RXD | USART12<br>_MISO | EC21 |        |        |                |        | RD    |                |  |  |  |
| PC12 |                      | USART13<br>_SCK  |                 | USART12<br>_SCK  |      |        |        |                |        | CS2   |                |  |  |  |
| PC13 |                      |                  |                 |                  |      |        |        | RTC_TA<br>MP1  |        |       |                |  |  |  |
| PC14 |                      |                  |                 |                  |      |        |        |                |        |       | SXIN           |  |  |  |
| PC15 |                      |                  |                 |                  |      |        |        |                |        |       | SXOUT          |  |  |  |
| PF0  | 1                    | CLKO             |                 |                  | 1    | 1      | 1      | 1              |        | 1     | XIN            |  |  |  |
| PF1  |                      |                  |                 |                  | ł    |        |        | 1              |        |       | XOUT           |  |  |  |
| PF2  |                      |                  |                 | USART12<br>_SS   |      | T21CAP | T21OUT | EC40           |        | CS1   |                |  |  |  |

Table 25. GPIO Alternative Function (continued)

NOTES:

1. On connection with debugger host, SWCLK and SWDIO pins are always for SW-DP pins. So, the corresponding bits of PB\_MOD/PB\_TYP/PB\_AFSR1/PB\_PUPD registers may not be written by software.

2. RTCOUT must be set in PC13MODE in the RTCPFCR register.



# 5.3 Registers

Base address of PCU is introduced in the followings:

| Table | 26. | Base | Address      | of         | PCU |
|-------|-----|------|--------------|------------|-----|
| 10010 |     | Buoo | / (a a l 000 | <b>~</b> · |     |

| Name | Base address | Description    |
|------|--------------|----------------|
| PA   | 0x4000_1000  | General Port A |
| РВ   | 0x4000_1100  | General Port B |
| PC   | 0x4000_1200  | General Port C |
| PF   | 0x4000_1500  | General Port F |

## Table 27. PCU and GPIO Register Map

|            |        | _    |                                                     |             |               |
|------------|--------|------|-----------------------------------------------------|-------------|---------------|
| Name       | Offset | Туре | Description                                         | Reset value | Reference     |
| Pn_MOD     | 0x0000 | RW   | Port n Mode Register                                | 0xXXXX_XXXX | <u>5.3.1</u>  |
| Pn_TYP     | 0x0004 | RW   | Port n Output Type Selection<br>Register            | 0x0000_0000 | <u>5.3.2</u>  |
| Pn_AFSR1   | 0x0008 | RW   | Port n Alternative Function<br>Selection Register 1 | 0xXXXX_XXXX | <u>5.3.3</u>  |
| Pn_AFSR2   | 0x000C | RW   | Port n Alternative Function<br>Selection Register 2 | 0x0000_0000 | <u>5.3.4</u>  |
| Pn_PUPD    | 0x0010 | RW   | Port n Pull-up/down Resistor<br>Selection Register  | 0x0000_XXXX | <u>5.3.5</u>  |
| Pn_INDR    | 0x0014 | RO   | Port n Input Data Register                          | 0x0000_XXXX | <u>5.3.6</u>  |
| Pn_OUTDR   | 0x0018 | RW   | Port n Output Data Register                         | 0x0000_0000 | <u>5.3.7</u>  |
| Pn_BSR     | 0x001C | WO   | Port n Output Bit Set Register                      | 0x0000_0000 | <u>5.3.8</u>  |
| Pn_BCR     | 0x0020 | WO   | Port n Output Bit Clear<br>Register                 | 0x0000_0000 | <u>5.3.9</u>  |
| Pn_OUTDMSK | 0x0024 | RW   | Port n Output Data Mask<br>Register                 | 0x0000_0000 | <u>5.3.10</u> |
| Pn_DBCR    | 0x0028 | RW   | Port n Debounce Control<br>Register                 | 0x0000_0000 | <u>5.3.11</u> |
| Pn_IER     | 0x002C | RW   | Port n interrupt enable register                    | 0x0000_0000 | <u>5.3.12</u> |
| Pn_ISR     | 0x0030 | RW   | Port n interrupt status register                    | 0x0000_0000 | <u>5.3.13</u> |
| Pn_ICR     | 0x0034 | RW   | Port n interrupt control register                   | 0x0000_0000 | <u>5.3.14</u> |
| PCR.USBCON | 0x0540 | RW   | USB Control Register                                | 0x0000_0000 | <u>5.3.15</u> |
| PCU_PORTEN | 0x0FF0 | WO   | Port Access Enable                                  | 0x0000_0000 | <u>5.3.16</u> |

NOTE:

1. Where n = A, B, C, and F



# 5.3.1 Pn\_MOD: PORT n mode register

Input or output control of each port pin. Each pin can be configured as an input pin, an output pin or an alternative function pin. Size of this register is 32-bit, and it is able to do 32/16/8-bit access (n = A, B, C, and F).

|        |        |        |            |        |        |       |            | P      | C_MOD | )=0x40    | 00_120   | 0, PF_ | MOD=  | 0x4000 | _1500 |
|--------|--------|--------|------------|--------|--------|-------|------------|--------|-------|-----------|----------|--------|-------|--------|-------|
| 31 30  | 29 28  | 27 26  | 25 24      | 23 22  | 21 20  | 19 18 | 17 16      | 15 14  | 13 12 | 11 10     | 98       | 76     | 54    | 32     | 1 0   |
| MODE15 | MODE14 | MODE13 | MODE12     | MODE11 | MODE10 | MODE9 | MODE8      | MODE7  | MODE6 | MODE5     | MODE4    | MODE3  | MODE2 | MODE1  | MODE0 |
| 00     | 00     | 00     | 00         | 00     | 00     | 00    | 00         | 00     | 00    | 00        | 00       | 00     | 00    | 00     | 00    |
| RW     | RW     | RW     | RW         | RW     | RW     | RW    | RW         | RW     | RW    | RW        | RW       | RW     | RW    | RW     | RW    |
|        |        |        | 2x+1<br>2x | N      | 10DEx  |       | Port<br>00 | n Mode |       | n bits, x | :0 to 15 |        |       |        |       |

01

10

11

PA\_MOD=0x4000\_1000, PB\_MOD=0x4000\_1100 PC MOD=0x4000 1200, PF MOD=0x4000 1500

NOTE

For exception, the reset value is, PA\_MOD : 0xEBFFFFF / PB\_MOD : 0xFFF0FFFF / PC\_MOD : 0xFFFFFFF / PF\_MOD : 0x0000003F

Alternative function mode

Output mode

Reserved

PC13, PC14, PC15 output mode must use RTCPFCR register. Refer to 23.2.15 RTCPFCR: RTC pin function configuration register

# 5.3.2 Pn\_TYP: Port n output type selection register

Pn\_TYP selects control option from a Push-pull output and Open-drain output for each port pin. Size of this register is 32-bit, and it is able to do 32/16/8-bit access (n = A, B, C, and F).

|                                                 |       |       |       |       |        |       |      |      |     |      |      |      |      |      |      | 104<br>504 |
|-------------------------------------------------|-------|-------|-------|-------|--------|-------|------|------|-----|------|------|------|------|------|------|------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15    | 14    | 13    | 12    | 11     | 10    | 9    | 8    | 7   | 6    | 5    | 4    | 3    | 2    | 1    | 0          |
| Reserved                                        | TYP15 | ТҮР14 | ТҮР13 | ТҮР12 | 117Р11 | ТҮР10 | ТҮР9 | ТҮР8 | 797 | ТҮР6 | ТҮР5 | ТҮР4 | ТҮРЗ | ТҮР2 | ТҮР1 | ТҮРО       |
| -                                               | 0     | 0     | 0     | 0     | 0      | 0     | 0    | 0    | 0   | 0    | 0    | 0    | 0    | 0    | 0    | 0          |
|                                                 | RW    | RW    | RW    | RW    | RW     | RW    | RW   | RW   | RW  | RW   | RW   | RW   | RW   | RW   | RW   | RW         |

| х       | TYPx                 | Port n Output Type Selection bits, x:0 to 15 |
|---------|----------------------|----------------------------------------------|
|         |                      | 0 Push-pull output                           |
|         |                      | 1 Open-drain output                          |
| NOTE    |                      | : PC13, PC14, and PC15 cannot                |
| be used | d as open-drain. Onl | push-pull is available.                      |



#### 5.3.3 Pn\_AFSR1: Port n alternative function selection register 1

Pn\_AFSR1 registers must be set properly before using this port. Otherwise the port cannot be guaranteed for its functionality. Size of this register is 32-bit, and it is able to do 32/16/8-bit access (n = A, B, C, and F).

|       |     |    |      |     |     |    |    |    |     |    |    |      |     |    | P  | <u>C_/</u> | <b>AFS</b> | R1 | <b> =0</b> 2 | <u>x40</u> | <u>00</u> | _12 | 208 | 8, PI | F_/ | \FS | R1 | =0: | x4( | 000 | _1! | 508 |
|-------|-----|----|------|-----|-----|----|----|----|-----|----|----|------|-----|----|----|------------|------------|----|--------------|------------|-----------|-----|-----|-------|-----|-----|----|-----|-----|-----|-----|-----|
| 31 30 | 29  | 28 | 27 2 | 26  | 25  | 24 | 23 | 22 | 21  | 20 | 19 | ) 18 | 17  | 16 | 15 | 14         | 13         | 12 | 2 11         | 1(         | )         | 9   | 8   | 7     | 6   | 5   | 4  | 3   | 3   | 2   | 1   | 0   |
| AF    | SB7 |    | А    | FS  | SB6 |    |    | AF | SB5 |    |    | AF   | SB4 |    |    | AF         | SB3        | 3  |              | AF         | S         | 32  |     |       | AF  | SB  | 1  |     | ļ   | ٩FS | В0  |     |
| 00    | 000 |    |      | 000 | 00  |    |    | 00 | 00  |    |    | 00   | 00  |    |    | 00         | 00         |    |              | 0          | 00        | 0   |     |       | 00  | 000 |    |     |     | 000 | 00  |     |
|       | RW  |    |      | RV  | V   |    |    | R  | W   |    |    | R    | W   |    |    | R          | W          |    |              |            | RW        |     |     |       | F   | RM  |    |     |     | RW  |     |     |

| P   | A_4 | ١FS | R1= | =0x4 | 4000 | )_1 | 008 | , PI | B_A | FSI | R1= | :0x4 | 400  | 0_1 | 108 |   |
|-----|-----|-----|-----|------|------|-----|-----|------|-----|-----|-----|------|------|-----|-----|---|
| P   | C_/ | ١FS | R1= | =0x  | 400  | 0_1 | 208 | , Pl | F_A | FSI | R1= | 0x4  | 1000 | )_1 | 508 |   |
| 4 5 | 4.4 | 40  | 40  | 44   | 40   | 0   | 0   | 7    | ~   | -   | 4   | 0    | 0    | 4   | ^   | ſ |

| 4x+3  | AFSBx | Port n Alterr                | native Function Selection bits, x:0 to 7 |
|-------|-------|------------------------------|------------------------------------------|
| 4x    |       | 0000                         | Alternative Function 0 (AF0)             |
|       |       | 0001                         | Alternative Function 1 (AF1)             |
|       |       | 0010                         | Alternative Function 2 (AF2)             |
|       |       | Alternative Function 3 (AF3) |                                          |
|       |       | 0100                         | Alternative Function 4 (AF4)             |
|       |       | 0101                         | Alternative Function 5 (AF5)             |
|       |       | 0110                         | Alternative Function 6 (AF6)             |
|       |       | 0111                         | Alternative Function 7 (AF7)             |
|       |       | 1000                         | Alternative Function 8 (AF8)             |
|       |       | 1001                         | Alternative Function 9 (AF9)             |
|       |       | 1010                         | Alternative Function 10 (AF10)           |
|       |       | Others                       | Reserved                                 |
| NOTE: |       |                              | When HSE is used as the system           |

clock (MCLK), the AFSBx bits for PF0, PF1 must be configured as AF10 before changing the system clock and the value should not be changed.



# 5.3.4 Pn\_AFSR2: Port n alternative function selection register 2

Pn\_AFSR2 registers must be set properly before using this port. Otherwise the port cannot be guaranteed for its functionality. Size of this register is 32-bit, and it is able to do 32/16/8-bit access (n = A, B, C, and F).

|             |             |             |             | PC_AFSR2=0  | 0x4000_120C, | PF_AFSR2=0 | )x4000_150C |
|-------------|-------------|-------------|-------------|-------------|--------------|------------|-------------|
| 31 30 29 28 | 27 26 25 24 | 23 22 21 20 | 19 18 17 16 | 15 14 13 12 | 11 10 9 8    | 7 6 5 4    | 3 2 1 0     |
| AFSB15      | AFSB14      | AFSB13      | AFSB12      | AFSB11      | AFSB10       | AFSB9      | AFSB8       |
| 0000        | 0000        | 0000        | 0000        | 0000        | 0000         | 0000       | 0000        |
| RW          | RW          | RW          | RW          | RW          | RW           | RW         | RW          |

| PA_AFSR2=0x4000_ | 100C, PB | _AFSR2=0x4000_110C |
|------------------|----------|--------------------|
| PC_AFSR2=0x4000_ | 120C, PF | _AFSR2=0x4000_150C |

| 4(x-8)+3<br>4(x-8) | AFSRx | Port n Alter | ort n Alternative Function Selection bits, x:8 to 15 |  |  |  |  |  |  |
|--------------------|-------|--------------|------------------------------------------------------|--|--|--|--|--|--|
|                    |       | 0000         | Alternative Function 0 (AF0)                         |  |  |  |  |  |  |
|                    |       | 0001         | Alternative Function 1 (AF1)                         |  |  |  |  |  |  |
|                    |       | 0010         | Alternative Function 2 (AF2)                         |  |  |  |  |  |  |
|                    |       | 0011         | Alternative Function 3 (AF3)                         |  |  |  |  |  |  |
|                    |       | 0100         | Alternative Function 4 (AF4)                         |  |  |  |  |  |  |
|                    |       | 0101         | Alternative Function 5 (AF5)                         |  |  |  |  |  |  |
|                    |       | 0110         | Alternative Function 6 (AF6)                         |  |  |  |  |  |  |
|                    |       | 0111         | Alternative Function 7 (AF7)                         |  |  |  |  |  |  |
|                    |       | 1000         | Alternative Function 8 (AF8)                         |  |  |  |  |  |  |
|                    |       | 1001         | Alternative Function 9 (AF9)                         |  |  |  |  |  |  |
|                    |       | 1010         | Alternative Function 10 (AF10)                       |  |  |  |  |  |  |
|                    |       | Others       | Reserved                                             |  |  |  |  |  |  |

NOTES:

When LSE is used as the system clock (MCLK) the AFSBx bits for PC14, PC15 must be configured as AF10 before changing the system clock and the value should not be changed. For exception, the reset value of PA\_AFSR2: 0x01100000.



#### Pn\_PUPD: Port n pull-up/down resistor selection register 5.3.5

Each pin of the ports has on-chip pull-up/down resistor which can be configured by Pn\_PUPD registers. Size of this register is 32-bit, and it is able to do 32/16/8-bit access (n = A, B, C, and F).

|        |        |        |        |        |        |       |       | PC    |       | )=0x40 | 00_121 | 0, PF_ | PUPD= | =0x400 | 0 <u>1510</u> |
|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|--------|--------|--------|-------|--------|---------------|
| 31 30  | 29 28  | 27 26  | 25 24  | 23 22  | 21 20  | 19 18 | 17 16 | 15 14 | 13 12 | 11 10  | 98     | 76     | 54    | 32     | 1 0           |
| PUPD15 | PUPD14 | PUPD13 | PUPD12 | PUPD11 | PUPD10 | PUPD9 | PUPD8 | PUPD7 | PUPD6 | PUPD5  | PUPD4  | PUPD3  | PUPD2 | PUPD1  | PUPD0         |
| 00     | 00     | 00     | 00     | 00     | 00     | 00    | 00    | 00    | 00    | 00     | 00     | 00     | 00    | 00     | 00            |
| RW     | RW     | RW     | RW     | RW     | RW     | RW    | RW    | RW    | RW    | RW     | RW     | RW     | RW    | RW     | RW            |

| PA_PUPD=0x4000 | 1010, PB | PUPD=0x4000 | 1110 |
|----------------|----------|-------------|------|
| PC_PUPD=0x4000 | 1210, PF |             | 1510 |

| 2x+1   | PUPDx | Port n Pull-up/down Resistor Selection bits, x:0 to 15 |
|--------|-------|--------------------------------------------------------|
| 2x     |       | 00 Disable pull-up/down resistor                       |
|        |       | 01 Enable pull-up resistor                             |
|        |       | 10 Enable pull-down resistor                           |
|        |       | 11 Reserved                                            |
| NOTES: |       |                                                        |

The pull-up resistors for the test mode pin (PB8, PB9) and the SWD pin (PA14, PA13) are initially enabled. For exception, the reset value of PA\_PUPD, PB\_PUPD register is 0x14000000, 0x00050000

#### 5.3.6 Pn\_INDR: Port n input data register

respectively.

Each pin level status can be read in the Pn\_INDR register. Even if a pin is alternative mode except analog mode and output in alternative mode, the pin level can be detected in the Pn\_INDR register.

Size of this register is 32-bit, and it is able to do 32/16/8-bit access (n = A, B, C, and F).

| 31 30 29 28 27 26 25 24       23 22 21 20 19 18 17 16       15       14       13       12       11       10       9       8       7       6       5       4       3       2       1       0         Reserved       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$       \$\$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                 |     |          |    |    |        |    |       |       |       |       |       |       |       |       |       | 114<br>514 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|-----|----------|----|----|--------|----|-------|-------|-------|-------|-------|-------|-------|-------|-------|------------|
| Reserved       Image: Arrow and the constraint of the constrated of the constraint of the constrated of the constrai | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15  | 14       | 13 | 12 | 11     | 10 | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Reserved                                        | DR1 | <u>_</u> |    |    | INDR11 |    | INDR9 | INDR8 | INDR7 | INDR6 | INDR5 | INDR4 | INDR3 | INDR2 | INDR1 | INDR0      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | -                                               | х   | х        | х  | х  | х      | х  | х     | х     | х     | х     | х     | х     | х     | х     | х     | х          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                 | RO  | RO       | RO | RO | RO     | RO | RO    | RO    | RO    | RO    | RO    | RO    | RO    | RO    | RO    | RO         |

| x INDRx Port n Input Data bit, x:0 to 15 |
|------------------------------------------|
|------------------------------------------|



PA OUTDR=0x4000 1018, PB OUTDR=0x4000 1118

#### 5.3.7 Pn\_OUTDR: Port n output data register

Pn\_OUTDR registers define output level of a pin when the pin is set as output and GPIO mode. Size of this register is 32-bit, and it is able to do 32/16/8-bit access (n = A, B, C, and F).

|                                                 |         | P       | c_c     | UTI     | DR=     | 0x4     | 000    | _12           | 18,    | PF_    | OU     | TDR    | =0x    | 400    | 0_1           | 518    |
|-------------------------------------------------|---------|---------|---------|---------|---------|---------|--------|---------------|--------|--------|--------|--------|--------|--------|---------------|--------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15      | 14      | 13      | 12      | 11      | 10      | 9      | 8             | 7      | 6      | 5      | 4      | 3      | 2      | 1             | 0      |
| Reserved                                        | OUTDR15 | OUTDR14 | OUTDR13 | OUTDR12 | OUTDR11 | OUTDR10 | OUTDR9 | <b>0UTDR8</b> | OUTDR7 | OUTDR6 | OUTDR5 | OUTDR4 | OUTDR3 | OUTDR2 | <b>OUTDR1</b> | OUTDR0 |
| -                                               | 0       | 0       | 0       | 0       | 0       | 0       | 0      | 0             | 0      | 0      | 0      | 0      | 0      | 0      | 0             | 0      |
|                                                 | RW      | RW      | RW      | RW      | RW      | RW      | RW     | RW            | RW     | RW     | RW     | RW     | RW     | RW     | RW            | RW     |

| Х      | OUTDRx                 | Port n Output Data bit, x:0 to 15<br>The OUTDR bits can be individually set/cleared by writing to the<br>Pn_BSR/Pn_BCR register |
|--------|------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| NOTE:  | PC13, PC14, PC15 o     | utput mode must use RTCPFCR register. Refer to 23.2.15 RTCPFCR:                                                                 |
| RTC pi | n function configurati | ion register                                                                                                                    |

### 5.3.8 Pn\_BSR: Port n output bit set register

Pn\_BSR registers control each bit of Pn\_OUTDR register. Writing '1' into the specific bit field will set a corresponding bit of Pn\_OUTDR to '1'. Writing '0' has no effect.

Size of this register is 32-bit, and it is able to do 32/16/8-bit access (n = A, B, C, and F).

|                                                              |       |       |       | PA    | _BS   | SR=   | 0x4( | 000  | _101         | IC, I | PB_  | BSF  | R=0× | 400  | 0_1 <sup>·</sup> | 11C        |
|--------------------------------------------------------------|-------|-------|-------|-------|-------|-------|------|------|--------------|-------|------|------|------|------|------------------|------------|
|                                                              |       |       |       | PC    | _B\$  | SR=(  | 0x4( | 000  | _121         | IC, I | PF_  | BSR  | =0x  | 400  | 0_1              | <u>51C</u> |
| 31 30 29 28 27 26 25 24 <mark>23 22 21 20 19 18 17 16</mark> | 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7            | 6     | 5    | 4    | 3    | 2    | 1                | 0          |
| Reserved                                                     | BSR15 | BSR14 | BSR13 | BSR12 | BSR11 | BSR10 | 6YS8 | 8AS8 | <b>LAS</b> B | 9XSB  | BSR5 | BSR4 | BSR3 | BSR2 | BSR1             | BSR0       |
| -                                                            | 0     | 0     | 0     | 0     | 0     | 0     | 0    | 0    | 0            | 0     | 0    | 0    | 0    | 0    | 0                | 0          |
|                                                              | WO    | WO    | WO    | WO    | WO    | WO    | WO   | WO   | WO           | WO    | WO   | WO   | WO   | WO   | WO               | WO         |

| х | BSRx                                 | Port n Output Set bit, x: 0 to 15. These bits are always read to 0x00           |
|---|--------------------------------------|---------------------------------------------------------------------------------|
|   |                                      | 0 No effect                                                                     |
|   |                                      | 1 Set the corresponding OUTDRx bit (automatically cleared to 0)                 |
|   | PC13, PC14, PC15<br>PC13, PC14, PC15 | output mode must use RTCPFCR register. Refer to 23.2.15 RTCPFCR: ation register |



#### 5.3.9 Pn\_BCR: Port n output bit clear register

Pn\_BCR registers control each bit of Pn\_OUTDR register. Writing '1' into the specific bit field will set a corresponding bit of Pn\_OUTDR to '0'. Writing '0' has no effect.

Size of this register is 32-bit, and it is able to do 32/16/8-bit access (n = A, B, C, and F).

|                                                 |       |       |       |       |       |       |      |      |      |      |      |      |      |      | 0_1<br>0_1 |      |
|-------------------------------------------------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------------|------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1          | 0    |
| Reserved                                        | BCR15 | BCR14 | BCR13 | BCR12 | BCR11 | BCR10 | BCR9 | BCR8 | BCR7 | BCR6 | BCR5 | BCR4 | BCR3 | BCR2 | BCR1       | BCR0 |
| -                                               | 0     | 0     | 0     | 0     | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0          | 0    |
|                                                 | WO    | WO    | WO    | WO    | WO    | WO    | WO   | WO   | WO   | WO   | WO   | WO   | WO   | WO   | WO         | WO   |



#### 5.3.10 Pn\_OUTDMSK: Port n output data mask register

Pn\_OUTDMSK registers protect each bit of Pn\_OUTDR registers. Writing '1' into the specific bit field will protect a corresponding bit of Pn\_OUTDR. Writing '0' is unmasked.

Size of this register is 32-bit, and it is able to do 32/16/8-bit access (n = A, B, C, and F).

|                                                 |           | _0U       |           |           |           |           |          |          |                 |                 |                 |          |                 |          |          |            |
|-------------------------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|-----------------|-----------------|-----------------|----------|-----------------|----------|----------|------------|
|                                                 | PC        | _00       | TD        | NSK       | (=0x      | 400       | 0_1      | 224,     | PF              | _Οι             | JTD             | MSK      | (=0)            | (400     | 0_1      | <u>524</u> |
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15        | 14        | 13        | 12        | 11        | 10        | 9        | 8        | 7               | 6               | 5               | 4        | 3               | 2        | 1        | 0          |
| Reserved                                        | OUTDMSK15 | OUTDMSK14 | OUTDMSK13 | OUTDMSK12 | OUTDMSK11 | OUTDMSK10 | OUTDMSK9 | OUTDMSK8 | <b>OUTDMSK7</b> | <b>OUTDMSK6</b> | <b>OUTDMSK5</b> | OUTDMSK4 | <b>OUTDMSK3</b> | OUTDMSK2 | OUTDMSK1 | OUTDMSK0   |
| -                                               | 0         | 0         | 0         | 0         | 0         | 0         | 0        | 0        | 0               | 0               | 0               | 0        | 0               | 0        | 0        | 0          |
| · ·                                             | RW        | RW        | RW        | RW        | RW        | RW        | RW       | RW       | RW              | RW              | RW              | RW       | RW              | RW       | RW       | RW         |

| х     | OUTDMSKx                  | Port n Output Data Mask bit, x: 0 to 15.                        |
|-------|---------------------------|-----------------------------------------------------------------|
|       |                           | 0 Unmask. The corresponding OUTDR bit can be changed.           |
|       |                           | 1 Mask. The corresponding OUTDRx bit is protected.              |
| NOTE: | PC13, PC14, PC15 ou       | utput mode must use RTCPFCR register. Refer to 23.2.15 RTCPFCR: |
| RTC p | in function configuration | on register                                                     |



PA\_DBCR=0x4000\_1028, PB\_DBCR=0x4000\_1128

#### 5.3.11 Pn\_DBCR: Port n debounce control register

Size of this register is 32-bit, and it is able to do 32/16/8-bit access (n = A, B, C, and F).

|                                                 |        |        | Ρ      | C_C    | вс     | R=0    | x40   | 00_ <sup>-</sup> | 1228  | 3, PI | F_D   | BCF   | <b>R=0</b> > | (400  | 0_1   | 528   |
|-------------------------------------------------|--------|--------|--------|--------|--------|--------|-------|------------------|-------|-------|-------|-------|--------------|-------|-------|-------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15     | 14     | 13     | 12     | 11     | 10     | 9     | 8                | 7     | 6     | 5     | 4     | 3            | 2     | 1     | 0     |
| Reserved                                        | DBEN15 | DBEN14 | DBEN13 | DBEN12 | DBEN11 | DBEN10 | DBEN9 | DBEN8            | DBEN7 | DBEN6 | DBEN5 | DBEN4 | DBEN3        | DBEN2 | DBEN1 | DBEN0 |
| -                                               | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0                | 0     | 0     | 0     | 0     | 0            | 0     | 0     | 0     |
|                                                 | RW     | RW     | RW     | RW     | RW     | RW     | RW    | RW               | RW    | RW    | RW    | RW    | RW           | RW    | RW    | RW    |

| X | DBENx | Port n Debounce Enable bit, x: 0 to 15.<br>Port debounce length = selected debounce clock period * (4 to 5) |
|---|-------|-------------------------------------------------------------------------------------------------------------|
|   |       | 0 Disable debounce filter                                                                                   |
|   |       | 1 Enable debounce filter                                                                                    |

If a level is not detected on an enabled pin three or more times in a row at the sampling clock, the signal is eliminated as noise.

The port debounce should be disabled before Power Down mode.

#### 5.3.12 Pn\_IER: Port n interrupt enable register

Each pin of A31G32x can be an external interrupt source. In this case, both of edge trigger interrupt and level trigger interrupt are supported.

Pn\_IER registers can configure the interrupt mode (n = A, B, C, and F).

|    |       |       |       |       |       |       |       |       |       |       |       |      |      |      |      | 0_112C<br>0_152C |
|----|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|------|------|------|------|------------------|
| 31 | 30    | 29 28 | 27 26 | 25 24 | 23 22 | 21 20 | 19 18 | 17 16 | 15 14 | 13 12 | 11 10 | 98   | 76   | 54   | 32   | 1 0              |
|    | PIE15 | PIE14 | PIE13 | PIE12 | PIE11 | PIE10 | PIE9  | PIE8  | PIE7  | 93Id  | PIE5  | PIE4 | PIE3 | PIE2 | PIE1 | PIE0             |
|    | 00    | 00    | 00    | 00    | 00    | 00    | 00    | 00    | 00    | 00    | 00    | 00   | 00   | 00   | 00   | 00               |
|    | RW    | RW   | RW   | RW   | RW   | RW               |

| 2x+1 | PIEx | Port n Pin interrupt Enable Selection bits, x:0 to 15 |
|------|------|-------------------------------------------------------|
| 2x   |      | 00 Disable Interrupt                                  |
|      |      | 01 Enable interrupt as level trigger mode             |
|      |      | 10 Reserved                                           |
|      |      | 11 Enable interrupt as edge trigger mode              |
|      |      |                                                       |



#### 5.3.13 Pn\_ISR: Port n interrupt status register

When an interrupt is delivered to CPU, the interrupt status can be detected by reading Pn\_ISR registers. Pn\_ISR registers will report a source pin of the interrupt and a type of the interrupt (n = A, B, C, and F).

| 31       30       29       28       27       26       25       24       23       22       21       20       19       18       17       16       15       14       13       12       11       10       9       8       7       6       5       4       3       2       1       0         \$1       30       29       28       27       26       25       24       23       22       21       20       19       18       17       16       15       14       13       12       11       10       9       8       7       6       5       4       3       2       1       0         \$1       \$1       \$1       10       16       15       14       13       12       11       10       9       8       7       6       5       4       3       2       1       0         \$1       \$2       \$1       \$1       \$1       16       \$1       \$1       12       11       10       9       8       7       6       5       4       3       2       1       0         \$1       \$2       \$1       \$1 <td< th=""><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th>ISR=0x</th><th>4000_1</th><th>1230, P</th><th>F_ISR</th><th>=0X400</th><th>0_1530</th></td<> |       |       |       |       |       |       |       |       |       |       | ISR=0x | 4000_1 | 1230, P | F_ISR | =0X400 | 0_1530 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|--------|--------|---------|-------|--------|--------|
| 00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00         00<                                                   | 31 30 | 29 28 | 27 26 | 25 24 | 23 22 | 21 20 | 19 18 | 17 16 | 15 14 | 13 12 | 11 10  | 98     | 76      | 54    | 3 2    | 1 0    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | S.    | PIS14 |       | PIS12 | S     | PIS10 | PIS9  | PIS8  | _     | PIS6  | PIS5   |        | PIS3    | PIS2  | PIS1   |        |
| RW         RW<                                                   | 00    | 00    | 00    | 00    | 00    | 00    | 00    | 00    | 00    | 00    | 00     | 00     | 00      | 00    | 00     | 00     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW     | RW     | RW      | RW    | RW     | RW     |

| PA_ISR=0x4000_ | 1030, PB | _ISR=0x4000_ | 1130 |
|----------------|----------|--------------|------|
| PC_ISR=0x4000  | 1230, PF | ISR=0x4000   | 1530 |

| 2x+1 | PISx | Port n Pin interrupt Status bits, x:0 to 15                                                                                                   |
|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 2x   |      | 00 No interrupt event                                                                                                                         |
|      |      | 01 Low level interrupt or Falling edge interrupt event is present.                                                                            |
|      |      | 10 High level interrupt or Ralling edge interrupt event is present.                                                                           |
|      |      | 11 Both of rising and falling interrupt event is present in edge<br>trigger interrupt mode.<br>Not available in level trigger interrupt mode. |

#### 5.3.14 Pn\_ICR: Port n interrupt control register

Pn\_ICR registers control interrupt mode of port pins (n = A, B, C, and F).

|       |       |       |       |       |       |       |       |       | PC_I  | <u>CR=0x</u> | <u>4000_1</u> | 234, P | F_ICR= | =0x400 | 0 <u>1534</u> |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|--------------|---------------|--------|--------|--------|---------------|
| 31 30 | 29 28 | 27 26 | 25 24 | 23 22 | 21 20 | 19 18 | 17 16 | 15 14 | 13 12 | 11 10        | 98            | 76     | 54     | 32     | 1 0           |
| PIC15 | PIC14 | PIC13 | PIC12 | PIC11 | PIC10 | PIC9  | PIC8  | PIC7  | PIC6  | PIC5         | PIC4          | PIC3   | PIC2   | PIC1   | PICO          |
| 00    | 00    | 00    | 00    | 00    | 00    | 00    | 00    | 00    | 00    | 00           | 00            | 00     | 00     | 00     | 00            |
| RW           | RW            | RW     | RW     | RW     | RW            |

PA\_ICR=0x4000\_1034, PB\_ICR=0x4000\_1134 PC\_ICR=0x4000\_1234, PF\_ICR=0x4000\_1534

| 2x+1 | PICx | Port n Pin interrupt Control bits, x:0 to 15                                                       |
|------|------|----------------------------------------------------------------------------------------------------|
| 2x   |      | 00 Prohibit external interrupt                                                                     |
|      |      | 01 Low level interrupt or Falling edge interrupt mode                                              |
|      |      | 10 High level interrupt or Ralling edge interrupt mode                                             |
|      |      | 11 Both of rising and falling edge interrupt mode<br>Not support for level trigger interrupt mode. |



# 5.3.15 PCU\_USBCON: USB control register

PCU\_USBCON register controls USB pull-up/pull-down, VIL, VIH (only PA11, PA12).

#### USBCON=0x4000\_1540

| 31       | 30 29 2  | 8 27     | 26 25    | 24 | 23         | 22         | 21       | 20       | 19      | 18      | 17      | 16      | 15       | 14 | 13      | 12 | 11       | 10 | 9       | 8 | 7        | 6 | 5      | 4 | 3        | 2 | 1      | 0 |
|----------|----------|----------|----------|----|------------|------------|----------|----------|---------|---------|---------|---------|----------|----|---------|----|----------|----|---------|---|----------|---|--------|---|----------|---|--------|---|
| Reserved | TY_DNOPT | Reserved | ΤΧ υρορτ | I  | CONTROL_EN | DNASUS_YHA | VREF_SEL | Reserved | PD_ENDN | PD_ENDP | PU_ENDN | PU_ENDP | Reserved |    | VIH_CON |    | Reserved |    | VIH_CON |   | Reserved |   | PD_CON |   | Reserved |   | PU_CON |   |
| -        | 000      | -        | 000      | )  | 0          | 0          | 0        | -        | 0       | 0       | 0       | 0       | -        | C  | 000     |    | -        | (  | 000     |   | -        |   | 000    |   | -        | ( | 000    |   |
|          | RW       |          | RW       |    | RW         | RW         | RW       | -        | RW      | RW      | RW      | RW      | •        |    | RW      |    | •        |    | RW      |   | •        |   | RW     |   | •        |   | RW     |   |

| 30 | TX_DNOPT       | TX Driver Up Driving Stren | gth Opti  | ion      |                  |
|----|----------------|----------------------------|-----------|----------|------------------|
| 28 |                | 00 + 0%<br>0               |           | 100      | + 15%            |
|    |                | 00 + 5%<br>1               |           | 101      | + 20%            |
|    |                | 01 + 10%<br>0              |           | 110      | + 25%            |
|    |                | 01 -<br>1                  |           | 111      | + 30%            |
| 26 | TX_UPOPT       | TX Driver Down Driving St  | rength C  | Option   |                  |
| 24 |                | 00 + 0%<br>0               |           | 100      | + 15%            |
|    |                | 00 + 5%<br>1               |           | 101      | + 20%            |
|    |                | 01 + 10%<br>0              |           | 110      | + 25%            |
|    |                | 01 -<br>1                  |           | 111      | + 30%            |
| 23 | CONTROL_E<br>N | USB PHY pull up, pull dow  | n, VIL, V | /IH cont | trol enable      |
| 22 | PHY_SUSPN<br>D | PHY SUSPEND signal (ac     | tive HIG  | H)       |                  |
| 21 | VREF_SEL       | Single ended Receiver hys  | teresis   | referenc | e Voltage Select |
|    |                | 0 BGR 1.2V                 |           |          |                  |
|    |                | 1 VDD15 1.5V               |           |          |                  |
| 19 | PD_ENDN        | DN pin Pull down enable    |           |          |                  |
| 18 | PD_ENDP        | DP pin Pull down enable    |           |          |                  |
| 17 | PU_ENDN        | DN pin Pull up enable      |           |          |                  |
| 16 | PU_ENDP        | DP pin Pull up enable      |           |          |                  |
| 14 | VIH_CON        | VIH level select register  |           |          |                  |
| 12 |                | 000 0.4V                   | 100       | 0.8V     |                  |
|    |                | 001 0.5V                   | 101       | 0.9V     |                  |
|    |                | 010 0.6V                   | 110       | 1.0V     |                  |
|    |                | 011 0.7V                   | 111       | 1.1V     |                  |



| 10 | VIL_CON | VIL le | vel select registe  | r           |          |
|----|---------|--------|---------------------|-------------|----------|
| 8  |         | 000    | 1.6V                | 100         | 2.0V     |
|    |         | 001    | 1.7V                | 101         | 2.1V     |
|    |         | 010    | 1.8V                | 110         | 2.2V     |
|    |         | 011    | 1.9V                | 111         | 2.3V     |
| 6  | PD_CON  | Pull d | own resister sele   | ct register |          |
| 4  |         | 000    | 17.5KOhm            | 100         | 14.5KOhm |
|    |         | 001    | 16.3KOhm            | 101         | 13.8KOhm |
|    |         | 010    | 16KOhm              | 110         | 13KOhm   |
|    |         | 011    | 15.3KOhm            | 111         | 12.3KOhm |
| 2  | PU_CON  | Pull u | p resister select i | egister     |          |
| 0  |         | 000    | 1.97KOhm            | 100         | 1.26KOhm |
|    |         | 001    | 1.8KOhm             | 101         |          |
|    |         | 010    | 1.63KOhm            | 110         | 1.1KOhm  |
|    |         | 011    | 1.46KOhm            | 111         |          |

# 5.3.16 PCU\_PORTEN: Port access enable

PCU\_PORTEN register enables the register writing permission of all PCU registers.

|                                                                       | -       | —       |
|-----------------------------------------------------------------------|---------|---------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 6 5 4 | 3 2 1 0 |
| Reserved                                                              | POR     | TEN     |
| -                                                                     |         | •       |
|                                                                       | WC      | )       |

#### PCU\_PORTEN=0x4000\_1FF0

| 7<br>0                | PORTEN                                           |                       | e of 0x15 and 0x51 in thi<br>ers, and writing other value |                |
|-----------------------|--------------------------------------------------|-----------------------|-----------------------------------------------------------|----------------|
|                       | : Refer to the following<br>N=0x15; PORTEN=0x51; | gs to use PORTEN;     | // enable PORTEN                                          |                |
| <br>Pn_TYP,<br>PORTEN | , Pn_AFSR1,2, Pn_PUPD. Pn<br>N=0:                | _DBCR, Pn_IER, Pn_ICR |                                                           | // set Pn_MOD, |
| 1011121               | ,                                                |                       | // disable PORTEN                                         | N              |



# 5.4 Functional description

If an input function of a certain I/O port is used by Pin Control Register, an output function of the I/O port is disabled. Function of each port can be different in accordance with an Alternative Function Selection Register.

Input Data Register captures current data of the I/O pin or debounced input data at every GPIO clock cycle.



Figure 35. Port Diagram





Figure 36. Debounce Function Timing Diagram

- When configured as output, the value written to the GPIO Output Data Register is output on the I/O Pin.
- When setting the Bit Set Register, GPIO Output Data Register set the high.
- When setting the Bit Clr Register, GPIO Output Data Register set the Low.
- The Input Data Register captures the data present on the I/O pin or Debounced input data at every GPIO Clock cycle.



#### Figure 37. GPIO Diagram



# 6. Flash memory controller

Flash Memory Controller is an internal flash memory interface controller, and includes following features as shown below:

- 128 or 64KB Flash code memory
- Wait, 1-wait, 2-wait(default)
- Read protection support
- Self-Program support
- User option area
- 3-page (each 512 Bytes)
- Erase, Program in user mode

#### Table 28. Flash Memory Controller Features

| Item             | Description              |                          |
|------------------|--------------------------|--------------------------|
| Size             | 64KB                     | 128KB                    |
| Start Address    | 0x0000_0000              | 0x0000_0000              |
| End Address      | 0x0001_0000              | 0x0002_0000              |
| Page Size        | 512-byte                 | 512-byte                 |
| Total Page Count | 128 pages                | 256 pages                |
| PGM Unit         | 32-bit                   | 32-bit                   |
| Erase Unit       | 512-byte/ 1KB/ 4KB/ bulk | 512-byte/ 1KB/ 4KB/ bulk |





Figure 38. Flash Memory Map (128 KB Code Flash)



# 6.1 Registers

Base address of flash memory controller is introduced in the followings:

| Table 29. Base Address of Flash Memory Controller |
|---------------------------------------------------|
|---------------------------------------------------|

| Name             | Base address |
|------------------|--------------|
| Flash controller | 0x4000_0100  |

|           |        | r    |                                        |             |              |
|-----------|--------|------|----------------------------------------|-------------|--------------|
| Name      | Offset | Туре | Description                            | Reset value | Reference    |
| FMC_MR    | 0x0004 | R/W  | Flash Memory Mode Select<br>Register   | 0x0100_0000 | <u>6.1.1</u> |
| FMC_CR    | 0x0008 | R/W  | Flash Memory Control<br>Register       | 0x0000_0000 | <u>6.1.2</u> |
| FMC_AR    | 0x000C | R/W  | Flash Memory Address<br>Register       | 0x0000_0000 | <u>6.1.3</u> |
| FMC_DR    | 0x0010 | R/W  | Flash Memory Data<br>Register          | 0x0000_0000 | <u>6.1.4</u> |
| FMC_BUSY  | 0x0018 | R/W  | Flash Write Busy Status<br>Register    | 0x0000_0000 | <u>6.1.5</u> |
| FMC_CRC   | 0x0020 | R/W  | Flash CRC16 check value                | 0x0000_FFFF | <u>6.1.6</u> |
| FMC_CFG   | 0x0030 | R/W  | Flash Memory<br>Configuration Register | 0x0000_8200 | <u>6.1.7</u> |
| FMC_WPROT | 0x0034 | R/W  | Write Protection Register              | 0xFFFF_FFF  | <u>6.1.8</u> |
| FMC_LOCK  | 0x003C | R/W  | Flash LOCK Register                    | 0x0000_00FF | <u>6.1.9</u> |

### Table 30. FMC Register Map



#### 6.1.1 FMC\_MR: Flash memory mode register

FMC\_MR is an internal flash memory mode register. Size of this register is 32-bit.

Internal flash memory mode register. This register is 32-bit register.

#### FMC\_MR=0x4000\_0104

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0 |
|-----------------------------------------------------------------------|-----------------|
| Reserved                                                              | ACODE           |
| -                                                                     | 0x00            |
| · ·                                                                   | RW              |

| 7 | ACODE | 5A $\rightarrow$ A5 | Flash mode entry |
|---|-------|---------------------|------------------|
| 0 |       | $A5 \rightarrow 5A$ | Trim mode entry  |
|   |       | 81 → 28             | AMBA mode entry  |
|   |       | 66 <del>→</del> 99  | PROT mode entry  |

#### 6.1.2 FMC\_CR: Flash memory control register

FMC\_CR is an internal flash memory control register.

#### FMC\_CR=0x4000\_0108

| 31 30 29 28 27 26 25 | 24      | 23      | 22 21 20 19 18 17 16 | 15 14 13 | 12   | 11 10 9  | 8      | 7   | 6      | 5      | 4     | 3     | 2   | 1   | 0    |
|----------------------|---------|---------|----------------------|----------|------|----------|--------|-----|--------|--------|-------|-------|-----|-----|------|
| Reserved             | LOCKSEL | SELFPGM | Reserved             |          | IFEN | Reserved | BBLOCK | MAS | SECT4K | SECT1K | PMODE | WADCK | PGM | ERS | HVEN |
| -                    | 0       | 0       | -                    |          | 0    | -        | 0      | 0   | 0      | 0      | 0     | 0     | 0   | 0   | 0    |
|                      | RW      | RW      |                      |          | RW   | -        | RW     | RW  | RW     | RW     | RW    | RW    | RW  | RW  | RW   |

| 24 | LOCKSEL |   | LOCK (read protection) access enable.                                                                                                                                                                                                               |
|----|---------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 | SELFPGM |   | When this bit is set ("1"), PGM/ERS/HVEN will be cleared<br>automatically after WRBUSY falling edge. It also enable CPU<br>wait control when HVEN bit is set(1)<br>(start of program or erase operation)<br>It also affects to PMODE bit operation. |
| 12 | IFEN    | 0 | Info(OTP1/2/3) block enable                                                                                                                                                                                                                         |
|    |         | 1 | OTP1/2/3 area enable (it works with OTP3EN to OTP1EN) for<br>PMODE operation                                                                                                                                                                        |
| 8  | BBLOCK  | 0 | Boot Block (1st 4KB) not protected from Mass(Bulk) Erase                                                                                                                                                                                            |
|    |         | 1 | Boot Block (1st 4KB) protection enable from Mass(bulk) erase                                                                                                                                                                                        |
| 7  | MAS     | 0 | Mass (bulk) erase disable                                                                                                                                                                                                                           |
|    |         | 1 | Mass (bulk) erase enable.                                                                                                                                                                                                                           |
| 6  | SECT4K  | 0 | Sector 4K erase disable                                                                                                                                                                                                                             |
|    |         | 1 | Sector 4K erase enable                                                                                                                                                                                                                              |
| 5  | SECT1K  | 0 | Sector 1K erase disable                                                                                                                                                                                                                             |
|    |         | 1 | Sector 1K erase enable                                                                                                                                                                                                                              |
|    |         |   |                                                                                                                                                                                                                                                     |



| 4 | PMODE | 0 | Normal mode                                                                                                                                                                                            |
|---|-------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |       | 1 | PMODE enable(Flash Address path is connected with FMAR)<br>PMODE only valid when SELFPGM bit was not set(when<br>SELFPGM = 0)                                                                          |
| 3 | WADCK | 0 | Program/Erase address data latch clock disable                                                                                                                                                         |
|   |       | 1 | Program/Erase address data latch clock enable, this bit assert<br>for one system clock period so user cannot read                                                                                      |
| 2 | PGM   | 0 | Program mode disable                                                                                                                                                                                   |
|   |       | 1 | Program mode enable                                                                                                                                                                                    |
| 1 | ERS   | 0 | Erase mode disable                                                                                                                                                                                     |
|   |       | 1 | Erase mode enable                                                                                                                                                                                      |
| 0 | HVEN  | 0 | High Voltage cycle disable                                                                                                                                                                             |
|   |       | 1 | High Voltage cycle enable (start program or erase cycle)<br>User must set and clear in PMODE.<br>In SELFPGM mode, user must set HVEN then HVEN will be<br>cleared automatically after WRBUSY goes low. |
|   |       |   |                                                                                                                                                                                                        |

#### 6.1.3 FMC\_AR: Flash memory address register

FMC\_AR is an internal flash memory program/ erase/ address register.

|    |       |    |    |                                                                        |    |   |     |     |   |   |   |   |   |   |    |  | FM | C_AR= | 0x4000 | 0_010C |
|----|-------|----|----|------------------------------------------------------------------------|----|---|-----|-----|---|---|---|---|---|---|----|--|----|-------|--------|--------|
| 15 | 14    | 13 | 12 | 11                                                                     | 10 | 9 | 8   | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0  |  |    |       |        |        |
|    | FADDR |    |    |                                                                        |    |   |     |     |   |   |   |   |   |   |    |  |    |       |        |        |
|    |       |    |    |                                                                        |    |   | 0x0 | 000 |   |   |   |   |   |   |    |  |    |       |        |        |
|    |       |    |    |                                                                        |    |   | R   | W   |   |   |   |   |   |   |    |  |    |       |        |        |
|    |       |    |    |                                                                        |    |   |     |     |   |   |   |   |   |   |    |  |    |       |        |        |
|    |       | -  | 15 | 15 FADDR Word (32-bit) base address: 64K-word address for 256KB Flash. |    |   |     |     |   |   |   |   |   |   | า. |  |    |       |        |        |

| 15 | FADDR | Word (32-bit) base address. 04R-word address for 250RD Flash.            |
|----|-------|--------------------------------------------------------------------------|
| 0  |       | Auto Incremental after WADCK trigger (after latching of target address). |
|    |       |                                                                          |

#### 6.1.4 FMC\_DR: Flash data input register

FMC\_DR is an internal flash memory data input register.

#### FMC\_DR=0x4000\_0110

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |     |    |    |    |    |    |   |   |   |   | _ |   |   |   | - |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     | FD  | ٩ТА |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0 | 000 | 000 | 00 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    | RW |    |    |    |    |    |    |    |    |    |    |    |    |     |     |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| 31 | FDATA | Word size(32-bit) |
|----|-------|-------------------|
|    |       |                   |
| 0  |       |                   |



#### 6.1.5 FMC\_BUSY: Flash write busy status register

FMC\_BUSY is a flash write (program/erase) busy status monitor register. This register is a 1-bit read only register.

#### FMC\_BUSY=0x4000\_0118

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | Re | ser | /ed |    |    |    |    |    |   |   |   |   |   |   |   |   |   | WRBUSY |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | -   |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0      |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO     |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |        |

| 0 | WRBUSY | Write Busy status bit<br>FLBUSY bit goes high after set HVEN bit (in CTRL register).<br>FLBUSY bit goes low when WRBUSY becomes low after program (or |
|---|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |        | erase) complete.                                                                                                                                      |

#### 6.1.6 FMC\_CRC: Flash CRC check register

FMC\_CRC is the built-in CRC calculates the flash data automatically.

- 16-bit read only register [15:0], which enabled by CRCEN bit of CFG register

- At least 16-word read to get a CRC value

#### FMC\_CRC=0x4000\_0120

| 31 30 29 28 27 26 25 24 23 | 3 22 21 2 | 20 19 | 18 ´ | 17 <sup>·</sup> | 16 1 | 15 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7   | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------------------|-----------|-------|------|-----------------|------|-------|----|----|----|----|----|------|-----|----|---|---|---|---|---|---|
| Reserve                    | ed        |       |      |                 |      |       |    |    |    |    | CF | RC-0 | CCI | тт |   |   |   |   |   |   |
| -                          |           |       |      |                 |      |       |    |    |    |    | (  | ЭхF  | FFF |    |   |   |   |   |   |   |
|                            |           |       |      |                 |      |       |    |    |    |    |    | R    | W   |    |   |   |   |   |   |   |

| 15<br>0 | CRC- CCITT | CRC- CCITT check value read register<br>polynomial: $(1 + x5 + x12 + x16)$ |  |
|---------|------------|----------------------------------------------------------------------------|--|
|         |            | data width: 32 (the first serial bit is D[31])                             |  |



#### 6.1.7 FMC\_CFG: Flash memory configuration register

FMC\_CFG is an internal flash memory Configuration register.

| FMC | CFG | =0x4( | 000 | 0130 |
|-----|-----|-------|-----|------|
|     |     |       |     |      |

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 | 98   | 7       | 6     | 5 | 4  | 3   | 2    | 1 | 0 |
|-------------------------------------------------|-------------------|------|---------|-------|---|----|-----|------|---|---|
| WTIDKY                                          | Reserved          | TIAW | CRCINIT | CRCEN |   | Re | ese | erve | d |   |
| 0x7858                                          | -                 | 1 0  | 0       | 0     |   |    | -   | •    |   |   |
| WO                                              | -                 | RW   | RW      | RW    |   |    | -   |      |   |   |

| WTIDKY  |      | Write Identification Key.<br>On writes, write 0x7858 to these bits, otherwise the write is ignored.                                                                               |
|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WAIT    |      | This bits only be written in AMBA mode and MSB 16-bit (bit [31:16]) must be 0x7858                                                                                                |
|         | 00   | WAIT is 00, flash access in 1 cycle (0-wait)                                                                                                                                      |
|         | 01   | WAIT is 01, flash access in 2 cycles (1-wait)                                                                                                                                     |
|         | 10   | WAIT is 10, flash access in 3 cycles (2-wait) – default                                                                                                                           |
|         | 11   | WAIT is 11, flash access in 4 cycles (3-wait)                                                                                                                                     |
| CRCINIT | 0    | When this bit is set('1'), CRC register will be initialized<br>It should be reset again before read flash to generate CRC16<br>calculation<br>(Initial value of FMC_CRC is 0xFFF) |
| CRCEN   | 0    | CRC16 enable<br>CRC value will be calculated at every flash read timing                                                                                                           |
|         | WAIT | WAIT<br>00<br>01<br>10<br>11<br>CRCINIT<br>0                                                                                                                                      |

#### 6.1.8 FMC\_WPROT: Write protection register

FMC\_WPROT is an internal flash memory write protection register.

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |     |      |    |    |    |    |   | F | мс | _w | PR | OT= | =0x | 400 | 0_0 | 134 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|-----|------|----|----|----|----|---|---|----|----|----|-----|-----|-----|-----|-----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  | 15  | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6  | 5  | 4   | 3   | 2   | 1   | 0   |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |     |      |    |    |    |    |   |   |    |    |    |     |     |     |     |     |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | WP  | RO  | тіз | 1:01 |    |    |    |    |   |   |    |    |    |     |     |     |     |     |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     | .[• |      |    |    |    |    |   |   |    |    |    |     |     |     |     |     |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |     |      |    |    |    |    |   |   |    |    |    |     |     |     |     |     |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0xF | FFF | =_F | FFF  |    |    |    |    |   |   |    |    |    |     |     |     |     |     |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     | R   | RM  |      |    |    |    |    |   |   |    |    |    |     |     |     |     |     |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |     |      |    |    |    |    |   |   |    |    |    |     |     |     |     |     |

| 31<br>0 | WPR   | OT Write protection<br>Each 4 KB segments for whole memory address (needs 32 bits for<br>128KB flash) |
|---------|-------|-------------------------------------------------------------------------------------------------------|
| NOTE    | ES:   |                                                                                                       |
|         | 1. Ea | ch bit individually protects the 4KB area (Bit0: 0~0xFFF, Bit1: 0x1000~0x1FFF).                       |

2. The FM\_WPROT register can only be modified in PROT (FM\_MR = 66-> 99) mode.



# 6.1.9 FMC\_LOCK: Flash lock register

FMC\_LOCK is an internal flash memory read protection register.

#### FMC\_LOCK=0x4000\_013C

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4   | 3   | 2   | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|-----|-----|-----|---|---|
|    |    |    |    |    |    |    |    |    |    | R  | ese | rve | d  |    |    |    |    |    |    |    |    |   |   |   |   | F   | RPF | ROT |     |   |   |
|    |    |    |    |    |    |    |    |    |    |    | -   |     |    |    |    |    |    |    |    |    |    |   |   |   |   | 0x0 | 000 | _00 | )FF |   |   |
|    |    |    |    |    |    |    |    |    |    |    |     |     |    |    |    |    |    |    |    |    |    |   |   |   |   |     | R\  | N   |     |   |   |

| 7 F   | RPROT      | Read protection                                                                                                                                                                                  |
|-------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     |            | 0x0000_00FF is Default. Any other value will lock flash(enable read protection)<br>In user mode, 0xFF cannot be written<br>To unlock, user must erase LOCK area of Flash next to MAS(bulk) erase |
|       |            | <ul> <li>1<sup>st</sup> MAS(bulk) erase and then erase LOCK area</li> </ul>                                                                                                                      |
|       |            | - To unlock the flash, pin reset or power on reset required                                                                                                                                      |
|       |            | - When read protection occurs, Registers are shown as 0xAA55AA55.                                                                                                                                |
| NOTE: |            |                                                                                                                                                                                                  |
| 1.    | The FM_WPR | DT register can only be modified in PROT. (FM_MR = 66-> 99) mode.                                                                                                                                |



# 6.2 Functional description

#### 6.2.1 Flash erase and program examples

Basic steps of flash memory programming consist of the followings. Minimum Program or Erase unit is a Page, and 32-word (5-byte) becomes a page.

- Page erase
- Page program
- Self page erase
- Self page program

For all of erase operations, pre-program operation is required to prevent over erase of flash memory cells. In addition, a user must enable 48MHz internal oscillator first to erase or program flash.

#### Erase example

- 1. Enable flash mode to write FMC\_MCR register (write 0x5A and then write 0xA5 into FMC\_MR).
- 2. Set target Page address in FMC\_AR.
- 3. Set PMODE bit first.
- 4. Set ERS, WADCK, HVEN bits of FMC\_MCR.
- 5. Wait until IDLE bit of FMC\_MR register becomes "0" after erase.
- 6. Clear ERS, HVEN bits of FMC\_CR.
- 7. Set 0x80 to FMC\_BUSY.
- 8. Clear FMC\_CR.
- 9. Clear Flash mode (write 0x00 and then write 0x00 into FMC\_MR).



#### Program example

- 1. Enable flash mode to write FMC\_CR register (write 0x5A and then write 0xA5 into FMC\_MR).
- 2. Set PMODE bit first.
- 3. Set target Page address in FMC\_AR.
- 4. Set PGM bits of FMC\_CR.
- 5. Write word (32-bit) data into FMC\_DR, address increased automatically based on word address.
- 6. Set WADCK, HVEN bits of FMC\_CR.
- 7. Wait until IDLE bit of FMC\_MR register becomes "0" after program.
- 8. Clear HVEN bits of FMC\_CR.
- 9. Set 0x80 to FMC\_BUSY.
- 10. Clear PGM bits of FMC\_CR.
- 11. Clear FMC\_CR.
- 12. Clear Flash mode (write 0x00 and then write 0x00 into FMC\_MR).

#### Self Erase example

- 1. Enable flash mode to write FMC\_CR register (write 0x5A and then write 0xA5 into FMC\_MR).
- 2. Set SELFPGM, ERS bits of FMC\_CR.
- 3. Wait 5 clocks.
- 4. Write "0xFFFFFFF" into target address.
- 5. Wait 5 clocks.
- 6. Clear ERS bits of FMC\_CR.
- 7. Clear FMC\_CR.
- 8. Wait 5 clocks.
- 9. Clear Flash mode (write 0x00 and then write 0x00 into FMC\_MR).



### Self Program example

- 1. Enable flash mode to write FMC\_CR register (write 0x5A and then write 0xA5 into FMC\_MR).
- 2. Set SELFPGM, ERS bits of FMC\_CR.
- 3. Wait 5 clocks.
- 4. Write word (32-bit) data into target address.
- 5. Wait 5 clocks.
- 6. Clear ERS bits of FMC\_CR.
- 7. Clear FMC\_CR.
- 8. Wait 5 clocks.
- 9. Clear Flash mode (write 0x00 and then write 0x00 into FMC\_MR).



# 7. Direct Memory Access Controller (DMAC)

The direct memory access (DMA) controller is used for high-speed data transfers between peripherals and memories. DMA enables quick data transfers having memory to memory copying or moving of data within memory.

- 4 channels
- Single transfer only
- Support 8/16/32-bit data size
- Support multiple buffer with same size
- Interrupt condition is transferred through a peripheral interrupt.

# 7.1 Block diagram

In this section, DMAC block diagram is introduced in Figure 39.



Figure 39. DMAC Block Diagram



#### Registers 7.2

Base address of DMAC is introduced in the followings:

| Name   | Base address |
|--------|--------------|
| DMACH0 | 0x4000_0400  |
| DMACH1 | 0x4000_0410  |
| DMACH2 | 0x4000_0420  |
| DMACH3 | 0x4000_0430  |

### Table 31. Base Address of DMAC

### Table 32. DMAC Register Map

| Name    | Offset | Туре | Description                                  | Reset value | Reference    |
|---------|--------|------|----------------------------------------------|-------------|--------------|
| DCn.CR  | 0x0000 | RW   | DMA Channel n Control Register               | 0x0000_0000 | <u>7.2.1</u> |
| DCn.SR  | 0x0004 | RW   | DMA Channel n Status Register                | 0x0000_0000 | <u>7.2.2</u> |
| DCn.PAR | 0x0008 | R    | DMA Channel n Peripheral<br>Address Register | 0x0000_0000 | <u>7.2.3</u> |
| DCn.MAR | 0x000C | RW   | DMA Channel n Memory Address<br>Register     | 0x2000_0000 | <u>7.2.4</u> |

#### DCn.CR: DMA controller configuration register 7.2.1

DCn.CR registers are DMA operation control registers, and the register size is 32-bit.

|      |       |    |    |    |    |    |    |     |     |    |    |    |    |    |    |      | DC   | 2.0 | R= | 0x4 | 000 | _  | 420 | , D  | C3.  |    | =0x | 400 | 0_0 | 430      |
|------|-------|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|------|------|-----|----|-----|-----|----|-----|------|------|----|-----|-----|-----|----------|
| 31 3 | 0 29  | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21  | 20 | 19 | 18 | 17 | 16 | 15 | 14   | 13   | 12  | 11 | 10  | 9   | 8  | 7   | 6    | 5    | 4  | 3   | 2   | 1   | 0        |
| Re   | serve | ed |    |    |    |    | TF | RAN | SCI | NT |    |    |    |    | R  | lese | erve | ed  | F  | PER | ISE | ïL | F   | lese | erve | ed | SI  | ZE  | DIR | Reserved |
|      | -     |    |    |    |    |    |    | 0x0 | 000 |    |    |    |    |    |    |      | •    |     |    | (   | )   |    |     |      | -    |    | 0   | 0   | 0   | -        |
|      | •     |    |    |    |    |    |    | R   | W   |    |    |    |    |    |    |      |      |     |    | R   | W   |    |     |      | -    |    | R   | W   | RW  | -        |

# DC0.CR=0x4000\_0400, DC1.CR=0x4000\_0410



| 27<br>16 | TRANSCNT | Number of DMA transfer remained<br>Required transfer number should be written before enable DMA<br>transfer. |
|----------|----------|--------------------------------------------------------------------------------------------------------------|
|          |          | 0 DMA transfer is done.                                                                                      |
|          |          | N N transfers are remained                                                                                   |
| 11       | PERISEL  | Peripheral selection                                                                                         |
| 8        |          | N Associated peripheral selection.<br>Refer to DMA Peripheral connection table                               |
| 3        | SIZE     | Bus transfer size.                                                                                           |
| 2        |          | 00 DMA transfer is byte size transfer                                                                        |
|          |          | 01 DMA transfer is half word size transfer                                                                   |
|          |          | 10 DMA transfer is word size transfer                                                                        |
|          |          | 11 Reserved                                                                                                  |
| 1        | DIR      | Select transfer direction.                                                                                   |
|          |          | 0 Transfer direction is from memory to peripheral. (TX)                                                      |
|          |          | 1 Transfer direction is from peripheral to memory (RX)                                                       |

with selected peripheral. Below table shows peripheral selection numbers. This PERISEL field should be set with proper number of peripheral which will be connected with DMA interface.

| PERISEL[3:0] | Associate peripheral |
|--------------|----------------------|
| 0            | CHANNEL IDLE         |
| 1            | SPI20 RX             |
| 2            | SPI20 TX             |
| 3            | SPI21 RX             |
| 4            | SPI21 TX             |
| 5            | USART10 RX           |
| 6            | USART10 TX           |
| 7            | USART11 RX           |
| 8            | USART11 TX           |
| 9            | USART12 RX           |
| 10           | USART12 TX           |
| 11           | USART13 RX           |
| 12           | USART13 TX           |
| 13           | CRC                  |
| 14           | ADC                  |
| 15           | Reserved             |

#### Table 33. DMAC PERISEL Selection

PERISEL cannot have the same value in different channels. If the same PERISEL value is written in more than one channel, proper operation cannot be guaranteed. Unused channel should have CHANNEL IDLE value in PERISEL bit positions.



### 7.2.2 DCn.SR: DMA controller status register

DCn.SR registers represent current status of DMA Controller, and enable DMA function. The register size is 8-bit.

#### DC0.SR=0x4000\_0404 , DC1.SR=0x4000\_0414 DC2.SR=0x4000\_0424 , DC3.SR=0x4000\_0434

|                                                                     | -   | ,     |       |     | -     |
|---------------------------------------------------------------------|-----|-------|-------|-----|-------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 | 8 7 | 6 5 4 | 3 2   | 1 ( | 0     |
| Reserved                                                            | EOT | Res   | erved |     | DMAEN |
| -                                                                   | 1   |       | -     | (   | 0     |
|                                                                     | RO  |       | -     | R   | RW    |

| 7 | EOT   | End of transfer.                                                       |
|---|-------|------------------------------------------------------------------------|
|   |       | 0 Data to be transferred is existing.<br>TRANSCNT shows non zero value |
|   |       | 1 All data is transferred.<br>TRANSCNT shows now 0                     |
| 0 | DMAEN | DMA Enable                                                             |
|   |       | 0 DMA is in stop or hold state                                         |
|   |       | 1 DMA is running or enabled                                            |

#### 7.2.3 DCn.PAR: DMA controller peripheral address register

DCn.PAR registers represent peripheral addresses.

|                                                 | DC0.PAR=0x4000_0408 , DC1.PAR=0x4000_0418<br>DC2.PAR=0x4000_0428 , DC3.PAR=0x4000_0438 |  |  |  |  |  |  |  |  |
|-------------------------------------------------|----------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                  |  |  |  |  |  |  |  |  |
| Peripheral Base address Offset                  | PAR                                                                                    |  |  |  |  |  |  |  |  |
| 0x4000                                          | 0x0000                                                                                 |  |  |  |  |  |  |  |  |
| RO                                              | RW                                                                                     |  |  |  |  |  |  |  |  |
|                                                 |                                                                                        |  |  |  |  |  |  |  |  |

| 15 | PAR | Target Peripheral address of transmit buffer or receive buffer.                                                                                                                                               |
|----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0  |     | User must set exact target peripheral buffer address in this field.<br>If DIR is "0" this address is destination address of data transfer.<br>If DIR is "1", this address is source address of data transfer. |



#### 7.2.4 DCn.MAR: DMA controller memory address register

DCn.MAR registers represent the memory addresses.

#### DC0.MAR=0x4000\_040C , DC1.MAR=0x4000\_041C DC2.MAR=0x4000\_042C , DC3.MAR=0x4000\_043C

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |  |
|-------------------------------------------------|---------------------------------------|--|--|--|--|--|--|--|--|--|
| Memory Base address Offset                      | MAR                                   |  |  |  |  |  |  |  |  |  |
| 0x2000                                          | 0x0000                                |  |  |  |  |  |  |  |  |  |
| RO                                              | RW                                    |  |  |  |  |  |  |  |  |  |

| 15 | MAR | Target memory address of data transfer.                              |
|----|-----|----------------------------------------------------------------------|
| 0  |     | Address is automatically incremented according to SIZE bits when     |
|    |     | each transfer is done.                                               |
|    |     | If DIR is "0" this address is source address of data transfer.       |
|    |     | If DIR is "1", this address is destination address of data transfer. |



# 7.3 Functional description

A DMA controller performs direct memory transfer by sharing the system bus with CPU core. The system bus is shared by two AHB (Advanced High-performance Bus) masters following the round-robin priority strategy. So the DMA controller can share the half of system bandwidth.

The DMA controller can be triggered only by a peripheral request. When a peripheral requests a transfer to the DMA controller, a corresponding channel is activated and the bus is accessed to transfer the requested data from memory to peripheral data buffer or vice versa.

Basic steps to trigger DMAC data transfer consist of following 10 steps:

- 1. Set both of peripheral address and memory address.
- 2. Configure DMA operation mode and transfer count.
- 3. Enable a DMA channel.
- 4. DMA request is occurred from the peripheral.
- 5. DMA activates the channel which was requested.
- 6. DMA reads data from source address and saves in internal buffer.
- 7. DMA writes the buffered data to destination address.
- 8. Transfer count number is decreased by '1'.
- 9. When the transfer count is '0', EOT flag is set and noticed to peripheral to issue the interrupt
- 10. DMA does not have interrupt sources, and the interrupt related DMA status can be shown from assigned peripheral interrupt.





Figure 40. DMAC Functional Block Diagram

#### 7.3.1 DMA operation

A user can start DMA operation by following the procedure introduced below:

- 1. Set DCn.CR registers of DMA.
  - [27:16]: Set a number of data to transfer to DMA.
  - [11:8]: Select a peripheral to connect with DMA.
  - [3:2]: Select a buffer size to transfer.
  - [1]: Set a transfer type from TX and RX.
- 2. Set MAR register of DMA (memory address to which DMA accesses).
- 3. Set PAR register of DMA (peripheral address to which DMA accesses).
- 4. Check the EOT flag of DMA start and DCn.SR register.
- 5. Check the DMA flag through status register of each peripheral.
- 6. DMA stops.







Figure 41. DMAC Operation Sequence

Figure 42 shows the functional timing diagram of DMAC. Transfer request from a certain peripheral is pended internally and it will invoke source data read transfer on the AHB bus. The read data from the source address is stored in the internal buffer. Then this data will be transferred to the destination address when the AHB bus is available.

Figure 42 introduces the timing diagram for a DMA transfer from peripheral to memory. There is 4-clock cycle latencies during accessing the peripheral. If the bus is occupied by different bus master, there are amount of bus waiting cycles.





Figure 42. Timing Diagram of DMAC Transfer from Peripheral to Memory

Figure 43 introduces the timing diagram for a DMA transfer from memory to peripheral. There is 4-clock cycle latencies during accessing the peripheral. If the bus is occupied by different bus master, there are amount of bus waiting cycles.



Figure 43. Timing Diagram of DMAC Transfer from Memory to Peripheral

Figure 44 introduces an example of N data transfers with DMA. The DMA transfer is started when DCnSR.DMAEN is set. When all the number of transfer is completed, the DCnSR.DMAEN register will be cleared.



Figure 44. Timing Diagram Example of N DMAC Transfer



# 8. Static memory controller (EBI)

Static memory controller is used for external bus interfaces to control external memory I/Os. External memory area is divided to 4 sections. 1MByte memory area is allocated for each section respectively. Memory devices (SRAM, ROM and Flash) or I/O devices can be mapped to the memory section. Bus configurations such as bus width of external device and the number of wait are configurable in each section; a user can attach many kinds of memories or I/O devices.

Table 34 introduces pins assigned for static memory controller.

| Pin name | Туре | Description                                                                                                                                                                                                                                            |  |  |  |  |
|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| nCS[3:0] | 0    | Select memory region from 0 to 3.                                                                                                                                                                                                                      |  |  |  |  |
| nRD      | 0    | Perform read operation from external memory.                                                                                                                                                                                                           |  |  |  |  |
| nUWR     | 0    | Upper byte write signal.<br>When 16-bit bank is organized using 8bit memory, this pin indicates that D[15:8] is<br>being written to external memory                                                                                                    |  |  |  |  |
| nLWR/nWE | 0    | Lower byte write signal.<br>It is used in various ways according to the memory and bank organization.<br>When 8-bit or 16-bit bank is organized using 8-bit memory, this pin indicates that<br>lower byte, D[7:0] is being written to external memory. |  |  |  |  |
| nUDS     | 0    | Upper Data Select signal.<br>It is used in various ways according to the memory and bank organization.<br>When 16-bit bank is organized using 16-bit memory, this pin indicates that upper<br>byte is being selected.                                  |  |  |  |  |
| nLDS     | 0    | Lower Data Select signal.<br>It is used in various ways according to the memory and bank organization.<br>When 16-bit bank is organized using 16-bit memory, this pin indicates that lower<br>byte is being selected.                                  |  |  |  |  |
| nWAIT    | I    | This pin is an external wait signal pin.<br>If value of this pin becomes "L", wait is added as much as nWAIT maintains "L".                                                                                                                            |  |  |  |  |
| ALE      | 0    | Address Latch Enable<br>In the case of muxed Address/Data access, external address buffer for A[15:0] must<br>be used.<br>Address buffer latch AD[15:0] signals when ALE is high.                                                                      |  |  |  |  |
| A[19:16] | 0    | Upper Address bus for external memory devices                                                                                                                                                                                                          |  |  |  |  |
| AD[15:0] | I/O  | Address or Data input/output bus for external memory devices                                                                                                                                                                                           |  |  |  |  |

Table 34. Pin Assignment of Static Memory Controller



# 8.1 Block diagram



In this section, static memory controller is described in Figure 45.

Figure 45. Static Memory Controller Block Diagram

# 8.2 Registers

Base address of static memory controller is introduced in the followings:

| Name                     | Base address |  |  |
|--------------------------|--------------|--|--|
| Static memory controller | 0x4000_6200  |  |  |

#### Table 36. SMIF Register Map

| Name    | Offset                                        | Туре | Description                         | Reset value | Reference    |
|---------|-----------------------------------------------|------|-------------------------------------|-------------|--------------|
| SMIBCR0 | 0x0000                                        | RW   | nCS[0] memory area config. register | 0x00011F3F  | <u>8.2.1</u> |
| SMIBCR1 | 0x0004 RW nCS[1] memory area config. register |      | 0x00011F3F                          |             |              |
| SMIBCR2 | 0x0008                                        | RW   | nCS[2] memory area config. register | 0x00001F3F  |              |
| SMIBCR3 | 0x000C RW                                     |      | nCS[3] memory area config. register | 0x00001F3F  |              |



3

#### 8.2.1 SMIBCRn: Memory area configuration register n

BCRn registers are memory area configuration register. Register size is 32-bit.

#### SMIBCR0=0x4000\_6200, SMIBCR1=0x4000\_6204 SMIBCR2=0x4000\_6208, SMIBCR3=0x4000\_620C

|       |          |        |                                                                                                                                  | r       |      |     |                                      |            |                                                                                                                                                                       |                                              |  |  |  |  |
|-------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------|---------|------|-----|--------------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|--|--|--|--|
| 31 30 | 29 28    | 27 26  | 25 24                                                                                                                            | 23      | 22   | 21  | 20                                   | 19 18      | 17 16                                                                                                                                                                 | <u>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0</u> |  |  |  |  |
| IDLE  | Reserved | PREIDL | Reserved                                                                                                                         | EWEN    | EWP  | IOE | BLEN                                 | АН         | MWIDTH                                                                                                                                                                | Reserved NORMWAIT                            |  |  |  |  |
| 00    | -        | 00     | -                                                                                                                                | 0       | 0    | 0   | 0                                    | 0          | 0                                                                                                                                                                     | - 0x3F                                       |  |  |  |  |
| RW    | -        | RW     | -                                                                                                                                | RW      | RW   | RW  | RW                                   | RW RW - RW |                                                                                                                                                                       |                                              |  |  |  |  |
|       |          | -      |                                                                                                                                  |         |      |     |                                      |            |                                                                                                                                                                       |                                              |  |  |  |  |
|       |          |        | 31<br>30                                                                                                                         | ID      | LE   |     |                                      |            |                                                                                                                                                                       | E cycle at memory access time                |  |  |  |  |
|       |          |        | 00                                                                                                                               |         |      |     |                                      |            | 00                                                                                                                                                                    | No additional cycle                          |  |  |  |  |
|       |          |        |                                                                                                                                  |         |      |     |                                      |            | )1                                                                                                                                                                    | Insert 1 IDLE cycle                          |  |  |  |  |
|       |          |        |                                                                                                                                  |         |      |     |                                      |            | 0                                                                                                                                                                     | Insert 2 IDLE cycle                          |  |  |  |  |
|       |          | -      | 07                                                                                                                               |         |      |     |                                      |            | 1                                                                                                                                                                     | Insert 3 IDLE cycle                          |  |  |  |  |
|       |          |        | 27<br>26                                                                                                                         | Pr      | REID | )L  |                                      |            | 0 0                                                                                                                                                                   | falling timing of RD and nUWR/nLWR           |  |  |  |  |
|       |          |        | -                                                                                                                                |         |      |     |                                      |            | )0<br>)1                                                                                                                                                              | No additional cycle                          |  |  |  |  |
|       |          |        |                                                                                                                                  |         |      |     |                                      |            |                                                                                                                                                                       | Extend 1 clock cycle                         |  |  |  |  |
|       |          |        |                                                                                                                                  |         |      |     |                                      |            | 10         Extend 2 clock cycle           11         Extend 3 clock cycle                                                                                             |                                              |  |  |  |  |
|       |          | -      | 23                                                                                                                               | 23 EWEN |      |     |                                      |            | 0 Ignore external input nWAIT                                                                                                                                         |                                              |  |  |  |  |
|       |          |        | 23 LWLIN                                                                                                                         |         |      |     |                                      |            | 1 Enable external input nWAIT request                                                                                                                                 |                                              |  |  |  |  |
|       |          | -      | 22 EWP                                                                                                                           |         |      |     |                                      |            | 0 nWAIT polarity is active low                                                                                                                                        |                                              |  |  |  |  |
|       |          |        |                                                                                                                                  |         |      |     |                                      |            | 1 nWAIT polarity is active high                                                                                                                                       |                                              |  |  |  |  |
|       |          | -      | 21                                                                                                                               | 10      | E    |     |                                      |            | 0 Separated Address/Data access                                                                                                                                       |                                              |  |  |  |  |
|       |          |        |                                                                                                                                  |         |      |     |                                      | 1          |                                                                                                                                                                       | Enable muxed Address/Data access             |  |  |  |  |
|       |          | -      | 20                                                                                                                               | BL      | EN   |     |                                      | 0          | 0 Disable byte lane selection in case of 8bit me<br>organization                                                                                                      |                                              |  |  |  |  |
|       |          |        |                                                                                                                                  |         |      |     |                                      | 1          | 1 Enable byte lane selection in case of 8bit memo<br>organization                                                                                                     |                                              |  |  |  |  |
|       |          | -      | 19 AH<br>18                                                                                                                      |         |      |     |                                      | r          | When accessing A/D mux I/O area, "AH" represents the innumber of clock cycle) while the address is valid.<br>Address keeps the value for "AH + 1" clock (HCLK) cycle. |                                              |  |  |  |  |
|       |          |        |                                                                                                                                  |         |      |     |                                      | 0          | 00 Keep the address for 1 clock cycle                                                                                                                                 |                                              |  |  |  |  |
|       |          |        |                                                                                                                                  |         |      |     |                                      | 0          | )1                                                                                                                                                                    | Keep the address for 2 clock cycle           |  |  |  |  |
|       |          |        |                                                                                                                                  |         |      |     |                                      | 1          | 10 Keep the address for 3 clock cycle                                                                                                                                 |                                              |  |  |  |  |
|       |          | _      |                                                                                                                                  |         |      |     |                                      | 1          | 11 Keep the address for 4 clock cycle                                                                                                                                 |                                              |  |  |  |  |
|       |          | _      | 17 MWIDTH                                                                                                                        |         |      | 0   | 00 External memory bus is 8bit width |            |                                                                                                                                                                       |                                              |  |  |  |  |
|       |          | _      | 16                                                                                                                               |         |      |     |                                      | 0          | )1                                                                                                                                                                    | External memory bus is 16bit width           |  |  |  |  |
|       |          | _      | 5NORMWAITIt represents wait value to be used for memory read/write operation.064 wait is supported and wait value is NORMWAIT+1. |         |      |     |                                      |            |                                                                                                                                                                       |                                              |  |  |  |  |
|       |          | -      | NOTES                                                                                                                            |         |      |     |                                      |            |                                                                                                                                                                       |                                              |  |  |  |  |

#### NOTES:

1. Memory read/write access time. 1-64 wait is supported and wait value NORMWAIT - PREIDL.

2. NORMWAIT must be greater than PREIDL (NORMWAIT > PREIDL).



# 8.3 Functional description

External memory register is organized with 4 sections. Each section consists of 1MB address region. A[26:24] is used to select memory region and A[19:0] is used in each memory region.

Table 37 provides memory map information regarding internal address. External memory region offset is 0x60000000 in the memory map.

| A[26:24] | nCS[3:0] | Memory region              |
|----------|----------|----------------------------|
| 000      | 1110     | 0x6000_0000 to 0x600F_FFFF |
| 001      | 1101     | 0x6100_0000 to 0x610F_FFFF |
| 010      | 1011     | 0x6200_0000 to 0x620F_FFFF |
| 011      | 0111     | 0x6300_0000 to 0x630F_FFFF |

Table 37. Memory Region Selection and nCS Output by Address

#### 8.3.1 Chip select signal

Chip select signal, nCS[3:0] becomes "L" when corresponding memory region is selected, and it has a various signal width according to the IDLE field of the SMIBCRn. Chips select signal is changed at the rising edge of internal bus clock.

### 8.3.2 Byte lane control and control signal

Data access size of CPU or internal bus master can be 8-bit, 16-bit or 32-bit. SMI controller should sort the data form external bus. When bus master accesses external memory region, SMI determines which byte will be used between upper and lower byte according to bus control register.

Table 38 shows data is sorted by memory access size. Lower byte D[7:0] is used for 8-bit access, and upper byte D[15:8] is used for 16-bit access. Figure 46 shows that sort in 8-bit memory bus system. In this case, only D[7:0] is used regardless of memory access size.

| Internal access<br>width | External access cycle         | Upper byte lane<br>D[15:8] | Lower byte lane<br>D[7:0]  |  |
|--------------------------|-------------------------------|----------------------------|----------------------------|--|
| Byte size access         | 1 <sup>st</sup> EBI BUS Cycle | Not valid                  | Valid for byte A[1:0]      |  |
| Half word size           | 1 <sup>st</sup> EBI BUS Cycle | Not valid                  | Valid for byte A[0] = 0    |  |
| access                   | 2 <sup>nd</sup> EBI BUS Cycle | Not valid                  | Valid for byte A[0] = 1    |  |
| Word size access         | 1 <sup>st</sup> EBI BUS Cycle | Not valid                  | Valid for byte A[1:0] = 00 |  |
|                          | 2 <sup>nd</sup> EBI BUS Cycle | Not valid                  | Valid for byte A[1:0] = 01 |  |
|                          | 3 <sup>rd</sup> EBI BUS Cycle | Not valid                  | Valid for byte A[1:0] = 10 |  |
|                          | 4 <sup>th</sup> EBI BUS Cycle |                            | Valid for byte A[1:0] = 11 |  |

Table 38. Data Sort for 8-bit Memory Bus



Table 39 shows 16-bit memory bus system. In the case of byte access, it is determined which byte will be used between D[7:0] and D[15:8]. In case of half word or word access, D[15:0] and D[7:0] take upper byte and lower byte.

| Internal access<br>width | External access cycle         | Upper byte lane<br>D[15:8]    | Lower byte lane<br>D[7:0]     |
|--------------------------|-------------------------------|-------------------------------|-------------------------------|
| Byte size access         | 1 <sup>st</sup> EBI BUS Cycle | Not valid                     | Valid for byte A[0] = 0       |
|                          | 1 <sup>st</sup> EBI BUS Cycle | Valid for byte A[0] = 1       | Not valid                     |
| Half word size access    | 1 <sup>st</sup> EBI BUS Cycle | Valid for upper byte          | Valid for lower byte          |
| Word size                | 1 <sup>st</sup> EBI BUS Cycle | Valid for upper byte A[1] = 0 | Valid for lower byte A[1] = 0 |
| access                   | 2 <sup>nd</sup> EBI BUS Cycle | Valid for upper byte A[1] = 1 | Valid for lower byte A[1] = 1 |

Table 39. Data Sort for 16-bit Memory Bus

Signals nUWR and nLWR are generated according to the bus width, type of memory and A[0]. Table 40 shows example accessing 8-bit memory using 16-bit memory bus D[15:0].

# Table 40. Config Signal by A[0]

| Internal access size | A[0] | nUWR | nLWR | Access size |
|----------------------|------|------|------|-------------|
| Half word            | X    | L    | L    | 16-bit      |
| Byte                 | 0    | н    | L    | 8-bit       |
| Byte                 | 1    | L    | н    | 8-bit       |

Figure 46 shows bus configuration with 8-bit memory type. Signals nUWR and nLWR are used for 8-bit or 16-bit bus with 8-bit memory type.



Figure 46. Bus Configuration with 8-bit Memory



Figure 47 describes memory configuration with 16-bit memory. In this case, byte selection signals, nUDS and nLDS are required.



Figure 47. Bus Configuration with 16-bit Memory

As seen in Figure 47, with 8-bit memory, regardless of the bus width, nLWR and nUWR are connected for write operation, and nRD is connected for read operation. With 16-bit memory, nWE and nRD are connected in write and read operation. nUDS and nLDS are connected in both read and write operations. nUDS and nLDS are byte selection signals of memory.



#### 8.3.3 Bus control signal in read operation

Read operation by SMI is initiated after wait cycle of NORMWAIT in SMIBCRn register.

Figure 48 shows word read operation in case of "NORMWAIT =1". Word read is possible with 4 times of byte access because 8-bit bus is used.



Figure 48. Word Read Operation with 8-bit Memory and 8-bit Bus

Figure 49 shows half word read operation when "NORMWAIT = 2". Like the previous case, half word memory read is possible with 2 times of byte memory access because only 8-bit bus is used.



Figure 49. Half Word Read Operation with 8-bit Memory and 8-bit Bus



Figure 50 shows word read operation when "NORMWAIT = 2". D[15:0] is used as data bus because 16-bit bus is used. Word read is possible with 2 times of memory access.



Figure 50. Word Read Operation with 8-bit Memory and 16-bit Bus

Figure 51 shows half word read operation when "NORMWAIT = 2". D[15:0] is used as data bus because 16-bit bus is used. Half word read is possible with 1 times of memory access.



Figure 51. Half Word Read Operation with 8-bit Memory and 16-bit Bus



Figure 52 and Figure 53 show word and half word read operation when "NORMWAIT = 2". D[15:0] is used as data bus for 16-bit bus. Word and half word read are possible with 2 and 2 times of memory access. Because bus is organized with 16-bit memory, upper byte selection signal "nUDS" and lower byte signal "nLDS" is used with nRD signal.



Figure 52. Word Read Operation with 16-bit Memory and 16-bit Bus



Figure 53. Half Word Read Operation with 16-bit Memory and 16-bit Bus



# 8.3.4 Bus control signal in write operation

Figure 54 and Figure 55 show word and half word operations when "NORMWAIT = 1" and "NORMWAIT = 2". D[7:0] is used for 8-bit bus. Word and half word write operations are possible through 4 and 2 times of memory access. nUWR will not change to "L" because 8-bit bus is used.



Figure 54. Word Write Operation with 8-bit Memory and 8-bit Bus



Figure 55. Half Word Write Operation with 8-bit Memory and 8-bit Bus



Figure 56 and Figure 57 show word and half word write operations when "NORMWAIT= 2". D[7:0] is used for 16-bit bus. Word and half word writes are possible with 2 and 1 times of memory access.



Figure 56. Word Write Operation with 8-bit Memory and 16-bit Bus



Figure 57. Half Word Write Operation with 8-bit Memory and 16-bit Bus



Figure 58 and Figure 59 show word (half word) write operations when "NORMWAIT = 2". D[15:0] is used for 16-bit bus. Word (half word) write is possible with 2(1) times of memory access. Byte select signals (nUDS, nLDS) are used with nRD and nWE signals because 16-bit memory is used.



Figure 58. Word Write Operation with 16-bit Memory and 16-bit Bus



Figure 59. Half Word Write Operation with 16-bit Memory and 16-bit Bus



# 8.3.5 Timing change of control signals

As setting IDLE field, it is possible to change IDLE cycle. This equals to keeping "H" as long as cycle defined by changing nCS from "L" to "H" as shown in Figure 60 and Figure 61. nRD/nUWR/nLWR signals are possible to be extended up to 3 clock cycles by setting PREIDL field.

Figure 60 shows that nCS keeps "H" after memory access when IDLE field is set to "1". This represents that additional cycle is inserted as much as the number of IDLE.



Figure 60. Read Timing Changing by 'IDLE = 1'

Figure 61 shows that nLWR and nUWR are delayed as much as the number of PREAMBLE when PREIDL is "2". In case of read operation, nRD is delayed as much as PREAMBLE.



Figure 61. Write Timing Changing by 'PREIDL = 1'



# 8.3.6 Wait control while accessing memory

Internal wait is applied as much as NORMWAIT value while accessing memory and bus cycle can be extended by adding external wait using nWAIT input. Internal wait ranges from 1 to 64. It is applied automatically whenever accessing memory.

nWAIT becomes active according to EWP (External nWAIT Polarity). The bus enters in wait state internally until nWAIT becomes inactive. If EWO is "0", external wait is active when nWAIT is "L". If EWP is "1", external wait is active when nWAIT is "H".



Figure 62. Write Operation with External Wait (nWAIT), 'EXP = 0'



# 9. Watchdog timer (WDT)

Watchdog timer (WDT) rapidly detects CPU's malfunction such as endless looping caused by noise, and resumes the CPU to the normal state. WDT signal for malfunction detection can be used as either a CPU reset or an interrupt request. When WDT is not being used for malfunction detection, it can be used as a timer generating an interrupt at fixed intervals.

When WDT\_CNT value is reached to WDT\_WINDR value, a watchdog interrupt can be generated. The underflow time of WDT can be set by WDT\_DR. If the underflow occurs, an internal reset is generated. WDT operates on the WDTRC embedded RC oscillator clock.

WDT of A31G32x series features followings:

- 24-bit down counter (WDT\_CNT)
- Select reset or periodic interrupt
- Count clock selection
- Watchdog overflow output signal
- Counter window function

# 9.1 WDT block diagram

In this section, WDT block diagram is introduced in Figure 63.



Figure 63. WDT Block Diagram



# 9.2 Registers

Base address of WDT is introduced in the followings:

# Table 41. Base Address of WDT

| Name | Base address |
|------|--------------|
| WDT  | 0x4000_1A00  |

| Name      | Offset | Туре | Description                                | Reset value | Reference    |
|-----------|--------|------|--------------------------------------------|-------------|--------------|
| WDT_CR    | 0x0000 | RW   | Watch-dog Timer Control<br>Register        | 0x0000_0000 | <u>9.2.1</u> |
| WDT_SR    | 0x0004 | RW   | Watch-dog Timer Status<br>Register         | 0x0000_0080 | <u>9.2.2</u> |
| WDT_DR    | 0x0008 | RW   | Watch-dog Timer Data<br>Register           | 0x0000_3D09 | <u>9.2.3</u> |
| WDT_CNT   | 0x000C | RO   | Watch-dog Timer Counter<br>Register        | 0x0000_0FFF | <u>9.2.4</u> |
| WDT_WINDR | 0x0010 | RW   | Watch-dog Timer Window<br>Data Register    | 0x0000_FFFF | <u>9.2.5</u> |
| WDT_CNTR  | 0x0014 | WO   | Watch-dog Timer Counter<br>Reload Register | 0x0000_0000 | <u>9.2.6</u> |

# Table 42. WDT Register Map



# 9.2.1 WDT\_CR: Watchdog timer control register

WDT module should be configured properly before running. WDT module can make reset event or assert interrupt signal to system. Size of this register is 32-bit.

| WDT | CR=0x4000    | 1A00  |
|-----|--------------|-------|
|     | _011 0/4000_ | 17.00 |

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 | 9 8 7 6 5 4 | 3    | 2 1 0  |
|-------------------------------------------------|-------------------|-------------|------|--------|
| WTIDKY                                          | RSTEN CNTEN       |             |      | CLKDIV |
| 0x0000                                          | 000000            | 000000      | 0    | 0 00   |
| WO                                              | RW                | RW          | RW F | RW RW  |

| 31     | WTIDKY  | Write Identification Key.                                                          |  |  |  |  |  |
|--------|---------|------------------------------------------------------------------------------------|--|--|--|--|--|
| 16     |         | On writes, write 0x5A69 to these bits, otherwise the write is ignored.             |  |  |  |  |  |
| 15     | RSTEN   | Watch-dog Timer Reset Enable bits.                                                 |  |  |  |  |  |
| 10     |         | 0x25 Disable watch-dog timer reset.                                                |  |  |  |  |  |
|        |         | Others Enable watch-dog timer reset.                                               |  |  |  |  |  |
| 9      | CNTEN   | Watch-dog Timer Counter Enable bits.                                               |  |  |  |  |  |
| 4      |         | 0x1A Disable watch-dog timer counter.                                              |  |  |  |  |  |
|        |         | Others Enable window data match interrupt.                                         |  |  |  |  |  |
| 3      | WINMIEN | Watch-dog Timer Window Match Interrupt Enable bit.                                 |  |  |  |  |  |
|        |         | 0 Disable window data match interrupt.                                             |  |  |  |  |  |
|        |         | 1 Enable window data match interrupt.                                              |  |  |  |  |  |
| 2      | UNFIEN  | Watch-dog Timer Underflow Interrupt Enable bit.                                    |  |  |  |  |  |
|        |         | 0 Disable watch-dog timer underflow interrupt.                                     |  |  |  |  |  |
|        |         | 1 Enable watch-dog timer underflow interrupt.                                      |  |  |  |  |  |
| 1<br>0 | CLKDIV  | Watch-dog Timer Clock Divider bits, The clock which is selected by SCU_PPCLKSR[0]. |  |  |  |  |  |
|        |         | 00 fWDT/4                                                                          |  |  |  |  |  |
|        |         | 01 fWDT/16                                                                         |  |  |  |  |  |
|        |         | 10 fWDT/64                                                                         |  |  |  |  |  |
|        |         | 11 fWDT/256                                                                        |  |  |  |  |  |



#### 9.2.2 WDT\_SR: Watchdog timer status register

WDT\_SR register is 32-bit size, and able to do 32/16/8-bit access.

| WDT | SR=0> | (4000 | 1A04 |
|-----|-------|-------|------|
|     |       |       |      |

| 31 | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 | 8 | 7        | 6 5 | 4    | 3   | 2 1 | 0        |
|----|------------------------------------------------------------------|---|----------|-----|------|-----|-----|----------|
|    | Reserved                                                         |   | DBGCNTEN | Re  | eser | ved |     | UNFIFLAG |
|    | -                                                                |   | 1        |     | -    |     | 0   | 0 0      |
|    |                                                                  | ł | RW       |     |      |     | R   | W RW     |

| -         | 0     |                                                                  |
|-----------|-------|------------------------------------------------------------------|
| -         | •     | The watch-dog timer counter continues even if the core is halted |
|           | 1     | The watch-dog timer counter is stopped when the core is halted   |
| =         | Note: | This bit is set to "1b" by POR reset.                            |
| /INMIFLAG | Watch | n-dog Timer Window Match Interrupt Flag bit.                     |
| -         | 0     | No request occurred.                                             |
| -         | 1     | Request occurred, This bit is cleared to '0' when write '1'.     |
| NFIFLAG   | Watch | n-dog Timer Underflow Interrupt Flag bit.                        |
| -         | 0     | No request occurred.                                             |
| -         | 1     | Request occurred, This bit is cleared to '0' when write '1.      |
|           | -     | /INMIFLAG Watch<br>0<br>1<br>NFIFLAG Watch                       |

2. Window match flag is recommended for System Clock(fx) ≥ 2\*WDT Clock(WDT)

# 9.2.3 WDT\_DR: Watchdog timer data register

WDT\_DR register is used to update WDT\_CNT register. Size of this register is 32-bit.

|                        | WDT_DR=0x4000_                                            | 1A08 |
|------------------------|-----------------------------------------------------------|------|
| 31 30 29 28 27 26 25 2 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0  |
| Reserved               | DATA                                                      |      |
| -                      | 0x003D09                                                  |      |
|                        | RW                                                        |      |

| 23<br>0 | DATA | Watch-dog Timer Data bits. The range is 0x000000 to 0xFFFFFF. |
|---------|------|---------------------------------------------------------------|
| NOTE    | :    |                                                               |

1. Once any value is written to this data register, the register can't be changed until a system reset.



#### 9.2.4 WDT\_CNT: Watchdog timer counter register

WDT\_CNT register represents the current count value of 32-bit down counter. When the counter value reach to 0, the interrupt or reset will be asserted. Size of this register is 32-bit.

WDT\_CNT=0x4000\_1A0C

| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------------------------|---------------------------------------------------------------|
| Reserved                | CNT                                                           |
| -                       | 0x000FFF                                                      |
| -                       | RO                                                            |
|                         |                                                               |



#### 9.2.5 WDT\_WINDR: Watchdog timer window data register

WDT\_WINDR register is used to compare with WDT\_CNT for WINDOW function. Size of this register is 32-bit.

|                         |                                             | V | VDT | _w | /INE | DR= | 0x4 | 000 | )_1/ | A10 |
|-------------------------|---------------------------------------------|---|-----|----|------|-----|-----|-----|------|-----|
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 | 8 | 7   | 6  | 5    | 4   | 3   | 2   | 1    | 0   |
| Reserved                | WDATA                                       |   |     |    |      |     |     |     |      |     |
| -                       | 0x00FFFF                                    |   |     |    |      |     |     |     |      |     |
|                         | RW                                          |   |     |    |      |     |     |     |      |     |

| 23<br>0 | WDATA      | Watch-dog Timer Data bits. The range is 0x000000 to 0xFFFFF.                         |
|---------|------------|--------------------------------------------------------------------------------------|
| NOTE:   |            |                                                                                      |
| 1.      | Once any v | value is written to this data register, the register can't be changed until a system |

reset.



# 9.2.6 WDT\_CNTR: Watchdog timer counter reload register

WDT\_CNTR register is used to make reload signal. If reload signal is I, WDT\_DR Value is reloaded to WDT\_CNT. Size of this register is 32-bit.

| WDT | CNTR=0x400 | 0 1A14 |
|-----|------------|--------|
|     |            | •      |

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 6 5 4 3 | 2 1 0 |
|-----------------------------------------------------------------------|-----------|-------|
| Reserved                                                              | CNTR      |       |
| -                                                                     | 0x00      |       |
|                                                                       | WO        |       |

| 7 | CNTR | Watch-dog | Watch-dog Timer Counter Reload bits.                                                                              |  |  |  |  |  |  |  |  |
|---|------|-----------|-------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 0 |      | 0x6A      | Reload the WDTDR value to watch-dog timer counter and re-start. (Automatically cleared to "0x00" after operation) |  |  |  |  |  |  |  |  |
|   |      | Others    | No effect                                                                                                         |  |  |  |  |  |  |  |  |

# 9.3 Functional description

WDT counter can be enabled by CNTEN (WDT\_CR[9:4]). Corresponding bit field of the register CNTEN is set with any value other than 0x1A. As WDT activates, a down counter will start counting from loaded value.

If RSTEN (WDT\_CR[15:10]) is set with any value other than 0x25, WDT reset would be asserted when the WDT counter value reaches to '0' (underflow event) from WDT\_DR value. Before WDT counter reaches to '0', software can write 0x6A to WDT\_CNTR register in order to reload WDT counter when the counter value is less than or equal to the value of window data register. WDT reset may be asserted if the reload occurs when counter is greater than window data.



# 9.3.1 Timing diagram

In this section, WDT interrupt and reset timing diagram is introduced in Figure 64.



Figure 64. WDT Interrupt and WDT Reset Timing Diagram

### 9.3.2 Prescale table

WDT includes a 24-bit down counter with programmable pre-scaler to define different time-out intervals.

Clock sources of WDT can be WDT\_RC or PCLK. PCLK can be selected by WDTCLK (SCU\_PPCLKSR[0]) which is set to '1', then the WDTCNFIG[2] bit of configure option page 1 is cleared to logic "0b".

To configure a WDT counter as a base clock, user can control 2-bit pre-scaler CLKDIV [1:0] in the WDT\_CR register, and the maximum pre-scaled value is "clock source frequency/256". The pre-scaled WDT counter clock frequency values are listed in the following Table 43.

#### Selectable clock source (40KHz to 48MHz) and time-out interval at a single count

Time-out period = (Load Value + 1) \* (1/pre-scaled WDT counter clock frequency)

#### \*Time out period (when the Load Value reaches 0, underflow flag is set to '1')

| Clock source | WDTCLKIN  | WDTCLKIN/4  | WDTCLKIN/16     | WDTCLKIN/64     | WDTCLKIN/256     |  |  |
|--------------|-----------|-------------|-----------------|-----------------|------------------|--|--|
| WDTRC        | 31.250KHz | 7.8125KHz   | 1.953125KHz     | 488.28125Hz     | 122.0703125Hz    |  |  |
| MCCR3 WDT    | MCCR3 WDT | MCCR3 WDT/4 | MCCR3<br>WDT/16 | MCCR3<br>WDT/64 | MCCR3<br>WDT/256 |  |  |

#### Table 43. Pre-scaled WDT Counter Clock Frequency



# 10. Watch timer

Watch timer (WT) has functions for RTC (Real Time Clock) operation. It is generally used for RTC design. WT consists of a clock source select circuit, a timer counter circuit, an output select circuit and watch timer control registers.

Prior to operate WT, a user needs to determine an input clock source and output interval, and to set WTEN as '1' in watch timer control register (WT\_CR). It is able to execute simultaneously or individually. To stop or reset WT, clear the WTEN bit in WT\_CR register.

Watch timer counter circuit corporates a 26-bit counter. Low 14 bits of the counter form a binary counter and high 12 bits form an auto reload counter in order to raise resolution. In WTCLR, it can control WT clear and set interval value at write time, and it can read 12-bit WT counter value at read time.

# 10.1 WT block diagram

As shown in Figure 65, WT of A31G32x series have the following blocks:

- 14-bit divider
- 12-bit up-counter
- RTC function



Figure 65. Watch Timer Block Diagram



# 10.2 Registers

Base address of WT is introduced in the followings:

# Table 44. Base Address of WT

| Name | Base address |
|------|--------------|
| WT   | 0x4000_2000  |

# Table 45. WT Register Map

| Name   | Offset | Туре | Description                  | Reset value | Reference     |
|--------|--------|------|------------------------------|-------------|---------------|
| WT_CR  | 0x0000 | RW   | Watch Timer Control Register | 0x0000_0000 | <u>10.2.1</u> |
| WT_DR  | 0x0004 | RW   | Watch Timer Data Register    | 0x0000_0FFF | <u>10.2.2</u> |
| WT_CNT | 0x0008 | RO   | Watch Timer Counter Register | 0x0000_0000 | <u>10.2.3</u> |



# 10.2.1 WT\_CR: Watch timer control register

WT\_CR is a 32-bit register, and able to do 32/16/8-bit access.

### WT\_CR=0x4000\_2000

| 31 | 30 29 28 | 27 2 | 26 25 | 24 | 23 | 22 2 | 21 2 | 20   | 19 1 | 8 1 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6        | 5 | 4      | 3     | 2        | 1       | 0     |
|----|----------|------|-------|----|----|------|------|------|------|-----|----|----|----|----|----|----|----|----|---|---|------|----------|---|--------|-------|----------|---------|-------|
|    |          |      |       |    |    |      | Res  | serv | ved  |     |    |    |    |    |    |    |    |    |   |   | WTEN | Reserved |   | WTINTV | WTIEN | Reserved | WTIFLAG | WTCLR |
|    |          |      |       |    |    |      |      | -    |      |     |    |    |    |    |    |    |    |    |   |   | 0    | -        | C | 00     | 0     | •        | 0       | 0     |
|    |          |      |       |    |    |      |      | •    |      |     |    |    |    |    |    |    |    |    |   |   | RW   |          | F | RW     | RW    | •        | RW      | RW    |

| 7 | WTEN    | Watch Timer Operation Enable bit.                                                                 |
|---|---------|---------------------------------------------------------------------------------------------------|
|   |         | 0 Disable watch timer operation.                                                                  |
|   |         | 1 Enable watch timer operation.                                                                   |
| 5 | WTINTV  | Watch Timer Interval Selection bits.                                                              |
| 4 |         | 00 fWT/2 <sup>7</sup>                                                                             |
|   |         | 01 fWT/2 <sup>13</sup>                                                                            |
|   |         | 10 fWT/2 <sup>14</sup>                                                                            |
|   |         | 11 fWT/(2 <sup>14</sup> x(WTDR value + 1))                                                        |
|   |         | NOTE: These bits should be changed during WTEN bit is "0b".                                       |
| 3 | WTIEN   | Watch Timer Interrupt Enable bit.                                                                 |
|   |         | 0 Disable watch timer interrupt.                                                                  |
|   |         | 1 Enable watch timer interrupt.                                                                   |
| 1 | WTIFLAG | Watch Timer Interrupt Flag bit.                                                                   |
|   |         | 0 No request occurred.                                                                            |
|   |         | 1 Request occurred, This bit is cleared to '0' when write '1'.                                    |
| 0 | WTCLR   | Watch Timer Counter and Divider Clear bit.                                                        |
|   |         | 0 No effect.                                                                                      |
|   |         | <ol> <li>Clear the counter and divider (Automatically cleared to "0b" after operation)</li> </ol> |



# 10.2.2 WT\_DR: Watch timer data register

WT\_DR is a 32-bit register.

WT\_DR=0x4000\_2004

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 | 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |
|-------------------------------------------------------------|---------------------------|--|--|--|--|--|--|--|--|
| Reserved                                                    | WTDATA                    |  |  |  |  |  |  |  |  |
| -                                                           | 0xFFF                     |  |  |  |  |  |  |  |  |
|                                                             | RW                        |  |  |  |  |  |  |  |  |

11WTDATAWatch Timer Data bits. The range is 0x001 to 0xFFF.0

# 10.2.3 WT\_CNT: Watch timer counter register

WT\_CNT is a 32-bit register.

|                                         |          |       |       |    |    |    |    |    |       |    |   |   | ١  | WT_ | CN | T=( | )x4 | 000 | _20 | 80 |
|-----------------------------------------|----------|-------|-------|----|----|----|----|----|-------|----|---|---|----|-----|----|-----|-----|-----|-----|----|
| 31 30 29 28 27 26 25 24                 | 23 22 21 | 20 19 | 18 17 | 16 | 15 | 14 | 13 | 12 | 11    | 10 | 9 | 8 | 7  | 6   | 5  | 4   | 3   | 2   | 1   | 0  |
|                                         |          |       |       |    |    |    |    |    |       |    |   |   |    |     |    |     |     |     |     |    |
|                                         | Reserved | ł     |       |    |    |    |    |    | CNT   |    |   |   |    |     |    |     |     |     |     |    |
|                                         |          |       |       |    |    |    |    |    |       |    |   |   |    |     |    |     |     |     |     |    |
|                                         |          |       |       |    |    |    |    |    |       |    |   |   |    |     |    |     |     |     |     |    |
|                                         | -        |       |       |    |    |    |    |    | 0x000 |    |   |   |    |     |    |     |     |     |     |    |
| - · · · · · · · · · · · · · · · · · · · |          |       |       |    |    |    |    |    |       |    |   |   | RV | V   |    |     |     |     |     |    |
|                                         |          |       |       |    |    |    |    |    |       |    |   |   |    |     |    |     |     |     |     |    |





# 11. 16-bit timer

16-bit timer block comprises 4 channels of 16-bit general purpose timers. Each channel has an independent 16-bit counter and a dedicated prescaler that feeds a counting clock. 16-bit timer supports periodic timer, PWM pulse, one-shot and capture mode. In addition, one more optional free-run timer is provided. Main purpose of 16-bit timer is a periodical tick timer.

16-bit timer of A31G32x series features the followings:

- 16-bit up-counter
- Periodic timer mode
- One-shot timer mode
- PWM pulse mode
- Capture mode
- 12-bit prescaler
- Synchronous start and clear function

Table 46 introduces pins assigned for 16-bit timer.

#### Table 46. Pin Assignment of 16-bit Timer: External Pins

| Pin name | Туре | Description                   |
|----------|------|-------------------------------|
| EC1n     | I    | Timer 1n External Clock input |
| T1nCAP   | 1    | Timer 1n Capture input        |
| T1nOUT   | 0    | Timer 1n Output               |

NOTE:

1. n = 0, 1, 2, and 3



# 11.1 16-bit timer block diagram

In this section, 16-bit timer is described in a block diagram in Figure 66.



#### Figure 66. 16-bit Timer Block Diagram

# 11.2 Registers

Base address of 16-bit timer is introduced in the followings:

| Name    | Base address |
|---------|--------------|
| TIMER10 | 0x4000_2100  |
| TIMER11 | 0x4000_2200  |
| TIMER12 | 0x4000_2300  |
| TIMER13 | 0x4000_2700  |



| Name          | Offset | Туре | Description                                 | Reset value | Reference     |
|---------------|--------|------|---------------------------------------------|-------------|---------------|
| TIMER1n_CR    | 0x0000 | RW   | Timer/Counter 1n Control<br>Register        | 0x0000_0000 | <u>11.2.1</u> |
| TIMER1n_ADR   | 0x0004 | RW   | Timer/Counter 1n A Data<br>Register         | 0x0000_FFFF | <u>11.2.2</u> |
| TIMER1n_BDR   | 0x0008 | RW   | Timer/Counter 1n B Data<br>Register         | 0x0000_FFFF | <u>11.2.3</u> |
| TIMER1n_CAPDR | 0x000C | RO   | Timer/Counter 1n Capture<br>Data Register   | 0x0000_0000 | <u>11.2.4</u> |
| TIMER1n_PREDR | 0x0010 | RW   | Timer/Counter 1n Prescaler<br>Data Register | 0x0000_0FFF | <u>11.2.5</u> |
| TIMER1n_CNT   | 0x0014 | RO   | Timer/Counter 1n Counter<br>Register        | 0x0000_0000 | <u>11.2.6</u> |

| Table 48 | TIMER 1n | <b>Register Map</b> |   |
|----------|----------|---------------------|---|
|          |          | Register map        | · |

NOTE:

1. n = 0, 1, 2, and 3

# 11.2.1 TIMER1n\_CR: Timer/counter 1n control register

Timer module should be configured properly before running. When a target purpose is defined, the timer can be configured in the TIMERn\_CR register. After configuring TIMER1n\_CR, a user can start or stop the timer function by using TIMERn\_CR.

TIMER1n\_CR is a 32-bit register, and able to do 32/16/8-bit access. (n = 0, 1, 2, and 3)

|                                                 |      |       |       |       | 4000_2<br>4000_2 |        |        |        |        |          |          |      |       |
|-------------------------------------------------|------|-------|-------|-------|------------------|--------|--------|--------|--------|----------|----------|------|-------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 6 15 | 14    | 13 12 | 11    | 10 9             | 8      | 76     | 5      | 4      | 3        | 2        | 1    | 0     |
| Reserved                                        | TnEN | TnCLK | SMnT  | Thece | Reserved         | TnOPOL | TnCPOL | TnMIEN | TnCIEN | TnMIFLAG | TnCIFLAG | UPAU | TnCLR |
| -                                               | 0    | 0     | 00    | 0     | -                | 0      | 00     | 0      | 0      | 0        | 0        | 0    | 0     |
|                                                 | RW   | RW    | RW    | RW    | -                | RW     | RW     | RW     | RW     | RW       | RW       | RW   | RW    |

| 15                                      | T1nEN | Timer 1n Operation Enable bit.                                     |  |  |
|-----------------------------------------|-------|--------------------------------------------------------------------|--|--|
|                                         |       | 0 Disable timer 1n operation.                                      |  |  |
|                                         |       | 1 Enable timer 1n operation. (Counter clear and start)             |  |  |
| 14 T1nCLK Timer 1n Clock Selection bit. |       |                                                                    |  |  |
| 0 Select an internal prescaler clock.   |       |                                                                    |  |  |
|                                         |       | 1 Select an external clock.                                        |  |  |
|                                         |       | <b>NOTE</b> : This bit should be changed during T1nEN bit is "0b". |  |  |



| 13 | T1nMS     | Timer 1n Operation Mode Selection bits.                                                    |
|----|-----------|--------------------------------------------------------------------------------------------|
| 12 |           | 00 Timer/Counter mode. (T1nO: Toggle at A-match)                                           |
|    |           | 01 Capture mode. (The A-match interrupt can occur)                                         |
|    |           | 10 PPG one-shot mode. (T1nOUT: Programmable pulse output)                                  |
|    |           | 11 PPG repeat mode. (T1nOUT: Programmable pulse output)                                    |
|    |           | Note) This bit should be changed during TnEN bit is "0b".                                  |
| 11 | T1nECE    | Timer 1n External Clock Edge Selection bit.                                                |
|    |           | 0 Select falling edge of external clock.                                                   |
|    |           | 1 Select rising edge of external clock.                                                    |
| 8  | T1nOPOL   | T1nOUT Polarity Selection bit.                                                             |
|    |           | 0 Start high. (T1nOUT is low level at disable)                                             |
|    |           | 1 Start low. (T1nOUT is high level at disable)                                             |
| 7  | T1nCPOL   | Timer 1n Capture Polarity Selection bits.                                                  |
| 6  |           | 00 Capture on falling edge.                                                                |
|    |           | 01 Capture on rising edge.                                                                 |
|    |           | 10 Capture on both of falling and rising edge.                                             |
|    |           | 11 Reserved.                                                                               |
| 5  | T1nMIEN   | Timer 1n Match Interrupt Enable bit.                                                       |
|    |           | 0 Disable timer 1n match interrupt.                                                        |
|    |           | 1 Enable timer 1n match interrupt.                                                         |
| 4  | T1nCIEN   | Timer 1n Capture Interrupt Enable bit.                                                     |
|    |           | 0 Disable timer 1n capture interrupt.                                                      |
|    |           | 1 Enable timer 1n capture interrupt.                                                       |
| 3  | T1nMIFLAG | Timer 1n Match Interrupt Flag bit.                                                         |
|    |           | 0 No request occurred.                                                                     |
|    |           | 1 Request occurred, This bit is cleared to '0' when write '1'.                             |
| 2  | T1nCIFLAG | Timer 1n Capture Interrupt Flag bit.                                                       |
|    |           | 0 No request occurred.                                                                     |
|    |           | 1 Request occurred, This bit is cleared to '0' when write '1'.                             |
| 1  | T1nPAU    | Timer 1n Counter Temporary Pause Control bit.                                              |
|    |           | 0 Continue counting.                                                                       |
|    |           | 1 Temporary pause.                                                                         |
| 0  | T1nCLR    | Timer 1n Counter and Prescaler Clear bit.                                                  |
|    |           | 0 No effect.                                                                               |
|    |           | 1 Clear timer 1n counter and prescaler. (Automatically cleared to<br>"0b" after operation) |



#### TIMER1n\_ADR: Timer/counter 1n A data register 11.2.2

TIMER1n\_ADR is a 32-bit register, and able to do 32/16/8-bit access. (n = 0, 1, 2, and 3)

# TIMER10\_ADR=0x4000\_2104, TIMER11\_ADR =0x4000\_2204 TIMER12\_ADR =0x4000\_2304, TIMER13\_ADR =0x4000\_2704

|                                                 | 12_ABR = 0,4000_2304, IMMER 13_ABR = 0,4000_2704 |
|-------------------------------------------------|--------------------------------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0            |
| Reserved                                        | ADATA                                            |
| -                                               | 0xFFFF                                           |
|                                                 | RW                                               |

| 15 | ADATA | Timer/Counter 1n A Data bits. The range is 0x0002 to 0xFFFF.                            |
|----|-------|-----------------------------------------------------------------------------------------|
| 0  |       | NOTE:                                                                                   |
|    |       | <ol> <li>Do not write "0000H" in the TIMER1n_ADR register when<br/>PPG mode.</li> </ol> |

#### TIMER1n\_BDR: Timer/counter n B data register 11.2.3

TIMER1n\_BDR is a 32-bit register, and able to do 32/16/8-bit access. (n = 0, 1, 2, and 3)

| TIMER                                           | 12_BDR =0x4000_2308, TIMER13_BDR =0x4000_2708 |
|-------------------------------------------------|-----------------------------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0         |
| Reserved                                        | BDATA                                         |
| -                                               | 0xFFFF                                        |
|                                                 | RW                                            |

# TIMER10\_BDR=0x4000\_2108, TIMER11\_BDR =0x4000\_2208

| 0 | 15<br>0 | BDATA | Timer/Counter 1n B Data bits. The range is 0x0000 to 0xFFFF. |
|---|---------|-------|--------------------------------------------------------------|
|---|---------|-------|--------------------------------------------------------------|



# 11.2.4 TIMER1n\_CAPDR: Timer/counter 1n capture data register

TIMER1n\_ CAPDR is a 32-bit register, and able to do 32/16/8-bit access. (n = 10, 11, 12, and 13)

#### TIMER10\_CAPDR =0x4000\_210C, TIMER11\_CAPDR =0x4000\_220C TIMER12\_CAPDR =0x4000\_230C, TIMER13\_CAPDR =0x4000\_270C

| 31       30       29       28       27       26       25       24       23       22       21       20       19       18       17       16       15       14       13       12       11       10       9       8       7       6       5       4       3       2       1       0         Reserved       CAPD       C       0         -       0x000       R       R       R       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F       F |                                    |                              |          | <u></u>  |    |    | - |   | 07- | 1000 |   | ~ |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|------------------------------|----------|----------|----|----|---|---|-----|------|---|---|
| - 0x0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 31 30 29 28 27 26 25 24 23 22 21 2 | 20 19 1 <mark>8 17 16</mark> | 15 14 13 | 12 11 10 | 98 | 7  | 6 | 5 | 4 3 | 2    | 1 | 0 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reserved                           |                              |          |          | CA | PD |   |   |     |      |   |   |
| - R0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | -                                  | 0x0000                       |          |          |    |    |   |   |     |      |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | •                                  |                              | RO       |          |    |    |   |   |     |      |   |   |

| 15 | CAPD | Timer/Counter 1n Capture Data bits. |  |
|----|------|-------------------------------------|--|
|    |      | ·                                   |  |
| 0  |      |                                     |  |

### 11.2.5 TIMER1n\_PREDR: Timer/counter 1n prescaler data register

TIMER1n\_PREDR is a 32-bit register, and able to do 32/16/8-bit access. (n = 0, 1, 2, and 3)

|                                               | TIMER10_PREDR =0x4000<br>TIMER12_PREDR =0x4000 |  |       |  |  |  |  |
|-----------------------------------------------|------------------------------------------------|--|-------|--|--|--|--|
| 31 30 29 28 27 26 25 24 23 22 21 20           |                                                |  |       |  |  |  |  |
| Reserved                                      |                                                |  | PRED  |  |  |  |  |
| -                                             |                                                |  | 0xFFF |  |  |  |  |
|                                               | RW                                             |  |       |  |  |  |  |
| 11 PRED Timer/Counter 1n Prescaler Data bits. |                                                |  |       |  |  |  |  |

#### 11.2.6 TIMER1n\_CNT: Timer/counter n counter register

0

TIMER1n\_CNT is a 32-bit register, and able to do 32/16/8-bit access. (n = 0, 1, 2, and 3)

#### TIMER10\_CNT =0x4000\_2114, TIMER11\_CNT =0x4000\_2214 TIMER12\_CNT =0x4000\_2314, TIMER13\_CNT =0x4000\_2714

|                                                 | 12_0111 -0x4000_2014, HMERTO_0111 -0x4000_2714 |  |  |  |  |
|-------------------------------------------------|------------------------------------------------|--|--|--|--|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0          |  |  |  |  |
| Reserved                                        | CNT                                            |  |  |  |  |
| -                                               | 0x0000                                         |  |  |  |  |
|                                                 | RO                                             |  |  |  |  |

| 15 | CNT | Timer/Counter 1n Counter bits. |
|----|-----|--------------------------------|
| 0  |     |                                |



# 11.3 Functional description

#### 11.3.1 Timer counter 10/11/12/13

Timer/counter n can be clocked by an internal or an external clock source (EC1n). Its clock source is selected by a clock selection logic which is controlled by clock selection bits (T1nCLK). (n = 0, 1, 2, and 3)

• TIMER 1n clock source: fCLK/(TIMER1n\_PREDR +1), EC1n

In capture mode, by TnCAP, data is captured into input capture data register (TIMER1n\_CAPDR). TIMER 1n results the comparison between a counter and the data register through T1nOUT port in timer/counter mode. In addition, TIMER 1n outputs PWM wave form through T1nOUT port in the PPG mode.

Table 49 introduces various operating modes of TIMER 1n according to the value of timer/counter register.

| T1nEN | Alternative mode | T1nMS[1:0] | TIMER1n_PREDR | Timer 1n                       |  |
|-------|------------------|------------|---------------|--------------------------------|--|
| 1     | AF6              | 00         | 0xXXX         | 16-bit Timer/Counter Mode      |  |
| 1     | AF5              | 01         | 0xXXX         | 16-bit Capture Mode            |  |
| 1     | AF6              | 10         | 0xXXX         | 16-bit PPG Mode(one-shot mode) |  |
| 1     | AF6              | 11         | 0xXXX         | 16-bit PPG Mode(repeat mode)   |  |

#### Table 49. TIMER 1n Operating Modes



# 11.3.2 16-bit timer/counter mode

16-bit timer/counter mode is selected by control register as shown in Figure 67. The 16-bit timer has a counter and data register. The counter register is increased by internal or external clock input. Timer n can use the clock input with 12-bit prescaler division rates (TIMER1n\_PREDR) and external clock (EC1n). When each value of TIMER1n\_CNT and TIMERn\_ADR are identical in timer 1n, a match signal is generated and the interrupt of Timer 1n occurs. The TIMER1n\_CNT values are automatically cleared by the match signal. It can be also cleared by software (T1nCLR).



Figure 67. TIMER 1n Block Diagram in Timer/Counter Mode (n = 0, 1, 2, and 3)



Figure 68. Timer/Counter Mode Timing Example of TIMER 1n (n = 0, 1, 2, and 3)



Figure 69 shows the timer/counter mode operation of timer/counter 1n. Refer to Figure 13 for internal timer clock source and Table 25 for Timer1n Output pin.



Figure 69. Timer/Counter Mode Operation Sequence of TIMER 1n (n = 0, 1, 2, and 3)



# 11.3.3 16-bit capture mode

Timer n capture mode is evoked by setting T1nMS[1:0] as '01'. It can use an internal clock as a clock source. Basically, it has the same function as 16-bit timer/counter mode, and the interrupt occurs when TIMER1n\_CNT is equal to TIMER1n\_ADR. TIMER1n\_CNT value can be automatically cleared by a match signal. It can be cleared by software too (TnCLR).

A timer interrupt in capture mode is very useful when pulse width of captured signal is wider than the maximum period of the timer. The capture result is loaded into TIMER1n\_CAPDR. In the timer n capture mode, timer 1n output (TnO) waveform is not available.



Figure 70. TIMER 1n Block Diagram in Capture Mode (n = 0, 1, 2, and 3)









Figure 72. Express Timer Overflow in Capture Mode of TIMER 1n (n = 0, 1, 2, and 3)



#### 11. 16-bit timer



Figure 73 shows the capture mode operation of timer/counter 1n. Refer to Figure 13 for internal timer clock source and section Table 25 for Timer1n Output pin.

Figure 73. Capture Mode Operation Sequence of TIMER 1n (n = 0, 1, 2, and 3)



# 11.3.4 16-bit PPG mode

Timer 1n has a PPG (Programmable Pulse Generation) function. In PPG mode, the TnO pin outputs up to 16-bit resolution PWM output. This pin should be configured as a PWM output by setting corresponding PnAFSRx to 'AF6'. Period of the PWM output is determined by the TIMERn\_ADR, and duty of the PWM output is determined by the TIMER1n\_BDR.



Figure 74. TIMER 1n Block Diagram in PPG Mode (n = 0, 1, 2, and 3)



| Clear and                      | <u>and "Start High"(T1nOPOL = 0b).</u><br>Start    |             |
|--------------------------------|----------------------------------------------------|-------------|
| Set T1nEN                      |                                                    |             |
| Timer 1n clock                 |                                                    |             |
| Counter X 0                    |                                                    |             |
| TIMER1n_ADR M                  |                                                    |             |
| T1n Interrupt                  |                                                    |             |
| 1. TIMER1n_BDR(5) < TIMEI      | R1n_ADR                                            | $\setminus$ |
| T1nO                           | B Match                                            | A Match     |
| 2. TIMER1n_BDR >= TIMER        | 1n_ADR                                             |             |
| T1nO                           |                                                    | A Match     |
|                                |                                                    |             |
| 3. TIMER1n_BDR = "0000H"       |                                                    |             |
| T1nO Low Level                 |                                                    | A Match     |
| Set T1nEN Clear and S          | <b>b) and "Start High"(T1nOPOL = 0b).</b><br>Start |             |
| Timer 1n clock                 |                                                    |             |
| Counter X 0                    |                                                    | M-2 M-1 0   |
| TIMER1n_ADR M                  |                                                    |             |
| T1n Interrupt                  |                                                    |             |
| ا<br>1. TIMER1n_BDR(5) < TIMEF | R1n_ADR                                            |             |
| T1nO                           | B Match                                            | A Match     |
| 2. TIMER1n_BDR >= TIMER1       | In_ADR                                             |             |
| T1nO                           |                                                    | A Match     |
| 3. TIMER1n_BDR = "0000H"       |                                                    | <u> </u>    |
| T1nO Low Level                 |                                                    | A Match     |
| Low Level                      |                                                    |             |
|                                |                                                    |             |

Figure 75. PPG Mode Timing Example of TIMER 1n (n = 0, 1, 2, and 3)



Figure 76 shows the PPG mode operation of timer/counter 1n. Refer to Figure 13 for internal timer clock source and Table 25 for Timer1n Output pin.



Figure 76. PPG Mode Operation Sequence of TIMER 1n (n = 0, 1, 2, and 3)



# 12. 32-bit timer

32-bit timer block comprises 2 channels of 32-bit general purpose timers. Each channel has an independent 32-bit counter and a dedicated prescaler that feeds a counting clock. 32-bit timer supports periodic timer, PWM pulse, one-shot and capture mode. In addition, one more optional free-run timer is provided. Main purpose of 32-bit timer is a periodical tick timer.

32-bit timer of A31G32x series features the followings:

- 32-bit up-counter
- Periodic timer mode
- One-shot timer mode
- PWM pulse mode
- Capture mode
- 12-bit prescaler
- Synchronous start and clear function

Table 50 introduces pins assigned for 32-bit timer.

#### Table 50. Pin Assignment of 32-bit Timer: External Pins

| Pin name | Туре | Description                   |  |
|----------|------|-------------------------------|--|
| EC2n     | 1    | Timer 2n external clock input |  |
| T2nCAP   | 1    | Timer 2n capture input        |  |
| T2nOUT   | 0    | Timer/PWM/one-shot output     |  |

NOTE:

1. n = 0 or 1



# 12.1 32-bit timer block diagram

In this section, 32-bit timer is described in a block diagram in Figure 77.



Figure 77. 16-bit Timer Block Diagram



# 12.2 Registers

Base address of 32-bit timer is introduced in the followings:

### Table 51. Base Address of 32-bit Timer

| Name    | Base address |
|---------|--------------|
| TIMER20 | 0x4000_2500  |
| TIMER21 | 0x4000_2600  |

| Name              | Offset | Туре | Description                                 | Reset value | Reference     |  |  |
|-------------------|--------|------|---------------------------------------------|-------------|---------------|--|--|
| TIMER2n_CR        | 0x0000 | RW   | Timer/Counter 2n Control<br>Register        | 0x0000_0000 | <u>12.2.1</u> |  |  |
| TIMER2n_ADR       | 0x0004 | RW   | Timer/Counter 2n A Data<br>Register         | 0xFFFF_FFF  | <u>12.2.2</u> |  |  |
| TIMER2n_BDR       | 0x0008 | RW   | Timer/Counter 2n B Data<br>Register         | 0xFFFF_FFFF | <u>12.2.3</u> |  |  |
| TIMER2n_CAP<br>DR | 0x000C | RO   | Timer/Counter 2n Capture<br>Data Register   | 0x0000_0000 | <u>12.2.4</u> |  |  |
| TIMER2n_PRE<br>DR | 0x0010 | RW   | Timer/Counter 2n Prescaler<br>Data Register | 0x0000_0FFF | <u>12.2.5</u> |  |  |
| TIMER2n_CNT       | 0x0014 | RO   | Timer/Counter 2n Counter<br>Register        | 0x0000_0000 | <u>12.2.6</u> |  |  |

# Table 52. TIMER 2n Register Map

NOTE:

1. n = 0 or 1



#### 12.2.1 TIMER2n\_CR: Timer/counter 2n control register

Timer module should be configured properly before running. When a target purpose is defined, the timer can be configured in the TIMER2n\_CR register. After configuring TIMER2n\_CR, a user can start or stop the timer function by using TIMER2n\_CR.

TIMER1n\_CR is a 32-bit register, and able to do 32/16/8-bit access. (n = 0 or 1)

|                         |                |          |       |        | -     |        | _      |         |    |   | _              |                |                  |           | _      |        |
|-------------------------|----------------|----------|-------|--------|-------|--------|--------|---------|----|---|----------------|----------------|------------------|-----------|--------|--------|
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 | 18 17 16 | 5 15  | 14     | 13 12 | 11     | 10 9   | 8       | 7  | 6 | 5              | 4              | 3                | 2         | 1      | 0      |
| Reser                   | ved            | T2nCNCLR | T20EN | T20CLK | T20MS | T20ECE | CAPSEL | T200POL |    |   | <b>T20MIEN</b> | <b>T20CIEN</b> | <b>T20MIFLAG</b> | T20CIFLAG | T20PAU | T20CLR |
| -                       |                |          | 0     | 0      | 0     |        | 0      |         | C  | ) | 0              | 0              | 0                | 0         | 0      | 0      |
|                         |                | RW       | RW    | RW     | RW    | RW     | RW     | RW      | R۱ | N | RW             | RW             | RW               | RW        | RW     | RW     |
|                         |                |          | •     |        |       |        |        | •       | •  |   |                |                | •                | •         |        |        |
| 10                      |                | T: 0     |       |        |       | ( I    | A      |         |    |   |                |                |                  |           |        |        |

TIMER20\_CR=0x4000\_2500, TIMER21\_CR=0x4000\_2600

| 16 | T2nCNCLR             | Timer 2n counter clear after Capture                                                                 |
|----|----------------------|------------------------------------------------------------------------------------------------------|
|    |                      | 0 Clear counter after capture                                                                        |
|    |                      | 1 Keep counter after capture                                                                         |
| 15 | T2nEN                | Timer 2n Operation Enable bit.                                                                       |
|    |                      | 0 Disable timer 2n operation.                                                                        |
|    |                      | 1 Enable timer 2n operation. (Counter clear and start)                                               |
| 14 | T2nCLK               | Timer 2n Clock Selection bit.                                                                        |
|    |                      | 0 Select an internal prescaler clock.                                                                |
|    |                      | 1 Select an external clock.                                                                          |
|    | oit should be change | d during T2nEN bit is "0b".<br>rescaler clock, you should set T2nCLK bit in the SCU_PPCLKSR register |
| 13 | T2nMS                | Timer 2n Operation Mode Selection bits.                                                              |
| 12 |                      | 00 Timer/Counter mode. (T2nO: Toggle at A-match)                                                     |
|    |                      | 01 Capture mode. (The A-match interrupt can occur)                                                   |
|    |                      | 10 PPG one-shot mode. (T2nO: Programmable pulse output)                                              |

| 13 | T2nMS    | Timer | 2n Operation Mode Selection bits.                        |
|----|----------|-------|----------------------------------------------------------|
| 12 |          | 00    | Timer/Counter mode. (T2nO: Toggle at A-match)            |
|    |          | 01    | Capture mode. (The A-match interrupt can occur)          |
|    |          | 10    | PPG one-shot mode. (T2nO: Programmable pulse output)     |
|    |          | 11    | PPG repeat mode. (T2nO: Programmable pulse output)       |
|    |          | NOTE  | : This bit should be changed during T2nEN bit is "0b".   |
| 11 | T2nECE   | Timer | 2n External Clock Edge Selection bit.                    |
|    |          | 0     | Select falling edge of external clock.                   |
|    |          | 1     | Select rising edge of external clock.                    |
| 10 | CAPSEL   | Timer | 2n Capture Signal Selection bits.                        |
| 9  | <u> </u> | 00    | Select an external capture signal.                       |
|    |          | 01    | Not used                                                 |
|    |          | 10    | Select the WDTRC (Watch-dog timer RC oscillator) signal. |
|    |          | 11    | Not used                                                 |
|    |          | NOTE  | : This bit should be changed during T2nEN bit is "0b".   |
| 8  | T2nOPOL  | T2nO  | Polarity Selection bit.                                  |
|    |          | 0     | Start high. (T2nO is low level at disable)               |
|    |          | 1     | Start low. (T2nO is high level at disable)               |



| 7 | T2nCPOL   | Timer 2n Capture Polarity Selection bits.                                                  |
|---|-----------|--------------------------------------------------------------------------------------------|
| 6 |           | 00 Capture on falling edge.                                                                |
|   |           | 01 Capture on rising edge.                                                                 |
|   |           | 10 Capture on both of falling and rising edge.                                             |
|   |           | 11 Reserved.                                                                               |
| 5 | T2nMIEN   | Timer 2n Match Interrupt Enable bit.                                                       |
|   |           | 0 Disable timer 2n match interrupt.                                                        |
|   |           | 1 Enable timer 2n match interrupt.                                                         |
| 4 | T2nCIEN   | Timer 2n Capture Interrupt Enable bit.                                                     |
|   |           | 0 Disable timer 2n capture interrupt.                                                      |
|   |           | 1 Enable timer 2n capture interrupt.                                                       |
| 3 | T2nMIFLAG | Timer 2n Match Interrupt Flag bit.                                                         |
|   |           | 0 No request occurred.                                                                     |
|   |           | 1 Request occurred, This bit is cleared to '0' when write '1'.                             |
| 2 | T2nCIFLAG | Timer 2n Capture Interrupt Flag bit.                                                       |
|   |           | 0 No request occurred.                                                                     |
|   |           | 1 Request occurred, This bit is cleared to '0' when write '1'.                             |
| 1 | T2nPAU    | Timer 2n Counter Temporary Pause Control bit.                                              |
|   |           | 0 Continue counting.                                                                       |
|   |           | 1 Temporary pause.                                                                         |
| 0 | T2nCLR    | Timer 2n Counter and Prescaler Clear bit.                                                  |
|   |           | 0 No effect.                                                                               |
|   |           | 1 Clear timer 2n counter and prescaler. (Automatically cleared to<br>"0b" after operation) |

#### 12.2.2 TIMER2n\_ADR: Timer/counter 2n A data register

TIMER2n\_ADR is a 32-bit register, and able to do 32/16/8-bit access. (n = 0 or 1)

#### TIMER20\_ADR=0x4000\_2504, TIMER21\_ADR=0x4000\_2604

| 31 | 3 | 80 2 | 9 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|---|------|---|----|----|----|----|----|----|----|----|----|----|----|-----|-----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |   |      |   |    |    |    |    |    |    |    |    |    |    |    |     |     |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |      |   |    |    |    |    |    |    |    |    |    |    |    |     |     |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |      |   |    |    |    |    |    |    |    |    |    |    |    |     | ADA | AIA |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |      |   |    |    |    |    |    |    |    |    |    |    |    |     |     |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |      |   |    |    |    |    |    |    |    |    |    |    |    | 0xF | FFI | FF  | FF |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |      |   |    |    |    |    |    |    |    |    |    |    |    |     | R\  | N   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |      |   |    |    |    |    |    |    |    |    |    |    |    |     |     | -   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

 31
 ADATA
 Timer/Counter 2n A Data bits. The range is 0x0002 to 0xFFFFFFF.

 0
 0
 0

**NOTE**: Do not write "0000H" in the TIMER20\_ADR register when PPG mode.



#### 12.2.3 TIMER2n\_BDR: Timer/counter 2n B data register

TIMER2n\_BDR is a 32-bit register, and able to do 32/16/8-bit access. (n = 0 or 1)

#### TIMER20\_BDR=0x4000\_2508, TIMER21\_BDR=0x4000\_2608

| 31 | 3 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|---|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |   |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |    |    |    |    |    |    |    |    |    |    |    |    |    | I   | BD | ٩ТΑ |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |    |    |    |    |    |    |    |    |    |    |    |    |    | 0xF | FF | FFF | FF |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |    |    |    |    |    |    |    |    |    |    |    |    |    |     | R  | N   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |    |    |    |    |    |    |    |    |    |    |    |    |    |     | N  |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |



#### 12.2.4 TIMER2n\_CAPDR: Timer/counter 2n capture data register

TIMER2n\_ CAPDR is a 32-bit register, and able to do 32/16/8-bit access.

# TIMER20\_CAPDR=0x4000\_250C, TIMER21\_CAPDR=0x4000\_260C 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 CAPD CAPD NO 0x0000 R0

| 31<br>0 | CAPD | Timer/Counter 2n Capture Data bits. |  |
|---------|------|-------------------------------------|--|



# 12.2.5 TIMER2n\_PREDR: Timer/counter 2n prescaler data register

TIMER2n\_PREDR is a 32-bit register, and able to do 32/16/8-bit access.

|                                           |       |    | ••• | •  |    |    | ••• | , |   |   |     |    |   | • | ••• |   |   |
|-------------------------------------------|-------|----|-----|----|----|----|-----|---|---|---|-----|----|---|---|-----|---|---|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 | 17 16 | 15 | 14  | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6   | 5  | 4 | 3 | 2   | 1 | 0 |
| Reserved                                  |       |    |     |    |    |    |     |   |   |   | PR  | ED |   |   |     |   |   |
| 0x00000                                   |       |    |     |    |    |    |     |   |   |   | 0xF | FF |   |   |     |   |   |
| -                                         |       |    |     |    |    |    |     |   |   |   | R\  | N  |   |   |     |   |   |

| TIMER20_PREDR=0x4000_ | 2510, TIMER21 | PREDR=0x4000_2610 |  |
|-----------------------|---------------|-------------------|--|
|                       |               |                   |  |

| 11 | PRED | Timer/Counter 2n Prescaler Data bits. |  |
|----|------|---------------------------------------|--|
| 0  |      | f <sub>CLK</sub> /(TIMER2n_PREDR +1)  |  |

# 12.2.6 TIMER2n\_CNT: Timer/counter 2n counter register

TIMER2n\_CNT is a 32-bit register, and able to do 32/16/8-bit access.

|    |   |      |    |    |    |    |    |   |      |    |    |    |    | ••• |     |     |    |    | •^ |    |    | • • • | , |   |   |   | ••• | UN- |   |   | •14 |
|----|---|------|----|----|----|----|----|---|------|----|----|----|----|-----|-----|-----|----|----|----|----|----|-------|---|---|---|---|-----|-----|---|---|-----|
| 31 | 3 | 0 29 | 28 | 27 | 26 | 25 | 24 | 2 | 3 22 | 21 | 20 | 19 | 18 | 17  | 16  | 15  | 14 | 13 | 12 | 11 | 10 | 9     | 8 | 7 | 6 | 5 | 4   | 3   | 2 | 1 | 0   |
|    |   |      |    |    |    |    |    |   |      |    |    |    |    |     |     |     |    |    |    |    |    |       |   |   |   |   |     |     |   |   |     |
|    |   |      |    |    |    |    |    |   |      |    |    |    |    |     | C١  | ١T  |    |    |    |    |    |       |   |   |   |   |     |     |   |   |     |
|    |   |      |    |    |    |    |    |   |      |    |    |    |    |     |     |     |    |    |    |    |    |       |   |   |   |   |     |     |   |   |     |
|    |   |      |    |    |    |    |    |   |      |    |    |    |    | 0x( | 000 | 000 | 00 |    |    |    |    |       |   |   |   |   |     |     |   |   |     |
|    |   |      |    |    |    |    |    |   |      |    |    |    |    |     | R   | )   |    |    |    |    |    |       |   |   |   |   |     |     |   |   |     |
|    |   |      |    |    |    |    |    |   |      |    |    |    |    |     |     | •   |    |    |    |    |    |       |   |   |   |   |     |     |   |   |     |

#### TIMER20\_CNT=0x4000\_2514, TIMER21\_CNT=0x4000\_2514



# 12.3 Functional description

#### 12.3.1 Timer counter 2n

Timer/counter 2n can be clocked by an internal or an external clock source (EC2n). Its clock source is selected by a clock selection logic which is controlled by clock selection bits (T2nCLK).

• TIMER 2n clock source: fCLK/(TIMER2n\_PREDR +1), EC2n

In capture mode, by T2nCAP, data is captured into input capture data register (TIMER2n\_CAPDR). TIMER 2n results the comparison between a counter and the data register through T2nOUT port in timer/counter mode. In addition, TIMER 2n outputs PWM wave form through T2nOUT port in the PPG mode.

Table 53 introduces various operating modes of TIMER 2n according to the value of timer/counter register.

| T2nEN | Alternative mode | T2nMS[1:0] | TIMER2n_PREDR | TIMER 2n                       |
|-------|------------------|------------|---------------|--------------------------------|
| 1     | AF6, AF8         | 00         | 0xXXX         | 32-bit Timer/Counter Mode      |
| 1     | AF5, AF7         | 01         | 0xXXX         | 32-bit Capture Mode            |
| 1     | AF6, AF8         | 10         | 0xXXX         | 32-bit PPG Mode(one-shot mode) |
| 1     | AF6, AF8         | 11         | 0xXXX         | 32-bit PPG Mode(repeat mode)   |

Table 53. TIMER 2n Operating Modes



#### 12.3.2 32-bit timer/counter mode

32-bit timer/counter mode is selected by control register as shown in Figure 78. The 32-bit timer has a counter and data register.

The counter register is increased by internal or external clock input. TIMER 2n can use the clock input with 12-bit prescaler division rates (TIMER2n\_PREDR) and external clock (EC2n). When each value of TIMER20\_CNT and TIMER2n\_ADR are identical in TIMER 2n, a match signal is generated and the interrupt of Timer 2n occurs. The TIMER2n\_CNT values are automatically cleared by the match signal. It can be also cleared by software (T2nCLR).



Figure 78. TIMER 2n Block Diagram in Timer/Counter Mode



Figure 79. Timer/Counter Mode Timing Example of TIMER 2n



Figure 80 shows the timer/counter mode operation of timer/counter 2n. Refer to Figure 13 for internal timer clock source and Table 25 for Timer2n Output pin.



Figure 80. Timer/Counter Mode Operation Sequence of TIMER 2n (n = 0 or 1)



#### 12.3.3 32-bit capture mode

Timer 2n capture mode is evoked by setting T2nMS[1:0] as '01'. It can use an internal clock as a clock source. Basically, it has the same function as 32-bit timer/counter mode, and the interrupt occurs when TIMER2n\_CNT is equal to TIMER2n\_ADR. TIMER2n\_CNT value can be cleared by software (T2nCLR).

A timer interrupt in capture mode is very useful when pulse width of captured signal is wider than the maximum period of the timer. The capture result is loaded into TIMER2n\_BDR. In the TIMER 2n capture mode, TIMER 2n output (T2nOUT) waveform is not available. (n = 0 or 1).



Figure 81. TIMER 2n Block Diagram in Capture Mode



Figure 82. Capture Mode Timing Example of TIMER 2n (n = 0 and 1)





Figure 83. Express Timer Overflow in Capture Mode of TIMER 2n (T2nCNCLR = 1'b1)



Figure 84. Express Timer Overflow in Capture Mode of TIMER 2n (T2nCNCLR = 1'b0)



Figure 85 shows the capture mode operation of timer/counter 2n. Refer to Figure 13 for internal timer clock source and Table 25 for Timer2n Output pin.



Figure 85. Capture Mode Operation Sequence of TIMER 2n (n = 0 or 1)



#### 12.3.4 32-bit PPG mode

Timer 2n has a PPG (Programmable Pulse Generation) function. In PPG mode, the T2nOUT pin outputs up to 32-bit resolution PWM output. This pin should be configured as a PWM output by setting corresponding PnAFSRx to 'AF6' or 'AF7'. Period of the PWM output is determined by the TIMER2n\_ADR, and duty of the PWM output is determined by the TIMER2n\_BDR.



Figure 86. TIMER 2n Block Diagram in PPG Mode



| Set T2nEN                                                                                                                                                                                | and Start                                                  |                              |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|------------------------------|
| Timer 2n clock                                                                                                                                                                           |                                                            |                              |
| Counter X                                                                                                                                                                                |                                                            | 8 M-1 0 1 2 3 4              |
| TIMER2n_ADR M                                                                                                                                                                            |                                                            |                              |
| T2n Interrupt                                                                                                                                                                            |                                                            |                              |
| 1. TIMER2n_BDR(5) < 1                                                                                                                                                                    | TIMER2n_ADR                                                |                              |
| T2nOUT                                                                                                                                                                                   | B Match                                                    | A Match                      |
| 2. TIMER2n_BDR >= TI                                                                                                                                                                     | MER2n ADR                                                  |                              |
|                                                                                                                                                                                          |                                                            |                              |
|                                                                                                                                                                                          |                                                            | A Match                      |
| 3. TIMER2n_BDR = "0x                                                                                                                                                                     | 0000000"                                                   |                              |
| 1                                                                                                                                                                                        |                                                            |                              |
| Clear                                                                                                                                                                                    | <u>= 10b) and "Start High"(T2nOPOL = 0b).</u><br>and Start | A Match                      |
| One-shot Mode(T2nMS<br>Set T2nEN Clear                                                                                                                                                   |                                                            |                              |
| One-shot Mode(T2nMS<br>Set T2nEN Clear                                                                                                                                                   |                                                            | A Match                      |
| One-shot Mode(T2nMS<br>Set T2nEN Clear<br>Fimer 2n clock                                                                                                                                 |                                                            |                              |
| One-shot Mode(T2nMS<br>Set T2nEN Clear<br>Fimer 2n clock                                                                                                                                 |                                                            |                              |
| One-shot Mode(T2nMS         Set T2nEN       Clear         Fimer 2n clock       Image: Clear         Counter       X         TIMER2n_ADR       M         T2n Interrupt       Image: Clear | and Start                                                  |                              |
| One-shot Mode(T2nMS<br>Set T2nEN<br>Fimer 2n clock                                                                                                                                       | and Start                                                  |                              |
| One-shot Mode(T2nMS         Set T2nEN         Clear         Fimer 2n clock         Counter         X         TIMER2n_ADR         M         T2n Interrupt         1. TIMER2n_BDR(5) < T   | and Start                                                  | 8 / / M-2 / M-1 / 0          |
| One-shot Mode(T2nMS         Set T2nEN         Clear         Fimer 2n clock         Counter         X         TIMER2n_ADR         M         T2n Interrupt         1. TIMER2n_BDR(5) < T   | and Start                                                  | 8 / / M-2 / M-1 / 0          |
| One-shot Mode(T2nMS         Set T2nEN         Clear         Fimer 2n clock         Counter         X         TIMER2n_ADR         M         T2n Interrupt         1. TIMER2n_BDR(5) < T   | and Start                                                  | 8 ( M-2 ( M-1 ) 0<br>A Match |

Figure 87. PPG Mode Timing Example of TIMER 2n (n = 0 or 1)



Figure 88 shows the PPG mode operation of timer/counter 2n. Refer to Figure 13 for internal timer clock source and Table 25 for Timer2n Output pin.



Figure 88. PPG Mode Operation Sequence of TIMER 2n (n = 0 or 1)



# 13. Timer counter 30

Timer counter 30 of A31G24x series consist of a multiplexer, a comparator, 16-bit sized timer data registers A/B/C, and many other registers used for its operation. Main features are listed in the followings:

- 16-bit up/down-counter
- Periodic timer mode
- Back-to-Back mode
- Capture mode
- 12-bit prescaler

Table 54 introduces pins assigned for the timer counter 30.

| Pin name | Туре | Description                              |
|----------|------|------------------------------------------|
| EC30     | 1    | External clock input                     |
| T30CAP   | 1    | Capture input                            |
| BLNK30   | 1    | External sync signal input               |
| T40OUT   | 1    | Internal sync signal Input (Timer40 Out) |
| PWM30AA  | 0    | PWM output                               |
| PWM30AB  | 0    | PWM output                               |
| PWM30BA  | 0    | PWM output                               |
| PWM30BB  | 0    | PWM output                               |
| PWM30CA  | 0    | PWM output                               |
| PWM30CB  | 0    | PWM output                               |

#### Table 54. Pin Assignment of Timer Counter 30: External Pins



# 13.1 Timer counter 30 block diagram





Figure 89. Timer Counter 30 Block Diagram



# 13.2 Registers

Base address of 3-phase PWM timer 30 is introduced in the followings:

#### Table 55. Base Address of Timer Counter 30

| Name    | Base address |  |
|---------|--------------|--|
| TIMER30 | 0x4000_2400  |  |

#### Name Offset Description **Reset value** Reference Type TIMER30 CR RW Timer/Counter 30 Control 0x0000 0x0000 0000 13.2.1 Register TIMER30\_PDR 0x0004 RW Timer/Counter 30 Period 0x0000 FFFF <u>13.2.2</u> Data Register TIMER30 ADR 0x0008 RW Timer/Counter 30 A Data 0x0000 FFFF 13.2.3 Register TIMER30\_BDR 0x000C RW Timer/Counter 30 B Data 0x0000 FFFF 13.2.4 Register Timer/Counter 30 C Data RW 0x0000 FFFF TIMER30\_CDR 0x0010 13.2.5 Register 0x0014 RO Timer/Counter 0x0000\_0000 TIMER30\_CAPDR 30 <u>13.2.6</u> Capture Data Register TIMER30\_PREDR 0x0018 RW Timer/Counter 30 0x0000 0FFF 13.2.7 Prescaler Data Register TIMER30\_CNT 0x001C RO Timer/Counter 30 0x0000\_0000 13.2.8 Counter Register TIMER30\_OUTCR 0x0020 RW Timer/Counter 30 Output 0x0000 0000 <u>13.2.9</u> Control Register TIMER30\_DLY 0x0024 RW Timer/Counter 30 PWM 0x0000\_0000 13.2.10 Output Delay Data Register TIMER30\_INTCR 0x0028 RW 0x0000 0000 Timer/Counter 30 13.2.11 Interrupt Control Register TIMER30\_INTFLAG 0x002C RW Timer/Counter 30 0x0000\_0000 <u>13.2.12</u> Interrupt Flag Register TIMER30 HIZCR 0x0030 RW Timer/Counter 30 High-0x0000 0000 13.2.13 Impedance Control Register

#### Table 56. Timer Counter 30 Register Map



| Name          | Offset | Туре | Description                                                 | Reset value | Reference      |
|---------------|--------|------|-------------------------------------------------------------|-------------|----------------|
| TIMER30_ADTCR | 0x0034 | RW   | Timer/Counter 30 A/DC<br>Trigger Control Register           | 0x0000_0000 | <u>13.2.14</u> |
| TIMER30_ADTDR | 0x0038 | RW   | Timer/Counter 30 A/DC<br>Trigger Generator Data<br>Register | 0x0000_0000 | <u>13.2.15</u> |

Table 56. Timer Counter 30 Register Map (continued)

# 13.2.1 TIMER30\_CR: Timer/counter 30 control register

Timer module should be configured properly before running. When target purpose is defined, the timer can be configured in this register. After configuring this register, you can start or stop the timer function by TIMER30\_CR register.

TIMER30\_CR is a 32-bit register, and able to do 32/16/8-bit access.

#### TIMER30\_CR=0x4000\_2400

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 | 14 | 13 12 | 11     | 10    | 9     | 8      | 76      | 54   | 3 2 1 | 0      |
|-------------------------------------------------|----|----|-------|--------|-------|-------|--------|---------|------|-------|--------|
| Reserved                                        |    |    | T30MS | T30ECE | FORCA | DLYEN | DLYPOS | T30CPOL | UPDT | PMOC  | T30CLR |
| -                                               |    | 0  | 00    | 0      | 0     | 0     | 0      | 00      | 00   | 000   | 0      |
|                                                 | RW | RW | RW    | RW     | RW    | RW    | RW     | RW      | RW   | RW    | RW     |

0

1

| 15                     | T30EN               | Timer 30 Operation Enable bit.                                                                                                                                                                                                                                                                                                 |
|------------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        |                     | 0 Disable timer 30 operation.                                                                                                                                                                                                                                                                                                  |
|                        |                     | 1 Enable timer 30 operation. (Counter clear and start)                                                                                                                                                                                                                                                                         |
| 14 T30CLK              |                     | Timer 30 Clock Selection bit.                                                                                                                                                                                                                                                                                                  |
|                        |                     | 0 Select an internal prescaler clock.                                                                                                                                                                                                                                                                                          |
|                        |                     | 1 Select an external clock.                                                                                                                                                                                                                                                                                                    |
|                        | u select an interna | ged during T30EN bit is "0b".<br>I prescaler clock, you should set T30CLK bit in the SCU_PPCLKSR register                                                                                                                                                                                                                      |
| lf you                 | u select an interna |                                                                                                                                                                                                                                                                                                                                |
| lf you<br>first.<br>13 | u select an interna |                                                                                                                                                                                                                                                                                                                                |
| lf you<br>first.       | u select an interna | I prescaler clock, you should set T30CLK bit in the SCU_PPCLKSR register                                                                                                                                                                                                                                                       |
| lf you<br>first.<br>13 | u select an interna | I prescaler clock, you should set T30CLK bit in the SCU_PPCLKSR register Timer 30 Operation Mode Selection bits.                                                                                                                                                                                                               |
| lf you<br>first.<br>13 | u select an interna | I prescaler clock, you should set T30CLK bit in the SCU_PPCLKSR register         Timer 30 Operation Mode Selection bits.         00       Interval mode. (All match interrupts can occur)                                                                                                                                      |
| lf you<br>first.<br>13 | u select an interna | I prescaler clock, you should set T30CLK bit in the SCU_PPCLKSR register         Timer 30 Operation Mode Selection bits.         00       Interval mode. (All match interrupts can occur)         01       Capture mode. (The Period-match interrupt can occur)                                                                |
| lf you<br>first.<br>13 | u select an interna | I prescaler clock, you should set T30CLK bit in the SCU_PPCLKSR register         Timer 30 Operation Mode Selection bits.         00       Interval mode. (All match interrupts can occur)         01       Capture mode. (The Period-match interrupt can occur)         10       Back-to-back mode. (All interrupts can occur) |

Select falling edge of external clock.

Select rising edge of external clock.



| 10 | FORCA   | Timer 30 Output Mode Selection bit. This bit should be changed when the T30EN is "0b".                                             |
|----|---------|------------------------------------------------------------------------------------------------------------------------------------|
|    |         | <ul> <li>6-Channel mode (The PWM30xA/PWM30xB pins are output<br/>according to the TIMER30_xDR registers, respectively)</li> </ul>  |
|    |         | <ol> <li>Force A-Channel mode (The all PWM30xA/PWM30xB pins are<br/>output according to the only TIMER30_ADR registers)</li> </ol> |
| 9  | DLYEN   | Delay Time Insertion Enable bit.                                                                                                   |
|    |         | 0 Disable to insert delay time to the PWM30xA/PWM30xB.                                                                             |
|    |         | 1 Enable to insert delay time to the PWM30xA/PWM30xB.                                                                              |
| 8  | DLYPOS  | Delay Time Insertion Position.                                                                                                     |
|    |         | 0 Insert at front of PWM30xA and at back of PWM30xB pins.                                                                          |
|    |         | 1 Insert at back of PWM30xA and at front of PWM30xB pins.                                                                          |
| 7  | T30CPOL | Timer 30 Capture Polarity Selection bits.                                                                                          |
| 6  |         | 00 Capture on falling edge.                                                                                                        |
|    |         | 01 Capture on rising edge.                                                                                                         |
|    |         | 10 Capture on both of falling and rising edge.                                                                                     |
|    |         | 11 Reserved                                                                                                                        |
| 6  | UPDT    | Data Reload Time Selection bits.                                                                                                   |
| 4  |         | 00 Update data to buffer at the time of writing.                                                                                   |
|    |         | 01 Update data to buffer at period match.                                                                                          |
|    |         | 10 Update data to buffer at bottom.                                                                                                |
|    |         | 11 Not used.                                                                                                                       |
| 3  | PMOC    | Period Match Interrupt Occurrence Selection.                                                                                       |
| 1  |         | 000 Once every period match.                                                                                                       |
|    |         | 001 Once every 2 period match.                                                                                                     |
|    |         | 010 Once every 3 period match.                                                                                                     |
|    |         | 011 Once every 4 period match.                                                                                                     |
|    |         | 100 Once every 5 period match.                                                                                                     |
|    |         | 101 Once every 6 period match.                                                                                                     |
|    |         | 110 Once every 7 period match.                                                                                                     |
|    |         | 111 Once every 8 period match.                                                                                                     |

#### NOTES:

1. A period match counter is cleared as 0x00 when the T30CLR bit is set.

2. When changing the PMOC value, must clear the period match counter with T30CLR. Otherwise, malfunction may occur.

| 0 | T30CLR | Timer 30 Counter and Prescaler Clear bit.                                                 |
|---|--------|-------------------------------------------------------------------------------------------|
|   |        | 0 No effect.                                                                              |
|   |        | 1 Clear timer 30 counter and prescaler (Automatically cleared to<br>"0b" after operation) |



#### 13.2.2 TIMER30\_PDR: Timer/counter 30 period data register

TIMER30\_PDR is a 32-bit register, and able to do 32/16/8-bit access.

|                                                 | TIMER30_PDR=0x4000_2404               |  |  |  |  |  |  |
|-------------------------------------------------|---------------------------------------|--|--|--|--|--|--|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |
| Reserved                                        | PDATA                                 |  |  |  |  |  |  |
| -                                               | 0xFFF                                 |  |  |  |  |  |  |
| •                                               | RW                                    |  |  |  |  |  |  |
|                                                 |                                       |  |  |  |  |  |  |

| 15<br>0   | PDATA        | Timer/Counter 30 Period Data bits. The range is 0x0002 to 0xFFFF. |
|-----------|--------------|-------------------------------------------------------------------|
| <br>NOTE: | Do not write | "0x0000" in the TIMER30 PDR register when PPG mode.               |

#### 13.2.3 TIMER30\_ADR: Timer/counter 30 A data register

TIMER30\_ADR is a 32-bit register, and able to do 32/16/8-bit access.

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------------------------------------------------|---------------------------------------|
| Reserved                                        | ADATA                                 |
| -                                               | 0xFFFF                                |
| · ·                                             | RW                                    |
|                                                 |                                       |

#### TIMER30 ADR=0x4000 2408

| 15 | ADATA | Timer/Counter 30 A Data bits. The range is 0x0000 to 0xFFFF. |
|----|-------|--------------------------------------------------------------|
| 0  |       |                                                              |

#### 13.2.4 TIMER30\_BDR: Timer/counter 30 B data register

TIMER30\_BDR is a 32-bit register, and able to do 32/16/8-bit access.

#### TIMER30\_BDR=0x4000\_240C

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------------------------------------------------|---------------------------------------|
| Reserved                                        | BDATA                                 |
| -                                               | 0xFFFF                                |
|                                                 | RW                                    |

15 BDATA Timer/Counter 30 0

Timer/Counter 30 B Data bits. The range is 0x0000 to 0xFFFF.



#### 13.2.5 TIMER30\_CDR: Timer/counter 30 C data register

TIMER30\_CDR is a 32-bit register, and able to do 32/16/8-bit access.

| 31       30       29       28       27       26       25       24       23       22       21       20       19       18       17       16       15       14       13       12       11       10       9       8       7       6       5       4       3       2         Reserved       CDATA         -       0xFFFF | <u></u> |   | • |   |   |   |     |     |   |    |    |   |    |    |    |    |    |    |    |    |    |    |      |      |    |    |    |    |    |    |    |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---|---|---|---|---|-----|-----|---|----|----|---|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|----|----|----|
|                                                                                                                                                                                                                                                                                                                     | 1 0     | 2 | 3 | 4 | 5 | 6 | 7   | 8   | 9 | 10 | 11 | 2 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23   | 24   | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
| - 0xFFF                                                                                                                                                                                                                                                                                                             |         |   |   |   |   |   | ٩TA | CD/ |   |    |    |   |    |    |    |    |    |    |    |    |    | d  | erve | lese | R  |    |    |    |    |    |    |
|                                                                                                                                                                                                                                                                                                                     |         |   |   |   |   |   | FFF | 0xF | ( |    |    |   |    |    |    |    |    |    |    |    |    |    |      | -    |    |    |    |    |    |    |    |
| - RW                                                                                                                                                                                                                                                                                                                |         |   |   |   |   |   | N   | R   |   |    |    |   |    |    |    |    |    |    |    |    |    |    |      | -    |    |    |    |    |    |    |    |

TIMER30\_CDR=0x4000\_2410

15 CDATA Timer/Counter 30 C Data bits. The range is 0x0000 to 0xFFFF.

#### 13.2.6 TIMER30\_CAPDR: Timer/counter 30 capture data register

0

TIMER30\_CAPDR is a 32-bit register, and able to do 32/16/8-bit access.

| 31       30       29       28       27       26       25       24       23       22       21       20       19       18       17       16       15       14       13       1         Reserved | 12 11 1 |    | 3 7  | 6 | 5 | 4 | 3 | 2 | 1 | Λ |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----|------|---|---|---|---|---|---|---|
| Reserved                                                                                                                                                                                      |         | ~  |      |   |   |   |   |   | • | U |
|                                                                                                                                                                                               |         | C  | APD  |   |   |   |   |   |   |   |
| -                                                                                                                                                                                             |         | 0x | 0000 | ) |   |   |   |   |   |   |
| · ·                                                                                                                                                                                           |         |    | RO   |   |   |   |   |   |   |   |

15CAPDTimer/Counter 30 Capture Data bits.0

#### 13.2.7 TIMER30\_PREDR: Timer/counter 30 prescaler data register

TIMER30\_PREDR is a 32-bit register, and able to do 32/16/8-bit access.

|                                                             | TIMER30_PREDR=0x4000_2418 |
|-------------------------------------------------------------|---------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 | 11 10 9 8 7 6 5 4 3 2 1 0 |
| Reserved                                                    | PRED                      |
| -                                                           | 0xFFF                     |
|                                                             | RW                        |

Timer/Counter 30 Prescaler Data bits.



#### 13.2.8 TIMER30\_CNT: Timer/counter 30 counter register

TIMER30\_CNT is a 32-bit register, and able to do 32/16/8-bit access.

#### TIMER30\_CNT=0x4000\_241C

TIMER30 OUTCR=0x4000 2420

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------------------------------------------------|---------------------------------------|
| Reserved                                        | CNT                                   |
| -                                               | 0x0000                                |
| ·                                               | RO                                    |

<sup>15</sup> CNT 0

Timer/Counter 30 Counter bits.

#### 13.2.9 TIMER30\_OUTCR: Timer/counter 30 output control register

TIMER30\_OUTCR is a 32-bit register, and able to do 32/16/8-bit access.

|                                                 |      |      |       |       |       |       |       |       |          | -     | -     |       |          |       | _     |       |
|-------------------------------------------------|------|------|-------|-------|-------|-------|-------|-------|----------|-------|-------|-------|----------|-------|-------|-------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15   | 14   | 13    | 12    | 11    | 10    | 9     | 8     | 7        | 6     | 5     | 4     | 3        | 2     | 1     | 0     |
| WTIDKY                                          | POLB | POLA | PABOE | PBBOE | PCBOE | PAAOE | PBAOE | PCAOE | Reserved | LVLAB | LVLBB | LVLCB | Reserved | LVLAA | LVLBA | LVLCA |
| 0x0000                                          | 0    | 0    | 0     | 0     | 0     | 0     | 0     | 0     | 1        | 0     | 0     | 0     | 1        | 0     | 0     | 0     |
| WO                                              | RW   | RW   | RW    | RW    | RW    | RW    | RW    | RW    | •        | RW    | RW    | RW    | •        | RW    | RW    | RW    |

| 31 | WTIDKY | Write Identification Key.                                                         |
|----|--------|-----------------------------------------------------------------------------------|
| 16 |        | On writes, write 0xE06C to these bits, otherwise the write is ignored.            |
| 15 | POLB   | PWM30xB Output Polarity Selection bit. (x : A, B and C)                           |
|    |        | 0 Low level start. (The PWM30xB pins are started with low level after counting)   |
|    |        | 1 High level start. (The PWM30xB pins are started with high level after counting) |
| 14 | POLA   | PWM30xA Output Polarity Selection bit. (x : A, B and C)                           |
|    |        | 0 Low level start. (The PWM30xA pins are started with low level after counting)   |
|    |        | 1 High level start. (The PWM30xA pins are started with high level after counting) |
| 13 | PABOE  | PWM30AB Output Enable bit.                                                        |
|    |        | 0 Disable output.                                                                 |
|    |        | 1 Enable output.                                                                  |
| 12 | PBBOE  | PWM30BB Output Enable bit.                                                        |
|    |        | 0 Disable output.                                                                 |
|    |        | 1 Enable output.                                                                  |
| 11 | PCBOE  | PWM30CB Output Enable bit.                                                        |
|    |        | 0 Disable output.                                                                 |
|    |        | 1 Enable output.                                                                  |



| 10 | PAAOE | PWM30AA Output Enable bit.             |
|----|-------|----------------------------------------|
|    |       | 0 Disable output.                      |
|    |       | 1 Enable output.                       |
| 9  | PBAOE | PWM30BA Output Enable bit.             |
|    |       | 0 Disable output.                      |
|    |       | 1 Enable output.                       |
| 8  | PCAOE | PWM30CA Output Enable bit.             |
|    |       | 0 Disable output.                      |
|    |       | 1 Enable output.                       |
| 6  | LVLAB | Configure PWM30AB output When Disable. |
|    |       | 0 Low level                            |
|    |       | 1 High level                           |
| 5  | LVLBB | Configure PWM30BB output When Disable. |
|    |       | 0 Low level                            |
|    |       | 1 High level                           |
| 4  | LVLCB | Configure PWM30CB output When Disable. |
|    |       | 0 Low level                            |
|    |       | 1 High level                           |
| 2  | LVLAA | Configure PWM30AA output When Disable. |
|    |       | 0 Low level                            |
|    |       | 1 High level                           |
| 1  | LVLBA | Configure PWM30BA output When Disable. |
|    |       | 0 Low level                            |
|    |       | 1 High level                           |
| 0  | LVLCA | Configure PWM30CA output When Disable. |
|    |       | 0 Low level                            |
|    |       | 1 High level                           |

# 13.2.10 TIMER30\_DLY: Timer/counter 30 PWM output delay data register

TIMER30\_DLY is a 32-bit register, and able to do 32/16/8-bit access.

|                                                                   |   | тім | ER3 | 0_D | LY= | 0x4 | 000 | _24 | 24 |
|-------------------------------------------------------------------|---|-----|-----|-----|-----|-----|-----|-----|----|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 | 9 | 8   | 76  | 55  | 4   | 3   | 2   | 1   | 0  |
|                                                                   |   |     |     |     |     |     |     |     |    |
| Reserved                                                          |   |     |     | D   | LY  |     |     |     |    |
|                                                                   |   |     |     |     |     |     |     |     |    |
|                                                                   |   |     |     | 0   |     |     |     |     | _  |
| -                                                                 |   |     |     | UX  | 000 |     |     |     |    |
|                                                                   |   |     |     | F   | RW  |     |     |     |    |
|                                                                   |   |     |     |     |     |     |     |     |    |

| 9 | DLY | Timer/Counter 30 PWM Delay Data bits. Delay time: (DLY[9:0]+1)+fT30 |
|---|-----|---------------------------------------------------------------------|
| 0 |     |                                                                     |



# 13.2.11 TIMER30\_INTCR: Timer/counter 30 interrupt control register

TIMER30\_INTCR is a 32-bit register, and able to do 32/16/8-bit access.

| 31 30 29 28 27 26 25 24 | 23 22 21 | 20 19 18 | 17 16 | 15 | 14 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6      | 5       | 4        | 3               | 2               | 1        | 0        |
|-------------------------|----------|----------|-------|----|-------|----|----|----|---|---|---|--------|---------|----------|-----------------|-----------------|----------|----------|
|                         |          | Reserved |       |    |       |    |    |    |   |   |   | HIZIEN | T30CIEN | T30BTIEN | <b>T30PMIEN</b> | <b>T30AMIEN</b> | T30BMIEN | T30CMIEN |
|                         |          | -        |       |    |       |    |    |    |   |   |   | 0      | 0       | 0        | 0               | 0               | 0        | 0        |
|                         |          | -        |       |    |       |    |    |    |   |   |   | RW     | RW      | RW       | RW              | RW              | RW       | RW       |

|   | HIZIEN   | Timer 30 Output High-Impedance Interrupt Enable bit. |
|---|----------|------------------------------------------------------|
|   |          | 0 Disable timer 30 output high-impedance interrupt.  |
|   |          | 1 Enable timer 30 output high-impedance interrupt.   |
| 5 | T30CIEN  | Timer 30 Capture Interrupt Enable bit.               |
|   |          | 0 Disable timer 30 capture interrupt.                |
|   |          | 1 Enable timer 30 capture interrupt.                 |
| 4 | T30BTIEN | Timer 30 Bottom Interrupt Enable bit.                |
|   |          | 0 Disable timer 30 period interrupt.                 |
|   |          | 1 Enable timer 30 period interrupt.                  |
| 3 | T30PMIEN | Timer 30 Period Match Interrupt Enable bit.          |
|   |          | 0 Disable timer 30 period interrupt.                 |
|   |          | 1 Enable timer 30 period interrupt.                  |
| 2 | T30AMIEN | Timer 30 A-ch Match Interrupt Enable bit.            |
|   |          | 0 Disable timer 30 A-ch match interrupt.             |
|   |          | 1 Enable timer 30 A-ch match interrupt.              |
| 1 | T30BMIEN | Timer 30 B-ch Match Interrupt Enable bit.            |
|   |          | 0 Disable timer 30 B-ch match interrupt.             |
|   |          | 1 Enable timer 30 B-ch match interrupt.              |
| 0 | T30CMIEN | Timer 30 C-ch Match Interrupt Enable bit.            |
|   |          | 0 Disable timer 30 C-ch match interrupt.             |
|   |          | 1 Enable timer 30 C-ch match interrupt.              |

#### TIMER30\_INTCR=0x4000\_2428



# 13.2.12 TIMER30\_INTFLAG: Timer/counter 30 interrupt flag register

TIMER30\_INTFLAG is a 32-bit register, and able to do 32/16/8-bit access.

#### TIMER30\_INTFLAG=0x4000\_242C

| 31 30 | 29 | 28 | 27 | 26 | 25 | 24 | 4 23 | 22 | 21 | 20 | 19   | 18   | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6               | 5         | 4          | 3          | 2          | 1          | 0          |
|-------|----|----|----|----|----|----|------|----|----|----|------|------|----|----|----|----|----|----|----|----|---|---|---|-----------------|-----------|------------|------------|------------|------------|------------|
|       |    |    |    |    |    |    |      |    |    | R  | esei | rveo | d  |    |    |    |    |    |    |    |   |   |   | <b>DAJTIZIH</b> | T30CIFLAG | T30BTIFLAG | T30PMIFLAG | T30AMIFLAG | T30BMIFLAG | T30CMIFLAG |
|       |    |    |    |    |    |    |      |    |    |    | -    |      |    |    |    |    |    |    |    |    |   |   |   | 0               | 0         | 0          | 0          | 0          | 0          | 0          |
|       |    |    |    |    |    |    |      |    |    |    |      |      |    |    |    |    |    |    |    |    |   |   |   | RW              | RW        | RW         | RW         | RW         | RW         | RW         |

| 6 | HIZIFLAG   | Timer 30 Output High-Impedance Interrupt Flag bit.             |
|---|------------|----------------------------------------------------------------|
|   |            | 0 No request occurred.                                         |
|   |            | 1 Request occurred, This bit is cleared to '0' when write '1'. |
| 5 | T30CIFLAG  | Timer 30 Capture Interrupt Flag bit.                           |
|   |            | 0 No request occurred.                                         |
|   |            | 1 Request occurred, This bit is cleared to '0' when write '1'. |
| 4 | T30BTIFLAG | Timer 30 Bottom Interrupt Flag bit.                            |
|   |            | 0 No request occurred.                                         |
|   |            | 1 Request occurred, This bit is cleared to '0' when write '1'. |
| 3 | T30PMIFLAG | Timer 30 Period Match Flag Enable bit.                         |
|   |            | 0 No request occurred.                                         |
|   |            | 1 Request occurred, This bit is cleared to '0' when write '1'. |
| 2 | T30AMIFLAG | Timer 30 A-ch Match Interrupt Flag bit.                        |
|   |            | 0 No request occurred.                                         |
|   |            | 1 Request occurred, This bit is cleared to '0' when write '1'. |
| 1 | T30BMIFLAG | Timer 30 B-ch Match Interrupt Flag bit.                        |
|   |            | 0 No request occurred.                                         |
|   |            | 1 Request occurred, This bit is cleared to '0' when write '1'. |
| 0 | T30CMIFLAG | Timer 30 C-ch Match Interrupt Flag bit.                        |
|   |            | 0 No request occurred.                                         |
|   |            | 1 Request occurred, This bit is cleared to '0' when write '1'. |



# 13.2.13 TIMER30\_HIZCR: Timer/counter 30 high-impedance control register

TIMER30\_HIZCR is a 32-bit register, and able to do 32/16/8-bit access.

| TIMER30 | _HIZCR=0x4000 | _2430 |
|---------|---------------|-------|
|---------|---------------|-------|

| 31 30 29 28 27 26 25 24 23 22 | 21 20 19 18 17 16 | 15 14 13 12 11 10 9 | 8  | 7  | 65 | 4     | 3        | 2     | 1      | 0      |
|-------------------------------|-------------------|---------------------|----|----|----|-------|----------|-------|--------|--------|
| Reserved                      |                   |                     |    |    |    | HIZSW | Reserved | HEDGE | HIZSTA | HIZCLR |
|                               | -                 |                     | 0  | 0  | -  | 0     | -        | 0     | 0      | 0      |
|                               | •                 |                     | RW | RW | -  | RW    | •        | RW    | RO     | RW     |

| 8   | HIZCSSEL                     | High-Impedance output control signal selection                                                                                                                       |
|-----|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                              | 0 BLNK30                                                                                                                                                             |
|     |                              | 1 T40OUT                                                                                                                                                             |
| 7   | HIZEN                        | PWM30xA/PWM30xB Output High-Impedance Enable bit.                                                                                                                    |
|     |                              | 0 Disable to control the output high-impedance.                                                                                                                      |
|     |                              | 1 Enable to control the output high-impedance.                                                                                                                       |
| 4   | HIZSW                        | High-Impedance Output Software Setting.                                                                                                                              |
|     |                              | 0 No effect.                                                                                                                                                         |
|     |                              | 1 PWM30xA/PWM30xB pins go into high impedance.<br>(Automatically cleared to "0b" after operation)                                                                    |
| 2   | HEDGE                        | High-Impedance Edge Selection.                                                                                                                                       |
|     |                              | 0 Falling edge of the BLNK30 pin.                                                                                                                                    |
|     |                              | 1 Rising edge of the BLNK30 pin.                                                                                                                                     |
| 1   | HIZSTA                       | High-Impedance Status.                                                                                                                                               |
|     |                              | 0 Indicates that the pins are not under a Hi-Z state.                                                                                                                |
|     |                              | 1 Indicates that the pins are under a Hi-Z state.                                                                                                                    |
| 0   | HIZCLR                       | High-Impedance Output Clear bit.                                                                                                                                     |
|     |                              | 0 No effect.                                                                                                                                                         |
|     |                              | <ol> <li>Clear high-impedance output. (The PWM30xA/PWM30xB pins<br/>are back to output and this bit is automatically cleared to "0b"<br/>after operation)</li> </ol> |
| NOT | <b>E</b> : Where x = A, B, a | and C.                                                                                                                                                               |



#### 13.2.14 TIMER30\_ADTCR: Timer/counter 30 A/DC trigger control register

TIMER30\_ADTCR is a 32-bit register, and able to do 32/16/8-bit access.

|                            |                        |                |        | _     |         |         | _                  |         |
|----------------------------|------------------------|----------------|--------|-------|---------|---------|--------------------|---------|
| 31 30 29 28 27 26 25 24 23 | 3 22 21 20 19 18 17 16 | 15 14 13 12 11 | 10 9 8 | 7 6 5 | 4       | 3       | 2 1                | 0       |
|                            | Reserved               |                |        |       | T30BTTG | T30PMTG | T30AMTG<br>T30BMTG | T30CMTG |
|                            | -                      |                |        |       | 0       | 0       | 0 0                | 0       |
|                            | -                      |                |        |       | RW      | RW      | RW RW              | RW      |

#### TIMER30\_ADTCR=0x4000\_2434

| 4 | T30BTTG | Select Timer 30 Bottom for A/DC Trigger Signal Generator.       |
|---|---------|-----------------------------------------------------------------|
|   |         | 0 Disable A/DC trigger signal generator by bottom.              |
|   |         | 1 Enable A/DC trigger signal generator by bottom.               |
| 3 | T30PMTG | Select Timer 30 Period Match for A/DC Trigger Signal Generator. |
|   |         | 0 Disable A/DC trigger signal generator by period match.        |
|   |         | 1 Enable A/DC trigger signal generator by period match.         |
| 2 | T30AMTG | Select Timer 30 A-ch Match for A/DC Trigger Signal Generator.   |
|   |         | 0 Disable A/DC trigger signal generator by A-ch match.          |
|   |         | 1 Enable A/DC trigger signal generator by A-ch match.           |
| 1 | T30BMTG | Select Timer 30 B-ch Match for A/DC Trigger Signal Generator.   |
|   |         | 0 Disable A/DC trigger signal generator by B-ch match.          |
|   |         | 1 Enable A/DC trigger signal generator by B-ch match.           |
| 0 | T30CMTG | Select Timer 30 C-ch Match for A/DC Trigger Signal Generator.   |
|   |         | 0 Disable A/DC trigger signal generator by C-ch match.          |
|   |         | 1 Enable A/DC trigger signal generator by C-ch match.           |

NOTES:

1. A trigger signal generation is not related with the PMOC[2:0] bits of TIMER30\_CR register.

2. If several source for trigger is selected, a signal can be lost in case of the trigger generation counter is reloaded by another signal.



## 13.2.15 TIMER30\_ADTDR: Timer/counter 30 A/DC trigger generator data register

TIMER30\_ADTDR is a 32-bit register, and able to do 32/16/8-bit access.

| TIMER30 | ADTDR=0x4000 | 2438 |
|---------|--------------|------|
|         |              |      |

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 | 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |
|-------------------------------------------------------|---------------------------------|--|--|--|--|--|--|--|
| Reserved                                              | ADTDATA                         |  |  |  |  |  |  |  |
| -                                                     | 0x0000                          |  |  |  |  |  |  |  |
|                                                       | RW                              |  |  |  |  |  |  |  |

| 13<br>0 | CNT | Timer/Counter 30 A/DC Trigger Generation Data bits. |
|---------|-----|-----------------------------------------------------|
| NOTE    | ES: |                                                     |

1. ADTDR of Timer30 uses the adcnt timer as tclk (timer30 clock).

2. The adcnt timer counter is a 14-bit down counter.

3. It count down from the value written in ADTDR to 0. (Delay role).



# 13.3 Functional description

#### 13.3.1 Timer counter 30

The timer/counter 30 can be clocked by an internal or an external clock source (EC30). The clock source is selected by a clock selection logic which is controlled by the clock selection bits (T30CLK).

• TIMER 30 clock source: PCLK/(TIMER30\_PREDR +1), EC30

In capture mode, by T30CAP, data is captured into input capture data register (TIMER30\_CAPDR).

The PWM wave form to PWM30AA, PWM30AB, PWM30BA, PWM30BB, PWM30CA, PWM3CB Port (6-channel).

| T30EN | Alternative Mode | T30MS[1:0] | TIMER30_PREDR | Timer 30 MODE            |  |  |
|-------|------------------|------------|---------------|--------------------------|--|--|
| 1     | AF3              | 00         | 0xXXX         | 16-bit Interval Mode     |  |  |
| 1     | AF4              | 01         | 0xXXX         | 16-bit Capture Mode      |  |  |
| 1     | AF3              | 10         | 0xXXX         | 16-bit back-to-back Mode |  |  |

 Table 57. Timer 30 Operating Modes

#### 13.3.2 Timer 30 capture mode

16-bit timer 30 capture mode is set by configuring T30MS[1:0] as '01'. An internal clock input or an external clock input can be used as a clock source. Basically, the 16-bit timer 30 capture mode has the same function as the 16-bit interval mode has. Interrupts occur when value of TIMER30's 16-bit up/down counter equals to the one of TIMER30\_PDR. The 16-bit up/down counter values are automatically cleared by a match signal. It can be cleared by software (T30CLR) too.

The 16-bit timer 30's interrupt in capture mode is very useful when the pulse width of captured signal is wider than the maximum period of the timer. The capture result is loaded into TIMER30\_CAPDR.

Figure 90 shows 16-bit capture mode of the timer 30.





Figure 90. 16-bit Capture Mode of Timer 30



Figure 91 shows the capture mode operation of 32-bit Timer30. Refer to Figure 13 for internal timer clock source and Table 25 for Timer 30 capture pin.



Figure 91. Capture Mode Operation Sequence of TIMER 30



#### 13.3.3 Timer 30 interval mode

Timer 30 interval mode is set by configuring T30MS[1:0] as '00'. The timer 30 has a counter and data registers. The 16-bit up/down counter is increased by an internal or an external clock input. The timer 30 can use the input clock with 12-bit prescaler division rates (TIMER30\_PREDR[11:0]). When the value of TIMER30 16-bit up/down counter and the value of TIMER30\_PDR are identical in timer 30, a match signal is generated and the period match interrupt of timer 30 is occurred. The period match interrupt can be occurred which once every 1, 2, 3, 4, 5, 6, 7, or 8 period match (PMOC[2:0]). The 16-bit up/down counter value is automatically cleared by match signal. It can be cleared by software (T30CLR) too.

The timer 30 Interval mode can be operated for BLDC motor control. It has 6-channel pins output up to 16-bit resolution PWM output. When the value of 16-bit up/down counter and TIMER30\_PDR are identical in timer 30, a period match signal is generated and the period match interrupt of timer 30 is occurred.

The timer 30 A, B, and C match signals are generated and the A, B, and C match interrupts of timer 30 are occurred, when the 16-bit counter value are identical to the value of TIMER30\_xDR. The period and duty of the PWM output is determined by the TIMER30\_PDR (PWM period register), and T3xDR (each channel PWM duty register).

- PWM Period = [TIMER30\_PDR ] X Source Clock
- PWM Duty(A-ch) = [ TIMER30\_ADR ] X Source Clock
- PWM Duty(B-ch) = [ TIMER30\_BDR ] X Source Clock
- PWM Duty(C-ch) = [ TIMER30\_CDR ] X Source Clock

The POLA/POLB bit of TIMER30\_OUTCR register decides the polarity of PWM output. If the POLA/POLB bit is set to '1b', the PWM30xA/PWM30xB output is high level start, respectively. And if the POLA/POLB bit is cleared to '0b', the PWM30xA/PWM30xB output is low level start, respectively.

| PxAOE | PxBOE | POLxA | POLxB | PWM3xA Pin put   | PWM3xB Pin Output |
|-------|-------|-------|-------|------------------|-------------------|
| 1     | 1 1   |       | 0     | Low level start  | Low level start   |
|       |       |       | 1     | Low level start  | High level start  |
|       |       | 1     | 0     | High level start | Low level start   |
|       |       | 1     | 1     | High level start | High level start  |

| Table 58 | PWM | <b>Channel Polarity</b> |  |
|----------|-----|-------------------------|--|
|----------|-----|-------------------------|--|

NOTE:

1. Where x = A, B, and C.





Figure 92. Example of PWM at 4MHZ



Figure 93. Example of Changing the Period in Absolute Duty Cycle at 4MHz



#### Data reload time selection

The data reload time can choose among "update data to buffer at the time of writing", "update data to buffer at period match", or "update data to buffer at bottom".

#### PWM output delay

If using the DLYEN bit, DLYPOS bit, and TIMER30\_DLY register, it can delay the PWM output. The DLYPOS setting to '0', the delay inserts at front of PWM30xA and at back of PWM30xB pins. The DLYPOS setting to '1', the delay inserts at back of PWM30xA and at front of PWM30xB pins. The settings of DLYEN bit, DLYPOS bit, and TIMER30\_DLY register are applied equally to all PWM channels.



| Set T30EN                                                                                                                                                                                                                                             | ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer 30 clock                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Counter X                                                                                                                                                                                                                                             | $\left(\begin{array}{c}0\\1\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}3\\4\end{array}\right)\left(\begin{array}{c}5\\5\end{array}\right)\left(\begin{array}{c}6\\7\end{array}\right)\left(\begin{array}{c}8\\8\end{array}\right)\left(\begin{array}{c}1\\8\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}3\\1\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{c}1\\2\end{array}\right)\left(\begin{array}{$ |
| TIMER30_PDR M                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| T30 Period Match                                                                                                                                                                                                                                      | Γ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| a. TIMER30_ADR(5)                                                                                                                                                                                                                                     | < TIMER30_PDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| PWM30AA                                                                                                                                                                                                                                               | Low Level Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PWM30AB                                                                                                                                                                                                                                               | Low Level Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| T30 A Match                                                                                                                                                                                                                                           | Γ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| b. TIMER30_BDR >=                                                                                                                                                                                                                                     | TIMER30_PDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| PWM30BA                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PWM30BB                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| T30 B Match                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| c. TIMER30_CDR = "                                                                                                                                                                                                                                    | l<br>0x0000"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| PWM30CA                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PWM30CB                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                       | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                       | (POLA = 0b), "High Level Start" (POLB = 1b), and DLYPOS = 0b when delay time insertion enable<br>ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2. "Low Level Start"                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2. "Low Level Start"                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2. "Low Level Start"<br>Set T30EN                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2. "Low Level Start"<br>Set T30EN<br>Timer 30 clock                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2. "Low Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR M                                                                                                                                                                     | ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2. "Low Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)                                                                                                                            | ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2. "Low Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)                                                                                                                            | ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2. "Low Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA                                                                                                                   | ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2. "Low Level Start"<br>Set T30EN<br>Fimer 30 clock<br>Counter<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA<br>PWM30AB                                                                                                        | saar and Start       0 × 1 × 2 × 3 × 4 × 5 × 6 × 7 × 8 × × M-2 × M-1 × 0 × 1 × 2 × 3       Image: Constraint of the start       Image: Constraint of the start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2. "Low Level Start"<br>Set T30EN<br>Cirimer 30 clock<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA<br>PWM30AB<br>T30 A Match                                                                                     | saar and Start       0 × 1 × 2 × 3 × 4 × 5 × 6 × 7 × 8 × × M-2 × M-1 × 0 × 1 × 2 × 3       Image: Constraint of the start       Image: Constraint of the start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2. "Low Level Start",<br>Set T30EN Ck<br>Timer 30 clock Ch<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(6)                                                           | ar and Start       0     1     2     3     4     5     6     7     8     M-2     M-1     0     1     2     3       < TIMER30_PDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2. "Low Level Start"<br>Set T30EN<br>Cimer 30 clock<br>Counter<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(6)<br>PWM30BA                                                         | aar and Start       0 \ 1 \ 2 \ 3 \ 4 \ 5 \ 6 \ 7 \ 8 \ \ M-2 \ M-1 \ 0 \ 1 \ 2 \ 3       < TIMER30_PDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2. "Low Level Start"<br>Set T30EN<br>Cimer 30 clock<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(6)<br>PWM30BA<br>PWM30BB                                            | ar and Start       0 × 1 × 2 × 3 × 4 × 5 × 6 × 7 × 8 × × M-2 × M-1 × 0 × 1 × 2 × 3       < TIMER30_PDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2. "Low Level Start",<br>Set T30EN Ck<br>Timer 30 clock Ch<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(6)<br>PWM30BB<br>T30 B Match                                 | ar and Start       0 × 1 × 2 × 3 × 4 × 5 × 6 × 7 × 8 × × M-2 × M-1 × 0 × 1 × 2 × 3       < TIMER30_PDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2. "Low Level Start",<br>Set T30EN Ck<br>Timer 30 clock Ch<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(6)<br>PWM30BA<br>PWM30BB<br>T30 B Match<br>c. TIMER30_CDR(M- | aar and Start         0       1       2       3       4       5       6       7       8       M-2       M-1       0       1       2       3         <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# Figure 94. Interval Mode Timing Chart With "DLYPOS = 0"



| īmer 30 clock □                                                                                                                                                                                                              |                                                                                                                                                                                           |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Counter X                                                                                                                                                                                                                    | $\begin{array}{c} \begin{array}{c} \\ \end{array}$                                                                                                                                        |
|                                                                                                                                                                                                                              | $ \begin{array}{c} & & & \\ & & & \\ & & \\ & & \\ & & \\ & & \\ \end{array} $                                                                                                            |
| TIMER30_PDR M                                                                                                                                                                                                                |                                                                                                                                                                                           |
| T30 Period Match                                                                                                                                                                                                             |                                                                                                                                                                                           |
| a. TIMER30_ADR(5)                                                                                                                                                                                                            | <u>!</u>                                                                                                                                                                                  |
| PWM30AA                                                                                                                                                                                                                      | High Level Start                                                                                                                                                                          |
| PWM30AB                                                                                                                                                                                                                      | Low Level Start                                                                                                                                                                           |
| T30 A Match                                                                                                                                                                                                                  |                                                                                                                                                                                           |
| b. TIMER30_BDR >=                                                                                                                                                                                                            | TIMER30_PDR                                                                                                                                                                               |
| PWM30BA                                                                                                                                                                                                                      |                                                                                                                                                                                           |
| PWM30BB                                                                                                                                                                                                                      |                                                                                                                                                                                           |
| T30 B Match                                                                                                                                                                                                                  |                                                                                                                                                                                           |
| c. TIMER30_CDR = '                                                                                                                                                                                                           | <br>"0x0000"                                                                                                                                                                              |
| PWM30CA                                                                                                                                                                                                                      |                                                                                                                                                                                           |
| PWM30CB                                                                                                                                                                                                                      |                                                                                                                                                                                           |
|                                                                                                                                                                                                                              | i                                                                                                                                                                                         |
| 2. "High Level Start'                                                                                                                                                                                                        | (POLA = 1b), "High Level Start" (POLB = 1b), and DLYPOS = 1b when delay time insertion enable<br>ear and Start<br>↓                                                                       |
| Set T30EN                                                                                                                                                                                                                    |                                                                                                                                                                                           |
| 2. "High Level Start<br>Set T30EN                                                                                                                                                                                            |                                                                                                                                                                                           |
| 2. "High Level Start<br>Set T30EN<br>Timer 30 clock<br>Counter                                                                                                                                                               |                                                                                                                                                                                           |
| 2. "High Level Start"<br>Set T30EN C<br>imer 30 clock C<br>Counter X<br>TIMER30_PDR M                                                                                                                                        |                                                                                                                                                                                           |
| 2. "High Level Start"<br>Set T30EN C<br>imer 30 clock C<br>Counter X<br>TIMER30_PDR M                                                                                                                                        | ear and Start<br>↓<br>1 1 1 2 1 3 1 4 5 1 6 1 7 1 8 1 X M-2 X M-1 X 0 X 1 X 2 X 3<br>1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                                                                |
| 2. "High Level Start"<br>Set T30EN C<br>imer 30 clock<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match                                                                                                                      | ear and Start<br>↓<br>0 1 2 3 4 5 6 7 8 XM-2 M-1 0 1 2 3<br>< TIMER30_PDR<br>High Level Start                                                                                             |
| 2. "High Level Start"<br>Set T30EN C<br>imer 30 clock<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA                                                                                      | ear and Start<br>↓<br>0 1 2 3 4 5 6 7 8 XM-2 M-1 0 1 2 3<br>< TIMER30_PDR<br>High Level Start                                                                                             |
| 2. "High Level Start"<br>Set T30EN C<br>imer 30 clock<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA                                                                                      | ear and Start                                                                                                                                                                             |
| 2. "High Level Start"<br>Set T30EN Cl<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA<br>PWM30AB                                                                         | ear and Start<br>↓<br>0 X 1 X 2 X 3 X 4 X 5 X 6 X 7 X 8 XXM-2 XM-1 X 0 X 1 X 2 X 3<br>↓<br><pre></pre>                                                                                    |
| 2. "High Level Start"<br>Set T30EN Cl<br>imer 30 clock Cl<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA<br>PWM30AB<br>T30 A Match                                                        | ear and Start<br>↓<br>0 X 1 X 2 X 3 X 4 X 5 X 6 X 7 X 8 XXM-2 XM-1 X 0 X 1 X 2 X 3<br>↓<br><pre></pre>                                                                                    |
| 2. "High Level Start"<br>Set T30EN Cl<br>imer 30 clock<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(8)                                      | ear and Start                                                                                                                                                                             |
| 2. "High Level Start"<br>Set T30EN Cl<br>imer 30 clock Cl<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(8)<br>PWM30BA                        | ear and Start<br>0 1 2 3 4 5 6 7 8 M-2 M-1 0 1 2 3<br>TIMER30_PDR<br>High Level Start<br>High Level Start<br>High Level Start<br>High Level Start<br>High Level Start<br>High Level Start |
| 2. "High Level Start"<br>Set T30EN Cl<br>imer 30 clock Cl<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(8)<br>PWM30BA<br>PWM30BB                        | ear and Start                                                                                                                                                                             |
| 2. "High Level Start"<br>Set T30EN Cl<br>imer 30 clock<br>Counter X<br>TIMER30_PDR M<br>T30 Period Match<br>a. TIMER30_ADR(5)<br>PWM30AA<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(8)<br>PWM30BA<br>PWM30BB<br>T30 B Match | ear and Start                                                                                                                                                                             |

# Figure 95. Interval Mode Timing Chart With "DLYPOS = 1



#### Back-to-back mode

The back-to-back mode is set by T30MS[1:0] as '10'. In the back-to-back mode, the 16-bit up/down counter repeats up/down count. In fact, the effective duty and period becomes twofold of the register set values. If the TIMER30\_PDR's data value is set to "0x3210, 16-bit up/down counter will increase until it reaches 0x3210. At this point, a period match signal is generated and the period match interrupt occurs. And then the 16-bit up/down counter will decrease until it reaches 0x0000. At this point, the bottom interrupt occurs. It is repeated in this way.



|                                                                                                                                                                                                                                                              | POLA = 0b) , "Low Level Start"(POLB = 0b), and DLYPOS = 0b when delay time insertion enable<br>ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer 30 clock                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Counter X                                                                                                                                                                                                                                                    | 0 1 2 3 4 5 6 7 6 5 4 3 2 1 0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| TIMER30_PDR 7                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| T30 Period Match                                                                                                                                                                                                                                             | Γ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| T30 Bottom Interrupt                                                                                                                                                                                                                                         | Π                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| a. TIMER30_ADR(5)                                                                                                                                                                                                                                            | < TIMER30_PDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| PWM30AA                                                                                                                                                                                                                                                      | Low Level Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PWM30AB                                                                                                                                                                                                                                                      | Low Level Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| T30 A Match                                                                                                                                                                                                                                                  | Π                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| b. TIMER30_BDR >=                                                                                                                                                                                                                                            | TIMER30_PDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PWM30BA                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PWM30BB                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| T30 B Match                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| c. TIMER30_CDR = "                                                                                                                                                                                                                                           | 0x0000"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| PWM30CA                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PWM30CB                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Set T30EN Cle                                                                                                                                                                                                                                                | (POLA = 1b), "High Level Start"(POLB = 1b), and DLYPOS = 1b when delay time insertion enable<br>ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2. "High Level Start"                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR 7<br>T30 Period Match<br>T30 Bottom Interrupt                                                                                                                               | $\begin{bmatrix} 2 & 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 $ |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR 7<br>T30 Period Match                                                                                                                                                       | ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR 7<br>T30 Period Match<br>T30 Bottom Interrupt                                                                                                                               | ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR 7<br>T30 Period Match<br>T30 Bottom Interrupt<br>a. TMIER30_ADR(5)                                                                                                          | ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR 7<br>T30 Period Match<br>T30 Bottom Interrupt<br>a. TMIER30_ADR(5)<br>PWM30AA                                                                                               | Arr and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR 7<br>T30 Period Match<br>T30 Bottom Interrupt<br>a. TMIER30_ADR(5)<br>PWM30AA<br>PWM30AB                                                                                    | ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR 7<br>T30 Period Match<br>T30 Bottom Interrupt<br>a. TMIER30_ADR(5)<br>PWM30AA<br>PWM30AB<br>T30 A Match                                                                     | ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR 7<br>T30 Period Match<br>T30 Bottom Interrupt<br>a. TMIER30_ADR(5)<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(6)                                                           | ear and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR 7<br>T30 Period Match<br>T30 Bottom Interrupt<br>a. TMIER30_ADR(5)<br>PWM30AA<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(6)<br>PWM30BA                                     | Arr and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR 7<br>T30 Period Match<br>T30 Bottom Interrupt<br>a. TMIER30_ADR(5)<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(6)<br>PWM30BA<br>PWM30BB<br>T30 B Match                      | Arr and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR 7<br>T30 Period Match<br>T30 Bottom Interrupt<br>a. TMIER30_ADR(5)<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(6)<br>PWM30BA<br>PWM30BB<br>T30 B Match                      | Arr and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2. "High Level Start"<br>Set T30EN<br>Timer 30 clock<br>Counter X<br>TIMER30_PDR 7<br>T30 Period Match<br>T30 Bottom Interrupt<br>a. TMIER30_ADR(5)<br>PWM30AA<br>PWM30AB<br>T30 A Match<br>b. TIMER30_BDR(6)<br>PWM30BB<br>T30 B Match<br>C. TIMER30_CDR(6) | Arr and Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

# Figure 96. Back-to-Back Mode Timing Chart



# **Emergency protective function**

This protective function is used for emergency stop, when the PWM30xA/PWM30xB output highimpedance enable bit, HIZEN is enabled. When the signal on the external BLNK input pin or internal comparator 3 output goes active (falling or rising edge triggered), the PWM30xA/PWM30xB ports are immediately disabled high-impedance against output and a high-impedance interrupt is occurred. The TIMER30\_HIZCR register is used for high-impedance control. The high-impedance source is the external BLNK input pin. The high-impedance edge can be selected by HEDGE bit as falling or rising edge. If the HIZST read value is '1', it indicates that the pins are under a high-impedance state. To return from the high-impedance state, the HIZCLR bit set to '1'. If HIZSW bit is set to '1', PWM30xA/PWM30xB pins go into high impedance by software. It can be used for debugging. (x: A, B and C).



Figure 97. Example of PWM External Synchronization with BLNK Input (x: A, B and C)



# Force A-channel mode

If FORCA bit is set to '1', it is possible to enable or disable all PWM output pins through PWM outputs which occur from A-ch duty counter. It is noted that the inversion outputs of A, B, C channel have the same A-ch output waveform.



Figure 98. Example of Force A-Channel Mode





Figure 99. Force A-Channel Mode Block Diagram



# 6-channel mode

If FORCA bit sets to '0', it is possible to enable or disable PWM output pin and inversion output pin generated through the duty counter of each channel. The inversion output is the reverse phase of the PWM output. A AA/AB output of the A-channel duty register, a BA/BB output of the B-channel duty register, a CA/CB output of the C-channel duty register are controlled respectively.



Figure 100. Example of 6-Channel Mode





Figure 101. 6-Channel Mode Block Diagram



# 14. Timer counter 40

Timer counter 40 block comprises a single channel 16-bit general purpose timer. This has an independent 32-bit counter and a dedicated prescaler feeds counting clock. It supports periodic timer, PWM pulse, one-shot timer and capture mode. In addition, optional free-run timer is provided.

Main purpose of the timer counter 40 is a periodical tick timer, and main features are listed in the followings:

- 16-bit up-counter
- Periodic timer mode
- One-shot timer mode
- PWM pulse mode
- 3-Channel XOR Capture mode
- 12-bit prescaler
- Synchronous start and clear function

Table 59 introduces pins assigned for the timer counter 40.

| Pin name | Туре | Description               |
|----------|------|---------------------------|
| EC40     | I    | External clock input      |
| T40_CH1  | I    | Capture input             |
| T40_CH2  | I    | Capture input             |
| T40_CH3  | I    | Capture input             |
| T40OUT   | 0    | Timer/PWM/one-shot output |



# 14.1 Timer counter 40 block diagram

In this section, timer counter 40 is introduced in a block diagram.



Figure 102. Timer Counter 40 Block Diagram



# 14.2 Registers

Base address of 16-bit timer 40 is introduced in the followings:

| Table 60 | . Base Address | of Timer | Counter 40 |
|----------|----------------|----------|------------|
|----------|----------------|----------|------------|

| Name    | Base address |
|---------|--------------|
| TIMER40 | 0x4000_2800  |

# Table 61. Timer Counter 30 Register Map

| Name               | Offset | Туре | Description                               | Reset value | Reference     |
|--------------------|--------|------|-------------------------------------------|-------------|---------------|
| TIMER40_CR         | 0x0000 | RW   | Timer/Counter 40 Control<br>Register      | 0x0000_0000 | <u>14.2.1</u> |
| TIMER40_ADR        | 0x0004 | RW   | Timer/Counter 40 A Data<br>Register       | 0xFFFF_FFFF | <u>14.2.2</u> |
| TIMER40_BDR        | 0x0008 | RW   | Timer/Counter 40 B Data<br>Register       | 0xFFFF_FFFF | <u>14.2.3</u> |
| TIMER40_CAPDR      | 0x000C | RO   | Timer/Counter 40 Capture<br>Data Register | 0x0000_0000 | <u>14.2.4</u> |
| TIMER40_PREDR      | 0x0010 | RW   | Timer/Counter40Prescaler Data Register    | 0x0000_0FFF | <u>14.2.5</u> |
| TIMER40_PREDR<br>2 | 0x0014 | RW   | Timer/Counter40Prescaler Data Register 2  | 0x0000_0FFF | <u>14.2.6</u> |
| TIMER40_CNT        | 0x0018 | RO   | Timer/Counter 40 Counter<br>Register      | 0x0000_0000 | <u>14.2.7</u> |



# 14.2.1 TIMER40\_CR: Timer/counter 40 control register

Timer module should be configured properly before running. When target purpose is defined, the timer can be configured in this register. After configuring this register, you can start or stop the timer function by TIMER40\_CR register.

TIMER40\_CR is a 16-bit register, and able to do 32/16/8-bit access.

#### 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 T40CAPCHS EL **T40MIFLAG** T40CIFLAG T40CLK T40MIEN T40ECE ۲ T40MS T400P01 T40CIEN T40PAU T40EN T40CPO T40CLI Reserved 0 \_ 0 0 00 0 00 0 00 0 0 0 0 0 RW 15 T40EN Timer 40 Operation Enable bit. 0 Disable timer 40 operation. 1 Enable timer 40 operation. (Counter clear and start) 14 T40CLK Timer 40 Clock Selection bit. 0 Select an internal prescaler clock. 1 Select an external clock. NOTES: This bit should be changed during T40EN bit is "0b". 1. 2. If you select an internal prescaler clock, you should set T40CLK bit in the SCU\_PPCLKSR register first. 13 T40MS Timer 40 Operation Mode Selection bits. 12 00 Timer/Counter mode. (T40O: Toggle at A-match) 01 Capture mode. (The A-match interrupt can occur) 10 PPG one-shot mode. (T40O: Programmable pulse output) 11 PPG repeat mode. (T40O: Programmable pulse output) Note) This bit should be changed during T40EN bit is "0b". 11 Timer 40 External Clock Edge Selection bit. T40ECE 0 Select falling edge of external clock. Select rising edge of external clock. 1 10 T40CAPCHSEL Timer 40 Capture Channel Selection bits. 9 00 T40\_CH1 Select T40\_CH2 Select 01 T40\_CH3 Select 10 11 T40 CH1 XOR CH2 XOR CH3 Select Note) This bit should be changed during T40EN bit is "0b". T40OPOL 8 T40O Polarity Selection bit. Start high. (T40O is low level at disable) 0 1 Start low. (T40O is high level at disable)





|                                                  | <ul><li>00 Capture on falling edge.</li><li>01 Capture on rising edge.</li></ul>                                                               |
|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                  | 01 Capture on rising edge.                                                                                                                     |
|                                                  |                                                                                                                                                |
|                                                  | 10 Capture on both of falling and rising edge.                                                                                                 |
|                                                  | 11 Reserved.                                                                                                                                   |
| T40MIEN                                          | Timer 40 Match Interrupt Enable bit.                                                                                                           |
|                                                  | 0 Disable timer 40 match interrupt.                                                                                                            |
|                                                  | 1 Enable timer 20 match interrupt.                                                                                                             |
| T40CIEN                                          | Timer 40 Capture Interrupt Enable bit.                                                                                                         |
|                                                  | 0 Disable timer 40 capture interrupt.                                                                                                          |
|                                                  | 1 Enable timer 20 capture interrupt.                                                                                                           |
| T40MIFLAG                                        | Timer 40 Match Interrupt Flag bit.                                                                                                             |
|                                                  | 0 No request occurred.                                                                                                                         |
|                                                  | 1 Request occurred, This bit is cleared to '0' when write '1'.                                                                                 |
| T40CIFLAG                                        | Timer 40 Capture Interrupt Flag bit.                                                                                                           |
|                                                  | 0 No request occurred.                                                                                                                         |
|                                                  | 1 Request occurred, This bit is cleared to '0' when write '1'.                                                                                 |
| T40PAU                                           | Timer 40 Counter Temporary Pause Control bit.                                                                                                  |
|                                                  | 0 Continue counting.                                                                                                                           |
|                                                  | 1 Temporary pause.                                                                                                                             |
| T40CLR Timer 40 Counter and Prescaler Clear bit. |                                                                                                                                                |
|                                                  | 0 No effect.                                                                                                                                   |
|                                                  | <ol> <li>Clear timer40 counter and clock prescaler and capture clock<br/>presclaer. (Automatically cleared to "0b" after operation)</li> </ol> |
|                                                  | T40CIEN<br>T40MIFLAG<br>T40CIFLAG<br>T40PAU                                                                                                    |

PCLK) must be activated for the capture mode. This is because the fclk is used as a capture clock which is controlling the capture operation.

2. If the internal clock is used as a timer clock source, the fclk is active and the capture mode runs normally.

#### 14.2.2 TIMER40\_ADR: Timer/counter 40 A data register

TIMER40\_ADR is a 16-bit register, and able to do 32/16/8-bit access.

|                                                 | TIMER40_ADR=0x4000_2804               |
|-------------------------------------------------|---------------------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
| RESERVED                                        | ADATA                                 |
| -                                               | 0xFFFF                                |
|                                                 | RW                                    |
|                                                 |                                       |

| 15 | ADATA | Timer/Counter 20 A Data bits. The range is 0x0002 to 0xFFFF.          |
|----|-------|-----------------------------------------------------------------------|
| 0  |       | NOTE: Do not write "0000H" in the TIMER20_ADR register when PPG mode. |



31

TIMER40 BDR=0x4000 2808

# 14.2.3 TIMER40\_BDR: Timer/counter 40 B data register

TIMER40\_BDR is a 16-bit register, and able to do 32/16/8-bit access.

| 1 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------------------------------------|---------------------------------------|
| RESERVED                                       | BDATA                                 |
| _                                              | 0xFFFF                                |
| -                                              | RW                                    |

15 BDATA Timer/Counter 40 B Data bits. The range is 0x0000 to 0xFFFF.

#### 14.2.4 TIMER40\_CAPDR: Timer/counter 40 capture data register

TIMER40\_CAPDR is a 16-bit register, and able to do 32/16/8-bit access.

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------------------------------------------------|---------------------------------------|
| RESERVED                                        | CAPD                                  |
| -                                               | 0x0000                                |
|                                                 | RO                                    |
|                                                 |                                       |

#### TIMER40\_CAPDR=0x4000\_280C

15 CAPD 0 Timer/Counter 40 Capture Data bits.

### 14.2.5 TIMER40\_PREDR: Timer/counter 40 prescaler data register

TIMER40\_PREDR is a 16-bit register, and able to do 32/16/8-bit access.

# TIMER40\_PREDR=0x4000\_2810

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 | 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------------------------------------------------------------|---------------------------|
| Reserved                                                    | PREDR                     |
| -                                                           | 0xFFF                     |
|                                                             | RW                        |

| 11 | PREDR | Timer/Counter 40 Prescaler Data bits. |  |
|----|-------|---------------------------------------|--|
| 0  |       | f <sub>CLK</sub> /(TIMER40_PREDR +1)  |  |



#### 14.2.6 TIMER40\_PREDR2: Timer/counter 40 prescaler data register 2

TIMER40\_PREDR2 is a 16-bit register, and able to do 32/16/8-bit access.

| TIMER40_PREDR2=0x4000_ | 2814 |
|------------------------|------|
|------------------------|------|

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 | 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |
|-------------------------------------------------------------|---------------------------|--|--|
| Reserved                                                    | PREDR2                    |  |  |
| -                                                           | 0xFFF                     |  |  |
|                                                             | RW                        |  |  |

| 11<br>0 | PREDR2 | Timer/Counter 40 Capture Prescaler Data bits.<br>f <sub>Capture</sub> /(TIMER40_PREDR2 +1) |
|---------|--------|--------------------------------------------------------------------------------------------|
|         |        |                                                                                            |

NOTES:

1. When using ECn (external clock) as a timer clock source in capture mode, fclk (CCR6 or PCLK) must be activated for the capture mode. This is because the fclk is used as a capture clock which is controlling the capture operation.

2. If the internal clock is used as a timer clock source, the fclk is active and the capture mode runs normally.

#### 14.2.7 TIMER40\_CNT: Timer/counter 40 counter register

TIMER40\_CNT is a 16-bit register, and able to do 32/16/8-bit access.

#### TIMER40\_CNT=0x4000\_2818

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |
|-------------------------------------------------|---------------------------------------|--|--|--|
| Reserved                                        | CNT                                   |  |  |  |
| -                                               | 0x0000                                |  |  |  |
|                                                 | RO                                    |  |  |  |

| 15 | CNT | Timer/Counter 40 Counter bits. |
|----|-----|--------------------------------|
| 0  |     |                                |



# 14.3 Functional description

# 14.3.1 Timer counter 40

The timer/counter 40 can be clocked by an internal or an external clock source (EC40). The clock source is selected by a clock selection logic which is controlled by the clock selection bits (T40CLK).

• TIMER 40 clock source: fCLK/(TIMER40\_PREDR +1), EC40

In capture mode, by T40CAP, data is captured into input capture data register (TIMER40\_CAPDR). Timer 40 outputs the comparison result between counter and data register through T40O port in timer/counter mode. In addition, Timer 40 outputs PWM wave form through T40O port in the PPG mode.

| T40EN | Alternative Mode | T40MS[1:0] | TIMER40_PR | Timer 40 MODE                  |
|-------|------------------|------------|------------|--------------------------------|
| 1     | AF8              | 00         | 0xXXX      | 32-bit Timer/Counter Mode      |
| 1     | AF7              | 01         | 0xXXX      | 32-bit Capture Mode            |
| 1     | AF8              | 10         | 0xXXX      | 32-bit PPG Mode(one-shot mode) |
| 1     | AF8              | 11         | 0xXXX      | 32-bit PPG Mode(repeat mode)   |

 Table 62. Timer 40 Operating Modes

# 14.3.2 16-bit timer/counter mode

16-bit timer/counter mode is selected by control register as shown in Figure 103. The 16-bit timer has a counter and data register. The counter register is increased by internal or external clock input. Timer 40 can use the clock input with 12-bit prescaler division rates (TIMER40\_PREDR) and external clock (EC40).

When each value of TIMER40\_CNT and TIMER40\_ADR are identical in timer 40, a match signal is generated and the interrupt of Timer 40 occurs. The TIMER40\_CNT values are automatically cleared by the match signal. It can be also cleared by software (T40CLR).





Figure 103. TIMER 40 Block Diagram in 16-bit Timer/Counter Mode



Figure 104. 16-bit Timer/Counter Mode Timing Example of TIMER 40



Figure 105 shows the timer/counter mode operation of timer 40. Refer to Figure 13 for internal timer clock source and Table 25 for Timer 40 output pin.



Figure 105. 16-bit Timer/Counter Mode Operation Sequence of TIMER 40



# 14.3.3 16-bit capture mode

TIMER40 capture mode is evoked by configuring T40MS[1:0] as '01'. The clock source can use the internal clock. Basically, it has the same function as the 32-bit timer/counter mode has, and the interrupt occurs when TIMER40\_CNT is equal to TIMER40\_ADR. TIMER40\_CNT values are cleared by software (T40CLR).

This timer interrupt in capture mode is very useful when the pulse width of captured signal is wider than the maximum period of the timer.

The capture result is loaded into TIMER40\_CAPDR. In the TIMER40 capture mode, TIMER40 output (T40O) waveform is not available.

T40ADR (16-bit A Data Register) Reload Buffer Register A To other block T40CLK of PPCLKSR Register T40MIEN A Match fcLk/(T40PREDR+1) T40 Match interrupt 2 T40MIELAG T40PAU MCCR 12-bit Compara A Maich T40CLR T40EN T40CNT (16-bit Counter) R Edge Detector Clear FC40 CLKSEL T40ECE T40CHSEL[1:0] T40CAPDR (Capture Data Register) T40CPOL[1:0] T40MS[1:0] XOR T40CIEN Т40\_СН3 T40 Capture interrupt Capture Sign 12-bit T40CIFLAG T40\_CH2 E/(T40PREDR2+1) T40 CH1

Figure 106 shows 16-bit capture mode of the timer 40.

Figure 106. 16-bit Capture Mode of Timer 40









Figure 108. Express Timer Overflow in Capture Mode of TIMER 40



Figure 109 shows the capture mode operation of Timer40. Refer to Figure 13 for internal timer clock source and Table 25 for Timer 40 capture pin.

When use an external clock in TIMER40 capture mode, fclk (internal clock) must be enabled. Fclk is a Timer40 capture source.



Figure 109. Capture Mode Operation Sequence of TIMER 40



# 14.3.4 16-bit PPG mode

Timer 40 has a PPG (Programmable Pulse Generation) function. In PPG mode, the T40OUT pin outputs up to 16-bit resolution PWM output. This pin should be configured as a PWM output by setting corresponding PnAFSRx to 'AF8'. Period of the PWM output is determined by the TIMER40\_ADR, and duty of the PWM output is determined by the TIMER40\_BDR.



Figure 110. TIMER 40 Block Diagram in PPG Mode



| Set T40EN                                                                                                                                                                                                                                  | Ind Start                                               |                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|----------------------------|
| Fimer 40 clock                                                                                                                                                                                                                             |                                                         |                            |
| Counter X 0                                                                                                                                                                                                                                |                                                         | 8 M-1 0 1 2 3 4            |
| TIMER40_ADR M                                                                                                                                                                                                                              |                                                         |                            |
| T40 Interrupt                                                                                                                                                                                                                              |                                                         | Д                          |
| ا<br>1. TIMER40_BDR(5) < TI                                                                                                                                                                                                                | MER40_ADR                                               |                            |
| T400                                                                                                                                                                                                                                       | B Match                                                 | A Match                    |
| 2. TIMER40_BDR >= TIM                                                                                                                                                                                                                      | ER40 ADR                                                | Y                          |
| T400                                                                                                                                                                                                                                       |                                                         | A Match                    |
|                                                                                                                                                                                                                                            |                                                         | AMACH                      |
| 3. TIMER40_BDR = "0x0                                                                                                                                                                                                                      | 000000"                                                 |                            |
| T400 I avril avril                                                                                                                                                                                                                         |                                                         |                            |
| One-shot Mode(T40MS =                                                                                                                                                                                                                      | <b>10b) and "Start High"(T40OPOL = 0b).</b><br>nd Start | A Match                    |
| One-shot Mode(T40MS =<br>Set T40EN Clear a                                                                                                                                                                                                 |                                                         |                            |
| One-shot Mode(T40MS =<br>Set T40EN Clear a                                                                                                                                                                                                 |                                                         | A Match                    |
| One-shot Mode(T40MS =<br>Set T40EN Clear a                                                                                                                                                                                                 |                                                         |                            |
| One-shot Mode(T40MS =       Set T40EN       Clear a       "imer 40 clock       Counter       X       0       TIMER40_ADR                                                                                                                   |                                                         |                            |
| One-shot Mode(T40MS =       Set T40EN       Timer 40 clock       Counter       X       0       TIMER40_ADR       M       T40 Interrupt                                                                                                     | nd Start                                                | 8 / M-2 / M-1 / 0          |
| One-shot Mode(T40MS =         Set T40EN         Clear a         "imer 40 clock         Counter         X         0         TIMER40_ADR         M         T40 Interrupt         1. TIMER40_BDR(5) < TIMER40_BDR(5)                          | nd Start                                                |                            |
| One-shot Mode(T40MS =         Set T40EN         Clear a         Timer 40 clock         Counter         X         0         TIMER40_ADR         M         1. TIMER40_BDR(5)                                                                 | AER40_ADR                                               | 8 / / M-2 / M-1 / 0        |
| One-shot Mode(T40MS =         Set T40EN         Clear a         imer 40 clock         Counter         X         0         TIMER40_ADR         M         T40 Interrupt         1. TIMER40_BDR(5)         T400         2. TIMER40_BDR >= TIM | AER40_ADR                                               | 8 / / M-2 / M-1 / 0        |
| One-shot Mode(T40MS =       Set T40EN       Timer 40 clock       Counter       X       0       TIMER40_ADR       M       T40 Interrupt                                                                                                     | AER40_ADR<br>B Match<br>B Match                         | 8 ( M-2 M-1 ) 0<br>A Match |

Figure 111. PPG Mode Timing Example of TIMER 40



Figure 112 shows the PPG mode operation of timer/counter 40. Refer to Figure 13 for internal timer clock source and Table 25 for Timer 40 output pin.



Figure 112. PPG Mode Operation Sequence of TIMER 40



# 15. Universal synchronous/asynchronous receiver/transmitter

Universal Synchronous and Asynchronous serial Receiver and Transmitter (USART) is a highly flexible serial communication device. The main features are listed below:

- Full Duplex Operation. (Independent Serial Receive and Transmit Registers)
- Asynchronous or Synchronous Operation.
- Baud Rate Generator.
- Supports Serial Frames with 5,6,7,8, or 9 Data bits and 1 or 2 Stop bits.
- Odd or Even Parity Generation and Parity Check are Supported by Hardware.
- Data OverRun Detection.
- Framing Error Detection.
- Three Separate Interrupts on TX Completion, TX Data Register Empty and RX Completion.
- Double Speed Asynchronous communication mode.

Additional features are:

- 0% Error Baud Rate by floating point count register.
- Supports receive time out interrupt.
- Supports direct memory access and interrupt.

Table 63 introduces pins assigned for the USART.

#### Table 63. Pin Assignment of USART: External Pins

| Pin name | Туре | Description                                   |  |
|----------|------|-----------------------------------------------|--|
| TXD      | 0    | UART Channel n transmit output                |  |
| RXD      | I    | UART Channel n receive input                  |  |
| SS       | I/O  | SPIn Slave select input / output              |  |
| SCK      | I/O  | SPIn Serial clock input / output              |  |
| MOSI     | I/O  | SPIn Serial data (Master output, Slave input) |  |
| MISO     | I/O  | SPIn Serial data (Master input, Slave output) |  |

NOTE:

1. n = 10, 11, 12 and 13



# 15.1 USART block diagram





Figure 113. UART Block Diagram (n = 10, 11, 12, and 13)





Figure 114. SPIN Block Diagram (n = 10, 11, 12, and 13)

# 15.2 Registers

Base address of USART is introduced in the followings:

| Table | 64. | Base | Address | of | USART |
|-------|-----|------|---------|----|-------|
|-------|-----|------|---------|----|-------|

| Name     | Base address |
|----------|--------------|
| USART 10 | 0x4000_3800  |
| USART 11 | 0x4000_3900  |
| USART 12 | 0x4000_3A00  |
| USART 13 | 0x4000_3B00  |



| Name        | Offset | Туре | Description                             | Reset value | Reference     |
|-------------|--------|------|-----------------------------------------|-------------|---------------|
| USARTn_CR1  | 0x00   | RW   | USARTn Control Register 1               | 0x0000_0000 | <u>15.2.1</u> |
| USARTn_CR2  | 0x04   | RW   | USARTn Control Register 2               | 0x0000_0000 | <u>15.2.2</u> |
| USARTn_ST   | 0x0C   | RW   | USARTn Status Register                  | 0x0000_0080 | <u>15.2.3</u> |
| USARTn_BDR  | 0x10   | RW   | USARTn Baud Rate<br>Generation Register | 0x0000_0FFF | <u>15.2.4</u> |
| USARTn_DR   | 0x14   | RW   | USARTn Data Register                    | 0x0000_0000 | <u>15.2.5</u> |
| USARTn_FPCR | 0x18   | RW   | Floating Point Count Register           | 0x0000_0000 | <u>15.2.6</u> |
| USARTn_RTO  | 0x1C   | RW   | RTO Register                            | 0x0000_0000 | <u>15.2.7</u> |

# Table 65. USART Register Map

NOTE:

1. n = 10, 11, 12 and 13

# 15.2.1 USARTn\_CR1: USARTn control register 1

USART module should be configured properly before running. USARTn\_CR1 is a 32-bit register, and able to do 32/16/8-bit access (n = 10, 11, 12, and 13).

|                                                |         |       | 000_3800<br>000_3A00, |      |       |       |       |        |        |         |      |      |
|------------------------------------------------|---------|-------|-----------------------|------|-------|-------|-------|--------|--------|---------|------|------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 1 | 6 15 14 | 13 12 | 11 10 9               | 8    | 7     | 6     | 5     | 4      | 3      | 2       | 1    | 0    |
| Reserved                                       | USTnMS  | USTnP | USTnS                 | ORDn | CPOLn | CPHAn | DRIEn | TXCIEn | RXCIEn | WAKEIEn | TXEn | RXEn |
| -                                              | 00      | 00    | 000                   | 0    | 0     | 0     | 0     | 0      | 0      | 0       | 0    | 0    |
|                                                | RW      | RW    | RW                    | RW   | RW    | RW    | RW    | RW     | RW     | RW      | RW   | RW   |

| 15      | USTnMS | USARTn              | Operation Mode Selection bits.                                   |
|---------|--------|---------------------|------------------------------------------------------------------|
| 14      |        | 00                  | Asynchronous Mode. (UART)                                        |
|         |        | 01                  | Synchronous Mode.                                                |
|         |        | 10                  | Reserved.                                                        |
|         |        | 11                  | SPI Mode                                                         |
| 13      | USTnP  | Selects Pa          | arity Generation and Check method. (only UART mode)              |
| 12      |        | 00                  | No parity.                                                       |
|         |        | 01                  | Reserved.                                                        |
|         |        | 10                  | Even parity.                                                     |
|         |        | 11                  | Odd parity.                                                      |
| 11<br>9 | USTnS  | Selects th<br>mode. | e length of data bit in a frame when Asynchronous or Synchronous |
|         |        | 000                 | 5 bit.                                                           |
|         |        | 001                 | 6 bit.                                                           |
|         |        | 010                 | 7 bit.                                                           |
|         |        | 011                 | 8 bit.                                                           |
|         |        | 111                 | 9 bit.                                                           |
|         |        | Others              | Reserved.                                                        |



| 8   | ORDn            | Selects the           | ne first data bit                                                           | to be transmitted. (only  | SPI mode)                        |  |  |  |  |  |  |  |  |
|-----|-----------------|-----------------------|-----------------------------------------------------------------------------|---------------------------|----------------------------------|--|--|--|--|--|--|--|--|
|     |                 | 0                     | LSB-first.                                                                  |                           |                                  |  |  |  |  |  |  |  |  |
|     |                 | 1                     | MSB-first.                                                                  |                           |                                  |  |  |  |  |  |  |  |  |
| 7   | CPOLn           | Selects the           | ne clock polarit                                                            | y of ACK in synchronous   | s or SPI mode.                   |  |  |  |  |  |  |  |  |
|     |                 | 0                     | TXD Char                                                                    | nge @Rising Edge, RXD     | Change @Falling Edge.            |  |  |  |  |  |  |  |  |
|     |                 | 1                     | TXD Char                                                                    | nge @Falling Edge, RXD    | Change @Rising Edge.             |  |  |  |  |  |  |  |  |
| 6   | CPHAn           |                       | Ln and this bit<br>SCK. (only SPI                                           |                           | npled on the leading or trailing |  |  |  |  |  |  |  |  |
|     |                 | CPOLn                 | CPHAn                                                                       | Leading edge              | Trailing edge                    |  |  |  |  |  |  |  |  |
|     |                 | 0                     | 0                                                                           | Sample (Rising)           | Setup (Falling)                  |  |  |  |  |  |  |  |  |
|     |                 | 0                     | 1                                                                           | Setup (Rising)            | Sample (Falling)                 |  |  |  |  |  |  |  |  |
|     |                 | 1                     | 0                                                                           | Sample (Falling)          | Setup (Rising)                   |  |  |  |  |  |  |  |  |
|     |                 | 1                     | 1                                                                           | Setup (Falling)           | Sample (Rising)                  |  |  |  |  |  |  |  |  |
| 5   | DRIEn           | Transmit              | Data Register                                                               | Empty Interrupt Enable I  | pit.                             |  |  |  |  |  |  |  |  |
|     |                 | 0                     | Disable th                                                                  | e transmit data empty in  | terrupt.                         |  |  |  |  |  |  |  |  |
|     |                 | 1                     | Enable the transmit data empty interrupt.                                   |                           |                                  |  |  |  |  |  |  |  |  |
| 4   | TXCIEn          | Transmit              | smit Complete Interrupt Enable bit.<br>Disable transmit complete interrupt. |                           |                                  |  |  |  |  |  |  |  |  |
|     |                 | 0                     |                                                                             |                           |                                  |  |  |  |  |  |  |  |  |
|     |                 | 1                     | Enable transmit complete interrupt.                                         |                           |                                  |  |  |  |  |  |  |  |  |
| 3   | RXCIEn          | Receive (             | Complete Inter                                                              | rupt Enable bit.          |                                  |  |  |  |  |  |  |  |  |
|     |                 | 0                     | Disable re                                                                  | eceive complete interrupt |                                  |  |  |  |  |  |  |  |  |
|     |                 | 1                     | Enable re                                                                   | ceive complete interrupt. |                                  |  |  |  |  |  |  |  |  |
| 2   | WAKEIEn         | device is<br>requeste | in deep sleep<br>d to wake-up s                                             |                           |                                  |  |  |  |  |  |  |  |  |
|     |                 | 0                     | Disable as                                                                  | synchronous wake-up int   | errupt.                          |  |  |  |  |  |  |  |  |
|     |                 | 1                     | Enable as                                                                   | synchronous wake-up inte  | errupt.                          |  |  |  |  |  |  |  |  |
| 1   | TXEn            | Enables t             | he Transmitte                                                               | r unit.                   |                                  |  |  |  |  |  |  |  |  |
|     |                 | 0                     | Transmitte                                                                  | er is disabled.           |                                  |  |  |  |  |  |  |  |  |
|     |                 | 1                     | Transmitte                                                                  | er is enabled.            |                                  |  |  |  |  |  |  |  |  |
| 0   | RXEn            | Enables t             | he Receiver u                                                               | nit.                      |                                  |  |  |  |  |  |  |  |  |
|     |                 | 0                     | Receiver                                                                    | is disabled.              |                                  |  |  |  |  |  |  |  |  |
|     |                 | 1                     | Receiver                                                                    | is enabled.               |                                  |  |  |  |  |  |  |  |  |
| NOT | F. The CPOI n a | nd CPHAn              | bits should be                                                              | changed during the TXE    | n and RXEn bits are "0b"         |  |  |  |  |  |  |  |  |



# 15.2.2 USARTn\_CR2: USARTn control register 2

USART module should be configured properly before running. USARTn\_CR2 is a 32-bit register, and able to do 32/16/8-bit access (n = 10, 11, 12, and 13).

| USART<br>USART1                                 |         |       |    |       |        |        |       |         |        |         |                       |       |        |         |                |
|-------------------------------------------------|---------|-------|----|-------|--------|--------|-------|---------|--------|---------|-----------------------|-------|--------|---------|----------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14   | 13    | 12 | 11    | 10     | 9      | 8     | 7       | 6      | 5       | 4                     | 3     | 2      | 1       | 0              |
| Reserved                                        | DMATYIE | 1ARXI | OE | RTOEN | FPCREN | USTnEN | DBLSn | MASTERn | LOOPSn | DISSCKn | UST <sub>N</sub> SSEN | FXCHn | USTnSB | USTnTX8 | <b>USTnRX8</b> |
| -                                               | 0       | 0     | 0  | 0     | 0      | 0      | 0     | 0       | 0      | 0       | 0                     | 0     | 0      | 0       | 0              |
|                                                 | RV      | RW    | RW | RW    | RW     | RW     | RW    | RW      | RW     | RW      | RW                    | RW    | RW     | RW      | RW             |

| 14 | DMATXIE | DMA TX Interrupt bit                                                                        |
|----|---------|---------------------------------------------------------------------------------------------|
|    |         | 0 Disable DMA TX Interrupt                                                                  |
|    |         | 1 Enable DMA TX Interrupt                                                                   |
| 13 | DMARXIE | DMA RX Interrupt bit                                                                        |
|    |         | 0 Disable DMA RX Interrupt                                                                  |
|    |         | 1 Enable DMA RX Interrupt                                                                   |
| 12 | RTOIE   | RTO Interrupt bit                                                                           |
|    |         | 0 Disable RTO Interrupt                                                                     |
|    |         | 1 Enable RTO Interrupt                                                                      |
| 11 | RTOEN   | Activate RTO Block by supplying. After RTO occurs, Clear.                                   |
|    |         | 0 Disable RTO                                                                               |
|    |         | 1 Enable RTO                                                                                |
| 10 | FPCREN  | Activate Floating Point Counter Register                                                    |
|    |         | 0 Disable Floating Point Counter Register                                                   |
|    |         | 1 Enable Floating Point Counter Reigster.                                                   |
| 9  | USTnEN  | Activate USARTn Block by supplying.                                                         |
|    |         | 0 Disable USARTn block.                                                                     |
|    |         | 1 Enable USARTn block.                                                                      |
| 8  | DBLSn   | Selects receiver sampling rate. (only UART mode)                                            |
|    |         | 0 Normal asynchronous operation.                                                            |
|    |         | 1 Double speed asynchronous operation.                                                      |
| 7  | MASTERn | Selects master or slave in SPIn or synchronous mode and controls the direction of SCKn pin. |
|    |         | 0 Slave operation. (External clock for SCKn)                                                |
|    |         | 1 Master operation. (Internal clock for SCKn)                                               |
| 6  | LOOPSn  | Control the Loop Back mode of USARTn for test mode.                                         |
|    |         | 0 Normal operation.                                                                         |
|    |         | 1 Loop Back mode.                                                                           |
| 5  | DISSCKn | In synchronous mode operation, selects the waveform of SCKn output.                         |
|    |         | 0 SCKn is free-running while USARTn is enabled in synchronous master mode.                  |
|    |         | 1 SCKn is active while any frame is on transferring.                                        |



| 4 | USTnSSEN | This bit controls the SSn pin operation. (only SPI mode)                                                                                             |
|---|----------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |          | 0 Disable.                                                                                                                                           |
|   |          | 1 Enable.                                                                                                                                            |
| 3 | FXCHn    | SPIn port function exchange control bit. (only SPI mode)                                                                                             |
|   |          | 0 No effect.                                                                                                                                         |
|   |          | 1 Exchange MOSIn and MISOn function.                                                                                                                 |
| 2 | USTnSB   | Selects the length of stop bit in asynchronous or synchronous mode.                                                                                  |
|   |          | 0 1 Stop bit.                                                                                                                                        |
|   |          | 1 2 Stop bit.                                                                                                                                        |
| 1 | USTnTX8  | The ninth bit of data frame in asynchronous or synchronous mode of operation. Write this bit first before loading the USTnDR register.               |
|   |          | 0 MSB (9 <sup>th</sup> bit) to be transmitter is '0'.                                                                                                |
|   |          | 1 MSB (9 <sup>th</sup> bit) to be transmitter is '1'.                                                                                                |
| 0 | USTnRX8  | The ninth bit of data frame in asynchronous or synchronous mode of operation. Read this bit first before reading the receive buffer (only UART mode) |
|   |          | 0 MSB (9 <sup>th</sup> bit) to be received is '0'.                                                                                                   |
|   |          | 1 MSB (9 <sup>th</sup> bit) to be received is '1'.                                                                                                   |

# 15.2.3 USARTn\_ST: USARTn status register

USARTn\_ST is a 32-bit register, and able to do 32/16/8-bit access (n = 10, 11, 12, and 13).

| USART12_ST =0x4000_3                                              | A0C    | , US   | SAR  | RT13 | 3_S  | T =   | 0x4  | 000  | _3E | <u> 30C</u> |
|-------------------------------------------------------------------|--------|--------|------|------|------|-------|------|------|-----|-------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 | ) 9    | 8      | 7    | 6    | 5    | 4     | 3    | 2    | 1   | 0           |
| Reserved                                                          | DMATXF | DMARXF | DREn | TXCn | RXCn | WAKEn | RTOF | DORn | Fen | Pen         |
| -                                                                 | 0      | 0      | 1    | 0    | 0    | 0     | 0    | 0    | 0   | 0           |
| · .                                                               | RW     | RW     | RW   | RW   | RO   | RW    | RW   | RO   | RW  | RW          |

#### USART10\_ST =0x4000\_380C, USART11\_ST =0x4000\_390C USART12\_ST =0x4000\_3A0C\_USART13\_ST =0x4000\_3B0C

| 9 | DMATXF | DMA Transmit Operation Complete flag. (DMA to USART)                                                                                                                                                           |
|---|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |        | 0 DMA Transmit Operation is working or is disabled                                                                                                                                                             |
|   |        | 1 DMA Transmit Op is done                                                                                                                                                                                      |
| 8 | DMARXF | DMA Receive Operation Complete flag. (USART to DMA)                                                                                                                                                            |
|   |        | 0 DMA Receive Operation is working or is disabled                                                                                                                                                              |
|   |        | 1 DMA Transmit Op is done                                                                                                                                                                                      |
| 7 | DREn   | Transmit Data Register Empty Interrupt Flag. The DRE flag indicates if the transmit data register (USARTn_DR) is ready to receive new data. If DRE is '1', the data register is empty and ready to be written. |
|   |        | 0 Transmit buffer is not empty.                                                                                                                                                                                |
|   |        | 1 Transmit buffer is empty. This bit is cleared to '0' when write '1'.                                                                                                                                         |
| 6 | TXCn   | Transmit Complete Interrupt Flag. This flag is set when the entire frame<br>in the transmit shift register has been shifted out and there is no new<br>data currently present in the transmit buffer.          |
|   |        | 0 No request occurred.                                                                                                                                                                                         |
|   |        | 1 Transmit buffer is empty and the data in transmit shift register are shifted out completely. This bit is cleared to '0' when write '1'.                                                                      |



| 5 | RXCn  | Receive Complete Interrupt Flag. This flag is set when there are unread<br>data in the receive buffer and cleared when all the data in the receive<br>buffer are read.            |
|---|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |       | 0 There is no data unread in the receive buffer.                                                                                                                                  |
|   |       | 1 There are more than 1 data in the receive buffer.                                                                                                                               |
| 4 | WAKEn | Asynchronous Wake-up Interrupt Flag. This flag is set when the RXI pin is detected low while the CPU is in deep sleep mode. (only UAR mode)                                       |
|   |       | 0 No request occurred.                                                                                                                                                            |
|   |       | 1 Request occurred, This bit is cleared to '0' when write '1'.                                                                                                                    |
| 3 | RTOF  | Receive Time Out Interrupt flag. This bit is cleared to '0' when write '1'                                                                                                        |
|   |       | 0 Receive time out is not generated                                                                                                                                               |
|   |       | 1 Receive time out is generated                                                                                                                                                   |
| 2 | DORn  | This bit is set if data OverRun occurs. While this bit is set, the incomin<br>data frame is ignored. This flag is valid until the receive buffer is read.                         |
|   |       | 0 No Data OverRun.                                                                                                                                                                |
|   |       | 1 Data OverRun detected.                                                                                                                                                          |
| 1 | Fen   | This bit is set if the first stop bit of next character in the receive buffer i detected as '0'. This bit is valid until the receive buffer is read. (on UART mode)               |
|   |       | 0 No Frame Error.                                                                                                                                                                 |
|   |       | 1 Frame Error detected.                                                                                                                                                           |
| 0 | Pen   | This bit is set if the next character in the receive buffer has a Parity Error<br>while parity is checked. This bit is valid until the receive buffer is read<br>(only UART mode) |
|   |       | 0 No Parity Error.                                                                                                                                                                |
|   |       | 1 Parity Error detected.                                                                                                                                                          |

# 15.2.4 USARTn\_BDR: USARTn baud rate generation register

USARTn\_BDR is a 32-bit register, and able to do 32/16/8-bit access (n = 10, 11, 12, and 13).

|                                        | 00_38<br>0_3A |     |   |   |   |   |       |    |   |   |   |  |  |  |  |  |  |
|----------------------------------------|---------------|-----|---|---|---|---|-------|----|---|---|---|--|--|--|--|--|--|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 | 11 10         | ) 9 | 8 | 7 | 6 | 5 | 4     | 3  | 2 | 1 | 0 |  |  |  |  |  |  |
| Reserved                               |               |     |   |   |   |   | BDATA |    |   |   |   |  |  |  |  |  |  |
| -                                      |               |     |   |   |   |   | 0xFFF |    |   |   |   |  |  |  |  |  |  |
|                                        |               |     |   |   |   |   |       | RV | N |   |   |  |  |  |  |  |  |
|                                        |               |     |   |   |   |   |       |    |   |   |   |  |  |  |  |  |  |

| or SPI mode. |
|--------------|
|--------------|



# 15.2.5 USARTn\_DR: USARTn data register

USARTn\_DR is a 32-bit register, and able to do 32/16/8-bit access (n = 10, 11, 12, and 13).

#### USART10\_DR =0x4000\_3814, USART11\_DR =0x4000\_3914 USART12\_DR =0x4000\_3A14, USART13\_DR =0x4000\_3B14

| 31 30 29 28 27 26 25 24 23 22 21 20 1 | 9 18 17 16 | 15 14 | 13 | 12 | 11 1 | 10 | 9 | 8 | 7   | 6  | 5 | 4  | 3  | 2 | 1 | 0 |
|---------------------------------------|------------|-------|----|----|------|----|---|---|-----|----|---|----|----|---|---|---|
| Reserv                                | ved        |       |    |    |      |    |   |   |     |    |   | DA | TA |   |   |   |
| -                                     |            |       |    |    |      |    |   |   | 0x0 | 00 |   |    |    |   |   |   |
| <u>.</u>                              |            |       |    |    |      |    |   |   | RV  | V  |   |    |    |   |   |   |

| - |      | The UCART Transmitte (for and Descine to (for above the second 1/2) address with    |
|---|------|-------------------------------------------------------------------------------------|
| 1 | DATA | The USART Transmit buffer and Receive buffer share the same I/O address with        |
| 0 |      | this DATA register. The Transmit Data Buffer is the destination for data written    |
|   |      | to the USARTn_DR register. Reading the USTnDR register returns the contents         |
|   |      | of the Receive Buffer. Write to this register only when the DRE flag is set. In SPI |
|   |      | master mode, the SCK clock is generated when data are written to this register.     |

**NOTE**: This byte won't be written when the block is disabled or the both of TXEn and RXEn bits are "0b".

# 15.2.6 USARTn\_FPCR: USARTn floating point count register

USARTn\_FPCR is a 32-bit register, and able to do 32/16/8-bit access (n = 10, 11, 12, and 13).

#### USART10\_FPCR =0x4000\_3818, USART11\_ FPCR =0x4000\_3918 USART12\_FPCR =0x4000\_3A18, USART13\_FPCR =0x4000\_3B18

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0 |
|-----------------------------------------------------------------------|-----------------|
| Reserved                                                              | FPCR            |
| -                                                                     | 0xFFF           |
| •                                                                     | RW              |

| 7 | FPCR | USART Floating Point Counter |  |
|---|------|------------------------------|--|
| 0 |      | 8-bit floating point counter |  |



# 15.2.7 USARTn\_RTO: USARTn RTO register

USARTn\_RTO is a 32-bit register, and able to do 32/16/8-bit access (n = 10, 11, 12, and 13).

#### USART10\_RTO =0x4000\_381C, USART11\_ RTO =0x4000\_391C USART12\_ RTO =0x4000\_3A1C, USART13\_ RTO =0x4000\_3B1C

|                         | 00ART12_RT0 =0x4000_0AT0; 00ART10_RT0 =0x4000_            | 3010 |  |  |
|-------------------------|-----------------------------------------------------------|------|--|--|
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0  |  |  |
| Reserved                | RTO                                                       |      |  |  |
| -                       | 0x00000                                                   |      |  |  |
| -                       | RW                                                        |      |  |  |
|                         |                                                           |      |  |  |

| 23 | RTO | USART receive time out register |
|----|-----|---------------------------------|
| 20 | NIO |                                 |
| 0  |     |                                 |

# 15.3 Functional description

USART comprises clock generator, transmitter and receiver.

The clock generation logic consists of synchronization logic for external clock input used by synchronizing or SPI slave operation, and the baud rate generator for asynchronous or master (synchronous or SPI) operation.

The transmitter consists of a single write buffer, a serial shift register, parity generator and control logic for handling different serial frame formats. The write buffer allows continuous transfer of data without any delay between frames.

The receiver is the most complex part of the UART module due to its clock and data recovery units. The recovery unit is used for asynchronous data reception. In addition to the recovery unit, the receiver includes a parity checker, a shift register, a two-level receive FIFO (USARTn\_DR) and control logic. The receiver supports the same frame formats as the transmitter and can detect frame error, data overrun and parity errors (n = 10, 11, 12 and 13).



# 15.3.1 USART clock generation



Figure 115. Clock Generation Block Diagram (USARTn, n = 10, 11, 12, and 13)

The clock generation logic generates the base clock for the transmitter and receiver. The USART supports four modes of clock operation and those are normal asynchronous, double speed asynchronous, master synchronous and slave synchronous modes.

The clock generation scheme for master SPI and slave SPI mode is the same as master synchronous and slave synchronous operation mode.

USTnMS[1:0] bits in USARTn\_CR1 register selects asynchronous or synchronous operation. Asynchronous double speed mode is controlled by the DBLS bit in the USARTn\_CR2 register.

The MASTER bit in USARTn\_CR2 register controls whether the clock source is internal (master mode, output pin) or external (slave mode, input pin). The SCKn pin is active only when the USART operates in synchronous or SPI mode.

Table 67 shows the equations for calculating baud rate (in bps).

| Operating Mode                           | Equation for Calculating Baud Rate |
|------------------------------------------|------------------------------------|
| Asynchronous Normal Mode (DBLSn=0)       | Baud Rate= PCLK/(16(USARTn_BDR+1)) |
| Asynchronous Double Speed Mode (DBLSn=1) | Baud Rate= PCLK/(8(USARTn_BDR+1))  |
| Synchronous or SPI Master Mode           | Baud Rate= PCLK/(2(USARTn_BDR+1))  |

| Table 66. | Equations | for Calculating | <b>USART Baud</b> | <b>Rate Register</b> | Settings |
|-----------|-----------|-----------------|-------------------|----------------------|----------|
|           |           | ioi ouiouiuiig  |                   |                      | eet      |

NOTE:

1. n = 10, 11, 12 and 13



# 15.3.2 External clock (SCKn)

External clocking is used in the synchronous or SPI slave mode of operation.

External clock input from the SCKn pin is sampled by a synchronization logic to remove meta-stability. Output from the synchronization logic must be passed through an edge detector before it is used by the transmitter and receiver. This process introduces two CPU clock period delay. The maximum frequency of the external SCKn pin is limited by 1MHz.

# 15.3.3 Synchronous mode operation

External clocking is used in the synchronous or SPI slave mode of operation.

When synchronous or SPI mode is used, the SCKn pin will be used as either clock input (slave) or clock output (master). Data sampling and transmitter are issued on the different edge of SCKn clock respectively. For example, if data input on RXDn (MISOn in SPI mode) pin is sampled on the rising edge of SCKn clock, data output on TXDn (MOSIn in SPI mode) pin is altered on the falling edge.

CPOLn bit in USARTn\_CR1 register selects which SCKn clock edge is used for data sampling and which is used for data change. As shown in the Figure 116, when CPOLn is zero, the data will be changed at rising edge of SCKn and sampled at falling edge of SCKn.



Figure 116. Synchronous Mode SCKn Timing (USARTn, n = 10, 11, 12, and 13)



# 15.3.4 UART data format

A serial frame is defined to be one character of data bits with synchronization bits (start and stop bits), and optionally a parity bit for error detection. USART supports all 30 combinations of the following as valid frame formats.

- 1 start bit
- 5, 6, 7, 8 or 9 data bits
- no, even or odd parity bit.
- 1 or 2 stop bits.

A frame starts with a start bit followed by the least significant data bit (LSB). Next data bits, up to nine, are succeeding, ending with the most significant bit (MSB). If parity function is enabled, the parity bit is inserted between the last data bit and the stop bit.

A high-to-low transition on data pin is considered as start bit. When a complete frame is transmitted, it can be directly followed by a new frame, or the communication line can be set to an idle state. The idle means high state of data pin.

Figure 117 shows possible combinations of the frame formats. Bits inside brackets are optional.



Figure 117. Frame Format (USART)

Single data frame consists of the following bits:

- Idle: No communication on communication line (TXDn/RXDn)
- St: Start bit (Low)
- Dm: Data bits (0~8)
- Parity bit ----- Even parity, Odd parity, No parity
- Stop bit(s) ----- 1 bit or 2 bits

Frame format of UART is set by configuring USTnS[2:0], USTnP[1:0] bits in USARTn\_CR1 register and USTnSB bit in USARTn\_CR2 register. Transmitter and receiver use the same figures (n = 10, 11, 12 and 13).



# 15.3.5 UART parity bit

Parity bit is calculated by doing an exclusive-OR of all data bits. If odd parity is used, the result of the exclusive-OR is inverted. Parity bit is located between the MSB and first stop bit of a serial frame.

- Peven = Dm-1 ^ ... ^ D3 ^ D2 ^ D1 ^ D0 ^ 0
- Podd = Dm-1 ^ ... ^ D3 ^ D2 ^ D1 ^ D0 ^ 1
- Peven: Parity bit using even parity
- Podd: Parity bit using odd parity
- Dm: Data bit n of the character

# 15.3.6 UART transmitter

UART transmitter is enabled by configuring TXEn bit in USARTn\_CR1 register. When the transmitter is enabled, TXDn pin should be set to TXDn function for the serial output pin of UART by the PB\_AFSR1/PD\_AFSR1 and PB\_MOD/PD\_MOD. Baud rate, operation mode and frame format must be set up once before starting any transmission.

In synchronous operation mode, SCKn pin is used as a transmission clock, so it should be selected to function SCKn by PB\_AFSR1/PD\_AFSR1 and PB\_MOD/PD\_MOD (n = 10, 11, 12 and 13).

# UART sending TX data

A data transmission is initiated by loading the transmit buffer (USARTn\_DR register I/O location) with the data to be transmitted. The data be written in transmit buffer is moved to the shift register when the shift register is ready to send a new frame. The shift register is loaded with the new data if it is in idle state or immediately after the last stop bit of the previous frame is transmitted. When the shift register is loaded with new data, it will transfer one complete frame according to the settings of control registers. If the 9-bit characters are used in asynchronous or synchronous operation mode, the ninth bit must be written to the USTnTX8 bit in USARTn\_CR2 register before it is loaded to the transmit buffer USARTn\_DR register ( n = 10, 11, 12 and 13 ).



### UART transmitter flag and interrupt

The USART transmitter has two flags which indicate its state. One is USART data register empty flag (DREn) and the other is transmit completion flag (TXCn). Both flags can be interrupt sources.

DREn flag indicates whether the transmit buffer is ready to receive new data. This bit is set when the transmit buffer is empty and cleared when the transmit buffer contains data to be transmitted but has not yet been moved into the shift register. And also this flag can be cleared by writing '0' to this bit position. Writing '1' to this bit position is prevented.

When the data register empty interrupt enable (DRIEn) bit in USARTn\_CR1 register is set and the global interrupt is enabled, USTnST status register empty interrupt is generated while DREn flag is set.

The transmit complete (TXCn) flag bit is set when the entire frame in the transmit shift register has been shifted out and there is no more data in the transmit buffer. The TXCn flag is automatically cleared when the transmit complete interrupt serve routine is executed, or it can be cleared by writing '0' to TXCn bit in USARTn\_ST register.

When the transmit complete interrupt enable (TXCIEn) bit in USARTn\_CR1 register is set and the global interrupt is enabled, UART transmit complete interrupt is generated while TXCn flag is set (n = 10, 11, 12 and 13).

### UART parity generator

The parity generator calculates the parity bit for the serial frame data to be sent. When parity bit is enabled (USTnP1=1), the transmitter control logic inserts the parity bit between the MSB and the first stop bit of the frame to be sent.

#### UART disabling transmitter

Disabling the transmitter by clearing the TXEn bit will not become effective until ongoing transmission is completed. When the transmitter is disabled, the TXDn pin can be used as a normal general purpose I/O (n = 10, 11, 12 and 13).



### 15.3.7 UART receiver

USART receiver is enabled by setting the RXEn bit in the USARTn\_CR1 register. When the receiver is enabled, the RXDn pin should be set to RXDn function for the serial input pin of UART by PB\_AFSR1/PD\_AFSR1 and PB\_MOD/PD\_MOD. The baud-rate, mode of operation and frame format must be set before serial reception. In synchronous or SPI operation mode the SCKn pin is used as transfer clock input, so it should be selected to do SCKn function by PB\_AFSR1/PD\_AFSR1 and PB\_MOD/PD\_MOD. In SPI operation mode the SSn input pin in slave mode can be configured as SSn output pin in master mode. This can be done by setting USTnSSEN bit in USARTn\_CR2 register (n = 10, 11, 12 and 13).

### UART receiving RX data

When UART is in synchronous or asynchronous operation mode, the receiver starts data reception when it detects a valid start bit (LOW) on RXDn pin. Each bit after start bit is sampled at pre-defined baud-rate (asynchronous) or sampling edge of SCKn (synchronous), and shifted into the receive shift register until the first stop bit of a frame is received. Even if there's the second stop bit in the frame, the second stop bit is ignored by the receiver. That is, receiving the first stop bit means that a complete serial frame is presented in the receiver shift register and contents of the shift register are to be moved into the receive buffer. The receive buffer is read by reading the USARTn\_DR register.

If 9-bit characters are used (USTnS[2:0] = "111"), the ninth bit is stored in the USTnRX8 bit position in the USARTn\_CR2 register. The ninth bit must be read from the USTnRX8 bit before reading the low 8 bits from the USARTn\_TDR register. Likewise, the error flags Fen, DORn, Pen must be read before reading the data from USARTn\_DR register. It's because the error flags are stored in the same FIFO position of the receive buffer (n = 10, 11, 12 and 13).

#### UART receiver flag and interrupt

The UART receiver has one flag that indicates the receiver state.

A receive complete (RXCn) flag indicates whether there are unread data in the receive buffer. This flag is set when there is unread data in the receive buffer and cleared when the receive buffer is empty. If the receiver is disabled (RXEn=0), the receiver buffer is flushed and the RXCn flag is cleared.

When a receive complete interrupt enable (RXCIEn) bit in the USARTn\_CR1 register is set and global interrupt is enabled, the UART receiver complete interrupt is generated while RXCn flag is set.

The UART receiver has three error flags which are frame error (Fen), data overrun (DORn) and parity error (Pen). These error flags can be read from the USARTn\_ST register. As received data is stored in the 2-level receive buffer, these error flags are also stored in the same position of receive buffer. So, before reading received data from USARTn\_DR register, read the USARTn\_ST register first which contains error flags.

The frame error (Fen) flag indicates the state of the first stop bit. The Fen flag is "0" when the stop bit was correctly detected as "1", and the Fen flag is "1" when the stop bit was incorrect, i.e. detected as "0". This flag can be used for detecting out-of-sync conditions between data frames.



The data overrun (DORn) flag indicates data loss due to a receive buffer full condition. DORn occurs when the receive buffer is full, and another new data is presented in the receive shift register which are to be stored into the receive buffer. After the DORn flag is set, all the incoming data are lost. To avoid data loss or clear this flag, read the receive buffer.

The parity error (Pen) flag indicates that the frame in the receive buffer had a parity error when received. If parity check function is not enabled (USTnP1=0), the Pen bit is always read "0" (n = 10, 11, 12 and 13).

### UART parity checker

If parity bit is enabled (USTnP1=1), the Parity Checker calculates the parity of the data bits in incoming frame and compares the result with the parity bit from the received serial frame (n = 10, 11, 12 and 13).

#### UART disabling receiver

In contrast to transmitter, disabling the Receiver by clearing RXEn bit makes the Receiver inactive immediately.

When the receiver is disabled, the receiver flushes the receive buffer, the remaining data in the buffer is all reset, and the RXDn pin can be used as a normal general purpose I/O (n = 10, 11, 12 and 13).

#### Asynchronous data reception

To receive asynchronous data frame, the USART includes a clock and data recovery unit. The clock recovery logic is used for synchronizing the internally generated baud-rate clock to the incoming asynchronous serial frame on the RXDn pin.

The data recovery logic does sampling and low pass filtering the incoming bits, and removing the noise of RXDn pin.

The next figure illustrates the sampling process of the start bit of an incoming frame. The sampling rate is 16 times of the baud-rate in normal mode and 8 times the baud-rate for double speed mode (DBLSn=1). The horizontal arrows show the synchronization variation due to the asynchronous sampling process. Note that larger time variation is shown when using the double speed mode (n = 10, 11, 12 and 13).







When the receiver is enabled (RXEn=1), the clock recovery logic tries to find a high-to-low transition on the RXDn line, the start bit condition. After detecting high to low transition on RXDn line, the clock recovery logic uses samples 8, 9 and 10 for normal mode to decide if a valid start bit is received. If more than 2 samples have logical low level, it is considered that a valid start bit is detected and the internally generated clock is synchronized to the incoming data frame. And the data recovery can begin. The synchronization process is repeated for each start bit.

As described above, when the receiver clock is synchronized to the start bit, the data recovery can begin. Data recovery process is almost same to the clock recovery process. The data recovery logic samples 16 times for each incoming bits for normal mode and 8 times for double speed mode, and uses sample 8, 9 and 10 to decide data value. If more than 2 samples have low levels, the received bit is considered to a logic '0' and if more than 2 samples have high levels, the received bit is considered to a logic '1'.

The data recovery process is then repeated until a complete frame is received including the first stop bit. The decided bit value is stored in the receive shift register in order. Note that the Receiver only uses the first stop bit of a frame. Internally, after receiving the first stop bit, the Receiver is in idle state and waiting to find start bit.



Figure 119. Asynchronous Data and Parity Bit Sampling (n = 10, 11, 12 and 13)

The process for detecting stop bit is same as clock and data recovery process. That is, if 2 or more samples of 3 center values have high level, correct stop bit is detected, else a frame error (Fen) flag is set. After deciding whether the first stop bit is valid or not, the Receiver goes to idle state and monitors the RXDn line to check a valid high to low transition is detected (start bit detection). (n = 10, 11, 12 and 13).





Figure 120. Stop Bit Sampling and Next Start Bit Sampling (n = 10, 11, 12 and 13)

### 15.3.8 SPI mode

USART can be set to operate in industrial standard SPI compliant mode. The SPI mode features the followings:

- Full Duplex, Three-wire synchronous data transfer.
- Mater and Slave Operation.
- Supports all four SPI modes of operation (mode 0, and 1).
- Selectable LSB first or MSB first data transfer.
- Double buffered transmit and receive.
- Programmable transmit bit rate.

When the SPI mode is enabled by configuring USTnMS[1:0] as "11", the slave select (SSn) pin becomes active LOW input in slave mode operation, or can be output in master mode operation if USTnSSEN bit is set to '0'.

Note that during SPI mode of operation, the pin RXDn is renamed as MISOn, and TXDn is renamed as MOSIn for compatibility to other SPI devices (n = 10, 11, 12, and 13).

### 15.3.9 SPI clock formats and timing

To accommodate a wide variety if synchronous serial peripherals from different manufacturers, the USART has a clock polarity bit (CPOLn) and a clock phase control bit (CPHAn) to select one of four clock formats for data transfers. CPOLn selectively insert an inverter in series with the clock. CPHAn chooses between two different clock phase relationships between the clock and data. Note that CPHAn and CPOLn bits in USARTn\_CR1 register have different meanings according to the USTnMS[1:0] bits which decides the operating mode of USART.

Table 67 shows four combinations of CPOLn and CPHAn for SPI modes 10, 11, 12 and 13 (n = 10, 11, 12, and 13).



| SPIn Mode | CPOLn | CPHAn | Leading Edge     | Trailing Edge    |
|-----------|-------|-------|------------------|------------------|
| 0         | 0     | 0     | Sample (Rising)  | Setup (Falling)  |
| 1         | 0     | 1     | Setup (Rising)   | Sample (Falling) |
| 2         | 1     | 0     | Sample (Falling) | Setup (Rising)   |
| 3         | 1     | 1     | Setup (Falling)  | Sample (Rising)  |

Table 67. CPOL Functionality

NOTE:

1. n = 10, 11, 12 and 13



Figure 121. USART SPIn Clock Formats when CPHAn = 0 (n = 10, 11, 12 and 13)

When CPHAn=0, the slave begins to drive its MISOn output with the first data bit value when SSn goes to active low. The first SCKn edge causes both the master and the slave to sample the data bit value on their MISOn and MOSIn inputs, respectively.

At the second SCKn edge, the USART shifts the second data bit value out to the MOSIn and MISOn outputs of the master and slave, respectively. Unlike the case of CPHAn=1, when CPHAn=0, the slave's SSn input must go to its inactive high level between transfers. This is because the slave can prepare the first data bit when it detects falling edge of SSn input (n = 10, 11, 12 and 13).





Figure 122. USART SPIn Clock Formats when CPHAn=1 (n = 10, 11, 12 and 13)

When CPHAn=1, the slave begins to drive its MISOn output when SSn goes active low, but the data is not defined until the first SCKn edge. The first SCKn edge shifts the first bit of data from the shifter onto the MOSIn output of the master and the MISOn output of the slave.

The next SCKn edge causes both the master and slave to sample the data bit value on their MISOn and MOSIn inputs, respectively. At the third SCKn edge, the USART shifts the second data bit value out to the MOSIn and MISOn output of the master and slave respectively. When CPHAn=1, the slave's SSn input is not required to go to its inactive high level between transfers.

Because the SPIn logic reuses the USART resources, SPIn mode of operation is similar to that of synchronous or asynchronous operation. SPIn transfer is initiated by checking for the USART Data Register Empty flag (DREn=1) and then writing a byte of data to the USTnDR Register. In master mode of operation, even if transmission is not enabled (TXEn=0), writing data to the USTnDR register is necessary because the clock SCKn is generated from transmitter block.



# 15.3.10 Baud rate settings (example)

| Baud   | fOSC=1.00MHz    |        |         |         | fOSC=1.8432MHz |         |         |       | fOSC=2.00MHz    |         |                    |       |  |  |  |
|--------|-----------------|--------|---------|---------|----------------|---------|---------|-------|-----------------|---------|--------------------|-------|--|--|--|
| Rate   | DBLSn=0 DBLSn=1 |        |         | DBLSn=0 |                |         |         |       | DBLSn=0 DBLSn=1 |         |                    |       |  |  |  |
|        | UBAUD           | ERROR  | UBAUD   | ERROR   | UBAUD          | ERROR   | UBAUD   | ERROR | UBAUD           | ERROR   | UBAUD              | ERROR |  |  |  |
| 2400   | 25              | 0.2%   | 51      | 0.2%    | 47             | 0.0%    | 95      | 0.0%  | 51              | 0.2%    | 103                | 0.2%  |  |  |  |
| 4800   | 12              | 0.2%   | 25      | 0.2%    | 23             | 0.0%    | 47      | 0.0%  | 25              | 0.2%    | 51                 | 0.2%  |  |  |  |
| 9600   | 6               | -7.0%  | 12      | 0.2%    | 11             | 0.0%    | 23      | 0.0%  | 12              | 0.2%    | 25                 | 0.2%  |  |  |  |
| 14.4K  | 3               | 8.5%   | 8       | -3.5%   | 7              | 0.0%    | 15      | 0.0%  | 8               | -3.5%   | 16                 | 2.1%  |  |  |  |
| 19.2K  | 2               | 8.5%   | 6       | -7.0%   | 5              | 0.0%    | 11      | 0.0%  | 6               | -7.0%   | 12                 | 0.2%  |  |  |  |
| 28.8K  | 1               | 8.5%   | 3       | 8.5%    | 3              | 0.0%    | 7       | 0.0%  | 3               | 8.5%    | 8                  | -3.5% |  |  |  |
| 38.4K  | 1               | -18.6% | 2       | 8.5%    | 2              | 0.0%    | 5       | 0.0%  | 2               | 8.5%    | 6                  | -7.0% |  |  |  |
| 57.6K  | -               | -      | 1       | 8.5%    | 1              | -25.0%  | 3       | 0.0%  | 1               | 8.5%    | 3                  | 8.5%  |  |  |  |
| 76.8K  | -               | -      | 1       | -18.6%  | 1              | 0.0%    | 2       | 0.0%  | 1               | -18.6%  | 2                  | 8.5%  |  |  |  |
| 115.2K | -               | -      | -       | -       | -              | -       | 1       | 0.0%  | -               | -       | 1                  | 8.5%  |  |  |  |
| 230.4K | -               | -      | -       | -       | -              | -       | -       | -     | -               | -       | -                  | -     |  |  |  |
| Baud   | fOSC=3.6        | B64MHz |         |         | fOSC=4.0       | OMHz    |         |       | fOSC=7.37       | 728MHz  | 1                  | 1     |  |  |  |
| Rate   | DBLSn=0         |        | DBLSn=1 |         | DBLSn=0        |         | DBLSn=1 |       | DBLSn=0         |         | DBLSn=1            |       |  |  |  |
|        | UBAUD           | ERROR  | UBAUD   | ERROR   | UBAUD          | ERROR   | UBAUD   | ERROR | UBAUD           | ERROR   | UBAUD              | ERROR |  |  |  |
| 2400   | 95              | 0.0%   | 191     | 0.0%    | 103            | 0.2%    | 207     | 0.2%  | 191             | 0.0%    | -                  | -     |  |  |  |
| 4800   | 47              | 0.0%   | 95      | 0.0%    | 51             | 0.2%    | 103     | 0.2%  | 95              | 0.0%    | 191                | 0.0%  |  |  |  |
| 9600   | 23              | 0.0%   | 47      | 0.0%    | 25             | 0.2%    | 51      | 0.2%  | 47              | 0.0%    | 95                 | 0.0%  |  |  |  |
| 14.4K  | 15              | 0.0%   | 31      | 0.0%    | 16             | 2.1%    | 34      | -0.8% | 31              | 0.0%    | 63                 | 0.0%  |  |  |  |
| 19.2K  | 11              | 0.0%   | 23      | 0.0%    | 12             | 0.2%    | 25      | 0.2%  | 23              | 0.0%    | 47                 | 0.0%  |  |  |  |
| 28.8K  | 7               | 0.0%   | 15      | 0.0%    | 8              | -3.5%   | 16      | 2.1%  | 15              | 0.0%    | 31                 | 0.0%  |  |  |  |
| 38.4K  | 5               | 0.0%   | 11      | 0.0%    | 6              | -7.0%   | 12      | 0.2%  | 11              | 0.0%    | 23                 | 0.0%  |  |  |  |
| 57.6K  | 3               | 0.0%   | 7       | 0.0%    | 3              | 8.5%    | 8       | -3.5% | 7               | 0.0%    | 15                 | 0.0%  |  |  |  |
| 76.8K  | 2               | 0.0%   | 5       | 0.0%    | 2              | 8.5%    | 6       | -7.0% | 5               | 0.0%    | 11                 | 0.0%  |  |  |  |
| 115.2K | 1               | 0.0%   | 3       | 0.0%    | 1              | 8.5%    | 3       | 8.5%  | 3               | 0.0%    | 7                  | 0.0%  |  |  |  |
| 230.4K | -               | -      | 1       | 0.0%    | -              | -       | 1       | 8.5%  | 1               | 0.0%    | 3                  | 0.0%  |  |  |  |
| 250K   | -               | -      | 1       | -7.8%   | -              | -       | 1       | 0.0%  | 1               | -7.8%   | 3                  | -7.8% |  |  |  |
| 0.5M   | -               | -      | -       | -       | -              | -       | -       | -     | -               | -       | 1                  | -7.8% |  |  |  |
| Baud   | fOSC=8.0        | OMHz   |         |         | fOSC=11.0      | )592MHz |         |       | fOSC=14.7       | 7456MHz |                    | 1     |  |  |  |
| Rate   | DBLSn=0         |        | DBLSn=1 |         | DBLSn=0        |         | DBLSn=1 |       | DBLSn=0         |         | DBLSn=1            |       |  |  |  |
|        | UBAUD           | ERROR  | UBAUD   | ERROR   | UBAUD          | ERROR   | UBAUD   | ERROR | UBAUD           | ERROR   | UBAUD              | ERROR |  |  |  |
| 2400   | 207             | 0.2%   | -       | -       | -              | -       | -       | -     | -               | -       | -                  | -     |  |  |  |
| 4800   | 103             | 0.2%   | 207     | 0.2%    | 143            | 0.0%    | -       | -     | 191             | 0.0%    | -                  | -     |  |  |  |
| 9600   | 51              | 0.2%   | 103     | 0.2%    | 71             | 0.0%    | 143     | 0.0%  | 95              | 0.0%    | 191                | 0.0%  |  |  |  |
| 14.4K  | 34              | -0.8%  | 68      | 0.6%    | 47             | 0.0%    | 95      | 0.0%  | 63              | 0.0%    | 127                | 0.0%  |  |  |  |
| 19.2K  | 25              | 0.2%   | 51      | 0.2%    | 35             | 0.0%    | 71      | 0.0%  | 47              | 0.0%    | 95                 | 0.0%  |  |  |  |
| 28.8K  | 16              | 2.1%   | 34      | -0.8%   | 23             | 0.0%    | 47      | 0.0%  | 31              | 0.0%    | 63                 | 0.0%  |  |  |  |
| 38.4K  | 12              | 0.2%   | 25      | 0.2%    | 17             | 0.0%    | 35      | 0.0%  | 23              | 0.0%    | 47 0.09            |       |  |  |  |
| 57.6K  | 8               | -3.5%  | 16      | 2.1%    | 11             | 0.0%    | 23      | 0.0%  | 15              | 0.0%    | 31 0.0             |       |  |  |  |
| 76.8K  | 6               | -7.0%  | 12      | 0.2%    | 8              | 0.0%    | 17      | 0.0%  | 11              | 0.0%    | 23 0.0%            |       |  |  |  |
| 115.2K | 3               | 8.5%   | 8       | -3.5%   | 5              | 0.0%    | 11      | 0.0%  | 7               | 0.0%    | 15 0.0%            |       |  |  |  |
| 230.4K | 1               | 8.5%   | 3       | 8.5%    | 2              | 0.0%    | 5       | 0.0%  | 3               | 0.0%    | 7                  | 0.0%  |  |  |  |
| 250K   | 1               | 0.0%   | 3       | 0.0%    | 2              | -7.8%   | 5       | -7.8% | 3               | -7.8%   | 6                  | 5.3%  |  |  |  |
|        | -               | -      | 1       | 0.0%    | -              | -       | 2       | -7.8% | 1               | -7.8%   | 3                  | -7.8% |  |  |  |
| 0.5M   | -               |        |         |         |                |         |         |       |                 |         | 3 -7.8%<br>1 -7.8% |       |  |  |  |

# Table 68. Baud Rate Settings Example



### 15.3.11 0% error baud rate

This USART system supports the floating point counter logic for the 0% error of baud rate. By using the 8bits floating point counter logic, the cumulative error to below the decimal point can be removed.

The floating point counter value is defined by baud rate error. In the baud rate formula, USARTn\_BDR is presented the integer count value. For example, If you want to use the 57600 baud rate (fXIN = 16MHz), a calculated integer count value must be 16.36 value (USARTn\_BDR+1 = 16000000/(16×57600) = 17.36). Here, USARTn\_BDR which can be set is the nearest big integer number 17. To realize 0% error of baud rate, floating point counter value must be 92 ((0.36) x 256 = 92). Namely you have to write the 92 (decimal number) in USARTn\_FPCR and 17 (decimal number) in USART\_BAUD.



Figure 123. 0% Error Baud Rate Diagram

### 15.3.12 Receive time out (RTO)

This USART system supports the receive time out (RTO) interrupt. The RTO counter uses the system clock and continues counting while the RXD input is not present. If the RTO counter matches USARTn\_RTO, RTOF becomes 1. RTOEN is set to 1 to enable this operation, and RTOEN is automatically set to 0 when an RTO match occurs. You can use RTO interrupts with RTOIE.



# 16. I2C

# 16. I2C interface

I2C is one of industrial standard serial communication protocols, and which uses 2 bus lines such as Serial Data Line (SDAn) and Serial Clock Line (SCLn) to exchange data. Because both SDAn and SCLn lines are open-drain output, each line needs pull-up resistor respectively.

I2C features the followings (n = 0 and 1):

- Compatible with I2C bus standard.
- Multi-master operation.
- Up to 1MHz data transfer read speed.
- 7-bit address.
- Support two slave address.
- Both master and slave operation.
- Bus busy detection

Table 69 introduces pins assigned for I2C interface.

| Та | ble 69. | Pin Ass | signment | of I2C: | External | Pins |  |
|----|---------|---------|----------|---------|----------|------|--|
|    |         |         |          |         |          |      |  |

| Pin name | Туре | Description                                      |
|----------|------|--------------------------------------------------|
| SCL0     | I/O  | I2C channel 0 Serial clock bus line (open-drain) |
| SDA0     | I/O  | I2C channel 0 Serial data bus line (open-drain)  |
| SCL1     | I/O  | I2C channel 1 Serial clock bus line (open-drain) |
| SDA1     | I/O  | I2C channel 1 Serial data bus line (open-drain)  |

NOTE:

1. n = 0 and 1



# 16.1 I2C block diagram



In this section, I2C interface block is described in a block diagram.

### Figure 124. I2C Block Diagram

## 16.2 Registers

Base address of I2C is introduced in the followings:

| Table 70. | <b>Base Address</b> | of I2C Interface |
|-----------|---------------------|------------------|
|-----------|---------------------|------------------|

| Name | Base address |
|------|--------------|
| 12C0 | 0x4000_4800  |
| I2C1 | 0x4000_4900  |



| Name      | Offset | Туре | Description                   | Reset value | Reference     |
|-----------|--------|------|-------------------------------|-------------|---------------|
| l2Cn_CR   | 0x00   | RW   | I2Cn Control Register         | 0x0000_0000 | <u>16.2.1</u> |
| l2Cn_ST   | 0x04   | RW   | I2Cn Status Register          | 0x0000_0000 | <u>16.2.2</u> |
| I2Cn_SAR1 | 0x08   | RW   | I2Cn Slave Address Register 1 | 0x0000_0000 | <u>16.2.3</u> |
| l2Cn_SAR2 | 0x0C   | RW   | I2Cn Slave Address Register 2 | 0x0000_0000 | <u>16.2.4</u> |
| l2Cn_DR   | 0x10   | RW   | I2Cn Data Register            | 0x0000_0000 | <u>16.2.5</u> |
| I2Cn_SDHR | 0x14   | RW   | I2Cn SDA Hold Time Register   | 0x0000_0001 | <u>16.2.6</u> |
| l2Cn_SCLR | 0x18   | RW   | I2Cn SCL Low Period Register  | 0x0000_003F | <u>16.2.7</u> |
| I2Cn_SCHR | 0x1C   | RW   | I2Cn SCL High Period Register | 0x0000_003F | <u>16.2.8</u> |
| l2Cn_MR   | 0x20   | RW   | I2Cn Mode Control Register    | 0x0000_0000 | <u>16.2.9</u> |

Table 71. I2C Register Map

NOTE:

1. n = 0 and 1

### 16.2.1 I2Cn\_CR: I2Cn control register

The register can be set to configure I2C operation mode and simultaneously allowed for I2C transactions to be kicked off. I2Cn\_CR is a 32-bit register and able to do 32/16/8-bit access.

I2C0\_CR=0x4000\_4800, I2C1\_CR=0x4000\_4900

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7  | 6      | 5     | 4       | 3 2    | 2 1    | 0       |
|-----------------------------------------------------------------------|----|--------|-------|---------|--------|--------|---------|
| Reserved                                                              | 뜨  | I2CnEN | RESET | I2CnIEN | ACKNEN | STOPCn | STARTCn |
| -                                                                     | 0  | 0      | 0     | 0       | 0      | 0 0    | 0       |
|                                                                       | RW | RW     | RW    | RO      | RW F   | RO RW  | RW      |

| 7 | I2CnIFLAG | Interrupt flag bit                                  |
|---|-----------|-----------------------------------------------------|
|   |           | 0 No interrupt is generated or interrupt is cleared |
|   |           | 1 An interrupt is generated                         |
| 6 | I2CnEN    | Activate I2Cn Block (by supplying clock)            |
|   |           | 0 Disable I2C block                                 |
|   |           | 1 Enable I2C block                                  |
| 5 | RESET     | Initialize internal register of I2C                 |
|   |           | 0 No operation                                      |
|   |           | 1 Initialize I2C, auto cleared                      |
| 4 | I2CnIEN   | I2Cn Interrupt Enable bit.                          |
|   |           | 0 Disable interrupt, operates in polling mode       |
|   |           | 1 Enable interrupt                                  |



| 3  | ACKnEN   | l Cor               | trols ACK signal generation at ninth SCL period.                                |
|----|----------|---------------------|---------------------------------------------------------------------------------|
|    |          | 0                   | No ACK signal is generated. (SDA = 1)                                           |
|    |          | 1                   | ACK signal is generated. (SDA = 0)                                              |
| NO | TES:     |                     |                                                                                 |
|    | 1. ACK s | ignal is output (\$ | SDA = 0) for the following 3 cases. Where $x = 0$ and 1.                        |
|    | 2. When  | received addres     | s packet equals to SLAx[6:0] bits in I2Cn_SARx register.                        |
|    | 3. When  | received addres     | s packet equals to value 0x00 with GCALLn enabled.                              |
|    | 4. When  | I2Cn operates a     | as a receiver (master or slave)                                                 |
| 2  | IMASTE   |                     | present Operation Mode of I2Cn. This bit is cleared to "0b" on STOF<br>idition. |
|    |          | 0                   | I2Cn is in slave mode.                                                          |
|    |          | 1                   | I2Cn is in master mode.                                                         |
| 1  | STOPCr   | ו _STC              | DP Condition Generation When I2Cn is master.                                    |
|    |          | 0                   | No effect.                                                                      |
|    |          | 1                   | STOP condition is to be generated.                                              |
| 0  | STARTO   | Cn STA              | ART Condition Generation When I2Cn is master.                                   |
|    |          | 0                   | No effect.                                                                      |
|    |          | 1                   | START or Repeated START condition is to be generated.                           |

### 16.2.2 I2Cn\_ST: I2Cn status register

I2Cn\_ST is a 32-bit register and able to do 32/16/8-bit access.

# I2C0\_ST=0x4000\_4804, I2C1\_ST=0x4000\_4904

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 | 98 | 7      | 6     | 5      | 4     | 3      | 2     | 1      | 0      |
|-------------------------------------------------------------------|----|--------|-------|--------|-------|--------|-------|--------|--------|
| Reserved                                                          |    | GCALLn | TENDn | STOPDn | SSELn | MLOSTn | BUSYn | TMODEn | RXACKn |
| -                                                                 |    | 0      | 0     | 0      | 0     | 0      | 0     | 0      | 0      |
|                                                                   |    | RW     | RW    | RW     | RW    | RW     | RW    | RO     | RW     |

| 7 | GCALLn | This bit has different meaning depending on whether I2C is master or<br>slave. When I2C is a master, this bit represents whether it received<br>AACK (address ACK) from slave. |
|---|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |        | 0 No AACK is received. (Master mode)                                                                                                                                           |
|   |        | 1 AACK is received (Master mode). It may be set to "1b" after address transmission.                                                                                            |
|   |        | When I2C is a slave, this bit is used to indicate general call.                                                                                                                |
|   |        | 0 General call address is not detected. (Slave mode)                                                                                                                           |
|   |        | 1 General call address is detected. (Slave mode)                                                                                                                               |
| 6 | TENDn  | This bit is set when 1-byte of data is transferred completely.                                                                                                                 |
|   |        | 0 1 byte of data is not completely transferred.                                                                                                                                |
|   |        | 1 1 byte of data is completely transferred.                                                                                                                                    |
| 5 | STOPDn | This bit is set when a STOP condition is detected.                                                                                                                             |
|   |        | 0 A STOP condition is not detected.                                                                                                                                            |
|   |        | 1 A STOP condition is detected.                                                                                                                                                |
| 4 | SSELn  | This bit is set when I2C is addressed by other master.                                                                                                                         |
|   |        | 0 I2C is not selected as a slave.                                                                                                                                              |
|   |        | 1 I2C is addressed by other master and acts as a slave.                                                                                                                        |



| 3        | MLOSTn | This bit represents the result of bus arbitration in master mode.   |
|----------|--------|---------------------------------------------------------------------|
|          |        | 0 I2C maintains bus mastership.                                     |
|          |        | 1 I2C has lost bus mastership during arbitration process.           |
| 2 BUSYn  |        | This bit reflects bus status.                                       |
|          |        | 0 I2C bus is idle, so a master can issue a START condition.         |
|          |        | 1 I2C bus is busy.                                                  |
| 1 TMODEn | TMODEn | This bit is used to indicate whether I2C is transmitter or receiver |
|          |        | 0 I2C is a receiver.                                                |
|          |        | 1 I2C is a transmitter.                                             |
| 0 RXACKn |        | This bit shows the state of ACK signal.                             |
|          |        | 0 No ACK is received.                                               |
|          |        | 1 ACK is received at ninth SCL period.                              |

NOTES:

- 1. The GCALLn, TENDn, STOPDn, SSELn, and MLOSTn bits can be source of interrupt.
- 2. When an I2C interrupt occurs except for deep sleep mode, the SCL line is held low.
- 3. To release SCL, Clear to "0b" all interrupt source bits in I2Cn\_ST register.
- 4. The GCALLn, TENDn, STOPDn, SSELn, MLOSTn, and RXACKn bits are cleared when "1b" is written to the corresponding bit.

### 16.2.3 I2Cn\_SAR1: I2Cn slave address register 1

I2Cn\_SAR1 is a 32-bit register and able to do 32/16/8-bit access.

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 | 0        |
|-----------------------------------------------------------------------|---------------|----------|
| Reserved                                                              | SLAn          | GCALLNEN |
| _                                                                     | 0000000       | 0        |
| -                                                                     | RW            | RW       |

| I2C0_SAR1=0x4000_ | 4808, I2C1 | SAR1=0x4000 | 4908 |
|-------------------|------------|-------------|------|
|                   |            |             |      |

| 7<br>1 | SLAn     | These bits configure the slave address 0 in slave mode.                                |  |
|--------|----------|----------------------------------------------------------------------------------------|--|
| 0      | GCALLnEN | This bit decides whether I2Cn allows general call address 0 or not in I2Cn slave mode. |  |
|        |          | 0 Ignore general call address 0.                                                       |  |
|        |          | 1 Allow general call address 0.                                                        |  |



## 16.2.4 I2Cn\_SAR2: I2Cn slave address register 2

I2Cn\_SAR2 is a 32-bit register and able to do 32/16/8-bit access.

|                                                 | I2C0_SAR2=0x4000_480C, | I2C1_SAR2=0x4000_49 | 90C      |
|-------------------------------------------------|------------------------|---------------------|----------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8  | 7 6 5 4 3 2 1       | 0        |
| Reserved                                        |                        | SLAn                | GCALLnEN |
| 0x000000                                        |                        | 0000000             | 0        |
| -                                               |                        | RW                  | RW       |

| 7<br>1 | SLAn     | These bits configure the slave address 1 in slave mode.                           |  |
|--------|----------|-----------------------------------------------------------------------------------|--|
| 0      | GCALLnEN | This bit decides whether I2Cn allows general call address 1 or n I2Cn slave mode. |  |
|        |          | 0 Ignore general call address 1.                                                  |  |
|        |          | 1 Allow general call address 1.                                                   |  |

### 16.2.5 I2Cn\_DR: I2Cn data register

I2Cn\_DR is a 32-bit register and able to do 32/16/8-bit access.

#### I2C0\_DR=0x4000\_4810, I2C1\_DR=0x4000\_4910

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0 |
|-----------------------------------------------------------------------|-----------------|
| Reserved                                                              | DATA            |
|                                                                       | 0x0F            |
|                                                                       | RW              |

| 7 | DATA | The I2Cn_DR Transmit buffer and Receive buffer share the same I/O                                                                  |
|---|------|------------------------------------------------------------------------------------------------------------------------------------|
| 0 |      | address with this DATA register. The Transmit Data Buffer is the destination for data written to the I2Cn_DR register. Reading the |
|   |      | I2Cn_DR register returns the contents of the Receive Buffer.                                                                       |



### 16.2.6 I2Cn\_SDAHR: I2Cn SDA hold time register

I2Cn\_ SDAHR is a 32-bit register and able to do 32/16/8-bit access.

| I2C0_SDHR=0x4000_4814                                                 | , I2C1_SDHR=0x4000_4914 |
|-----------------------------------------------------------------------|-------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0         |
| Reserved                                                              | HLDT                    |
|                                                                       | 0x0F                    |
|                                                                       | RW                      |

| 7<br>0 | HLDT | This register is used to control SDA output timing from the falling edge<br>of SCL.<br>Note that SDA is changed after tPCLK X (I2Cn_SDHR+2). In master                                |
|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |      | mode, load half the value of I2Cn_SCLR to this register to make SDA change in the middle of SCL.                                                                                      |
|        |      | In slave mode, configure this register regarding the frequency of SCL from master.                                                                                                    |
|        |      | The SDA is changed after tPCLK X (I2Cn_SDHR+2) in master mode.<br>So, to insure operation in slave mode, the value tPCLK X (I2Cn_SDHR<br>+ 2) must be smaller than the period of SCL. |
|        |      |                                                                                                                                                                                       |

### 16.2.7 I2Cn\_SCLLR: I2Cn SCL low period register

I2Cn\_SCLLR is a 32-bit register and able to do 32/16/8-bit access.

#### I2C0\_SCLR=0x4000\_4818, I2C1\_SCLR=0x4000\_4918

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0 |
|-----------------------------------------------------------------------|-----------------|
| Reserved                                                              | SCLL            |
|                                                                       | 0xF             |
|                                                                       | RW              |

| 7<br>0 | SCLL | This register defines the low period of SCL in master mode. The base clock is PCLK and the period is calculated by the formula: tPCLK X (4 X |
|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------|
|        |      | I2Cn_SCLR + 2) where tPCLK is the period of PCLK.                                                                                            |



### 16.2.8 I2Cn\_SCLHR: I2Cn SCL high period register

I2Cn\_ SCLHR is a 32-bit register and able to do 32/16/8-bit access.

### I2C0\_SCHR=0x4000\_481C, I2C1\_SCHR=0x4000\_491C

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0 |  |  |  |  |  |
|-----------------------------------------------------------------------|-----------------|--|--|--|--|--|
| Reserved                                                              | SCLH            |  |  |  |  |  |
|                                                                       | 0xF             |  |  |  |  |  |
|                                                                       | RW              |  |  |  |  |  |

| 7 | SCLH | This register defines the high period of SCL in master mode. The base   |
|---|------|-------------------------------------------------------------------------|
| 0 |      | clock is PCLK and the period is calculated by the formula: tPCLK X (4 X |
|   |      | I2Cn_SCHR + 2) where tPCLK is the period of PCLK.                       |

#### 16.2.9 I2Cn\_MR: I2Cn mode control register

#### I2C0\_SCHR=0x4000\_4820, I2C1\_SCHR=0x4000\_4920

| 31 | 30 | 0 29 | 28 | 27 | 26 | 25 | 24 | 23 | 3 22 | 21 | 20 | 19 | 18 | 17 | 16   | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |
|----|----|------|----|----|----|----|----|----|------|----|----|----|----|----|------|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------|
|    |    |      |    |    |    |    |    |    |      |    |    |    |    | Re | ser\ | ved |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DIS_SDAH |
|    |    |      |    |    |    |    |    |    |      |    |    |    |    |    |      |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0        |
|    |    |      |    |    |    |    |    |    |      |    |    |    |    |    |      |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW       |

| 0 | 0 DIS_SDAH Disabl |   | e SDA hold time                                                                                                                                                                                                                                                                                   |  |  |  |  |
|---|-------------------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|   |                   | 0 | Enable SDA hold time                                                                                                                                                                                                                                                                              |  |  |  |  |
|   |                   |   | When I2CST is written, the MSB of the transmitted data of I2CDR<br>is on the output to SDA port before three system clocks from the<br>rising edge of SCL.<br>The other bits after the MSB bit are outputted to SDA port in the<br>timing<br>Controlled by I2CSDAHR from the falling edge of SCL. |  |  |  |  |
|   |                   | 1 | Disable SDA hold time                                                                                                                                                                                                                                                                             |  |  |  |  |
|   |                   |   | When I2CDR is written, the MSB of the transmitted data of I2CDR is on the output to SDA port directly. The other bits after the MSB bit are outputted after the falling edge of SCL irrespective of I2CSDAHR.                                                                                     |  |  |  |  |



# 16.3 Functional description

### 16.3.1 I2C bit transfer

Data on the SDAn line must be stable during HIGH period of the clock, SCLn. HIGH or LOW state of the data line can only change when the clock signal on the SCLn line is LOW. The exceptions are START(S), repeated START(Sr) and STOP(P) condition where data line changes when clock line is high.



Figure 125. I2C Bus Bit Transfer (n = 0 and 1)

## 16.3.2 START/repeated START/STOP

One master can issue a START (S) condition to notice other devices connected to the SCLn, SDAn lines that it will use the bus. A STOP (P) condition is generated by the master to release the bus lines so that other devices can use it.

- A high to low transition on the SDAn line while SCLn is high defines a START (S) condition.
- A low to high transition on the SDAn line while SCLn is high defines a STOP (P) condition.

START and STOP conditions are always generated by the master. The bus is considered to be busy after START condition. The bus is considered to be free again after STOP condition, ie, the bus is busy between START and STOP condition. If a repeated START condition (Sr) is generated instead of STOP condition, the bus stays busy. So, the START and repeated START conditions are functionally identical.



Figure 126. START and STOP Condition (n = 0 and 1)



### 16.3.3 Data transfer

Every byte put on the SDAn line must be 8-bits long. The number of bytes that can be transmitted per transfer is unlimited. Each byte has to be followed by an acknowledge bit. Data is transferred with the most significant bit (MSB) first.

If a slave can't receive or transmit another complete byte of data until it has performed some other function, it can hold the clock line SCLn LOW to force the master into a wait state. Data transfer then continues when the slave is ready for another byte of data and releases clock line SCLn.



Figure 127. I2C Bus Data Transfer (n = 0 and 1)

### 16.3.4 Acknowledge

The acknowledge related clock pulse is generated by the master. The transmitter releases the SDAn line (HIGH) during the acknowledge clock pulse. The receiver must pull down the SDAn line during the acknowledge clock pulse so that it remains stable LOW during the HIGH period of this clock pulse. When a slave is addressed by a master (Address Packet), and if it is unable to receive or transmit because it's performing some real time function, the data line must be left HIGH by the slave.

And also, when a slave addressed by a master is unable to receive more data bits, the slave receiver must release the SDAn line (Data Packet). The master can then generate either a STOP condition to abort the transfer, or a repeated START condition to start a new transfer.

If a master receiver is involved in a transfer, it must signal the end of data to the slave transmitter by not generating any acknowledge on the last byte that was clocked out of the slave. The slave transmitter must release the data line to allow the master to generate a STOP or repeated START condition.





Figure 128. I2C Bus Acknowledge (n = 0 and 1)

# 16.3.5 Synchronization/Arbitration

Clock synchronization is performed using the wired-AND connection of I2C interfaces to the SCLn line. This means that a HIGH to LOW transition on the SCLn line will cause the devices concerned to start counting off their LOW period and it will hold the SCLn line in that state until the clock HIGH state is reached. However the LOW to HIGH transition of this clock may not change the state of the SCLn line if another clock is still within its LOW period. In this way, a synchronized SCLn clock is generated with its LOW period determined by the device with the longest clock LOW period, and its HIGH period determined by the one with the shortest clock HIGH period.

A master may start a transfer only if the bus is free. Two or more masters may generate a START condition. Arbitration takes place on the SDAn line, while the SCLn line is at the HIGH level, in such a way that the master which transmits a HIGH level, while another master is transmitting a LOW level will switch off its DATA output state because the level on the bus doesn't correspond to its own level. Arbitration continues for many bits until a winning master gets the ownership of I2C bus. Its first stage is comparison of the address bits.



Figure 129. Clock Synchronization during the Arbitration Procedure (n = 0 and 1)





Figure 130. Arbitration Procedure between Two Masters (n = 0 and 1)

### 16.3.6 I2C operation

The I2C is byte-oriented and interrupt based. Interrupts are issued after all bus events except for a transmission of a START condition. Because the I2C is interrupt based, the application software is free to carry on other operations during an I2C byte transfer.

Note that when an I2C interrupt is generated, I2CnIFLAG flag in I2CnIEN register is set, it is cleared when all interrupt source bits in the I2Cn\_ST register are cleared to "0b". When I2C interrupt occurs, the SCLn line is hold LOW until clearing "0b" all interrupt source bits in I2Cn\_ST register. When the I2CnIFLAG flag is set, the I2Cn\_ST contains a value indicating the current state of the I2C bus. According to the value in I2Cn\_ST, software can decide what to do next.

I2C can operate in 4 modes by configuring master/slave, transmitter/receiver. The operating mode is configured by a winning master. A more detailed explanation follows below. (n = 0 and 1)



#### 16. I2C

### Master transmitter

To operate I2C in master transmitter, follow the recommended steps below:

- 1. Enable I2C by setting I2CnEN bit in I2Cn\_CR. This provides main clock to the peripheral.
- 2. Load SLA+W into the I2Cn\_DR where SLA is address of slave device and W is transfer direction from the viewpoint of the master. For master transmitter, W is '0'. Note that I2Cn\_DR is used for both address and data.
- 3. Configure baud rate by writing desired value to both I2Cn\_SCLR and I2Cn\_SCHR for the Low and High period of SCLn line.
- Configure the I2Cn\_SDHR to decide when SDAn changes value from falling edge of SCLn. If SDA should change in the middle of SCLn LOW period, load half the value of I2Cn\_SCLR to the I2Cn\_SDHR.
- 5. Set the STARTCn bit in I2Cn\_CR. This transmits a START condition. And also configure how to handle interrupt and ACK signal. When the STARTCn bit is set, 8-bit data in I2Cn\_DR is transmitted out according to the baud-rate.
- 6. This is ACK signal processing stage for address packet transmitted by master. When 7-bit address and 1-bit transfer direction is transmitted to target slave device, the master can know whether the slave acknowledged or not in the 9th high period of SCLn. If the master gains bus mastership, I2C generates GCALL interrupt regardless of the reception of ACK from the slave device. When I2C loses bus mastership during arbitration process, the MLOSTn bit in I2Cn\_ST is set, and I2C waits in idle state or can be operate as an addressed slave. To operate as a slave when the MLOSTn bit in I2Cn\_ST is set, the ACKnEN bit in I2Cn\_CR must be set and the received 7-bit address must equal to the SLAn bits in I2Cn\_SAR1/2. In this case I2C operates as a slave transmitter or a slave receiver (go to appropriate section). In this stage, I2C holds the SCLn LOW. This is because to decide whether I2C continues serial

In this stage, I2C holds the SCLn LOW. This is because to decide whether I2C continues serial transfer or stops communication. The following steps continue assuming that I2C does not lose mastership during first data transfer.

I2C (master) can choose one of the following cases regardless of the reception of ACK signal from slave.

- Case 1. Master receives ACK signal from slave, so continues data transfer because slave can receive more data from master. In this case, load data to transmit to I2Cn\_DR.
- Case 2. Master stops data transfer even if it receives ACK signal from slave. In this case, set the STOPC bit in I2Cn\_CR.
- Case 3. Master transmits repeated START condition with not checking ACK signal. In this case, load SLA+R/W into the I2Cn\_DR and set STARTCn bit in I2Cn\_CR.

After doing one of the actions above, clear all interrupt source bits in I2Cn\_ST to "0b" to release SCLn line.

For the Case 1, move to step 7. For the Case 2, move to step 9 to handle STOP interrupt. For the Case 3, move back to step 6 after transmitting the data in I2Cn\_DR and if transfer direction bit is '1' go to master receiver section.



- 7. 1-Byte of data is being transmitted. During data transfer, bus arbitration continues.
- 8. This is ACK signal processing stage for data packet transmitted by master. I2C holds the SCLn LOW. When I2C loses bus mastership while transmitting data arbitrating other masters, the MLOSTn bit in I2Cn\_ST is set. If then, I2C waits in idle state. When the data in I2Cn\_DR is transmitted completely, I2C generates TENDn interrupt.

I2C can choose one of the following cases regardless of the reception of ACK signal from slave.

- Case A. Master receives ACK signal from slave, so continues data transfer because slave can receive more data from master. In this case, load data to transmit to I2Cn\_DR.
- Case B. Master stops data transfer even if it receives ACK signal from slave. In this case, set the STOPCn bit in I2CnCR.
- Case C. Master transmits repeated START condition with not checking ACK signal. In this case, load SLA+R/W into the I2Cn\_DR and set the STARTCn bit in I2Cn\_CR.

After doing one of the actions above, clear all interrupt source bits in I2Cn\_ST to "0b" to release SCL line. For the Case A, move back to step 7. For the Case B, move to step 9 to handle STOP interrupt. For the Case C, move back to step 6 after transmitting the data in I2C\_DR, and if transfer direction bit is '1' go to master receiver section.

9. This is the final step for master transmitter function of I2C, handling STOP interrupt. The STOP bit indicates that data transfer between master and slave is over. To clear I2Cn\_ST, write "0" to I2CnST. After this, I2C enters in idle state.



### Master receiver

To operate I2C in master receiver, follow the recommended steps below:

- 1. Enable I2C by setting I2CnEN bit in I2Cn\_CR. This provides main clock to the peripheral.
- 2. Load SLA+R into the I2Cn\_DR where SLA is address of slave device and R is transfer direction from the viewpoint of the master. For master receiver, R is '1'. Note that I2Cn\_DR is used for both address and data.
- 3. Configure baud rate by writing desired value to both I2Cn\_SCLR and I2Cn\_SCHR for the Low and High period of SCLn line.
- Configure the I2CnSDHR to decide when SDAn changes value from falling edge of SCLn. If SDAn should change in the middle of SCLn LOW period, load half the value of I2Cn\_SCLR to the I2Cn\_SDHR.
- 5. Set the STARTCn bit in I2Cn\_CR. This transmits a START condition. And also configure how to handle interrupt and ACK signal. When the STARTCn bit is set, 8-bit data in I2Cn\_DR is transmitted out according to the baud-rate.
- 6. This is ACK signal processing stage for address packet transmitted by master. When 7-bit address and 1-bit transfer direction is transmitted to target slave device, the master can know whether the slave acknowledged or not in the 9th high period of SCLn. If the master gains bus mastership, I2C generates GCALL interrupt regardless of the reception of ACK from the slave device. When I2C loses bus mastership during arbitration process, the MLOSTn bit in I2Cn\_ST is set, and I2C waits in idle state or can be operate as an addressed slave. To operate as a slave when the MLOSTn bit in I2Cn\_ST is set, the ACKnEN bit in I2Cn\_CR must be set and the received 7-bit address must equal to the SLAn bits in I2Cn\_SAR1/2. In this case I2C operates as a slave transmitter or a slave receiver (go to appropriate section). In this stage, I2C holds the SCLn LOW. This is because to decide whether I2C continues serial transfer or stops communication. The following steps continue assuming that I2C does not lose mastership during first data transfer.

I2C (master) can choose one of the following cases according to the reception of ACK signal from slave.

- Case 1. Master receives ACK signal from slave, so continues data transfer because slave can prepare and transmit more data to master. Configure ACKnEN bit in I2Cn\_CR to decide whether I2C Acknowledges the next data to be received or not.
- Case 2. Master stops data transfer because it receives no ACK signal from slave. In this case, set the STOPCn bit in I2Cn\_CR.
- Case 3. Master transmits repeated START condition due to no ACK signal from slave. In this case, load SLA+R/W into the I2Cn\_DR and set STARTCn bit in I2Cn\_CR.

After doing one of the actions above, clear all interrupt source bits in I2Cn\_ST to "0b" to release SCLn line. For the Case 1, move to step 7. For the Case 2, move to step 9 to handle STOP interrupt. For the Case 3, move to step 6 after transmitting the data in I2Cn\_DR and if transfer direction bit is '0' go to master transmitter section.



- 7. 1-Byte of data is being received.
- 8. This is ACK signal processing stage for data packet transmitted by slave. I2C holds the SCLn LOW. When 1-Byte of data is received completely, I2C generates TENDn interrupt.

I2C can choose one of the following cases according to the RXACKn flag in I2Cn\_ST.

- Case A. Master continues to receive data from slave. To do this, set ACKnEN bit in I2Cn\_CR to acknowledge the next data to be received.
- Case B. Master wants to terminate data transfer when it receives next data by not generating ACK signal. This can be done by clearing ACKnEN bit in I2Cn\_CR.
- Case C. Because no ACK signal is detected, master terminates data transfer. In this case, set the STOPCn bit in I2Cn\_CR.
- Case D. No ACK signal is detected, and master transmits repeated START condition. In this case, load SLA+R/W into the I2CnDR and set the STARTCn bit in I2Cn\_CR.

After doing one of the actions above, clear all interrupt source bits in I2Cn\_ST to "0b" to release SCLn line. For the Case A and B, move to step 7. For the Case C, move to step 9 to handle STOP interrupt. For the Case D, move to step 6 after transmitting the data in I2Cn\_DR, and if transfer direction bit is '0' go to master transmitter section.

9. This is the final step for master receiver function of I2C, handling STOP interrupt. The STOP bit indicates that data transfer between master and slave is over. To clear I2Cn\_ST, write "0" value to I2Cn\_ST. After this, I2C enters idle state.



### Slave transmitter

To operate I2C in slave transmitter, follow the recommended steps below:

- If the main operating clock (SCLK) of the system is slower than that of SCLn, load value 0x00 into I2Cn\_SDHR to make SDAn change within one system clock period from the falling edge of SCLn. Note that the hold time of SDAn is calculated by SDAH x period of SCLK where SDAH is multiple of number of SCLK coming from I2CnSDHR. When the hold time of SDAn is longer than the period of SCLK, I2C (slave) cannot transmit serial data properly.
- 2. Enable I2C by setting I2CnIEN bit and I2CnEN bit in I2Cn\_CR. This provides main clock to the peripheral.
- 3. When a START condition is detected, I2C receives one byte of data and compares it with SLAn bits in I2Cn\_SAR1/2. If the GCALLnEN bit in I2Cn\_SAR1/2 is enabled, I2C compares the received data with value 0x00, the general call address.
- 4. If the received address does not equal to SLAn bits in I2Cn\_SAR, I2C enters idle state ie, waits for another START condition. Else if the address equals to SLAn bits and the ACKnEN bit is enabled, I2C generates SSELn interrupt and the SCLn line is held LOW. Note that even if the address equals to SLAn bits, when the ACKnEN bit is disabled, I2C enters idle state. When SSELn interrupt occurs, load transmit data to I2Cn\_DR and clear to "0b" all interrupt source bits in I2Cn\_ST to release SCLn line.
- 5. 1-Byte of data is being transmitted.
- 6. In this step, I2C generates TENDn interrupt and holds the SCLn line LOW regardless of the reception of ACK signal from master. Slave can select one of the following cases:

Case 1. No ACK signal is detected and I2C waits STOP or repeated START condition.

Case 2. ACK signal from master is detected. Load data to transmit into I2Cn\_DR.

After doing one of the actions above, clear all interrupt source bits in I2Cn\_ST to "0b" to release SCLn line. For the Case 1, move to step 7 to terminate communication. For the Case 2, move back to step 5. In either case, a repeated START condition can be detected. For that case, move back to step 4.

7. This is the final step for slave transmitter function of I2C, handling STOP interrupt. The STOPCn bit indicates that data transfer between master and slave is over. To clear I2Cn\_ST, write "0" to I2Cn\_ST. After this, I2C enters idle state.



### Slave receiver

To operate I2C in slave receiver, follow the recommended steps below:

- If the main operating clock (SCLK) of the system is slower than that of SCLn, load value 0x00 into I2Cn\_SDHR to make SDAn change within one system clock period from the falling edge of SCLn. Note that the hold time of SDAn is calculated by SDAH x period of SCLK where SDAH is multiple of number of SCLK coming from I2Cn\_SDHR. When the hold time of SDAn is longer than the period of SCLK, I2C (slave) cannot transmit serial data properly.
- 2. Enable I2C by setting I2CnIEN bit in I2CnCR. This provides main clock to the peripheral.
- 3. When a START condition is detected, I2C receives one byte of data and compares it with SLA bits in I2C\_SAR. If the GCALLnEN bit in I2Cn\_SAR1/2 is enabled, I2C compares the received data with value 0x00, the general call address.
- 4. If the received address does not equal to SLAn bits in I2Cn\_SAR1/2, I2C enters idle state ie, waits for another START condition. Else if the address equals to SLAn bits and the ACKnEN bit is enabled, I2C generates SSELn interrupt and the SCLn line is held LOW. Note that even if the address equals to SLA bits, when the ACKnEN bit is disabled, I2C enters idle state. When SSELn interrupt occurs and I2C is ready to receive data, clear to "0b" all interrupt source bits in I2Cn\_ST to release SCLn line.
- 5. 1-Byte of data is being received.
- 6. In this step, I2C generates TENDn interrupt and holds the SCLn line LOW regardless of the reception of ACK signal from master. Slave can select one of the following cases:
  - Case 1. No ACK signal is detected (ACKnEN=0) and I2C waits STOP or repeated START condition.
  - Case 2. ACK signal is detected (ACKnEN=1) and I2C can continue to receive data from master.

After doing one of the actions above, clear all interrupt source bits in I2CnST to "0b" to release SCLn line. For the Case 1, move to step 7 to terminate communication. For the Case 2, move back to step 5. In either case, a repeated START condition can be detected. For that case, move back to step 4.

7. This is the final step for slave receiver function of I2C, handling STOP interrupt. The STOPCn bit indicates that data transfer between master and slave is over. To clear I2CnST, write "0" to I2CnST. After this, I2C enters idle state.



# 17. Serial peripheral interface (SPI)

A channel serial interface is provided for synchronous serial communications with external peripherals. SPI block support both of master and slave mode. Four signals will be used for SPI communication such as SS, SCK, MOSI, and MISO.

SPI of A31G32x series features the followings:

- Master or Slave operation.
- Programmable clock polarity and phase.
- 8, 9, 16, 17-bit wide transmit/receive register.
- 8, 9, 16, 17-bit wide data frame.
- Loop-back mode.
- Programmable start, burst, and stop delay time.
- DMA transfer operation.

Table 72 introduces pins assigned for SPI.

### Table 72. Pin Assignment of SPI: External Pins

| Pin name | Туре | Description                                   |
|----------|------|-----------------------------------------------|
| SSn      | I/O  | SPIn Slave select input / output              |
| SCKn     | I/O  | SPIn Serial clock input / output              |
| MOSIn    | I/O  | SPIn Serial data (Master output, Slave input) |
| MISOn    | I/O  | SPIn Serial data (Master input, Slave output) |

NOTE: n = 20 and 21



# 17.1 SPI block diagram



In this section, SPI is described in a block diagram in Figure 131.

Figure 131. SPI Block Diagram

# 17.2 Registers

Base address of SPI is introduced in the followings:

| Table 73. B | ase Address of SP |  |
|-------------|-------------------|--|
|-------------|-------------------|--|

| Name  | Base address |
|-------|--------------|
| SPI20 | 0x4000_4C00  |
| SPI21 | 0x4000_4D00  |

Table 74. SPI Register Map

| Name     | Offset | Туре | Description                 | Reset value | Reference     |
|----------|--------|------|-----------------------------|-------------|---------------|
| SPIn.TDR | 0x00   | W    | SPIn Transmit Data Register | 0x000000    | <u>17.2.1</u> |
| SPIn.RDR | 0x00   | R    | SPIn Receive Data Register  | 0x000000    | <u>17.2.2</u> |
| SPIn.CR  | 0x04   | RW   | SPIn Control Register       | 0x001020    | <u>17.2.3</u> |
| SPIn.SR  | 0x08   | RW   | SPIn Status Register        | 0x000006    | <u>17.2.4</u> |
| SPIn.BR  | 0x0C   | RW   | SPIn Baud rate Register     | 0x0000FF    | <u>17.2.5</u> |
| SPIn.EN  | 0x10   | RW   | SPIn Enable register        | 0x000000    | <u>17.2.6</u> |
| SPIn.LR  | 0x14   | RW   | SPIn delay Length Register  | 0x010101    | <u>17.2.7</u> |



#### SPIn.TDR: SPI transmit data register 17.2.1

SPIn.TDR is a 17-bit sized read/write register. It contains serial transmit data.

|                                             | SPI20.1DR=0X4000_4C00, SPI21.1DR=0X4000_4D00 |  |  |  |  |  |
|---------------------------------------------|----------------------------------------------|--|--|--|--|--|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 1 | 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0     |  |  |  |  |  |
| Reserved                                    | TDR                                          |  |  |  |  |  |
| 0                                           | 0x00000                                      |  |  |  |  |  |
|                                             | RW                                           |  |  |  |  |  |

| SPI20.TDR=0x4000_ | _4C00, | SPI21.TDR=0x4000_ | _4D00 |
|-------------------|--------|-------------------|-------|
|                   |        |                   |       |

| 16<br>0 | TDR | Transmit Data Register |
|---------|-----|------------------------|

### 17.2.2 SPIn.RDR: SPI receive data register

SPIn.RDR is a 17-bit sized read/write register. It contains serial receive data.

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 | 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |
|----------------------------------------------|------------------------------------------|--|--|--|--|--|--|
| Reserved                                     | RDR                                      |  |  |  |  |  |  |
| 0                                            | 0x00000                                  |  |  |  |  |  |  |
| •                                            | RW                                       |  |  |  |  |  |  |
|                                              |                                          |  |  |  |  |  |  |

#### SPI20.RDR=0x4000\_4C00, SPI21.RDR=0x4000\_4D00

| 16 | BUB | Pocoivo Doto Pogistor |  |
|----|-----|-----------------------|--|
| 10 | NUN | Receive Data Register |  |
| 0  |     |                       |  |
| 0  |     |                       |  |

### 17.2.3 SPIn.CR: SPI control register

SPIn.CR is a 20-bit sized read/write register and can be set to configure SPI operation mode.

### SPI20.CR=0x4000\_4C04, SPI21.CR=0x4000\_4D04

| 31 30 29 28 27 26 25 24 23 22 21 | 20   | 19   | 18    | 17    | 16    | 15   | 14   | 13    | 12    | 11  | 10     | 9     | 8             | 7        | 6 | 5  | 4    | 3    | 2    | 1 0   |
|----------------------------------|------|------|-------|-------|-------|------|------|-------|-------|-----|--------|-------|---------------|----------|---|----|------|------|------|-------|
| Reserved                         | TXBC | RXBC | DTXIE | DRXIE | SSCIE | TXIE | RXIE | SSMOD | SSOUT | TBE | SSMARK | OMOSS | <b>TOdOSS</b> | pendesed |   | MS | MSBF | CPHA | CPOL | BITSZ |
| 0                                | 0    | 0    | 0     | 0     | 0     | 0    | 0    | 0     | 1     | 0   | 0      | 0     | 0             | -        |   | 1  | 0    | 0    | 0    | 00    |
|                                  | RW   | RW   | RW    | RW    | RW    | RW   | RW   | RW    | RW    | RW  | RW     | RW    | RW            |          |   | RW | RW   | RW   | RW   | RW    |



| 20 | TXBC   | Tx buffer clear bit.                                                             |
|----|--------|----------------------------------------------------------------------------------|
|    |        | 0 No action                                                                      |
|    |        | 1 Clear Tx buffer                                                                |
| 19 | RXBC   | Rx buffer clear bit                                                              |
|    |        | 0 No action                                                                      |
|    |        | 1 Clear Rx buffer                                                                |
| 18 | TXDIE  | DMA Tx Done Interrupt Enable bit.                                                |
|    |        | 0 DMA Tx Done Interrupt is disabled.                                             |
|    |        | 1 DMA Tx Done Interrupt is enabled.                                              |
| 17 | RXDIE  | DMA Rx Done Interrupt Enable bit.                                                |
|    |        | 0 DMA Rx Done Interrupt is disabled.                                             |
|    |        | 1 DMA Rx Done Interrupt is enabled.                                              |
| 16 | SSCIE  | SS Edge Change Interrupt Enable bit.                                             |
|    |        | 0 nSS interrupt is disabled.                                                     |
|    |        | 1 nSS interrupt is enabled for both edges ( $L \rightarrow H, H \rightarrow L$ ) |
| 15 | TXIE   | Transmit Interrupt Enable bit.                                                   |
|    |        | 0 Transmit Interrupt is disabled.                                                |
|    |        | 1 Transmit Interrupt is enabled.                                                 |
| 14 | RXIE   | Receive Interrupt Enable bit.                                                    |
|    |        | 0 Receive Interrupt is disabled.                                                 |
|    |        | 1 Receive Interrupt is enabled.                                                  |
| 13 | SSMOD  | SS Auto/Manual output select bit.                                                |
|    |        | 0 SS output is not set by SSOUT (SPInCR[12]).                                    |
|    |        | SS signal is in normal operation mode.                                           |
|    |        | 1 SS output signal is set by SSOUT.                                              |
| 12 | SSOUT  | SS output signal select bit.                                                     |
|    |        | 0 SS output is 'L.'                                                              |
|    |        | 1 SS output is 'H'.                                                              |
| 11 | LBE    | Loop-back mode select bit in master mode.                                        |
|    |        | 0 Loop-back mode is disabled.                                                    |
|    |        | 1 Loop-back mode is enabled.                                                     |
| 10 | SSMASK | SS signal masking bit in slave mode.                                             |
|    |        | 0 SS signal masking is disabled. Receive data when SS signal is active           |
|    |        | 1 SS signal masking is enabled. Receive data at SCLK edges. SS sign              |
|    |        | is ignored.                                                                      |
| 9  | SSMO   | SS output signal select bit.                                                     |
|    |        | 0 SS output signal is disabled.                                                  |
|    |        | 1 SS output signal is enabled.                                                   |
| 8  | SSPOL  | SS signal Polarity select bit.                                                   |
|    |        | 0 SS signal is Active-Low.                                                       |
|    |        | 1 SS signal is Active-High.                                                      |
| 5  | MS     | Master/Slave select bit.                                                         |
|    |        | 0 SPI is in Slave mode.                                                          |
|    |        | 1 SPI is in Master mode.                                                         |
| 4  | MSBF   | MSB/LSB Transmit select bit.                                                     |
|    |        | 0 LSB is transferred first.                                                      |
|    |        | 1 MSB is transferred first.                                                      |
| 3  | CPHA   | SPI Clock Phase bit.                                                             |
|    |        | 0 Sampling of data occurs at odd edges (1, 3, 5,, 15).                           |
|    |        |                                                                                  |



| 2   | CPOL    | SPI Clock Polarity bit. |                                    |  |  |  |  |  |  |  |  |
|-----|---------|-------------------------|------------------------------------|--|--|--|--|--|--|--|--|
|     |         | 0                       | Active-high clocks selected.       |  |  |  |  |  |  |  |  |
|     |         | 1                       | Active-low clocks selected.        |  |  |  |  |  |  |  |  |
| 1   | BITSZ   | Tran                    | smit/Receive Data Bits select bit. |  |  |  |  |  |  |  |  |
| 0   |         | 00                      | 8 bits                             |  |  |  |  |  |  |  |  |
|     |         | 01                      | 9 bits                             |  |  |  |  |  |  |  |  |
|     |         | 10                      | 16 bits                            |  |  |  |  |  |  |  |  |
|     |         | 11                      | 17 bits                            |  |  |  |  |  |  |  |  |
| NOT | <b></b> |                         |                                    |  |  |  |  |  |  |  |  |

NOTES:

- 1. CPOL=0, CPHA=0 : data sampling at rising edge, data changing at falling edge
- 2. CPOL=0, CPHA=1 : data sampling at falling edge, data changing at rising edge
- 3. CPOL=1, CPHA=0 : data sampling at falling edge, data changing at rising edge
- 4. CPOL=1, CPHA=1 : data sampling at rising edge, data changing at falling edge

### 17.2.4 SPIn.SR: SPI status register

SPIn.SR is a 10-bit sized read/write register. It contains the status of SPI interface.

| SPI20.SR=0x40                                                     | 00_    | 4C0    | )8, 3    | SPI   | 21.8 | SR=  | 0x4  | 000    | )_4I | <b>208</b> |
|-------------------------------------------------------------------|--------|--------|----------|-------|------|------|------|--------|------|------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 | 9      | 8      | 7        | 6     | 5    | 4    | 3    | 2      | 1    | 0          |
| Reserved                                                          | TXDMAF | RXDMAF | Reserved | SSDET | SSON | OVRF | UDRF | TXIDLE | TRDY | RRDY       |
| -                                                                 | 0      | 0      | -        | 0     | 0    | 0    | 0    | 1      | 1    | 0          |
|                                                                   | RC1    | RC1    | -        | RC1   | RC1  | RC1  | RC1  | R      | R    | R          |

| 9 | TXDMAF | DMA Transmit Operation Complete flag. (DMA to SPI)                                         |
|---|--------|--------------------------------------------------------------------------------------------|
|   |        | 0 DMA Transmit Op is working or is disabled.                                               |
|   |        | 1 DMA Transmit Op is done.                                                                 |
| 8 | RXDMAF | DMA Receive Operation Complete flag. (SPI to DMA)                                          |
|   |        | 0 DMA Receive Operation is working or is disabled.                                         |
|   |        | 1 DMA Transmit Op is done.                                                                 |
| 6 | SSDET  | The rising or falling edge of SS signal Detect flag.                                       |
|   |        | 0 SS edge is not detected.                                                                 |
|   |        | 1 SS edge is detected. The bit is cleared when it is written as "0".                       |
| 5 | SSON   | SS signal Status flag.                                                                     |
|   |        | 0 SS signal is inactive.                                                                   |
|   |        | 1 SS signal is active.                                                                     |
| 4 | OVRF   | Receive Overrun Error flag.                                                                |
|   |        | 0 Receive Overrun error is not detected.                                                   |
|   |        | 1 Receive Overrun error is detected.<br>This bit is cleared by writing or reading SPInRDR. |
|   |        |                                                                                            |



| 3 | UDRF   | Transmit Underrun Error flag.                                                                             |
|---|--------|-----------------------------------------------------------------------------------------------------------|
|   |        | 0 Transmit Underrun is not occurred.                                                                      |
|   |        | <ol> <li>Transmit Underrun is occurred.<br/>This bit is cleared by writing or reading SPInTDR.</li> </ol> |
| 2 | TXIDLE | Transmit/Receive Operation flag.                                                                          |
|   |        | 0 SPI is transmitting data                                                                                |
|   |        | 1 SPI is in IDLE state.                                                                                   |
| 1 | TRDY   | Transmit buffer Empty flag.                                                                               |
|   |        | 0 Transmit buffer is busy.                                                                                |
|   |        | <ol> <li>Transmit buffer is ready.</li> <li>This bit is cleared by writing data to SPInTDR.</li> </ol>    |
| 0 | RRDY   | Receive buffer Ready flag.                                                                                |
|   |        | 0 Receive buffer has no data.                                                                             |
|   |        | <ol> <li>Receive buffer has data.<br/>This bit is cleared by writing data to SPInRDR.</li> </ol>          |

### 17.2.5 SPIn.BR: SPI baud rate register

SPIn.BR is a 16-bit sized read/write register. Baud rate can be set by writing the register.

|                                                 | SPI20.BR=0x4000_4C0C, SPI21.BR=0x4000_4D0C |  |  |  |  |  |  |  |  |  |  |
|-------------------------------------------------|--------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0      |  |  |  |  |  |  |  |  |  |  |
| Reserved                                        | BR                                         |  |  |  |  |  |  |  |  |  |  |
| -                                               | 0x00FF                                     |  |  |  |  |  |  |  |  |  |  |
|                                                 | RW                                         |  |  |  |  |  |  |  |  |  |  |

| 0 Baud Rate = PCLK / (BR + 1) |
|-------------------------------|
|-------------------------------|

NOTES:

- 1. BR[15:0] must be set 2 or greater. (BR[15:0] ≥ 2)
- 2. For SPI speed, it is recommended to set the BR value to 2 or higher so that the SPI input clock is divided by at least 3.
  - e.g., PCLK = 24 MHz, BR = 2, SPI Freq. = 24 MHz / (2 + 1) = 8 MHz



### 17.2.6 SPIn.EN: SPI enable register

SPIn.EN is a bit sized read/write register. It contains SPI enable bit.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21 | 20 | 19   | 18   | 17    | 16  | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|----|----|----|----|----|----|----|----|-----|-----|----|----|------|------|-------|-----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------|
|    |    |    |    |    |    |    |    |     |     |    |    |      |      | Re    | ser | /ed |    |    |    |    |    |   |   |   |   |   |   |   |   |   | NABLE  |
|    |    |    |    |    |    |    |    |     |     |    |    |      |      |       | _   |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Ш<br>0 |
|    |    |    |    |    |    |    |    |     |     |    |    |      |      |       | •   |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW     |
|    |    |    |    |    | -  | 0  | E  | NAE | BLE |    | SP | l En | able | e bit |     |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |        |
|    |    |    |    |    |    |    |    |     |     | -  |    |      |      |       |     |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |        |

| 0 | ENABLE | SPI Enable bit                                                                                                                                      |
|---|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|   |        | SPI is disabled.                                                                                                                                    |
|   |        | SPInSR is initialized by writing "0" to this bit but other registers aren't initialized.                                                            |
|   |        | SPI is enabled.                                                                                                                                     |
|   |        | When this bit is written as "1", the dummy data of transmit buffer will be shifted. To prevent this, write data to SPTDR before this bit is active. |

### 17.2.7 SPIn.LR: SPI delay length register

SPIn.LR is a 24-bit sized read/write register. It contains start, burst, and stop length value.

|                         |                         | SPI20.LR=0x4000_4C1   | I4, SPI21.LR=0x4000_4D14 |
|-------------------------|-------------------------|-----------------------|--------------------------|
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0          |
| Reserved                | SPL                     | BTL                   | STL                      |
| -                       | 0x01                    | 0x01                  | 0x01                     |
|                         | RW                      | RW                    | RW                       |

| 23 SPL<br>16 | StoPLength value                        |                                         |
|--------------|-----------------------------------------|-----------------------------------------|
|              | 0x01 to 0xFF: 1 to 255 SCLKs. (SPL ≥ 1) |                                         |
| 15 BTL<br>8  | BursTLength value                       |                                         |
|              |                                         | 0x01 to 0xFF: 1 to 255 SCLKs. (BTL ≥ 1) |
| 7 S<br>0     | STL                                     | STart Length value                      |
|              |                                         | 0x01 to 0xFF: 1 to 255 SCLKs. (STL ≥ 1) |





Figure 132. SPI wave form (STL, BTL and SPL)

# 17.3 Functional description

SPI Transmit block and Receive block share Clock Gen Block but they are independent each other. Transmit block and Receive block have double buffers and SPI is available for back to back transfer operation.

### 17.3.1 SPI timing

SPI has four modes of operation. These modes essentially control the way data is clocked in or out of an SPI device. The configuration is done by two bits in the SPI control register (SPInCR). The clock polarity is specified by the CPOL control bit, which selects an active high or active low clock. The clock phase (CPHA) control bit selects one of the two fundamentally different transfer formats.

To ensure a proper communication between master and slave both devices have to run in the same mode. This can require a reconfiguration of the master to match the requirements of different peripheral slaves.

The clock polarity has no significant effect on the transfer format. Switching this bit causes the clock signal to be inverted (active high becomes active low and idle low becomes idle high). The settings of the clock phase, however, selects one of the two different transfer timings, which are described closer in the next two chapters. Since the MOSI and MISO lines of the master and the slave are directly connected to each other, the diagrams show the timing of both device, master and slave.

The nSS line is the slave select input of the slave. The nSS pin of the master is not shown in the diagrams. It has to be inactive by a high level on this pin (if configured as input pin) or by configuring it as an output pin.

The timing of a SPI transfer where CPHA is zero is shown in Figure 133 and Figure 134. Two wave forms are shown for the SCK signal -one for CPOL equals zero and another for CPOL equals one.



When the SPI is configured as a slave, the transmission starts with the falling edge of the /SS line. This activates the SPI of the slave and the MSB of the byte stored in its data register (SPInTDR) is output on the MISO line. The actual transfer is started by a software write to the SPInTDR of the master. This causes the clock signal to be generated. In cases where the CPHA equals zero, the SCLK signal remains zero for the first half of the first SCLK cycle. This ensures that the data is stable on the input lines of both the master and the slave.

The data on the input lines is read with the edge of the SCLK line from its inactive to its active. The edge of the SCLK line from its active to its inactive state (falling edge if CPOL equals zero and rising edge if CPOL equals one) causes the data to be shifted one bit further so that the next bit is output on the MOSI and MISO lines.



Figure 133. SPI Transfer Timing 1/4 (CPHA=0, CPOL=0, MSBF=0)



Figure 134. SPI Transfer Timing 2/4 (CPHA=0, CPOL=1, MSBF=1)



The timing of a SPI transfer where CPHA is one is shown in Figure 135 and Figure 136. Two wave forms are shown for the SCLK signal -one for CPOL equals zero and another for CPOL equals one.

Like in the previous cases the falling edge of the nSS lines selects and activates the slave. Compared to the previous cases, where CPHA equals zero, the transmission is not started and the MSB is not output by the slave at this stage. The actual transfer is started by a software write to the SPInTDR of the master what causes the clock signal to be generated. The first edge of the SCLK signal from its inactive to its active state (rising edge if CPOL equals zero and falling edge if CPOL equals one) causes both the master and the slave to output the MSB of the byte in the SPInTDR.

As shown in Figure 133 and Figure 134, there is no delay of half a SCLK-cycle. The SCLK line changes its level immediately at the beginning of the first SCLK-cycle. The data on the input lines is read with the edge of the SCLK line from its active to its inactive state (falling edge if CPOL equals zero and rising edge if CPOL equals one). After eight clock pulses the transmission is completed.



Figure 135. SPI Transfer Timing 3/4 (CPHA=1, CPOL=0, MSBF=0)



Figure 136. SPI Transfer Timing 4/4 (CPHA=1, CPOL=1, MSBF=1)



# 17.3.2 DMA handshake

SPI supports DMA handshaking operation. In order to operate DMA handshake, DMA registers should be set first (see <u>chapter 7. DMAC</u>). As Transmitter and Receiver are independent each other, SPI can operate the two channels at the same time.

After DMA channel for receiver is enabled and receive buffer is filled, SPI sends Rx request to DMA to empty the buffer and waits ACK signal from DMA. If Receive buffer is filled again after ACK signal, SPI sends Rx request. If DMA Rx DONE becomes high, RXDMAF (SPInSR[8]) goes "1" and an interrupt is serviced when RXDIE (SPInCR[17]) is set.

Likewise, if transmit buffer is empty after DMA channel for transmitter is enabled, SPI sends Tx request to DMA to fill the buffer and waits ACK signal from DMA. If transmit buffer is empty again after ACK signal, SPI sends Tx request. If DMA Tx DONE becomes high, TXDMAF (SPInSR[9]) goes "1" and an interrupt is serviced when TXDIE (SPInCR[18]) is set.

Slave transmitter sends dummy data at the first transfer (8 to 17 SCLKs) in DMA handshake mode.



Figure 137. DMA Handshake Flow Chart



# 18. 12-bit ADC

ADC block of A31G32x series consists of an independent ADC unit featuring the followings:

- 16 Channel Analog Input
- Single mode and Continuous conversion mode
- Maximum 8 sequential conversion support
- Software trigger support
- Three internal trigger source (PWM, TIMER) Support
- Adjustable sample and hold time

Table 75 introduces pins assigned for ADC.

# Table 75. Pin Assignment of ADC: External Signal

| Pin name | Туре | Description               |
|----------|------|---------------------------|
| AVDD     | Р    | Analog Power(3.0V to VDD) |
| AVSS     | Р    | Analog GND                |
| AN0      | A    | ADC Input 0               |
| AN1      | A    | ADC Input 1               |
| AN2      | A    | ADC Input 2               |
| AN3      | A    | ADC Input 3               |
| AN4      | A    | ADC Input 4               |
| AN5      | A    | ADC Input 5               |
| AN6      | A    | ADC Input 6               |
| AN7      | A    | ADC Input 7               |
| AN8      | A    | ADC Input 8               |
| AN9      | A    | ADC Input 9               |
| AN10     | A    | ADC Input 10              |
| AN11     | A    | ADC Input 11              |
| AN12     | A    | ADC Input 12              |
| AN13     | A    | ADC Input 13              |
| AN14     | A    | ADC Input 14              |
| AN15     | A    | ADC Input 15              |



# 18.1 12-bit ADC block diagram

In this section, 12-bit ADC is described in a block diagram in Figure 138.



Figure 138. 12-bit ADC Block Diagram

# 18.2 Registers

Base address of ADC unit is introduced in the followings:

#### Table 76. Base Address of 12-bit ADC

| Name | Base address |
|------|--------------|
| ADC  | 0x4000_3000  |

#### Table 77. 12-bit ADC Register Map

| Name     | Offset | Туре | Description                       | Reset value | Reference     |
|----------|--------|------|-----------------------------------|-------------|---------------|
| ADC_MR   | 0x0000 | RW   | ADC Mode Register                 | 0x0000_0000 | <u>18.2.1</u> |
| ADC_CSCR | 0x0004 | RW   | Current Sequence/Channel Register | 0x0000_0000 | <u>18.2.2</u> |
| ADC_CCR  | 0x0008 | RW   | ADC Clock Control Register        | 0x0000_0080 | 18.2.3        |
| ADC_TRG  | 0x000C | RW   | ADC Trigger Selection<br>Register | 0x0000_0000 | <u>18.2.4</u> |



| Name          | Offset | Туре | Description                         | Reset value | Reference      |
|---------------|--------|------|-------------------------------------|-------------|----------------|
| ADC_SCSR<br>1 | 0x0018 | RW   | ADC Channel Selection 1<br>Register | 0x0000_0000 | <u>18.2.5</u>  |
| ADC_SCSR<br>2 | 0x001C | RW   | ADC Channel Selection 2<br>Register | 0x0000_0000 | <u>18.2.6</u>  |
| ADC_CR        | 0x0020 | RW   | ADC Control Register                | 0x0000_0000 | <u>18.2.7</u>  |
| ADC_SR        | 0x0024 | RC   | ADC State Register                  | 0x0000_0000 | <u>18.2.8</u>  |
| ADC_IER       | 0x0028 | RW   | ADC Interrupt Enable<br>Register    | 0x0000_0000 | <u>18.2.9</u>  |
| ADC_DDR       | 0x002C | RO   | ADC DMA Data Register               | 0x0000_0000 | <u>18.2.10</u> |
| ADC_DR0       | 0x0030 | RO   | ADC Sequence 0 Data<br>Register     | 0x0000_0000 | <u>18.2.11</u> |
| ADC_DR1       | 0x0034 | RO   | ADC Sequence 1 Data<br>Register     | 0x0000_0000 |                |
| ADC_DR2       | 0x0038 | RO   | ADC Sequence 2 Data<br>Register     | 0x0000_0000 |                |
| ADC_DR3       | 0x003C | RO   | ADC Sequence 3 Data<br>Register     | 0x0000_0000 |                |
| ADC_DR4       | 0x0040 | RO   | ADC Sequence 4 Data<br>Register     | 0x0000_0000 |                |
| ADC_DR5       | 0x0044 | RO   | ADC Sequence 5 Data<br>Register     | 0x0000_0000 |                |
| ADC_DR6       | 0x0048 | RO   | ADC Sequence 6 Data<br>Register     | 0x0000_0000 |                |
| ADC_DR7       | 0x004C | RO   | ADC Sequence 7 Data<br>Register     | 0x0000_0000 |                |
| ADC_CMPR      | 0x0070 | RW   | ADC Channel Comparator<br>Register  | 0x0000_0000 | <u>18.2.12</u> |

Table 77. 12-bit ADC Register Map (continued)



# 18.2.1 ADC\_MR: ADC mode register

ADC\_MR is a mode setting register for the ADC Module. This register must be set first for the intended use of the ADC Module.

#### ADC\_MR=0x4000\_3000

| 31 30 29 28 27 26 25 24 23 22 | 21      | 20     | 19 18    | 17    | 16 | 15 14 | 13 | 12 | 11       | 10 | 98     | 7    | 6    | 5 | 4 | 3        | 2 | 1 0    |
|-------------------------------|---------|--------|----------|-------|----|-------|----|----|----------|----|--------|------|------|---|---|----------|---|--------|
| Reserved                      | TRGINFO | CHINFO | Reserved | DMAEN |    | STSEL |    |    | Reserved |    | SEQCNT | ADEN | ARST |   |   | Recented | > | TRGSEL |
| -                             | 0       | 0      | -        | 0     |    | 0x00  | )  |    | -        | 0  | 00     | 0    | 0    | 0 | 0 | -        |   | 00     |
| -                             | RW      | RW     | -        | RW    |    | RW    |    |    | -        |    | RW     | RW   | RW   | R | N | -        |   | RW     |

| 21      | TRGINFO | Trigger                             | information option (In externa                                                                                                                                         | l trigger mode)                    |                          |  |  |  |  |  |  |
|---------|---------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|--------------------------|--|--|--|--|--|--|
|         |         | 0 Option disable                    |                                                                                                                                                                        |                                    |                          |  |  |  |  |  |  |
|         |         | 1 .                                 | 1 Trigger source information will be stored in ADCDR[31:24]                                                                                                            |                                    |                          |  |  |  |  |  |  |
| 20      | CHINFO  | Channe                              | el information option                                                                                                                                                  |                                    |                          |  |  |  |  |  |  |
|         |         | 0                                   | 0 Option disable                                                                                                                                                       |                                    |                          |  |  |  |  |  |  |
|         |         | 1 0                                 | Converted channel information                                                                                                                                          | will be stored                     | in ADCDR[20:16]          |  |  |  |  |  |  |
| 17      | DMAEN   | DMA E                               | nable bit (Must be set When A                                                                                                                                          | DEN =1)                            |                          |  |  |  |  |  |  |
|         |         | signal                              | the DMA function is enabled<br>from the DMAC, a DMA reques<br>erated or conversion is finished                                                                         | st is generated                    | at the interrupt request |  |  |  |  |  |  |
| 16      | STSEL   | Sampli                              | ng Time Selection                                                                                                                                                      |                                    |                          |  |  |  |  |  |  |
| 12      |         | Trigge<br>The ap<br>ADC S<br>Minimu | value to set the time window<br>r.<br>plied point is applied immediat<br>ampling Time is (2+STSEL [4:0<br>Im Sampling Time is 2 MCLK.<br>STSEL[4:0] = b'11111, Samplin | ely after Trigge<br>0]) MCLK cycle | er.<br>9.                |  |  |  |  |  |  |
| 10<br>8 | SEQCNT  | If ADN<br>SEQC                      | r of conversion in a sequence<br>IOD[5:4] is 0 and SEQCNT<br>NT by trigger event.<br>NT apply only in Single/Seque                                                     |                                    | CSEQN increase to        |  |  |  |  |  |  |
|         |         | 000                                 | Single Mode                                                                                                                                                            | 100                                | 5 Sequence ADC           |  |  |  |  |  |  |
|         |         | 001                                 | 2 Sequence ADC                                                                                                                                                         | 101                                | 6 Sequence ADC           |  |  |  |  |  |  |
|         |         | 010                                 | 3 Sequence ADC                                                                                                                                                         | 110                                | 7 Sequence ADC           |  |  |  |  |  |  |
|         |         | 011                                 | 4 Sequence ADC                                                                                                                                                         | 111                                | 8 Sequence ADC           |  |  |  |  |  |  |
| 7       | ADEN    | ADC E                               | nable bit                                                                                                                                                              |                                    |                          |  |  |  |  |  |  |
|         |         | 0                                   | Disable                                                                                                                                                                |                                    |                          |  |  |  |  |  |  |
|         |         | 1                                   | Enable                                                                                                                                                                 |                                    |                          |  |  |  |  |  |  |
| 6       | ARST    | After se                            | equence finish, restart bit.                                                                                                                                           |                                    |                          |  |  |  |  |  |  |
|         |         | 0                                   | Stop after finish (ASTART                                                                                                                                              | must be set to                     | o 1 to restart)          |  |  |  |  |  |  |
|         |         | 1                                   | Restart after finish                                                                                                                                                   |                                    |                          |  |  |  |  |  |  |



| 5 | ADMOD  | ADC N   | lode Selection bit.                     |
|---|--------|---------|-----------------------------------------|
| 4 |        | 00      | Single/Sequential Conversion Mode       |
|   |        | 01      | Burst Conversion Mode                   |
|   |        | 10      | Multiple Conversion Mode                |
|   |        | 11      | No effect                               |
| 1 | TRGSEL | Trigger | r Selection bit.                        |
| 0 |        | 00      | Event Trigger Disable/Soft Trigger Only |
|   |        | 01      | Timer Event Trigger/Soft Trigger        |
|   |        | 10      | Reserved                                |
|   |        | 11      | Reserved                                |

- When ADCMOD is set to Burst Conversion Mode, the ADC channel is controlled from BST0CH to BST7CH. Burst Mode always starts at BST0CH. (In 3-busrt mode, the analog input of the channel assigned in BST0CH / BST1CH / BST2CH is sequentially converted.)
- 2. If it is set to Multiple Mode, it will be converted as soon as it triggers regardless of the order of Trigger set in TRG register.

## 18.2.2 ADC\_CSCR: ADC current sequence/channel register

ADC\_CSCR consists of the Current Sequence Number and Current Active Channel value. CSEQN (Current Sequence Number) can set the Current Sequence Number immediately. This is a 16-bit register. In addition, the ADEN bit of the ADC\_MR Register must be set before this register is set.

ADC\_CSCR=0x4000\_3004

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 | 10 9 8 | 7 6 5    | 4 3 2 1 0 |
|----------------------------------------------------------------|--------|----------|-----------|
| Reserved                                                       | CSEQN  | Reserved | CACH      |
| -                                                              | 000    | -        | 0x00      |
| · .                                                            | RW     | -        | RO        |

| 10 | CSEQN | Current | Sequence Number,      |  |
|----|-------|---------|-----------------------|--|
| 8  |       | 000     | Current Sequence is 0 |  |
|    |       | 001     | Current Sequence is 1 |  |
|    |       | 010     | Current Sequence is 2 |  |
|    |       | 011     | Current Sequence is 3 |  |
|    |       | 100     | Current Sequence is 4 |  |
|    |       | 101     | Current Sequence is 5 |  |
|    |       | 110     | Current Sequence is 6 |  |
|    |       | 111     | Current Sequence is 7 |  |



| 4 | CACH | Current A | ctive Channel            |
|---|------|-----------|--------------------------|
| 0 |      | 00000     | ADC channel 0 is active  |
|   |      | 00001     | ADC channel 1 is active  |
|   |      | 00010     | ADC channel 2 is active  |
|   |      | 00011     | ADC channel 3 is active  |
|   |      | 00100     | ADC channel 4 is active  |
|   |      | 00101     | ADC channel 5 is active  |
|   |      | 00110     | ADC channel 6 is active  |
|   |      | 00111     | ADC channel 7 is active  |
|   |      | 01000     | ADC channel 8 is active  |
|   |      | 01001     | ADC channel 9 is active  |
|   |      | 01010     | ADC channel 10 is active |
|   |      | 01011     | ADC channel 11 is active |
|   |      | 01100     | ADC channel 12 is active |
|   |      | 01101     | ADC channel 13 is active |
|   |      | 01110     | ADC channel 14 is active |
|   |      | 01111     | ADC channel 15 is active |
|   |      | Others    | Reserved                 |

# 18.2.3 ADC\_CCR: ADC clock control register

ADC\_CCR is a clock control register of ADC Module. This is a 16-bit register.

|                                                 |        |       |    |      |    |   |       | ADC      | :_C     | CR | =0x4 | 400 | 0_3 | 800 |
|-------------------------------------------------|--------|-------|----|------|----|---|-------|----------|---------|----|------|-----|-----|-----|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15     | 14 13 | 12 | 11   | 10 | 9 | 3 7   | 6        | 5       | 4  | 3    | 2   | 1   | 0   |
| Reserved                                        | ADCPDA |       | CL | .KDI | V  |   | ADCPD | Reserved | CLKINVT |    | Re   | ser | /ed |     |
| -                                               | 0      |       | 0  | x00  |    |   | 1     | -        | 0       |    |      | -   |     |     |
|                                                 | RW     |       |    | RW   |    |   | RW    | •        | RW      |    |      | •   |     |     |

| 15 | ADCPDA  | ADC R DAC disable to save power                                                                                                                                                                                                                                                                                                                                                                            |
|----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |         | Don't set '1' here (it's optional bit)                                                                                                                                                                                                                                                                                                                                                                     |
| 14 | CLKDIV  | ADC clock division value bit(When EXTCLK is 0, CLKDIV Enable)                                                                                                                                                                                                                                                                                                                                              |
| 8  |         | <ul> <li>CLKDIV=0 → ADC Clock = ADC Input Clock (Bypass)</li> <li>CLKDIV=1 → ADC Clock = Clock Stop</li> <li>CLKDIV≥2 → ADC Clock = ADC Input Clock / CLKDIV</li> <li>NOTE: In continuous conversion mode or burst conversion mode, the CLKDIV must be set to 3 or higher</li> <li>When ADC clock is divided and CLKDIV value is set to 2 or more, ADC clock should be set not to exceed 24MHz.</li> </ul> |
| 7  | ADCPD   | ADC Deep sleep                                                                                                                                                                                                                                                                                                                                                                                             |
|    |         | 0 ADC Normal Mode                                                                                                                                                                                                                                                                                                                                                                                          |
|    |         | 1 ADC Deep sleep Mode                                                                                                                                                                                                                                                                                                                                                                                      |
| 5  | CLKINVT | Divide Clock Inversion (Option bit)                                                                                                                                                                                                                                                                                                                                                                        |
|    |         | 0 Duty ratio of divided clock is larger than 50%                                                                                                                                                                                                                                                                                                                                                           |
|    |         | 1 Duty ratio of divided clock is less than 50%                                                                                                                                                                                                                                                                                                                                                             |



# 18.2.4 ADC\_TRG: ADC trigger selection register

This Register is ADC Trigger Selection Register of ADC Module.

#### ADC\_TRG=0x4000\_300C

| 31 30 29 28 | 27 26 25 24 | 23 22 21 20 | 19 18 17 16 | 15 14 13 12 | 11 10 9 8 | 7 6 5 4 | 3 2 1 0           |
|-------------|-------------|-------------|-------------|-------------|-----------|---------|-------------------|
| SEQTRG7     | SEQTRG6     | SEQTRG5     | SEQTRG4     | SEQTRG3     | SEQTRG2   | SEQTRG1 | SEQTRG0<br>BSTTRG |
| 0000        | 0000        | 0000        | 0000        | 0000        | 0000      | 0000    | 0000              |
| RW          | RW          | RW          | RW          | RW          | RW        | RW      | RW                |

| 30<br>28 | SEQTRG7           | 8 <sup>th</sup> Sequence Trigger Source                                    |
|----------|-------------------|----------------------------------------------------------------------------|
| 27<br>24 | SEQTRG6           | 7 <sup>th</sup> Sequence Trigger Source                                    |
| 23<br>20 | SEQTRG5           | 6 <sup>th</sup> Sequence Trigger Source                                    |
| 19<br>16 | SEQTRG4           | 5 <sup>th</sup> Sequence Trigger Source                                    |
| 15<br>12 | SEQTRG3           | 4 <sup>th</sup> Sequence Trigger Source                                    |
| 11<br>8  | SEQTRG2           | 3 <sup>th</sup> Sequence Trigger Source                                    |
| 7<br>4   | SEQTRG1           | 2 <sup>ed</sup> Sequence Trigger Source                                    |
| 3<br>0   | SEQTRG0<br>BSTTRG | 1 <sup>st</sup> Sequence Trigger Source<br>Burst Conversion Trigger Source |

**NOTE**: 1<sup>st</sup> sequence is the highest priority in multi-mode, and 8<sup>th</sup> sequence is the lowest priority in multi-mode.



| Value | Timer (TRGSEL[1:0] = 0x1) |
|-------|---------------------------|
| 0     | TIMER 10                  |
| 1     | TIMER 11                  |
| 2     | TIMER 12                  |
| 3     | TIMER 13                  |
| 4     | TIMER 20                  |
| 5     | TIMER 21                  |
| 6     | TIMER 30                  |
| 7     | TIMER 40                  |
| 8     |                           |
| 9     |                           |
| 10    |                           |
| 11    |                           |
| 15    | ASTART                    |

Table 78. Trigger Source of ADC

NOTES:

- 1. ASTART is a S/W trigger in the ADC\_CR register.
- 2. In order to use Timer30 as a trigger, TIMER30\_ADTCR and TIMER30\_ADTDR must be set.

# 18.2.5 ADC\_SCSR1: ADC channel selection 1 register

ADC\_SCSR1 is a 32-bit register. Each selected channel is associated with a trigger selection register. When ADEN of ADC\_MR Register set, Can write in ADC\_SCSR1.

| 31 | 1 30 | 29  | 28   | 27 2 | 26  | 25   | 24    | 23  | 22   | 21  | 20 | 19 | 18  | 17  | 16 | 15 | 14   | 13  | 12 | 11 | 10  | 9   | 8 | 7  | 6    | 5   | 4 | 3      | 2 | 1 | 0 |
|----|------|-----|------|------|-----|------|-------|-----|------|-----|----|----|-----|-----|----|----|------|-----|----|----|-----|-----|---|----|------|-----|---|--------|---|---|---|
| R  | esei | ved |      | SEC  | )3C | н    |       | Res | ser\ | /ed |    | SE | Q20 | СН  |    | Re | ser\ | /ed |    | SE | Q10 | СН  |   | Re | ser\ | /ed |   | SEQ0CH |   |   |   |
|    | -    |     |      | 0x0  |     |      | - 0x0 |     |      |     |    | -  |     | 0x0 |    |    |      |     | -  |    |     | 0x0 |   |    |      |     |   |        |   |   |   |
|    | •    |     | RW - |      |     | RW - |       |     |      | RW  |    |    |     |     | -  |    |      | RW  |    |    |     |     |   |    |      |     |   |        |   |   |   |

| ADC_SCSR1=0x4000_3018 |
|-----------------------|
|-----------------------|

| 28<br>24 | SEQ3CH | 4 <sup>th</sup> Conversion Sequence Channel Selection |
|----------|--------|-------------------------------------------------------|
| 20<br>16 | SEQ2CH | 3 <sup>th</sup> Conversion Sequence Channel Selection |
| 12<br>8  | SEQ1CH | 2 <sup>th</sup> Conversion Sequence Channel Selection |
| 4<br>0   | SEQ0CH | 1 <sup>th</sup> Conversion Sequence Channel Selection |



# 18.2.6 ADC\_SCSR2: ADC channel selection 2 register

ADC\_SCSR2 is a 32-bit register. Each selected channel is associated with a trigger selection register. When ADEN of ADC\_MR Register set, Can write in ADC\_SCSR2.

| ADC | SCSR2 | =0x4000 | 301C |
|-----|-------|---------|------|
|     |       |         |      |

| 31 30 29 | 28 27 26 25 24 | 23 22 21 | 20 19 18 17 16 | 15 14 13 | 12 11 10 9 8 | 7 6 5    | 4 3 2 1 0 |  |  |
|----------|----------------|----------|----------------|----------|--------------|----------|-----------|--|--|
| Reserved | SEQ7CH         | Reserved | SEQ6CH         | Reserved | SEQ5CH       | Reserved | SEQ4CH    |  |  |
| -        | 0x0            | -        | 0x0            | -        | 0x0          | -        | 0x0       |  |  |
| -        | RW             | -        | RW             | -        | RW           | -        | RW        |  |  |

| 28<br>24 | SEQ7CH | 8 <sup>th</sup> Conversion Sequence Channel Selection |
|----------|--------|-------------------------------------------------------|
| 20<br>16 | SEQ6CH | 7 <sup>th</sup> Conversion Sequence Channel Selection |
| 12<br>8  | SEQ5CH | 6 <sup>th</sup> Conversion Sequence Channel Selection |
| 4<br>0   | SEQ4CH | 5 <sup>th</sup> Conversion Sequence Channel Selection |

# 18.2.7 ADC\_CR: ADC control register

ADC\_CR is a register for ADC Control.

#### ADC\_CR=0x4000\_3020

|                         |                         |                     |     |        | -      |     | _ |   |
|-------------------------|-------------------------|---------------------|-----|--------|--------|-----|---|---|
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 | 987 | 7 6    | 6 5 4  | 3 2 | 1 | 0 |
|                         | ASIUP                   | Reserv              | ed  | TRGCLR | ASTART |     |   |   |
|                         | (                       | )                   | -   |        | 0      | 0   |   |   |
|                         | 0                       |                     |     | RW     | RW     |     |   |   |

| 7 | ASTOP  | ADC S | STOP bit                                                                                                                                                                                                    |
|---|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |        | 0     | No Effect                                                                                                                                                                                                   |
|   |        | 1     | ADC conversion stop (will be clear next @ADC clock)<br>If ASTOP set after conversion cycle start, present conversion<br>would be completed.                                                                 |
| 1 | TRGCLR | ADC a | Il trigger flags cleared option                                                                                                                                                                             |
|   |        | 0     | No clear                                                                                                                                                                                                    |
|   |        | 1     | Clear all trigger flags of previous ADC operation                                                                                                                                                           |
| 0 | ASTART | ADC S | START bit                                                                                                                                                                                                   |
|   |        | 0     | No ADC Conversion                                                                                                                                                                                           |
|   |        | 1     | ADC Conversion Start (will be clear next @ADC clock) ADEN<br>should be "1" to start ADC<br>If ASTART is set as '1' when ARST is '0' in trigger event mode,<br>ADC conversion will start once as SEQCNT set. |



## 18.2.8 ADC\_SR: ADC state register

ADC\_SR is a register for indicating the ADC state.

## ADC\_SR=0x4000\_3024

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 | 8        | 76       | 5      | 4    | 3     | 2     | 1        | 0     |
|---------------------------------------------------------------------|----------|----------|--------|------|-------|-------|----------|-------|
| Reserved                                                            | COMPIFLG | Reserved | DOVRUN | DMAF | TRGIF | EOSIF | Reserved | EOCIF |
| -                                                                   | 0        | -        | 0      | 0    | 0     | 0     | -        | 0     |
| - ·                                                                 | RC       | -        | RO     | RO   | RC    | RC    | •        | RC    |

| 8                  | COMPIFLG      | Compare Interrupt Flag bit                         |
|--------------------|---------------|----------------------------------------------------|
|                    |               | 0 No Interrupt occurred                            |
|                    |               | 1 Interrupt occurred (Write '1' to Clear Flag)     |
| 5                  | DOVRUN        | DMA Overrun Flag (Not Interrupt)                   |
|                    |               | 0 No Flag occurred                                 |
|                    |               | 1 Flag occurred                                    |
| 4                  | DMAF          | DMA Done Received Flag (DMA transfer is completed) |
|                    |               | 0 No Flag occurred                                 |
|                    |               | 1 Flag occurred                                    |
| 3                  | TRGIF         | ADC Trigger Interrupt Flag                         |
|                    |               | 0 No Flag occurred                                 |
|                    |               | 1 Flag occurred (Write '1' to Clear Flag)          |
| 2                  | EOSIF         | Sequence End Interrupt Flag                        |
|                    |               | 0 No Flag occurred                                 |
|                    |               | 1 Flag occurred (Write '1' to Clear Flag)          |
| 0                  | EOCIF         | Sequence Conversion End Interrupt Flag             |
|                    |               | 0 No Flag occurred                                 |
|                    |               | 1 Flag occurred (Write '1' to Clear Flag)          |
| <b>NOT</b><br>Flag |               | ethod uses EOCIF bit.                              |
| Exan               | nple code)    |                                                    |
|                    | Le ((ADC_SR & | 0x01) == 1) // EOCIF Flag Checking                 |
| {                  | ADCSR = 02    | x1; // EOCIF Flag Clear                            |
|                    |               |                                                    |

}



# 18.2.9 ADC\_IER: ADC interrupt enable register

ADC\_IER is a register to enable ADC Interrupt.

## ADC\_IER=0x4000\_3028

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 3 22 | 21 | 20 | 19 | 18   | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4     | 3     | 2     | 1        | 0     |
|----|----|----|----|----|----|----|----|----|------|----|----|----|------|-----|----|----|----|----|----|----|----|---|---|---|---|---|-------|-------|-------|----------|-------|
|    |    |    |    |    |    |    |    |    |      |    |    | Re | ser\ | /ed |    |    |    |    |    |    |    |   |   |   |   |   | DMAIE | TRGIE | EOSIE | Reserved | EOCIE |
|    |    |    |    |    |    |    |    |    |      |    |    |    | -    |     |    |    |    |    |    |    |    |   |   |   |   |   | 0     | 0     | 0     | -        | 0     |
|    |    |    |    |    |    |    |    |    |      |    |    |    | •    |     |    |    |    |    |    |    |    |   |   |   |   |   | RW    | RW    | RW    |          | RW    |

| 4 | DMAIE | DMA Done Interrupt Enable                |  |
|---|-------|------------------------------------------|--|
|   |       | 0 Disable                                |  |
|   |       | 1 Enable                                 |  |
| 3 | TRGIE | ADC Trigger Conversion Interrupt Enable  |  |
|   |       | 0 Disable                                |  |
|   |       | 1 Enable                                 |  |
| 2 | EOSIE | ADC Sequence Conversion Interrupt Enable |  |
|   |       | 0 Disable                                |  |
|   |       | 1 Enable                                 |  |
| 0 | EOCIE | ADC Single Conversion Interrupt Enable   |  |
|   |       | 0 Disable                                |  |
|   |       | 1 Enable                                 |  |

## 18.2.10 ADC\_DDR: ADC DMA data register

ADC\_DDR is a register of ADC DMA Conversion result.

## ADC\_DDR=0x4000\_302C

|                 |                 |                 |                 |                 |                 |                 |                 |    |      |     |    |       |      |    |    |        |    |    |    |     |      |     |      |     |     |   |   |   |      | -    |   |
|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----|------|-----|----|-------|------|----|----|--------|----|----|----|-----|------|-----|------|-----|-----|---|---|---|------|------|---|
| 31              | 30              | 29              | 28              | 27              | 26              | 25              | 24              | 23 | 22   | 21  | 20 | 19    | 18   | 17 | 16 | 15     | 14 | 13 | 12 | 11  | 10   | 9   | 8    | 7   | 6   | 5 | 4 | 3 | 2    | 1    | 0 |
| <b>TRGINF07</b> | <b>TRGINFO6</b> | <b>TRGINFO5</b> | <b>TRGINFO4</b> | <b>TRGINFO3</b> | <b>TRGINFO2</b> | <b>TRGINFO1</b> | <b>TRGINFO0</b> | Re | ser\ | /ed |    | AD    | MA   | СН |    |        |    | AD | CE | DMA | A Te | mpo | orar | y D | ata |   |   | F | lese | erve | d |
| 0               | 0               | 0               | 0               | 0               | 0               | 0               | 0               |    | -    |     |    | 0     | )x00 | )  |    | 0x0000 |    |    |    |     |      |     | -    | -   |     |   |   |   |      |      |   |
| RO              |    | •    |     |    | RO RO |      |    |    |        |    |    |    |     |      |     |      |     |     |   |   |   |      |      |   |

| 31 | TRGINFOx  | ADC Trigger Information                                               |
|----|-----------|-----------------------------------------------------------------------|
| 24 | (x=0~7)   | (ADC Trigger Information is Trigger source captured at EOC time.)     |
|    | (// 0 //) | *Must be enable TRGINFO function of ADC MR Register.                  |
|    |           | Must be enable TRGINFO function of ADC_IMR Register.                  |
|    |           | Multiple Mode)                                                        |
|    |           | The lower the x of TRGINFOx, the higher the priority.                 |
|    |           | Multiple TRGINFO bits can be read as 1 if Pending by another trigger. |
|    |           |                                                                       |
|    |           | Single/Sequential Mode)                                               |
|    |           | It can reference the source Pending by another trigger.               |
|    |           | The currently processed trigger source must refer to CSEQN of CSC     |
|    |           | register.                                                             |
|    |           | register.                                                             |



| 20<br>16 | ADMACH | DMA ADC Channel Indicator<br>*Enable the CHINFO function of ADC_MR register.                                                                                |
|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>4  | ADDMAR | DMA ADC Conversion Result Data (12-bit)                                                                                                                     |
|          |        | e DMA function is not used, data is temporarily stored in this buffer before the presponding buffer, and channel information of the data can be also known. |

## 18.2.11 ADC\_DR: ADC sequence 0 to 7 data register

4

ADC\_DR indicates the result of the ADC Conversion. There are eight of these registers.

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |                 |                 |                 |                 |                 |                 |          | R1=0x4000_3034<br>R5=0x4000_3044 |            |    |    |     |    |    |   |   |   |     |      |    |   |   |   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------|----------------------------------|------------|----|----|-----|----|----|---|---|---|-----|------|----|---|---|---|
| 31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 30              | 29              | 28              | 27              | 26              | 25              | 24              | 23 22 21 | 20 19 18 17 16                   | 15 14      | 13 | 12 | 11  | 10 | 98 | 3 | 7 | 6 | 5   | 4    | 3  | 2 | 1 | 0 |
| <b>TRGINFO7</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <b>TRGINFO6</b> | <b>TRGINFO5</b> | <b>TRGINFO4</b> | <b>TRGINFO3</b> | <b>TRGINFO2</b> | <b>TRGINFO1</b> | <b>TRGINFO0</b> | Reserved | АСН                              |            |    |    |     |    |    |   |   | F | Res | serv | ed |   |   |   |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0               | 0               | 0               | 0               | 0               | 0               | 0               | -        | 0x00                             | 0x00 0x000 |    |    |     |    |    |   |   |   |     |      |    | - |   |   |
| RO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RO              | RO              | RO              | RO              | RO              | RO              | RO              |          | RO RO                            |            |    |    |     |    |    |   |   |   |     |      |    | - |   |   |
| 31       TRGINFOx       ADC Trigger Information         24       (x=0~7)       (ADC Trigger Information is Trigger source captured at EOC time.)         *Must be enable TRGINFO function of ADC_MR Register.         Multiple Mode)         The lower the x of TRGINFOx, the higher the priority.         Multiple TRGINFO bits can be read as 1 if Pending by another trigger.         Single/Sequential Mode)         It can reference the source Pending by another trigger.         The currently processed trigger source must refer to CSEQN of CSCI register.         20       ACH         16       * Enable the CHINFO function of ADC_MR register. |                 |                 |                 |                 |                 |                 |                 |          |                                  |            |    |    | SCR |    |    |   |   |   |     |      |    |   |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                 |                 |                 |                 | 1               | 5               | P               | DDATA    | ADC Input dat                    | а          |    |    |     |    |    |   |   |   |     |      |    |   |   |   |



# 18.2.12 ADC\_CMPR: ADC channel compare register

ADC\_CMPR is an ADC channel compare control register.

## ADC\_CMPR=0x4000\_3070

| 31 | 13 | 30 29 | 28   | 27  | 26 | 25 | 24      | 23     | 22       | 21  | 20 | 19 <sup>-</sup> | 18  | 17 | 16 | 15    | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0 |
|----|----|-------|------|-----|----|----|---------|--------|----------|-----|----|-----------------|-----|----|----|-------|----|----|----|----|----|----|---|---|---|---|---|---|-----|-----|---|
|    |    | Re    | eser | ved |    |    | COMPIEN | COMPEN | Reserved | LTE |    | С               | СН  |    |    |       |    |    |    |    | CV | AL |   |   |   |   |   | R | ese | rve | d |
|    |    |       | -    |     |    |    | 0       | 0      | -        | 0   |    | 00              | 000 | )  |    | 0x000 |    |    |    |    |    | -  |   |   |   |   |   |   |     |     |   |
|    |    |       | -    |     |    |    | RW      | RW     | •        | RW  |    | I               | RW  |    |    | RW    |    |    |    |    |    |    |   |   |   |   |   |   |     |     |   |

| 24      | COMPIEN | Compare  | Interrupt Enable bit               |
|---------|---------|----------|------------------------------------|
|         |         | 0        | Disable                            |
|         |         | 1        | Enable                             |
| 23      | COMPEN  | Compare  | Operation Enable bit               |
|         |         | 0        | Disable                            |
|         |         | 1        | Enable                             |
| 21      | LTE     | AD Conve | ersion Value Output Timing Setting |
|         |         | 0        | When ADC > CVAL, Output            |
|         |         | 1        | When ADC ≤ CVAL, Output            |
| 20      | CCH     | Compare  | Channel                            |
| 16      |         | 00000    | Compare Channel is ADC channel 0   |
|         |         | 00001    | Compare Channel is ADC channel 1   |
|         |         | 00010    | Compare Channel is ADC channel 2   |
|         |         | 00011    | Compare Channel is ADC channel 3   |
|         |         | 00100    | Compare Channel is ADC channel 4   |
|         |         | 00101    | Compare Channel is ADC channel 5   |
|         |         | 00110    | Compare Channel is ADC channel 6   |
|         |         | 00111    | Compare Channel is ADC channel 7   |
|         |         | 01000    | Compare Channel is ADC channel 8   |
|         |         | 01001    | Compare Channel is ADC channel 9   |
|         |         | 01010    | Compare Channel is ADC channel 10  |
|         |         | 01011    | Compare Channel is ADC channel 11  |
|         |         | 01100    | Compare Channel is ADC channel 12  |
|         |         | 01101    | Compare Channel is ADC channel 13  |
|         |         | 01110    | Compare Channel is ADC channel 14  |
|         |         | 01111    | Compare Channel is ADC channel 15  |
|         |         | 10000    | Compare Channel is ADC channel 16  |
|         |         | Others   | Reserved                           |
| 15<br>4 | CVAL    | Compare  | Value Bit                          |



# 18.3 Functional description

# 18.3.1 ADC single mode timing diagram

When ADC\_MR.ADMOD is 0x0 and ADC\_MR.SEQCNT is 0x0, The ADC conversion starts when the CR.ASTART bit is set to '1'. When ADC\_CR.ASTART is set, SOC (start of conversion) is active at 3 ADC clocks and ADC\_SR.EOCIRQ is set at 2 ADC clocks and 2 PCLKs after the end of conversion.



Figure 139. ADC Single Mode Timing (When ADC.MR.AMOD = '0')

# 18.3.2 ADC burst mode timing diagram

There are two source for creating SOC in Burst Mode. First, TRG event (timer and MPWM) and ASTART. If TRGSEL is set to Timer Event Trigger or MPWM Event Trigger, the SOC will be the trigger of TRG.BSTTRG. For example, if TRG.BSTTRG is set to TIMER3, ADC Conversion is started by the trigger of TIMER3. When a trigger event of BSTTRG occurs, the ADC will change the ADC channel to the value set by MR.SEQCNT. See Figure 140.





Figure 140. ADC Burst Mode Timing (When ADC.MR.AMOD = '1')



Figure 141. ADC Trigger Timing in Burst Mode (SEQCNT = 3'b111, 8 Sequential Conversion)

# 18.3.3 ADC sequential mode timing diagram

To set sequential mode, ADC\_MR.ADMOD is 2'b00 and ADC\_MR.SEQCNT must not be 3'b000. The operation of the sequential mode is the almost same as burst mode. Difference is the source of the SOC. Each SOC is created by a trigger of SEQTRGx with each SEQCNT. See Figure 142.





Figure 142. ADC Sequential Mode Timing (When MR.AMOD = '0' and MR.SEQCNT ≠ '0')



(SEQCNT = 3'b111, 8 Sequential Conversion)



## 18.3.4 ADC multiple mode timing diagram

In multiple mode operation, if the desired trigger source is set to TRG.SEQTRG, conversion begins when the corresponding trigger occurs regardless of the order of SEQTRG. For example, if MR.SEQCNT is 3'b011, if one of the four trigger sources (TIMER, MPWM) is selected and CR.ASTART is set, conversion will be processed by the first occurred trigger source, regardless of sequence. It is different from sequential mode and burst mode.



Figure 144. ADC Multiple Mode Timing (When MR.AMOD = '2' and MR.SEQCNT ≠ '0')



Figure 145. ADC Trigger Timing in Multiple Mode (SEQCNT = 3'b111, 8 Multiple Conversion)



# 19. 10-bit DAC

Digital-to-analog (D/A) converter uses successive approximation logic to convert 10-bit digital value to an analog output level.

DAC module has six registers which are the DAC control register (DACCR), DAC data high register (DACDRH), DAC data low register (DACDRL), DAC buffer high register (DACBRH), DAC buffer low register (DACBRL) and programmable gain selection register (PGSR).

# 19.1 10-bit DAC block diagram and analog power pin



In Figure 146, 10-bit DAC is described in a block diagram.

Figure 146. 10-bit DAC Block Diagram







# 19.2 Registers

Base address of DAC unit is introduced in the followings:

| Table | 79. | Base | Address | of  | DAC  |
|-------|-----|------|---------|-----|------|
| 10010 |     | Duoo | /       | ••• | 0/10 |

| Name | Base address |
|------|--------------|
| DAC  | 0x4000_3500  |

#### Table 80. 10-bit DAC Register Map

| Name    | Offset | Туре | Description                          | Reset value | Reference     |
|---------|--------|------|--------------------------------------|-------------|---------------|
| DACDR   | 0x0000 | RW   | DAC data high register               | 0x0000_0000 | <u>19.2.1</u> |
| DACBR   | 0x0004 | RO   | DAC buffer high register             | 0x0000_0000 | <u>19.2.2</u> |
| DACCR   | 0x0008 | RW   | DAC control register                 | 0x0000_0000 | <u>19.2.3</u> |
| PGSR    | 0x000C | RW   | Programmable gain selection register | 0x0000_0005 | <u>19.2.4</u> |
| DAOFSCR | 0x0010 | RW   | DAC offset control register          | 0x0000_0000 | <u>19.2.5</u> |

# 19.2.1 DAC\_DR: DAC data register

## DAC\_DR=0x4000\_3500

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 | 13 12 11 10 9 8 7 6 5 4 | 3 2 1 0  |
|-------------------------------------------------------|-------------------------|----------|
| Reserved                                              | DACDR                   | Reserved |
| -                                                     | 000                     | -        |
|                                                       | RW                      | -        |

| 13 | DACDR | DAC Data (10-bit)                   |
|----|-------|-------------------------------------|
| 4  |       | The DACDR[13:4] is a binary format. |



#### 19.2.2 DAC\_BR: DAC buffer register

#### DAC BR=0x4000 3504

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 | 13 12 11 10 9 8 7 6 5 4 | 3 2 1 0  |
|-------------------------------------------------------|-------------------------|----------|
| Reserved                                              | DACBR                   | Reserved |
| -                                                     | 000                     | -        |
|                                                       | R                       |          |
|                                                       |                         |          |

| 13 | DACBR | DAC Buffer Data (10-bit)            |  |
|----|-------|-------------------------------------|--|
| 4  |       | The DACBR[13:4] is a binary format. |  |

## 19.2.3 DAC\_CR: DAC control register

#### DAC\_CR=0x4000\_3508 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Ч Ш ZШ N л П Reserved REFSEL DACRLDS Reserved ADATID DAC OUT3 DACEN DACBC DAC\_OUT2\_ DAC OUT1 DACIE DACIFR DAC\_BUF\_ Reserved 0 0 0 0 0 0 0 0 0 0 0 -\_ -RW RW . -•

| 13 | DAC OUT3 EN | DAC_OUT3 output enable                                                                                                                |
|----|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| -  |             | NOTE: DAC_OUT3 isn't connected to Pin.                                                                                                |
|    |             | 0 Disable                                                                                                                             |
|    |             | 1 Enable                                                                                                                              |
| 12 | DAC_OUT2_EN | DAC_OUT2 output enable<br><b>NOTE:</b> DAC_OUT2 is connected to PA5. Therefore, when using<br>DAC_OUT2,<br>PA5 cannot be used as GPIO |
|    |             | 0 Disable                                                                                                                             |
|    |             | 1 Enable                                                                                                                              |
| 11 | DAC_OUT1_EN | DAC_OUT1 output enable<br><b>NOTE:</b> DAC_OUT1 is connected to PA4. Therefore, when using<br>DAC_OUT1,<br>PA4 cannot be used as GPIO |
|    |             | 0 Disable                                                                                                                             |
|    |             | 1 Enable                                                                                                                              |
| 10 | DAC_BUF_EN  | DAC Buffer Selection                                                                                                                  |
|    |             | 0 Disable (buffer bypass)                                                                                                             |
|    |             | 1 Enable                                                                                                                              |



| 8      | REFSEL  | DAC Reference Selection                                                                                                                                                                                                                                                                                                                                                           |
|--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ÷      |         | 0 AVDD (Internal)                                                                                                                                                                                                                                                                                                                                                                 |
|        |         | 1 DAVREF Pin (External)                                                                                                                                                                                                                                                                                                                                                           |
| 7      | DACIE   | Enable or Disable D/AC Interrupt                                                                                                                                                                                                                                                                                                                                                  |
|        |         | 0 Disable                                                                                                                                                                                                                                                                                                                                                                         |
|        |         | 1 Enable                                                                                                                                                                                                                                                                                                                                                                          |
| 6      | DACIFR  | When D/AC Interrupt occurs, this bit becomes '1'. The flag is cleared<br>only by writing a '0' to the bit. So, the flag should be cleared by<br>software. This interrupt is for a result that the DACDRH register<br>automatically increments to "800xH" or decrements to "000xH".<br>Write '1' has no effect.                                                                    |
|        |         | 0 D/AC interrupt no generation                                                                                                                                                                                                                                                                                                                                                    |
|        |         | 1 D/AC interrupt generation                                                                                                                                                                                                                                                                                                                                                       |
| 5      | ADATID  | Automatically DAC Data Increment/Decrement                                                                                                                                                                                                                                                                                                                                        |
|        |         | 0 Disable automatically D/AC data increment/decrement                                                                                                                                                                                                                                                                                                                             |
|        |         | <ol> <li>Automatically D/AC data increment from DACDR value to<br/>"800xH" when DACEN bit is changed to "1b".</li> <li>Automatically D/AC data decrement from DACDR value to<br/>"000xH" when DACEN bit is changed to "0b".</li> <li>NOTE) It doesn't fetch data from FADPCM block during<br/>automatically data increment/decrement even if the<br/>FADFEN bit is '1'</li> </ol> |
| 4      | DACBC   | DAC Buffer Clear                                                                                                                                                                                                                                                                                                                                                                  |
|        |         | 0 No effect.                                                                                                                                                                                                                                                                                                                                                                      |
|        |         | 1 Clear the D/AC buffer (When write, automatically cleared to '0' after being cleared)                                                                                                                                                                                                                                                                                            |
| 2<br>1 | DACRLDS | DAC Reload Selection. These bits select a reload signal to load data from D/AC data register to buffer.                                                                                                                                                                                                                                                                           |
|        |         | 00 Always                                                                                                                                                                                                                                                                                                                                                                         |
|        |         | 01 Reserved                                                                                                                                                                                                                                                                                                                                                                       |
|        |         | 10 Timer 10 match signal                                                                                                                                                                                                                                                                                                                                                          |
|        |         | 11 Timer 11 match signal                                                                                                                                                                                                                                                                                                                                                          |
| 0      | DACEN   | DAC Enable Bit                                                                                                                                                                                                                                                                                                                                                                    |
|        |         | 0 Stop D/AC operation (Low level output)                                                                                                                                                                                                                                                                                                                                          |
|        |         | 1 Start D/AC operation                                                                                                                                                                                                                                                                                                                                                            |
|        |         |                                                                                                                                                                                                                                                                                                                                                                                   |



# 19.2.4 DAC\_PGSR: Programmable gain control register

#### DAC\_PGSR=0x4000\_350C

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 | 4 | 3    | 2    | 1    | 0    |  |
|-----------------------------------------------------------------------------|---|------|------|------|------|--|
| Reserved                                                                    |   | PGS3 | PGS2 | PGS1 | PGS0 |  |
| -                                                                           |   |      |      |      |      |  |
| ·                                                                           |   | RW   | RW   | RW   | RW   |  |

| 3 | PGS | Programm | nable Gain Selection |
|---|-----|----------|----------------------|
| 0 |     | 0000     | -30dB                |
|   |     | 0001     | -24dB                |
|   |     | 0010     | -18dB                |
|   |     | 0011     | -12dB                |
|   |     | 0100     | -6dB                 |
|   |     | 0101     | 0dB                  |
|   |     | 0110     | +6dB                 |
|   |     | 0111     | +12dB                |
|   |     | 1000     | +18dB                |
|   |     | 1001     | +24dB                |
|   |     | 1010     | +30dB                |
|   |     | Others   | Reserved             |

# 19.2.5 DAC\_OFSCR: DAC offset control register

#### DAC\_OFSCR=0x4000\_3510

|                                                                       | -      |          | -       |
|-----------------------------------------------------------------------|--------|----------|---------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 6    | 54       | 3 2 1 0 |
| Reserved                                                              | OFSDIR | Reserved | OFS     |
| -                                                                     | 0 0    | -        | 0       |
|                                                                       | RW RW  | -        | RW      |

| 7      | OFSEN  | D/AC Offset Control Enable Bit                                  |
|--------|--------|-----------------------------------------------------------------|
|        |        | 0 Disable                                                       |
|        |        | 1 Enable                                                        |
| 6      | OFSDIR | D/AC Offset Direction Selection Bit                             |
|        |        | 0 D/AC buffer data are subtracted by (n + 1)                    |
|        |        | 1 D/AC buffer data are added by (n + 1)                         |
|        |        | <b>NOTE</b> : Where n is the OFS value and $n = 0, 1, 2,, 15$ . |
| 3<br>0 | OFS    | D/AC Offset Value                                               |



# 19.3 Functional description

DAC is R-2R in structure and its data register is a binary in format. It is possible to update the DAC data register as the result output data (DODRH/L register) of FADPCM decoder every the FADPCM decoder result signal by FADFEN bit set to "1b". The 16-bit digital value of the D/AC data register goes into D/AC buffer register through the programmable gain controller every a reload signal. The reload signal is one of the "Always", "FADPCM decoder match signal", "Timer 0 match signal" and "Timer 1 match signal". The signal is selected by the DACRLDS[1:0] bits.

The programmable gain controller has eleven step (-30dB, -24dB, -18dB, -12dB, -6dB, 0dB, +6dB, +12dB, +18dB, +24dB and +30dB) and the gain is selected by the programmable gain register (PGSR).

The value of the DAC data register can be automatically incremented from the current data value to "800xH" when the DAC is enabled by DACEN bit set to "1b" and vice versa. At that time, the DAC interrupt flag bit (DACIFR) is set to "1b". The auto-increment/decrement structure for DAC data is useful to remove a pop noise when a speaker is turn on/off. Two kinds External D/AC Converter is be accessed

# 19.3.1 DAC data buffer register

DAC data and buffer registers are 16-bits, respectively. But only the upper 12-bits of the DAC buffer register specifies to generate DAC output signal. The reset value of the data and buffer is "0000H". The DAC output value, VDAC, is calculated by the following formula:

VDAC = VDD X (n ÷ 4096), (n = 0, 1, 2,,,,, 4095. That is DACBR[15:4] value)

# **19.3.2** Automatic DAC data increment/decrement

"Automatic DAC data increment/decrement" function is important when removing a pop noise. If this function is not embedded, a programmer has to code to reduce a pop noise on a speaker. In A31G32x series, DACDR[15:6] value increases a current DAC data value to 800H with "automatic D/AC data increment" when ADATID bit is set to "1b" and DACEN bit is changed to "1b" from "0b". DACDR[15:6] value decreases a current D/AC data value to 000H with "automatic D/AC data decrement" when ADATID bit is set to "1b" and DACEN bit "automatic D/AC data decrement" when ADATID bit is set to "1b" and DACEN bit is changed to "0b" from "1b".

Steps below introduce a procedure removing a pop noise when a speaker is turn on:

- 1. Write "05H" for 0dB to PGSR register.
- 2. Write "0000H" to DAC data register.



- 4. Clear DAC buffer register by DACBC bit set to "1b".
- 5. Select one of the "Timer 0 match signal" and "Timer 1 match signal" for DAC reload signal with DACRLDS[1:0] bits.
- 6. Start D/AC operation by DACEN bit set to "1b".

Steps below introduce a procedure removing a pop noise when a speaker is turned off:

- 1. Write "05H" for 0dB to PGSR register.
- 2. Keep the value of DACRLDS[1:0] bits set when speaker is turn on.
- 3. Stop D/AC operation by DACEN bit set to "0b".

## 19.3.3 Programmable gain controller

There are 11 selectable levels of gain in the programmable gain controller. The levels are -30dB, -24dB, -18dB, -12dB, -6dB, 0dB, +6dB, +12dB, +18dB, +24dB and +30dB. The gain is selected by configuring programmable gain register (PGSR).

The gain controller converts value of DACDR[15:0] by following the procedure introduced below:

- 1. Get the value of DAC data register (DACDR[15:0]).
- 2. Change the data into a 16-bit signed format.
- 3. Adjust the data by a selected gain.
- 4. Modify the data into a 16-bit binary format.
- 5. Write the data to the DAC buffer register (DACBR[15:0]).





Figure 148. DACBR[15:0] Value by a Selected Gain



# 20. Comparator

Comparator of A31G32x series compares one analogue voltage level with external reference voltage, or internal reference voltage output voltage.

The comparator features the followings:

- 2 Comparators
- Internal BGR reference for comparator
- Comparator output de-bounce function
- Level and edge interrupt mode support for comparator

# 20.1 Comparator block diagram



Figure 149. Comparator Block Diagram



# 20.2 Registers

Base address of the comparator unit is introduced in the followings:

# Table 81. Base Address of Comparator

| Name | Base address |
|------|--------------|
| COMP | 0x4000_3420  |

| Name     | Offset | Туре | Description                              | Reset value | Reference     |
|----------|--------|------|------------------------------------------|-------------|---------------|
| COMP0CR  | 0x0000 | RW   | Comparator 0 Control Register            | 0x0000_0000 | <u>20.2.1</u> |
| COMP1CR  | 0x0004 | RW   | Comparator 1 Control Register            | 0x0000_0000 | 20.2.2        |
| COMPDBNC | 0x0010 | RW   | Comparator Debounce Register             | 0x0000_0000 | 20.2.3        |
| COMPICON | 0x0014 | RW   | Comparator Interrupt Control<br>Register | 0x0000_0000 | <u>20.2.4</u> |
| COMPIEN  | 0x0018 | RW   | Comparator Interrupt Enable<br>Register  | 0x0000_0000 | <u>20.2.5</u> |
| COMPIST  | 0x001C | RO   | Comparator Interrupt Status<br>Register  | 0x0000_0000 | <u>20.2.6</u> |
| COMPICLR | 0x0020 | RW   | Comparator Interrupt Clear<br>Register   | 0x0000_0000 | 20.2.7        |

# Table 82. Comparator Register Map



# 20.2.1 COMP0CR: Comparator 0 control register

#### COMP0CR=0x4000\_3420

| 31 30 29 28 27 20 | 6 25      | 24     | 23 22                | 21 20      | 19 18     | 17 16       | 15 14 1    | 3 12     | 11 10 9 8              | 7     | 6 5 4            | 3 2 1 0                       |
|-------------------|-----------|--------|----------------------|------------|-----------|-------------|------------|----------|------------------------|-------|------------------|-------------------------------|
| Reserved          | COMPREFEN | WINDEN | Reserved             | COMP0_MODE | Reserved  | COMP0_HYSSE | Reserved   | COMP0 EN | Reserve                | d     | COMP0_INNSE<br>L | Reserved                      |
| -                 | 0         | 0      | -                    | 0          | -         | 0           | -          | 0        | -                      |       | 0                | -                             |
|                   | RW        | RW     | -                    | RW         | -         | RW          | -          | RW       |                        |       | RW               | -                             |
|                   | 25        | ·      | COMP                 | REFEN      |           |             |            |          | ference voltage        |       |                  |                               |
|                   |           |        |                      |            | _         | 0           |            |          | al reference vo        |       |                  |                               |
|                   |           |        |                      |            |           | 1           |            |          | al reference vo        | tage  |                  |                               |
|                   | 24        |        | WINDE                | :N         | -         |             | / mode Er  |          |                        |       |                  | <u> </u>                      |
|                   |           |        |                      |            | -         | 0           |            |          | ow mode                |       |                  | <u> </u>                      |
|                   | NOT       |        |                      |            |           | 1           | Enable     | vinac    | ow mode                | 14/   |                  | the least of                  |
|                   |           | npar   | ator 1 is<br>onnecte |            | ted to th | ne input    | of compai  | ator (   | In<br>) (PA [01]), and |       |                  | the input of<br>I and PA [03] |
|                   | 21        |        | COMP                 | 0_MODI     | Ε         | Compa       | rator 0 mc | de Se    | election               |       |                  |                               |
|                   | 20        |        |                      |            | _         | 00          | UL powe    | ər       |                        |       |                  |                               |
|                   |           |        |                      |            | _         | 01          | Low pow    | ver      |                        |       |                  |                               |
|                   |           |        |                      |            | _         | 10          | Medium     | powe     | er                     |       |                  |                               |
|                   |           |        |                      |            |           | 11          | High sp    |          |                        |       |                  |                               |
|                   | 17        |        | COMP                 | 0_HYSS     | SEL _     | Compa       | rator 0 Hy | steres   | sis mode selec         | ion   |                  |                               |
|                   | 16        |        |                      |            | _         | 00          | Off        |          |                        |       |                  |                               |
|                   |           |        |                      |            | _         | 01          | Low        |          |                        |       |                  |                               |
|                   |           |        |                      |            | -         | 10          | Medium     |          |                        |       |                  |                               |
|                   |           |        |                      |            |           | 11          | High       |          |                        |       |                  |                               |
|                   | 12        |        | COMP                 | U_EN       | _         |             | rator 0 En |          |                        |       |                  |                               |
|                   |           |        |                      |            | -         | 0           | Disable    |          |                        |       |                  |                               |
|                   | 6         |        | COMP                 |            |           | 1           | Enable     |          |                        | ation |                  |                               |
|                   | 6<br>4    |        | CONF                 | 0_INNS     | -         | 000         |            | leien    | ce(input -) Sele       | CLION |                  | <u> </u>                      |
|                   |           |        |                      |            | -         | 000         | PA[00]     | chard    | with DAC_OU            | T1)   |                  |                               |
|                   |           |        |                      |            | -         | 010         |            |          | with DAC_OU            |       |                  |                               |
|                   |           |        |                      |            | -         | 011         | Vref 1.2   |          |                        | 12)   |                  |                               |
|                   |           |        |                      |            | -         | 100         | Vref 0.9   |          |                        |       |                  |                               |
|                   |           |        |                      |            | _         | 100         | Vref 0.6   |          |                        |       |                  | <u> </u>                      |
|                   |           |        |                      |            | -         | 110         | Vref 0.3   |          |                        |       |                  |                               |
|                   |           |        |                      |            | -         | 111         | DAC_O      |          |                        |       |                  |                               |
|                   |           |        |                      |            |           |             | 27.0_0     |          |                        |       |                  |                               |
|                   | NOT       | E:     | <u>.</u>             |            |           |             | 0.1.70     |          |                        |       |                  |                               |

Since DAC\_OUT1 and DAC\_OUT2 are connected to the port, when using DAC\_OUT as a comparator reference, the GPIO function of the corresponding port cannot be used. Since DAC\_OUT3 is not connected to the port, GPIO function is not affected.



1.

#### 20.2.2 COMP1CR: Comparator 1 control register

#### COMP1CR=0x4000\_3424

|                               |            |          |             |          |          |    |      |      | - |   |             |   | UN- |     |      |   |
|-------------------------------|------------|----------|-------------|----------|----------|----|------|------|---|---|-------------|---|-----|-----|------|---|
| 31 30 29 28 27 26 25 24 23 22 | 21 20      | 19 18    | 17 16       | 15 14 13 | 12       | 11 | 10 9 | 8    | 7 | 6 | 5           | 4 | 3   | 2   | 1    | 0 |
| Reserved                      | COMP1_MODE | Reserved | COMP1_HYSSE | Reserved | COMP1_EN |    | Rese | rved |   |   | COMP1_INNSE | J | R   | ese | rveo | đ |
| -                             | 0          | -        | 0           | -        | 0        |    | -    |      |   |   | 0           |   |     | -   |      |   |
|                               | RW         | -        | RW          | -        | RW       |    |      |      |   |   | RW          |   |     | -   |      |   |

| 21 | COMP1_MODE   | Comp | arator 1 mode Selection               |
|----|--------------|------|---------------------------------------|
| 20 |              | 00   | UL power                              |
|    |              | 01   | Low power                             |
|    |              | 10   | Medium power                          |
|    |              | 11   | High speed                            |
| 17 | COMP1_HYSSEL | Comp | arator 1 Hysteresis mode selection    |
| 16 |              | 00   | Off                                   |
|    |              | 01   | Low                                   |
|    |              | 10   | Medium                                |
|    |              | 11   | High                                  |
| 12 | COMP1_EN     | Comp | arator 1 Enable                       |
|    |              | 0    | Disable Comparator                    |
|    |              | 1    | Enable Comparator                     |
| 6  | COMP1_INNSEL | Comp | arator 0 Reference(input -) Selection |
| 4  |              | 000  | PA[02]                                |
|    |              | 001  | PA[04] (shard with DAC_OUT1)          |
|    |              | 010  | PA[05] (shard with DAC_OUT2)          |
|    |              | 011  | Vref 1.2V                             |
|    |              | 100  | Vref 0.9V                             |
|    |              | 101  | Vref 0.6V                             |
|    |              | 110  | Vref 0.3V                             |
|    |              | 111  | DAC_OUT3                              |

## NOTE:

1. Since DAC\_OUT1 and DAC\_OUT2 are connected to the port, when using DAC\_OUT as a comparator reference, the GPIO function of the corresponding port cannot be used. Since DAC\_OUT3 is not connected to the port, GPIO function is not affected.



# 20.2.3 COMPDBNC: Comparator debounce register

|                                                |                     |        | COMPDBNC= | 0X4000_3430 |
|------------------------------------------------|---------------------|--------|-----------|-------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 1 | 15 14 13 12 11 10 9 | 8      | 7 6 5 4   | 3 2 1 0     |
| DBNCTB                                         | Reserved            | DBCSEL | C1DBNC    | CODBNC      |
| 0                                              | -                   | 0      | 0         | 0           |
| RW                                             | -                   | RW     | RW        | RW          |

#### COMPDBNC=0x4000 3430

| DBNCTB | Debounce time base counter                                                                                                   |
|--------|------------------------------------------------------------------------------------------------------------------------------|
|        | System clock/(DBNCTB *2) becomes shift clock of debounce logic<br>When DBNCTB is 0, system clock would be debounce clock.    |
| DBCSEL | Debounce time base clock selection                                                                                           |
|        | 0 System clock                                                                                                               |
|        | 1 LSI750kHz                                                                                                                  |
| C1DBNC | Debounce shift Selection                                                                                                     |
|        | When it is 0x0, debounce function is disable<br>Shift number of debounce logic is (C1DBNC + 1) when C1DBNC is more<br>than 1 |
| CODBNC | Debounce shift Selection                                                                                                     |
|        | When it is 0x0, debounce function is disable<br>Shift number of debounce logic is (C0DBNC + 1) when C0DBNC is more<br>than 1 |
|        | DBCSEL<br>C1DBNC                                                                                                             |

## 20.2.4 COMPICON: Comparator Interrupt control register

# COMPICON=0x4000\_3434

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 | 13    | 12    | 11 10    | 9     | 8     | 7 | 6    | 5    | 4  | 3      | 2 | 1 0     |
|-------------------------------------------------|-------|-------|-------|----------|-------|-------|---|------|------|----|--------|---|---------|
| Reserved                                        |       | TPOL1 | TPOL0 | Reserved | 1DOL1 | 0TOdi | F | lese | erve | ed | CIMODE | ) | COIMODE |
| -                                               |       | 0     | 0     | -        | 0     | 0     |   | •    | -    |    | 0      |   | 0       |
|                                                 |       | RW    | RW    |          | RW    | RW    |   |      | -    |    | RV     | I | RW      |

| 13 | TPOL1 | Comparator Trigger output polarity(to trigger other IP) |
|----|-------|---------------------------------------------------------|
|    |       | 0 output normal (comparator out high activates trigger) |
|    |       | 1 output inverted (XOR)                                 |
| 12 | TPOL0 | Comparator Trigger output polarity(to trigger other IP) |
|    |       | 0 output normal (comparator out high activates trigger) |
|    |       |                                                         |
|    |       | 1 output inverted (XOR)                                 |



| 9 | IPOL1   | Comparator 1 interrupt polarity(level mode) |
|---|---------|---------------------------------------------|
|   |         | 0 interrupt at comparator out high          |
|   |         | 1 interrupt at comparator out low           |
| 8 | IPOL0   | Comparator 0 interrupt polarity(level mode) |
|   |         | 0 interrupt at comparator out high          |
|   |         | 1 interrupt at comparator out low           |
| 3 | C1IMODE | Comparator 1 Interrupt Flag bit.            |
| 2 |         | 00 level interrupt (by IPOL1)               |
|   |         | 01 rising edge interrupt                    |
|   |         | 10 falling edge interrupt                   |
|   |         | 11 both edge interrupt                      |
| 1 | COIMODE | Comparator 0 Interrupt Flag bit.            |
| 0 |         | 00 level interrupt (by IPOL0)               |
|   |         | 01 rising edge interrupt                    |
|   |         | 10 falling edge interrupt                   |
|   |         | 11 both edge interrupt                      |

# 20.2.5 COMPIEN: Comparator interrupt enable register

## COMPIEN=0x4000\_3438

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0     |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------|-------|
|    |    |    |    |    |    |    |    |    |    |    |    |    | R  | ese | erve | d  |    |    |    |    |    |   |   |   |   |   |   |   |   | C1IEN | COIEN |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    | -   | -    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0     | 0     |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW    | RW    |

| 1 | C1IEN | Compara | tor 1 Enable |  |
|---|-------|---------|--------------|--|
|   |       | 0       | Disable      |  |
|   |       | 1       | Enable       |  |
| 0 | COIEN | Compara | tor 0 Enable |  |
|   |       | 0       | Disable      |  |
|   |       | 1       | Enable       |  |



# 20.2.6 COMPIST: Comparator interrupt status register

#### COMPIST=0x4000\_343C

| 3 | 1 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 2 | 3 22 | 21 | 20 | 19 | 18 | 17   | 16   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0     |
|---|---|----|----|----|----|----|----|----|---|------|----|----|----|----|------|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------|-------|
|   |   |    |    |    |    |    |    |    |   |      |    |    |    | R  | lese | erve | d  |    |    |    |    |    |   |   |   |   |   |   |   |   | C1IRQ | COIRQ |
|   |   |    |    |    |    |    |    |    |   |      |    |    |    |    |      | -    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0     | 0     |
|   |   |    |    |    |    |    |    |    |   |      |    |    |    |    |      | -    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RO    | RO    |

| 1 | C1IRQ | Compara | ator 1 interrupt Status       |
|---|-------|---------|-------------------------------|
|   |       | 0       | No Comparator Interrupt       |
|   |       | 1       | Comparator Interrupt asserted |
| 0 | COIRQ | Compara | ator 0 interrupt Status       |
|   |       | 0       | No Comparator Interrupt       |
|   |       | 1       | Comparator Interrupt asserted |

# 20.2.7 COMPICLR: Comparator interrupt clear register

#### COMPICLR=0x4000\_3440

|    |    |    |    |    |    |    |    |    |      |    |    |    |    |     |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   | _      |        |
|----|----|----|----|----|----|----|----|----|------|----|----|----|----|-----|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------|--------|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 3 22 | 21 | 20 | 19 | 18 | 17  | 16   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0      |
|    |    |    |    |    |    |    |    |    |      |    |    |    | R  | ese | erve | d  |    |    |    |    |    |   |   |   |   |   |   |   |   | C1ICLR | COICLR |
|    |    |    |    |    |    |    |    |    |      |    |    |    |    | -   | •    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0      | 0      |
|    |    |    |    |    |    |    |    |    |      |    |    |    |    |     |      |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RW     | RW     |

| 1 | C1ICLR | Comparator 1 Interrupt Clear (write "1" to clear C1IRQ) |
|---|--------|---------------------------------------------------------|
| 0 | COICLR | Comparator 0 Interrupt Clear (write "1" to clear C0IRQ) |



# 21. Cyclic redundancy check and checksum (CRC checksum)

Cyclic redundancy check (CRC) generator is used to get a 16-bit CRC code from Flash ROM and a generator polynomial. Among other applications, CRC-based techniques are used to verify data transmission or storage integrity. In the scope of the functional safety standards, they offer a means of verifying the Flash memory integrity. CRC generator helps compute a signature of the software during runtime, to be compared with a reference signature.

CRC generator of A31G32x series features the followings:

- Auto CRC (DMA) and User CRC Mode.
- Polynomial:
  - CRC-CCITT (G<sub>1</sub>(x) =  $x^{16} + x^{12} + x^5 + 1$ )
  - CRC-16 (G<sub>2</sub>(x) =  $x^{16} + x^{15} + x^2 + 1$ )
- CRC Mode and Checksum Mode.

# 21.1 CRC and checksum block diagram

Figure 150 describes the CRC and checksum in a block diagram.



Figure 150. CRC and Checksum Block Diagram



# 21.2 Registers

Base address of the CRC and checksum block is introduced in the followings:

#### Table 83. Base Address of CRC

| Name | Base address |
|------|--------------|
| CRC  | 0x4000_0300  |

## Table 84. CRC Register Map

| Name     | Offset | Туре | Description                           | Reset value | Reference     |
|----------|--------|------|---------------------------------------|-------------|---------------|
| CRC_CR   | 0x0000 | RW   | CRC/Checksum Control<br>Register      | 0x0000_0000 | <u>21.2.1</u> |
| CRC_IN   | 0x0004 | RW   | CRC/Checksum Input Data<br>Register   | 0x0000_0000 | <u>21.2.2</u> |
| CRC_RLT  | 0x0008 | RO   | CRC/Checksum Result Data<br>Register  | 0x0000_FFFF | <u>21.2.3</u> |
| CRC_INIT | 0x000C | RW   | CRC/Checksum Initial Data<br>Register | 0x0000_0000 | <u>21.2.4</u> |

# 21.2.1 CRC\_CR: CRC control register

CRC\_CR is a 32-bit register, and able to do 32/16/8-bit access.

#### CRC\_CR=0x4000\_0300

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 | 9        | 8       | 7        | 6      | 5     | 4     | 32       | 1       | 0      |
|-------------------------------------------------------------------|----------|---------|----------|--------|-------|-------|----------|---------|--------|
| Reserved                                                          | CRCINTEN | CRCINTF | Reserved | RLTCLR | MDSEL | POLYS | Reserved | FIRSTBS | CRCRUN |
| -                                                                 | 0        | 0       | -        | 0      | 0     | 0     | -        | 0       | 0      |
|                                                                   | RW       | RW      | -        | RW     | RW    | RW    | -        | RW      | RW     |

| CRCINTEN | CRC DMA interrupt enable bit                                   |
|----------|----------------------------------------------------------------|
|          | 0 Disable                                                      |
|          | 1 Enable                                                       |
| CRCINTF  | CRC DMA done interrupt flag bit                                |
|          | 0 No request occurred                                          |
|          | 1 Request occurred, This bit is cleared to '0' when write '1'. |
| -        |                                                                |



| 6                    | RLTCLR  | CRC/Checksum Result Data Register (CRC_RLT) Initialization bit.                                                                               |
|----------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------|
|                      |         | 0 No effect.                                                                                                                                  |
|                      |         | <ol> <li>Initialize the CRC_RLT register with the value of CRC_INIT (Thi<br/>bit is automatically cleared to "0b" after operation)</li> </ol> |
| <b>NOTE</b><br>+ 0x9 |         | s calculated by byte unit. Ex) On 0x34A7E991, CRCRLT = 0x34 + 0xA7 + 0xE                                                                      |
| 5                    | MDSEL   | CRC/Checksum Selection bit.                                                                                                                   |
|                      |         | 0 Select CRC.                                                                                                                                 |
|                      |         | 1 Select checksum.                                                                                                                            |
|                      |         | Note)<br>The checksum is calculated by byte unit. Ex) On 0x34A7E991, CRCRL<br>= 0x34 + 0xA7 + 0xE9 + 0x91.                                    |
| 4                    | POLYS   | Polynomial Selection bit. (CRC only)                                                                                                          |
|                      |         | 0 Select CRC-CCITT ( $G_1(x) = x^{16} + x^{12} + x^5 + 1$ )                                                                                   |
|                      |         | 1 Select CRC-16 ( $G_2(x) = x^{16} + x^{15} + x^2 + 1$ )                                                                                      |
| 1                    | FIRSTBS | First Shifted-in Selection bit. (CRC only)                                                                                                    |
|                      |         | 0 MSB-1 <sup>st</sup> .                                                                                                                       |
|                      |         | 1 LSB-1 <sup>st</sup> .                                                                                                                       |
| 0                    | CRCRUN  | CRC/Checksum enable control.<br>In DMA mode, this bit is a busy bit.                                                                          |
|                      |         | 0 CRC/Checksum disabled.                                                                                                                      |
|                      |         | <ol> <li>CRC/Checksum enabled.</li> <li>In DMA mode, this bit is automatically cleared to "0b" after CRC operation</li> </ol>                 |

1. The CRCRUN bit should be set to "1b" last time after setting appropriate values to the registers.

2. The 4 "NOP instruction" should follow immediately after this bit is set.

3. It will be calculated every writing data to the CRC\_IN register during CRCRUN=1.

4. It is prohibited writing any data to the CRC\_IN register during CRCRUN=0 or running in DMA mode.

## 21.2.2 CRC\_IN: CRC input data register

CRC\_IN is a 32-bit register.

#### CRC\_IN=0x4000\_0304

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 INDATA

0x00000000

RW

| 31<br>0 | INDATA          | CRC Input Data bits.                          |  |
|---------|-----------------|-----------------------------------------------|--|
| NOTE    | : The CRC IN re | gister should be written by 1-word (32-bits). |  |



#### 21.2.3 CRC\_RLT: CRC result data register

CRC\_RLT is a 32-bit register, and able to do 32/16/8-bit access.

#### CRC\_RLT=0x4000\_0308

| 31 30 29 28 2 | 7 26 25 24 | 23 22 21 | 20 19 | 18 17 | 16  | 15 14    | 13   | 12 | 11     | 10 | 9 | 8   | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------|------------|----------|-------|-------|-----|----------|------|----|--------|----|---|-----|------|---|---|---|---|---|---|---|
|               | Rese       | erved    |       |       |     |          |      |    |        |    | R | LTC | ΟΑΤΛ | Ą |   |   |   |   |   |   |
|               | -          |          |       |       |     |          |      |    | 0xFFFF |    |   |     |      |   |   |   |   |   |   |   |
|               |            |          |       |       |     |          |      |    |        |    |   | RV  | N    |   |   |   |   |   |   |   |
|               | 15         | RLTDATA  |       | CRC   | Res | ult Data | bits |    |        |    |   |     |      |   |   |   |   |   |   |   |

## 21.2.4 CRC\_INIT: CRC initial data register

CRC\_INIT is a 32-bit register, and able to do 32/16/8-bit access.

# 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Reserved INIDATA 0x0000 RW

| 15 | INIDATA | CRC Initial Data bits. |
|----|---------|------------------------|
| 0  |         |                        |



# 21.3 Functional description

## 21.3.1 CRC polynomial structure



## Figure 151. CRC Polynomial Structure

#### 21.3.2 CRC operation procedure in DMA mode

- 1. CRC/Checksum Enable and Clock Enable. (SCU\_PCER, SCU\_PER)
- 2. Set CRC initial data register. (CRCINIT)
- 3. Set CRC control register.
- 4. CRC operation enable (CRCRUN = 1)
- 5. DMA configuration & operation
- 6. Read the CRC result.

#### 21.3.3 CRC operation procedure in user CRC and checksum mode

- 1. CRC/Checksum Enable and Clock Enable (SCU\_PCER, SCU\_PER)
- 2. Set CRC initial data register. (CRC\_INIT)
- 3. Set CRC control register.
- 4. CRC operation enable. (CRCRUN = 1)
- 5. Input CRC Data at CRC\_IN.
- 6. CRC stop and read CRC result.



# 22. USB full speed device interface

USB block of A31G24x series controls USB 2.0 full speed interface. The USB block features the followings:

- Support for the following speeds:
  - Full-Speed (FS, 12-Mbps)
  - Low-Speed (LS, 1.5-Mbps)
- USB 2.0 full-speed
- Configurable number of endpoints from 1 to 4
- 2 KB dynamic FIFO support.
- Control/bulk/interrupt transfer support.

# 22.1 USB block diagram

Figure 152 describes the USB interface block of A31G32x series in a block diagram.



Figure 152. USB Interface Block Diagram



# 22.2 Registers

Base address of the USB interface block is introduced in the followings:

#### Table 85. Base Address of USB Interface

| Name | Base address |
|------|--------------|
| USB  | 0x5000_0000  |

| Name      | Offset | Туре | Description                                 | Reset value | Reference      |
|-----------|--------|------|---------------------------------------------|-------------|----------------|
| GOTGCTL   | 0x0000 | RW   | Control and Status Register                 | 0x0089_0000 | <u>22.2.1</u>  |
| GOTGINT   | 0x0004 | RW   | Interrupt Register                          | 0x0010_0000 | 22.2.2         |
| GAHBCFG   | 0x0008 | RW   | AHB Configuration Register                  | 0x0000_0000 | 22.2.3         |
| GUSBCFG   | 0x000C | RW   | USB Configuration Register                  | 0x0000_1448 | 22.2.4         |
| GRSTCTL   | 0x0010 | RW   | Reset Register                              | 0x8000_0000 | 22.2.5         |
| GINTSTS   | 0x0014 | RW   | Interrupt Register                          | 0x5400_0034 | 22.2.6         |
| GINTMSK   | 0x0018 | RW   | Interrupt Mask Register                     | 0x0000_0000 | 22.2.7         |
| GRXSTSR   | 0x001C | RW   | Receive Status Debug Read<br>Register       | 0x0000_0000 | 22.2.8         |
| GRXSTSP   | 0x0020 | RW   | Receive Status Read/Pop<br>Register         | 0x0000_0000 | 22.2.9         |
| GRXFSIZ   | 0x0024 | RW   | Receive FIFO Size Register                  | 0x0000_0200 | 22.2.10        |
| GNPTXFSIZ | 0x0028 | RW   | Non-periodic Transmit FIFO<br>Size Register | 0x0040_0200 | <u>22.2.11</u> |
| GSNPSID   | 0x0040 | RW   | Synopsys ID Register                        | 0x5531_100A | 22.2.12        |
| GHWCFG1   | 0x0044 | RW   | User HW Config1 Register                    | 0x0000_0000 | <u>22.2.13</u> |
| GHWCFG2   | 0x0048 | RW   | User HW Config2 Register                    | 0x0288_1114 | 22.2.14        |
| GHWCFG3   | 0x004C | RW   | User Hardware Config3 Register              | 0x01D8_4468 | 22.2.15        |
| GHWCFG4   | 0x0050 | RW   | User Hardware Config4 Register              | 0XD200_4030 | <u>22.2.16</u> |
| GLPMCFG   | 0x0054 | RW   | LPM Config Register                         | 0x0000_0000 | 22.2.17        |
| GPWRDN    | 0x0058 | RW   | Global Power Down register                  | 0x0000_0000 | 22.2.18        |
| GDFIFOCFG | 0x005C | RW   | Global DFIFO Configuration<br>Register      | 0x01D8_0200 | 22.2.19        |

### Table 86. USB Interface Register Map



| Name          | Offset | Туре | Description                                              | Reset value | Reference      |
|---------------|--------|------|----------------------------------------------------------|-------------|----------------|
| DIEPTXFi      | 0x013C | RW   | Device IN Endpoint Transmit<br>FIFO Size Register        | 0x0000_0000 | 22.2.20        |
| DCFG          | 0x0800 | RW   | Device Configuration Register                            | 0x0810_0000 | <u>22.2.21</u> |
| DCTL          | 0x0804 | RW   | Device Control Register                                  | 0x0000_0002 | <u>22.2.22</u> |
| DSTS          | 0x0808 | RW   | Device Status Register                                   | 0x0000_0002 | <u>22.2.23</u> |
| DIEPMSK       | 0x0810 | RW   | Device IN Endpoint Common<br>Interrupt Mask Register     | 0x0000_0000 | 22.2.24        |
| DOEPMSK       | 0x0814 | RW   | Device OUT Endpoint Common<br>Interrupt Mask Register    | 0x0000_0000 | <u>22.2.25</u> |
| DAINT         | 0x0818 | RW   | Device All Endpoints Interrupt<br>Register               | 0x0000_0000 | 22.2.26        |
| DAINTMSK      | 0x081C | RW   | Device All Endpoints Interrupt<br>Mask Register          | 0x0000_0000 | <u>22.2.27</u> |
| DTHRCTL       | 0x0830 | RW   | Device Threshold Control Register                        | 0x0C10_0020 | <u>22.2.28</u> |
| DIEPEMPM<br>S | 0x0834 | RW   | Device IN Endpoint FIFO Empty<br>Interrupt Mask Register | 0x0000_0000 | <u>22.2.29</u> |
| DIEPCTL0      | 0x0900 | RW   | Device Control IN Endpoint 0<br>Control Register         | 0x0000_8000 | 22.2.30        |
| DIEPINT0      | 0x0908 | RW   | Device IN Endpoint 0 Interrupt<br>Register               | 0x0000_0080 | 22.2.31        |
| DIEPDMA0      | 0x0914 | RW   | Device IN Endpoint 0 DMA<br>Address Register             | 0x0000_0000 | 22.2.32        |
| DTXFSTS0      | 0x0918 | RW   | Device IN Endpoint Transmit<br>FIFO Status Register      | 0x0000_0040 | 22.2.33        |
| DIEPDMAB0     | 0x091C | RW   | Device IN Endpoint 16 Buffer<br>Address Register         | 0x0000_0000 | 22.2.34        |
| DIEPCTLi      | 0x0920 | RW   | Device Control IN Endpoint I<br>Control Register         | 0x0000_0000 | <u>22.2.35</u> |
| DIEPINTi      | 0x0928 | RW   | Device IN Endpoint I Interrupt<br>Register               | 0x0000_0080 | 22.2.36        |
| DIEPDMAi      | 0x0934 | RW   | Device IN Endpoint I DMA<br>Address Register             | 0x0000_0000 | 22.2.37        |

Table 86. USB Interface Register Map (continued)



|           | -      |      |                                                     | · · · · <b>,</b> |                |
|-----------|--------|------|-----------------------------------------------------|------------------|----------------|
| Name      | Offset | Туре | Description                                         | Reset value      | Reference      |
| DTXFSTSi  | 0x0938 | RW   | Device IN Endpoint Transmit<br>FIFO Status Register | 0x0000_0040      | <u>22.2.38</u> |
| DIEPDMABi | 0x093C | RW   | Device IN Endpoint I Buffer<br>Address Register     | 0x0000_0000      | <u>22.2.39</u> |
| DOEPCTL0  | 0x0B00 | RW   | Device Control OUT Endpoint 0<br>Control Register   | 0x0000_8000      | 22.2.40        |
| DOEPINT0  | 0x0B08 | RW   | Device OUT Endpoint 0 Interrupt<br>Register         | 0x0000_0000      | <u>22.2.41</u> |
| DOEPDMA0  | 0x0B14 | RW   | Device OUT Endpoint 0 DMA<br>Address Register       | 0x0000_0000      | <u>22.2.42</u> |
| DOEPDMAB  | 0x0B1C | RW   | Device OUT Endpoint 16 Buffer<br>Address Register   | 0x0000_0000      | <u>22.2.43</u> |
| DOEPCTLi  | 0x0B20 | RW   | Device Control OUT Endpoint I<br>Control Register   | 0x0000_0000      | 22.2.44        |
| DOEPINTi  | 0x0B28 | RW   | Device OUT Endpoint I Interrupt<br>Register         | 0x0000_0000      | 22.2.45        |
| DOEPDMAi  | 0x0B34 | RW   | Device OUT Endpoint I DMA<br>Address Register       | 0x0000_0000      | 22.2.46        |
| DOEPDMAB  | 0x0B3C | RW   | Device OUT Endpoint I Buffer<br>Address Register    | 0x0000_0000      | 22.2.47        |
| PCGCCTL   | 0x0E00 | RW   | Power and Clock Gating Control<br>Register          | 0x0000_0000      | 22.2.48        |

Table 86. USB Interface Register Map (continued)



## 22.2.1 GOTGCTL: Control and status register

GOTGCTL register controls behavior of the controller, and reflects its status.

|    | GOTGCTL =0x5000_000 |      |     |    |    |      |      |     |    |    |    |    |    |    |    | 000 |    |    |    |     |      |   |   |   |   |   |   |   |   |   |   |
|----|---------------------|------|-----|----|----|------|------|-----|----|----|----|----|----|----|----|-----|----|----|----|-----|------|---|---|---|---|---|---|---|---|---|---|
| 31 | 30                  | 29   | 28  | 27 | 26 | 25   | 24   | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11  | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    | Re                  | ser\ | ved |    | Ν  | Лulť | Vall | dB( | C  |    |    |    |    |    |    |     |    |    | R  | ese | erve | d |   |   |   |   |   |   |   |   |   |
|    |                     | -    |     |    |    | 0    | )x02 | 2   |    |    |    |    |    |    |    |     |    |    |    | -   | -    |   |   |   |   |   |   |   |   |   |   |
|    |                     | -    |     |    |    |      | R    |     |    |    |    |    |    |    |    |     |    |    |    |     |      |   |   |   |   |   |   |   |   |   |   |

| 26 | MultValIdBC | Multi Valued ID pin (MultValIdBC)                                   |
|----|-------------|---------------------------------------------------------------------|
| 2  |             | Battery Charger ACA inputs in the following order:                  |
|    |             | • Bit 26: rid float.                                                |
|    |             | • Bit 25: rid gnd                                                   |
|    |             | • Bit 24: rid a                                                     |
|    |             | • Bit 23: rid b                                                     |
|    |             | • Bit 22: rid_c                                                     |
|    |             | Values:                                                             |
|    |             | <ul> <li>0x10 (RID FLOAT): B-Device not connected to ACA</li> </ul> |
|    |             | <ul> <li>0x8 (RID_GND): A-Device not connected to ACA</li> </ul>    |
|    |             | <ul> <li>0x4 (RID A): A-Device connected to ACA</li> </ul>          |
|    |             | • 0x2 (RID B): B-Device connected to ACA. VBUS is off.              |
|    |             | • 0x1 (RID C): B-Device connected to ACA. VBUS is on.               |
|    |             | Value After Reset: Varies based on Configuration                    |
|    |             | Exists: OTG_BC_SUPPORT==1                                           |
|    |             | Volatile: true                                                      |

#### 22.2.2 GOTGINT: Interrupt register

Application reads this register whenever an interrupt occurs. Corresponding bits in this register is cleared after the reading.

| GOTGINT =0x5000_0004 |
|----------------------|
|----------------------|

|                                  |              |    |    |    |    |    |    |    |    |    |     |     |   | - |   |   | • | •• |   |   |   |
|----------------------------------|--------------|----|----|----|----|----|----|----|----|----|-----|-----|---|---|---|---|---|----|---|---|---|
| 31 30 29 28 27 26 25 24 23 22 21 | 20           | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9   | 8 | 7 | 6 | 5 | 4 | 3  | 2 | 1 | 0 |
| Reserved                         | MultVallpChn |    |    |    |    |    |    |    |    | R  | ese | rve | d |   |   |   |   |    |   |   |   |
| -                                | 1            |    |    |    |    |    |    |    |    |    | -   |     |   |   |   |   |   |    |   |   |   |
|                                  | RW           |    |    |    |    |    |    |    |    |    | -   |     |   |   |   |   |   |    |   |   |   |

| 20 MultVallpChng | <ul> <li>This bit when set indicates that there is a change in the value of at least one ACA pin value.</li> <li>Values:</li> <li>0x1 (ACA_PIN_CHANGE): Indicates there is a change in ACA pin value.</li> <li>0x0 (NO_ACA_PIN_CHANGE): Indicates there is no change in ACA pin value.</li> </ul> |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|



#### 22.2.3 GAHBCFG: AHB configuration register

This register can be used to configure the core after power-on or a change in mode. This register mainly contains AHB system-related configuration parameters. Do not change this register after the initial programming. The application must program this register before starting any transactions on either the AHB or the USB.

#### GAHBCFG =0x5000\_0008

| 31 | 3 | 0 29 | 28   | 27  | 26 | 25 | 24              | 23        | 22             | 21         | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4 | 3 | 2       | 1 | 0           |
|----|---|------|------|-----|----|----|-----------------|-----------|----------------|------------|----|----|----|----|----|----|----|-----|-----|----|----|---|---|---|---|-------|---|---|---------|---|-------------|
|    |   | Re   | serv | ved |    |    | InvDescEndianes | AHBSingle | NotiAllDmaWrit | RemMemSupp |    |    |    |    |    |    | Re | ser | ved |    |    |   |   |   |   | DMAEn |   |   | HDSILEI |   | GlbIIntrMsk |
|    |   |      | -    |     |    |    | 0               | 0         | 0              | 0          |    |    |    |    |    |    |    | -   |     |    |    |   |   |   |   | 0     |   | ( | )       |   | 0           |
|    |   |      |      |     |    |    | RW              | RW        | RW             | RW         |    |    |    |    |    |    |    | •   |     |    |    |   |   |   |   | RW    |   | R | W       |   | RW          |

| 24 | InvDescEndianes | Invert Descriptor Endianess (InvDescEndianess)<br>• 1'b0: Descriptor Endianness is same as AHB Master Endianness.<br>• 1'b1:<br>-If the AHB Master endianness is Big Endian, the Descriptor Endianness<br>is Little Endian.<br>-If the AHB Master endianness is Little Endian, the Descriptor<br>Endianness is Big Endian.<br>Values:<br>• 0x0 (DISABLE): Descriptor Endianness is same as AHB Master<br>Endianness<br>• 0x1 (ENABLE): Descriptor Endianness is opposite to AHB Master<br>Endianness<br>Value After Reset: 0x0<br>Exists: OTG_EN_DESC_DMA == 1<br>Volatile: true                                                                                                                                                                                                                                                                                                                          |
|----|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 | AHBSingle       | <ul> <li>AHB Single Support (AHBSingle)</li> <li>This bit when programmed supports Single transfers for the remaining data in a transfer when the core is operating in DMA mode.</li> <li>1'b0: The remaining data in the transfer is sent using INCR burst size</li> <li>1'b1: The remaining data in the transfer is sent using Single burst size</li> <li>Note: If this feature is enabled, the AHB RETRY and SPLIT transfers still have INCR burst type. Enable this feature when the AHB Slave connected to the core does not support INCR burst (and when Split and Retry transactions are not being used in the bus).</li> <li>Values:</li> <li>0x0 (INCRBURST): The remaining data in the transfer is sent using INCR burst size</li> <li>0x1 (SINGLEBURST): The remaining data in the transfer is sent using Single burst size</li> <li>Value After Reset: 0x0</li> <li>Exists: Always</li> </ul> |



| 22 | NotiAllDmaWrit | <ul> <li>Notify All Dma Write Transactions (NotiAlIDmaWrit)</li> <li>This bit is programmed to enable the System DMA Done functionality for all the DMA write Transactions corresponding to the Channel/Endpoint. This bit is valid only when GAHBCFG.RemMemSupp is set to 1.</li> <li>GAHBCFG.NotiAlIDmaWrit = 1</li> <li>The core asserts int_dma_req for all the DMA write transactions on the AHB interface along with int_dma_done, chep_last_transact and chep_number signal informations. The core waits for sys_dma_done signal for all the DMA write transactions in order to complete the transfer of a particular Channel/Endpoint.</li> <li>GAHBCFG.NotiAlIDmaWrit = 0</li> <li>The core asserts int_dma_req signal only for the last transaction of DM/ write transfer corresponding to a particular Channel/Endpoint. Similarly the core waits for sys_dma_done signal only for that transaction of DM/ write to complete the transfer of a particular Channel/Endpoint.</li> <li>Values:</li> <li>0x1 (ALLTRANS): The core asserts int_dma_req for all the DMA write transactions on the AHB interface along with int_dma_done chep_last_transact and chep_number signal informations. The core waits for sys_dma_done signal for all the DMA write transactions in order to complete the transfer of a particular Channel/Endpoint.</li> <li>Values:</li> <li>0x1 (ALLTRANS): The core asserts int_dma_req for all the DMA write transactions on the AHB interface along with int_dma_done chep_last_transact and chep_number signal informations. The core waits for sys_dma_done signal for all the DMA write transactions in order to complete the transfer of a particular Channel/Endpoint.</li> <li>0x0 (LASTTRANS):</li> <li>Value After Reset: 0x0</li> <li>Exists: Always</li> </ul> |
|----|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21 | RemMemSupp     | Volatile: true<br>Remote Memory Support (RemMemSupp)<br>This bit is programmed to enable the functionality to wait for the system<br>DMA Done Signal for the DMA Write Transfers.<br>• GAHBCFG.RemMemSupp=1<br>The int_dma_req output signal is asserted when the DMA starts write<br>transfer to the external memory. When the core is done with the<br>Transfers it asserts int_dma_done signal to flag the completion of DM/<br>writes from the controller. The core then waits for sys_dma_done signal<br>from the system to proceed further and complete the Data Transfer<br>corresponding to a particular Channel/Endpoint.<br>• GAHBCFG.RemMemSupp=0<br>The int_dma_req and int_dma_done signals are not asserted and the<br>core proceeds with the assertion of the XferComp interrupt as soon at<br>the DMA write transfer is done at the Core Boundary and it does not<br>wait for the sys_dma_done signal to complete the DATA transfers.<br>Values:<br>• 0x0 (DISABLED): Remote Memory Support Feature disabled<br>• 0x1 (ENABLED): Remote Memory Support Feature enabled<br>Value After Reset: 0x0<br>Exists: Always<br>Volatile: true                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5  | DMAEn          | DMA Enable (DMAEn)<br>Reset: 1'b0<br>Values:<br>• 0x1 (DMAMODE): Core operates in a DMA mode<br>Value After Reset: 0x0<br>Exists: OTG_ARCHITECTURE != 0<br>Volatile: true                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |



| 4 | HbstLen     | Burst Length/Type (HbstLen)<br>Internal DMA Mode AHB Master burst type:<br>• 4'b0000 Single<br>• 4'b0011 INCR<br>• 4'b0011 INCR4<br>• 4'b0101 INCR8<br>• 4'b0101 INCR8<br>• 4'b0111 INCR16<br>• Others: Reserved<br>Values:<br>• 0x1 (WORD4ORINCR): 4 words or INCR<br>• 0x5 (WORD64ORINCR8): 64 words or INCR8<br>• 0x3 (WORD160RINCR4): 16 words or INCR4<br>• 0x3 (WORD10RSINGLE): 1 word or single<br>• 0x7 (WORD2560RINCR16): 256 words or INCR16<br>Value After Reset: 0x0<br>Exists: Always<br>Volatile: true                                                                                                  |
|---|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | GlblIntrMsk | <ul> <li>Global Interrupt Mask (GlbIIntrMsk)</li> <li>The application uses this bit to mask or unmask the interrupt line assertion to itself. Irrespective of this bit's setting, the interrupt status registers are updated by the controller.</li> <li>1'b0: Mask the interrupt assertion to the application.</li> <li>1'b1: Unmask the interrupt assertion to the application.</li> <li>Values:</li> <li>0x0 (MASK): Mask the interrupt assertion to the application.</li> <li>0x1 (NOMASK): Unmask the interrupt assertion to the application.</li> <li>Value After Reset: 0x0</li> <li>Exists: Always</li> </ul> |

## 22.2.4 GUSBCFG: USB configuration register

This register can be used to configure the core after power-on. It contains USB and USB-PHY related configuration parameters. The application must program this register before starting any transactions on either the AHB or the USB. Do not make changes to this register after the initial programming.

| GUSB | CFG | =0x5000 | 000C |
|------|-----|---------|------|
|      |     |         |      |

| 31           | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 | 6      | 5      | 4 3      | 2 1 0   |
|--------------|----------------------------------------------------------------------|--------|--------|----------|---------|
| CorruptTxPkt | Reserved                                                             | PHYSel | FSIntf | Reserved | ToutCal |
| 0            | -                                                                    | 1      | 0      | -        | 0       |
| W            |                                                                      | RW     | RW     |          | RW      |

| 31 | CorruptTxPkt | Corrupt Tx packet (CorruptTxPkt)<br>This bit is for debug purposes only. Never Set this bit to 1. The<br>application should always write 1'b0 to this bit.<br>Values: |
|----|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |              | <ul> <li>0x1 (DEBUG): Debug Mode</li> <li>0x0 (NODEBUG): Normal Mode</li> </ul>                                                                                       |



| 6 | PHYSel  | PHYSel                                                                                                                             |
|---|---------|------------------------------------------------------------------------------------------------------------------------------------|
|   |         | USB 1.1 Full-Speed Serial Transceiver Select (PHYSel) <ul> <li>1'b1: USB 1.1 full-speed serial transceiver</li> </ul>              |
|   |         | If a USB 1.1 Full-Speed Serial Transceiver interface was no                                                                        |
|   |         | selected in, this bit is always 0, with Write Only access.                                                                         |
|   |         | Values:<br>• 0x1 (USB11): USB 1.1 full-speed serial transceiver is selected                                                        |
| 5 | FSIntf  |                                                                                                                                    |
| Э | FSIIII  | Full-Speed Serial Interface Select (FSIntf)<br>The application uses this bit to select either a unidirectional o                   |
|   |         | bidirectional USB 1.1 full-speed serial transceiver interface.                                                                     |
|   |         | 1'b0: 6-pin unidirectional full-speed serial interface                                                                             |
|   |         | 1'b1: 3-pin bidirectional full-speed serial interface     1                                                                        |
|   |         | If a USB 1.1 Full-Speed Serial Transceiver interface was no<br>selected, this bit is always 0, with Write Only access. If a USB 1. |
|   |         | FS interface was selected, Then the application can Set this bit t                                                                 |
|   |         | select between the 3- and 6-pin interfaces, and access is Rea                                                                      |
|   |         | and Write.                                                                                                                         |
|   |         | Values:                                                                                                                            |
|   |         | <ul> <li>0x1 (FS3PIN): 3-pin bidirectional full-speed serial interface</li> </ul>                                                  |
|   |         | • 0x0 (FS6PIN): 6-pin unidirectional full-speed serial interface                                                                   |
| 2 | ToutCal | FS Timeout Calibration (ToutCal)                                                                                                   |
| 0 |         | The number of PHY clocks that the application programs in thi                                                                      |
|   |         | field is added to the full-speed interpacket timeout duration in th                                                                |
|   |         | core to account for any additional delays introduced by the PHY                                                                    |
|   |         | This can be required, because the delay introduced by the PHY i<br>generating the linestate condition can vary from one PHY t      |
|   |         | another.                                                                                                                           |
|   |         | The USB standard timeout value for full-speed operation is 16 t                                                                    |
|   |         | 18 (inclusive) bit times. The application must program this fiel                                                                   |
|   |         | based on the speed of enumeration. The number of bit time                                                                          |
|   |         | added per PHY clock are as follows:                                                                                                |
|   |         | Full-speed operation:                                                                                                              |
|   |         | <ul> <li>One 48-MHz PHY clock = 0.25 bit times</li> </ul>                                                                          |

#### 22.2.5 GRSTCTL: Reset register

The application uses this register to reset various hardware features inside the controller.

|         |        |    |    |    |    |    |    |    |    |    |      |     |    |    |    |    |    |    |    |    |    |   |        |   | GR | STC     | TL      | =0x | 500      | 0_0         | 010     |
|---------|--------|----|----|----|----|----|----|----|----|----|------|-----|----|----|----|----|----|----|----|----|----|---|--------|---|----|---------|---------|-----|----------|-------------|---------|
| 31      | 30     | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7 | 6  | 5       | 4       | 3   | 2        | 1           | 0       |
| AHBIdle | DMAReq |    |    |    |    |    |    |    |    | Re | ser\ | red |    |    |    |    |    |    |    |    |    |   | TxFNum |   |    | TxFFIsh | RxFFlsh | -   | Keservea | PIUFSSftRst | CSftRst |
| 1       | 0      |    |    |    |    |    |    |    |    |    | -    |     |    |    |    |    |    |    |    |    |    |   | 0      |   |    | 0       | 0       |     | -        | 0           | 0       |
| R       | R      |    |    |    |    |    |    |    |    |    | •    |     |    |    |    |    |    |    |    |    |    |   | RW     |   |    | RW      | RW      |     | -        | RW          | RW      |

| 31 | AHBIdle | AHB Master Idle (AHBIdle)<br>Indicates that the AHB Master State Machine is in the IDLE condition. |
|----|---------|----------------------------------------------------------------------------------------------------|
|    |         | Values:<br>• 0x1 (ACTIVE): AHB Master Idle                                                         |
|    |         | • 0x0 (INACTIVE): Not Idle                                                                         |
|    |         | Value After Reset: 0x1                                                                             |



| 30      | DMAReq      | DMA Request Signal (DMAReq)<br>Indicates that the DMA request is in progress. Used for debug.<br>Values:<br>• 0x1 (ACTIVE): DMA request is in progress<br>• 0x0 (INACTIVE): No DMA request                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 10<br>6 | TxFNum      | <ul> <li>TxFIFO Number (TxFNum)</li> <li>This is the FIFO number that must be flushed using the TxFIF</li> <li>Flush bit. This field must not be changed until the core clears th</li> <li>TxFIFO Flush bit.</li> <li>5'h0:</li> <li>-Tx FIFO 0 flush in device mode when in dedicated FIFO mode.</li> <li>5'h1:</li> <li>-TXFIFO 1 flush in device mode when in dedicated FIFO mode.</li> <li>5'h2:</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         |             | -TXFIFO 2 flush in device mode when in dedicated FIFO mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|         |             | <br>• 5'h4<br>-TXFIFO 4 flush in device mode when in dedicated FIFO mode.<br>• 5'h10: Flush all the transmit FIFOs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|         |             | Values:<br>• 0x3 (TXF3): -Periodic TxFIFO 3 flush in device mode when<br>shared FIFO operation –TXFIFO 3 flush in device mode when<br>dedicated FIFO mode<br>• 0v4 (TXF4): Device the state of the |
|         |             | <ul> <li>0x4 (TXF4): -Periodic TxFIFO 4 flush in device mode when<br/>shared FIFO operation –TXFIFO 4 flush in device mode when<br/>dedicated FIFO mode</li> <li>0x2 (TXF2): -Periodic TxFIFO 2 flush in device mode when</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|         |             | <ul> <li>shared FIFO operation –TXFIFO 2 flush in device mode when dedicated FIFO mode</li> <li>0x1 (TXF1): -Periodic TxFIFO 1 flush in device mode when</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|         |             | shared FIFO operation –TXFIFO 1 flush in device mode when dedicated FIFO mode<br>• 0x0 (TXF0): -Periodic TxFIF O flush in device mode when                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         |             | shared FIFO operation –TXFIFO 0 flush in device mode when<br>dedicated FIFO mode<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5       | TxFFlsh     | TxFIFO Flush (TxFFlsh)<br>This bit selectively flushes a single or all transmit FIFOs, but cannot<br>do so If the core is in the midst of a transaction.<br>The application must write this bit only after checking that the co                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         |             | <ul> <li>In application must write this brown and include the control of the target of targe</li></ul>  |
|         |             | <ul><li>the FIFO</li><li>WriteGRSTCTL.AHBIdle ensures the core is not writing anythir to the FIFO.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         |             | Flushing is normally recommended when FIFOs are reconfigure<br>or when switching between Shared FIFO and Dedicated Transm<br>FIFO operation. FIFO flushing is also recommended during devic<br>endpoint disable. The application must wait until the core clea<br>this bit before performing any operations. This bit takes eig<br>clocks to clear, using the slower clock of phy_clk or hclk.<br>Values:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|         |             | <ul> <li>0x1 (ACTIVE): Selectively flushes a single or all transmit FIFOs</li> <li>0x0 (INACTIVE): No Flush<br/>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4       | RxFFlsh     | RxFIFO Flush (RxFFlsh)<br>The application can flush the entire RxFIFO using this bit, but mu<br>first ensure that the core is not in the middle of a transaction.<br>The application must only write to this bit after checking that th<br>controller is neither reading from the RxFIFO nor writing to th<br>RxFIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|         |             | The application must wait until the bit is cleared before performir<br>any other operations. This bit requires eight clocks (slowest<br>PHY or AHB clock) to clear.<br>Values:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|         |             | • 0x1 (ACTIVE): Flushes the entire RxFIFO<br>• 0x0 (INACTIVE): Does not flush the entire RxFIFO<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1       | PIUFSSftRst | PIU FS Dedicated Controller Soft Reset (PIUFSSftRst)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |



|           | <ul> <li>Resets the PIU FS Dedicated Controller</li> <li>All module state machines in FS Dedicated Controller of PIU are reset to the IDLE state. Used to reset the FS Dedicated controlle in PIU in case of any PHY Errors like Loss of activity or Babble Error resulting in the PHY remaining in RX state for more than one frame boundary.</li> <li>This is a self-clearing bit and core clears this bit after all the necessary logic is reset in the core.</li> <li>Values:</li> <li>0x1 (RESET_ACTIVE): PIU FS Dedicated Controller Soft Reset</li> <li>0x0 (RESET_INACTIVE): No Reset</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 CSftRst | Core Soft Reset (CSftRst)<br>Resets the hclk and phy_clock domains as follows:<br>• Clears the interrupts and all the CSR registers except the<br>following register bits:<br>• PCGCCTL.RstPdwnModule<br>• PCGCCTL.GateHclk<br>• PCGCCTL.StopPPhyLPwrClkSelclk<br>• GUSBCFG.PhyLPwrClkSel<br>• GUSBCFG.FSIntf<br>• GGPIO<br>• GPWRDN<br>• HCFG.FSLSPclkSel<br>• DCFG.DevSpd<br>• DCTL.StfDiscon<br>• All module state machines<br>• All module state machines<br>• All module state machines<br>• All module state machines (except the AHB Slave Unit) are reset<br>to the IDLE state, and all the transmit FIFOs and the receive FIFC<br>are flushed.<br>• Any transactions on the AHB Master are terminated as soon a<br>possible, after gracefully completing the last data phase of an AHI<br>transfer. Any transactions on the USB are terminated immediately<br>• When Hibernation feature is enabled, the PMU module is no<br>reset by the Core Soft Reset.<br>The application can write to this bit any time it wants to reset th<br>core. This is a self-clearing bit and the core clears this bit after a<br>the necessary logic is reset in the core. Once this bit i<br>cleared software must wait at least 3 PHY clocks before doing an<br>access to the PHY domain (synchronization delay). Software must<br>also must check that bit 31 of this register is 1 (AHB Master i<br>IDLE) before starting any operation.<br>Typically software reset is used during software development and<br>also when you dynamically change the PHY selection bits in the<br>USB configuration registers listed above. When you change the<br>PHY, the corresponding clock for the PHY is selected and used if<br>the PHY domain. Once a new clock is selected, the PHY domain<br>has to be reset for proper operation.<br>Values:<br>• 0x1 (ACTIVE): No reset<br>Value After Reset. 0x0 |



#### 22.2.6 GINTSTS: Interrupt register

This register interrupts the application for system-level events in the current mode. To clear the interrupt status bits of type R\_SS\_WC, the application must write 1'b1 into the bit.

The FIFO status interrupts are read only; once software reads from or writes to the FIFO while servicing these interrupts, FIFO interrupt conditions are cleared automatically.

The application must clear the GINTSTS register at initialization before unmasking the interrupt bit to avoid any interrupts generated prior to initialization.

|         |      |      |         |    |          |    |          |         |          |        |        |       |             |      |            |          |        |         |          |          |            |           |          | 0 -    | .070 |   |          |   |
|---------|------|------|---------|----|----------|----|----------|---------|----------|--------|--------|-------|-------------|------|------------|----------|--------|---------|----------|----------|------------|-----------|----------|--------|------|---|----------|---|
| 31      | 30 2 | 9 28 | 27      | 26 | 25       | 24 | 23       | 22      | 21 20    | 19     | 18     | 17    | 16          | 15   | 14         | 13       | 12     | 11      | 10       | 98       | 7          | 6         | 5        | 4      | 3    | 2 | 1        | 0 |
| WkUpInt |      |      | LPM_Int |    | Reserved |    | ResetDet | FetSusp | Reserved | OEPInt | IEPInt | EPMis | RstrDoneInt | EOPF | ISOOutDrop | EnumDone | USBRst | USBSusp | ErlySusp | Reserved | GOUTNakEff | GINNakEff | Reserved | RxFLvI | Sof  |   | Reserved |   |
| 0       | -    |      | 0       |    | -        |    | 0        | 0       | -        | 0      | 0      | 0     | 0           | 0    | 0          | 0        | 0      | 0       | 0        | -        | 0          | 0         | -        | 1      | 0    |   | -        |   |
| RW      |      |      | RW      |    | -        |    | RW       | RW      | -        | R      | R      | RW    | RW          | RW   | RW         | RW       | RW     | RW      | RW       |          | RW         | R         | -        | R      | RW   |   |          |   |

| GINTSTS | =0x5000 | 0014 |
|---------|---------|------|
| 0111313 |         | 0014 |

| 31 | WkUpInt  | <ul> <li>Resume/Remote Wakeup Detected Interrupt (WkUpInt)</li> <li>Wakeup Interrupt during Suspend(L2) or LPM(L1) state.</li> <li>During Suspend(L2):</li> <li>This interrupt is asserted only when Host Initiated Resume is detected on USB.</li> <li>For more information, see 'Partial Power-Down and Clock Gating Programming Model' in the Programming Guide.</li> <li>During LPM(L1):</li> <li>This interrupt is asserted for either Host Initiated Resume o Device Initiated Remote Wakeup on USB.</li> </ul> |
|----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |          | For more information, see 'LPM Entry and Exit Programming<br>Model' in the Programming Guide.<br>Values:<br>• 0x1 (ACTIVE): Resume or Remote Wakeup Detected Interrupt<br>• 0x0 (INACTIVE): Not active                                                                                                                                                                                                                                                                                                                |
| 27 | LPM_Int  | LPM Transaction Received Interrupt (LPM_Int). This interrupt i<br>asserted when the device receives an LPM transaction an<br>responds with a non-ERRORed response. Has completed LPM<br>transactions for the programmed number of time<br>(GLPMCFG.RetryCnt).<br>Values:<br>• 0x1 (ACTIVE): LPM Transaction Received Interrupt<br>• 0x0 (INACTIVE): Not Active                                                                                                                                                        |
| 23 | ResetDet | Reset detected Interrupt (ResetDet)<br>In Device mode, this interrupt is asserted when a reset is detecte<br>on the USB in partial power-down mode when the device is i<br>Suspend.<br>Values:<br>• 0x1 (ACTIVE): Reset detected Interrupt<br>• 0x0 (INACTIVE): Not active                                                                                                                                                                                                                                            |



| 22 | FetSusp | Data Fetch Suspended (FetSusp)<br>This interrupt is valid only in DMA mode. This interrupt indicates<br>that the core has stopped fetching data for IN endpoints due to the<br>unavailability of TxFIFO space or Request Queue space. This<br>interrupt is used by the application for an endpoint mismatch                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |         | algorithm.<br>For example, after detecting an endpoint mismatch, the<br>application:<br>• Sets a Global non-periodic IN NAK handshake<br>• Disables In endpoints<br>• Flushes the FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|    |         | <ul> <li>Determines the token sequence from the IN Token Sequence Learning Queue</li> <li>Re-enables the endpoints</li> <li>Clears the Global non-periodic IN NAK handshake If the Global non-periodic IN NAK is cleared, the core has not ye fetched data for the IN endpoint, and the IN token is received. The core generates an 'IN token received when FIFO empty' interrupt The OTG Then sends the host a NAK response. To avoid this scenario, the application can check the GINTSTS.FetSusy interrupt, which ensures that the FIFO is full before clearing a Global NAK handshake.</li> <li>Alternatively, the application can mask the IN token received when FIFO empty interrupt when clearing a Global IN NAK handshake Values:</li> <li>0x1 (ACTIVE): Data Fetch Suspended</li> <li>0x0 (INACTIVE): Not active</li> </ul> |
| 19 | OEPInt  | OUT Endpoints Interrupt (OEPInt)<br>The controller sets this bit to indicate that an interrupt is pending<br>on one of the OUT endpoints of the core (in Device mode). The<br>application must read the Device All Endpoints Interrupt (DAINT<br>register to determine the exact number of the OUT endpoint of<br>which the interrupt occurred, and then read the corresponding<br>Device OUT Endpoint-n Interrupt (DOEPINTn) register to<br>determine the exact cause of the interrupt. The application must<br>clear the appropriate status bit in the corresponding DOEPINTn<br>register to clear this bit.<br>Values:<br>• 0x1 (ACTIVE): OUT Endpoints Interrupt<br>• 0x0 (INACTIVE): Not active                                                                                                                                   |
| 18 | IEPInt  | IN Endpoints Interrupt (IEPInt)<br>The core sets this bit to indicate that an interrupt is pending on one<br>of the IN endpoints of the core (in Device mode). The application<br>must read the Device All Endpoints Interrupt (DAINT) register to<br>determine the exact number of the IN endpoint on Device IN<br>Endpoint-n Interrupt (DIEPINTn) register to determine the exact<br>cause of the interrupt. The application must clear the appropriate<br>status bit in the corresponding DIEPINTn register to clear this bit<br>Values:<br>• 0x1 (ACTIVE): IN Endpoints Interrupt<br>• 0x0 (INACTIVE): Not active                                                                                                                                                                                                                  |
| 17 | EPMis   | <ul> <li>Endpoint Mismatch Interrupt (EPMis)</li> <li>Note: This interrupt is valid only in shared FIFO operation.</li> <li>Indicates that an IN token has been received for a non-periodi endpoint, but the data for another endpoint is present in the top of the Non-periodic Transmit FIFO and the IN endpoint mismatch count programmed by the application has expired.</li> <li>Values:</li> <li>0x1 (ACTIVE): Endpoint Mismatch Interrupt</li> <li>0x0 (INACTIVE): Not active</li> </ul>                                                                                                                                                                                                                                                                                                                                        |



| 16 | RstrDoneInt | Restore Done Interrupt (RstrDoneInt)<br>The controller sets this bit to indicate that the restore command<br>after Hibernation was completed by the core.<br>The controller continues from Suspended state into the mode<br>dictated by PCGCCTL.RestoreMode field.<br>Values:<br>• 0x1 (ACTIVE): Restore Done Interrupt<br>• 0x0 (INACTIVE): Not active                                                                                 |
|----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15 | EOPF        | End of Periodic Frame Interrupt (EOPF)<br>Indicates that the period specified in the Periodic Frame Interval<br>field of the Device Configuration register (DCFG.PerFrInt) has<br>been reached in the current microframe.<br>Values:<br>• 0x1 (ACTIVE): End of Periodic Frame Interrupt<br>• 0x0 (INACTIVE): Not active                                                                                                                 |
| 14 | ISOOutDrop  | Isochronous OUT Packet Dropped Interrupt (ISOOutDrop)<br>The controller sets this bit when it fails to write an isochronous OUT<br>packet into the RxFIFO because the RxFIFO does not have<br>enough space to accommodate a maximum packet size packet for<br>the isochronous OUT endpoint.<br>Values:<br>• 0x1 (ACTIVE): Isochronous OUT Packet Dropped Interrupt<br>• 0x0 (INACTIVE): Not active                                      |
| 13 | EnumDone    | Mode: Device only<br>Enumeration Done (EnumDone)<br>The core sets this bit to indicate that speed enumeration is<br>complete. The application must read the Device Status (DSTS)<br>register to obtain the enumerated speed.<br>Values:<br>• 0x1 (ACTIVE): Enumeration Done<br>• 0x0 (INACTIVE): Not active                                                                                                                             |
| 12 | USBRst      | USB Reset (USBRst)<br>The controller sets this bit to indicate that a reset is detected on the<br>USB.<br>Values:<br>• 0x1 (ACTIVE): USB Reset<br>• 0x0 (INACTIVE): Not active                                                                                                                                                                                                                                                          |
| 11 | USBSusp     | USB Suspend (USBSusp)<br>The controller sets this bit to indicate that a suspend was detected<br>on the USB. The controller enters the Suspended state when there<br>is no activity on the linestate signal for an extended period of time.<br>Values:<br>• 0x1 (ACTIVE): USB Suspend<br>• 0x0 (INACTIVE): Not Active                                                                                                                   |
| 10 | ErlySusp    | Early Suspend (ErlySusp)<br>The controller sets this bit to indicate that an Idle state has been<br>detected on the USB for 3 ms.<br>Values:<br>• 0x1 (ACTIVE): 3ms of Idle state detected<br>• 0x0 (INACTIVE): No Idle state detected                                                                                                                                                                                                  |
| 7  | GOUTNakEff  | <ul> <li>Global OUT NAK Effective (GOUTNakEff)</li> <li>Indicates that the Set Global OUT NAK bit in the Device Control register (DCTL.SGOUTNak), Set by the application, has taken effect in the core. This bit can be cleared by writing the Clear Global OUT NAK bit in the Device Control register (DCTL.CGOUTNak).</li> <li>Values:</li> <li>0x1 (ACTIVE): Global OUT NAK Effective</li> <li>0x0 (INACTIVE): Not Active</li> </ul> |



| 6 GINNakEff | Global IN Non-periodic NAK Effective (GINNakEff)<br>Indicates that the Set Global Non-periodic IN NAK bit in the Device<br>Control register (DCTL.SGNPInNak) set by the application, has<br>taken effect in the core. That is, the core has sampled the Global<br>IN NAK bit Set by the application. This bit can be cleared by<br>clearing the Clear Global Non-periodic IN NAK bit in the Device<br>Control register (DCTL.CGNPInNak). This interrupt does not<br>necessarily mean that a NAK handshake is sent out on the USB.<br>The STALL bit takes precedence over the NAK bit.<br>Values:                                                                                                                                                                                                                                                                            |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | <ul> <li>0x1 (ACTIVE): Set Global Non-periodic IN NAK bit</li> <li>0x0 (INACTIVE): Global Non-periodic IN NAK not active</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4 RxFLvl    | <ul> <li>RxFIFO Non-Empty (RxFLvl)</li> <li>Indicates that there is at least one packet pending to be read from the RxFIFO.</li> <li>Values:</li> <li>0x1 (ACTIVE): Rx Fifo is not empty</li> <li>0x0 (INACTIVE): Rx Fifo is empty</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3 Sof       | <ul> <li>Start of (micro)Frame (Sof)</li> <li>In Device mode, the controller sets this bit to indicate that an SOF token has been received on the USB. The application can read the Device Status register to get the current (micro) Frame number This interrupt is seen only when the core is operating at FS. This bit can be set only by the core and the application must write 1 to clear it.</li> <li>Note: This register may return 1'b1 if read immediately after power on reset. If the register bit reads 1'b1 immediately after power-or reset, it does not indicate that an SOF has been received. The read value of this interrupt is valid only after a valid connection between host and device is established. If the bit is set after power on reset the application can clear the bit.</li> <li>Values:</li> <li>0x1 (ACTIVE): Start of Frame</li> </ul> |

## 22.2.7 GINTMSK: Interrupt mask register

This register works with the Interrupt Register (GINTSTS) to interrupt the application. When an interrupt bit is masked, the interrupt associated with that bit is not generated. However, the GINTSTS register bit corresponding to that interrupt is still set.

| 31         | 30 29    | 28 | 27         | 26 25    | 24 | 23          | 22         | 21 20    | 19        | 18        | 17       | 16             | 15      | 14            | 13          | 12        | 11         | 10          | 98       | 7             | 6            | 5        | 4         | 3      | 2         | 1        | 0        |
|------------|----------|----|------------|----------|----|-------------|------------|----------|-----------|-----------|----------|----------------|---------|---------------|-------------|-----------|------------|-------------|----------|---------------|--------------|----------|-----------|--------|-----------|----------|----------|
| WkUpIntMsk | Reserved |    | LPM_IntMsk | Reserved |    | ResetDetMsk | FetSuspMsk | Reserved | OEPIntMsk | IEPIntMsk | EPMisMsk | RstrDoneIntMsk | EOPFMsk | ISOOutDropMsk | EnumDoneMsk | USBRstMsk | NSBSuspMsk | ErlySuspMsk | Reserved | GOUTNakEffMsk | GINNakEffMsk | Reserved | RxFLvIMsk | SofMsk | OTGIntMsk | peruesez | 50× 000× |
| 0          | -        |    | 0          | -        |    | 0           | 0          | -        | 0         | 0         | 0        | 0              | 0       | 0             | 0           | 0         | 0          | 0           | -        | 0             | 0            | -        | 0         | 0      | 0         | -        |          |
| RW         | -        |    | RW         | -        |    | RW          | RW         |          | RW        | RW        | RW       | RW             | RW      | RW            | RW          | RW        | RW         | RW          | •        | RW            | RW           | •        | RW        | RW     | RW        | •        |          |

#### GINTMSK =0x5000\_0018



| 31 | WkUpIntMsk     | Resume/Remote Wakeup Detected Interrupt Mask (WkUpIntMsk)<br>The WakeUp bit is used for LPM state wake up in a way similar to that<br>of wake up in suspend state.<br>Values:<br>• 0x0 (MASK): Resume or Remote Wakeup Detected Interrupt Mask<br>• 0x1 (NOMASK): Unmask Resume Remote Wakeup Detected Interrupt<br>Value After Reset: 0x0 |
|----|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27 | LPM_IntMsk     | LPM Transaction Received Interrupt (LPM_Int)<br>LPM Transaction received interrupt Mask<br>Values:<br>• 0x0 (MASK): LPM Transaction received interrupt Mask<br>• 0x1 (NOMASK): No LPM Transaction received interrupt Mask<br>Value After Reset: 0x0                                                                                        |
| 23 | ResetDetMsk    | Reset detected Interrupt Mask (ResetDetMsk)<br>Values:<br>• 0x0 (MASK): Reset detected Interrupt Mask<br>• 0x1 (NOMASK): No Reset detected Interrupt Mask<br>Value After Reset: 0x0                                                                                                                                                        |
| 22 | FetSuspMsk     | Data Fetch Suspended Mask (FetSuspMsk)<br>Values:<br>• 0x0 (MASK): Data Fetch Suspended Mask<br>• 0x1 (NOMASK): No Data Fetch Suspended Mask<br>Value After Reset: 0x0                                                                                                                                                                     |
| 19 | OEPIntMsk      | Mode: Device only<br>OUT Endpoints Interrupt Mask (OEPIntMsk)<br>Values:<br>• 0x0 (MASK): OUT Endpoints Interrupt Mask<br>• 0x1 (NOMASK): No OUT Endpoints Interrupt Mask<br>Value After Reset: 0x0                                                                                                                                        |
| 18 | IEPIntMsk      | Mode: Device only<br>IN Endpoints Interrupt Mask (IEPIntMsk)<br>Values:<br>• 0x0 (MASK): IN Endpoints Interrupt Mask<br>• 0x1 (NOMASK): No IN Endpoints Interrupt Mask<br>Value After Reset: 0x0                                                                                                                                           |
| 17 | EPMisMsk       | Mode: Device only<br>Endpoint Mismatch Interrupt Mask (EPMisMsk)<br>Values:<br>• 0x0 (MASK): Endpoint Mismatch Interrupt Mask<br>• 0x1 (NOMASK): No Endpoint Mismatch Interrupt Mask<br>Value After Reset: 0x0                                                                                                                             |
| 16 | RstrDoneIntMsk | Restore Done Interrupt Mask (RstrDoneIntMsk)<br>Values:<br>• 0x0 (MASK): Restore Done Interrupt Mask<br>• 0x1 (NOMASK): No Restore Done Interrupt Mask<br>Value After Reset: 0x0                                                                                                                                                           |
| 15 | EOPFMsk        | Mode: Device only<br>End of Periodic Frame Interrupt Mask (EOPFMsk)<br>Values:<br>• 0x0 (MASK): End of Periodic Frame Interrupt Mask<br>• 0x1 (NOMASK): No End of Periodic Frame Interrupt Mask<br>Value After Reset: 0x0                                                                                                                  |
| 14 | ISOOutDropMsk  | Mode: Device only<br>Isochronous OUT Packet Dropped Interrupt Mask (ISOOutDropMsk)<br>Values:<br>• 0x0 (MASK): Isochronous OUT Packet Dropped Interrupt Mask<br>• 0x1 (NOMASK): No Isochronous OUT Packet Dropped Interrupt Mask<br>Value After Reset: 0x0                                                                                 |



| 13 | EnumDoneMsk   | Mode: Device only<br>Enumeration Done Mask (EnumDoneMsk)<br>Values:<br>• 0x0 (MASK): Enumeration Done Mask                                                                                                                                     |
|----|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |               | • 0x1 (NOMASK): No Enumeration Done Mask<br>Value After Reset: 0x0                                                                                                                                                                             |
| 12 | USBRstMsk     | Mode: Device only<br>USB Reset Mask (USBRstMsk)<br>Values:<br>• 0x0 (MASK): USB Reset Mask<br>• 0x1 (NOMASK): No USB Reset Mask<br>Value After Reset: 0x0                                                                                      |
| 11 | USBSuspMsk    | Mode: Device only<br>USB Suspend Mask (USBSuspMsk)<br>Values:<br>• 0x0 (MASK): USB Suspend Mask<br>• 0x1 (NOMASK): No USB Suspend Mask<br>Value After Reset: 0x0                                                                               |
| 10 | ErlySuspMsk   | Mode: Device only<br>Early Suspend Mask (ErlySuspMsk)<br>Values:<br>• 0x0 (MASK): Early Suspend Mask<br>• 0x1 (NOMASK): No Early Suspend Mask<br>Value After Reset: 0x0                                                                        |
| 7  | GOUTNakEffMsk | Mode: Device only<br>Global OUT NAK Effective Mask (GOUTNakEffMsk)<br>Values:<br>• 0x0 (MASK): Global OUT NAK Effective Mask<br>• 0x1 (NOMASK): No Global OUT NAK Effective Mask<br>Value After Reset: 0x0                                     |
| 6  | GINNakEffMsk  | Mode: Device only,<br>Global Non-periodic IN NAK Effective Mask (GINNakEffMsk)<br>Values:<br>• 0x0 (MASK): Global Non-periodic IN NAK Effective Mask<br>• 0x1 (NOMASK): No Global Non-periodic IN NAK Effective Mask<br>Value After Reset: 0x0 |
| 4  | RxFLvIMsk     | Receive FIFO Non-Empty Mask (RxFLvIMsk)<br>Values:<br>• 0x0 (MASK): Receive FIFO Non-Empty Mask<br>• 0x1 (NOMASK): No Receive FIFO Non-Empty Mask<br>Value After Reset: 0x0                                                                    |
| 3  | SofMsk        | Start of (micro)Frame Mask (SofMsk)<br>Values:<br>• 0x0 (MASK): Start of Frame Mask<br>• 0x1 (NOMASK): No Start of Frame Mask<br>Value After Reset: 0x0                                                                                        |
| 2  | OTGIntMsk     | OTG Interrupt Mask (OTGIntMsk)<br>Values:<br>• 0x0 (MASK): OTG Interrupt Mask<br>• 0x1 (NOMASK): No OTG Interrupt Mask<br>Value After Reset: 0x0                                                                                               |



#### 22.2.8 GRXSTSR: Receive status debug read register

A read to GRXSTSR register returns the contents of the top of the Receive FIFO. A read to the Receive Status Read and Pop register additionally pops the top data entry out of the RxFIFO.

The core ignores the receive status pop/read when the receive FIFO is empty and returns a value of 32'h0000\_0000. The application must only pop the Receive Status FIFO when the Receive FIFO Non-Empty bit of the Core Interrupt register (GINTSTS.RxFLvI) is asserted.

NOTE: Do not read this register's reset value before configuring the core because the read value will be 'X' in the simulation.

|      |       |         |      |    |    |      |    |    |    |     |     |    |    |     |    |    |    |    |    |     |   | • |   |   | • |   |     | -** |   |
|------|-------|---------|------|----|----|------|----|----|----|-----|-----|----|----|-----|----|----|----|----|----|-----|---|---|---|---|---|---|-----|-----|---|
| 31 3 | 30 29 | 28 27 2 | 26 2 | 25 | 24 | 23 2 | 22 | 21 | 20 | 19  | 18  | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0 |
|      | Res   | served  |      |    |    | FN   | I  |    |    | Pkt | Sts |    | DF | PID |    |    |    |    | E  | 3Cn | t |   |   |   |   | 1 | ΞPN | lum | 1 |
|      |       | -       |      |    |    | 0    |    |    |    | 0   | )   |    | (  | )   |    |    |    |    |    | 0   |   |   |   |   |   |   | C   |     |   |
|      |       | •       |      |    |    | R    |    |    |    | F   | {   |    | F  | 2   |    |    |    |    |    | R   |   |   |   |   |   |   | R   |     |   |

GRXSTSR =0x5000 001C

| 24<br>21 | FN     | Mode: Device only<br>Frame Number (FN)<br>This is the least significant 4 bits of the (micro) Frame number in<br>which the packet is received on the USB. This field is supported<br>only when isochronous OUT endpoints are supported.<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20<br>17 | PktSts | Packet Status (PktSts)<br>Indicates the status of the received packet<br>• 4'b0001: Global OUT NAK (triggers an interrupt)<br>• 4'b0010: OUT data packet received<br>• 4'b0101: OUT transfer completed (triggers an interrupt)<br>• 4'b0100: SETUP transaction completed (triggers an interrupt)<br>• 4'b0110: SETUP data packet received<br>• Others: Reserved<br>Reset:4'h0<br>Values:<br>• 0x2 (INOUTDPRX): OUT data packet received<br>• 0x1 (OUTNAK): Global OUT NAK (triggers an interrupt)<br>• 0x4 (DSETUPCOM): SETUP transaction completed (triggers an<br>interrupt)<br>• 0x6 (DSETUPRX): SETUP data packet received<br>• 0x3 (INOUTTRCOM): IN or OUT transfer completed (triggers an<br>interrupt)<br>Value After Reset: 0x0 |
| 16<br>15 | DPID   | Data PID (DPID)<br>Indicates the Data PID of the received OUT data packet<br>• 2'b00: DATA0<br>• 2'b10: DATA1<br>• 2'b01: DATA2<br>• 2'b11: MDATA<br>Reset:2'h0<br>Values:<br>• 0x0 (DATA0): DATA0<br>• 0x3 (MDATA): MDATA<br>• 0x2 (DATA1): DATA1<br>• 0x1 (DATA2): DATA2<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                    |



| 14<br>4 | BCnt  | Byte Count (BCnt)<br>Indicates the byte count of the received data packet.<br>Value After Reset: 0x0                                |
|---------|-------|-------------------------------------------------------------------------------------------------------------------------------------|
| 3<br>0  | EPNum | Endpoint Number (EPNum)<br>Indicates the endpoint number to which the current received<br>packet belongs.<br>Value After Reset: 0x0 |

#### 22.2.9 GRXSTSP: Receive status read/pop register

A read to the GRXSTSP register returns the contents of the top of the Receive FIFO. A read to the Receive Status Read and Pop register additionally pops the top data entry out of the RxFIFO. The core ignores the receive status pop/read when the receive FIFO is empty and returns a value of 32'h0000\_0000. The application must only pop the Receive Status FIFO when the Receive FIFO Non-Empty bit of the Core Interrupt register (GINTSTS.RxFLvI) is asserted.

NOTE: Do not read this register's reset value before configuring the core because the read value is 'X' in the simulation.

#### GRXSTSR =0x5000\_001C

| 31 30 29 28 27 26 25 | 24 23 22 21 | 20 19 18 17 | 16 15 | 14 13 1 | 2 11 | 10 9 | 8  | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0 |
|----------------------|-------------|-------------|-------|---------|------|------|----|---|---|---|---|---|-----|-----|---|
| Reserved             | FN          | PktSts      | DPID  |         |      | BC   | nt |   |   |   |   | E | ΞPΝ | lum | ı |
| -                    | 0           | 0           | 0     |         |      | C    |    |   |   |   |   |   | C   | )   |   |
|                      | R           | R           | R     |         |      | F    |    |   |   |   |   |   | F   | {   |   |

| 24<br>21 | FN     | Mode: Device only<br>Frame Number (FN)<br>This is the least significant 4 bits of the (micro) Frame number in<br>which the packet is received on the USB. This field is supported<br>only when isochronous OUT endpoints are supported.<br>Value After Reset: 0x0                                                                                                                                                                                                                                                   |
|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20<br>17 | PktSts | Packet Status (PktSts)<br>Indicates the status of the received packet<br>• 4'b0001: Global OUT NAK (triggers an interrupt)<br>• 4'b0010: OUT data packet received<br>• 4'b0011: OUT transfer completed (triggers an interrupt)<br>• 4'b0100: SETUP transaction completed (triggers an interrupt)<br>• 4'b0110: SETUP data packet received<br>• Others: Reserved<br>Reset: 4'h0<br>Values:<br>• 0x0 (DATA0): DATA0<br>• 0x3 (MDATA): MDATA<br>• 0x2 (DATA1): DATA1<br>• 0x1 (DATA2): DATA2<br>Value After Reset: 0x0 |



| 16<br>15 | DPID | Data PID (DPID)<br>Indicates the Data PID of the received OUT data packet<br>• 2'b00: DATA0<br>• 2'b10: DATA1<br>• 2'b01: DATA2<br>• 2'b11: MDATA<br>Reset: 2'h0<br>Values:<br>• 0x0 (DATA0): DATA0<br>• 0x3 (MDATA): MDATA<br>• 0x2 (DATA1): DATA1<br>• 0x1 (DATA2): DATA2<br>Value After Reset: 0x0                                                  |
|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14<br>4  | BCnt | Byte Count (BCnt)<br>Indicates the byte count of the received data packet.<br>Value After Reset: 0x0                                                                                                                                                                                                                                                   |
| 3<br>0   | PNum | Endpoint Number (EPNum)<br>Indicates the endpoint number to which the current received<br>packet belongs.<br>Values:<br>• 0x2 (CHEP2): Channel or EndPoint 2<br>• 0x0 (CHEP0): Channel or EndPoint 0<br>• 0x3 (CHEP3): Channel or EndPoint 3<br>• 0x4 (CHEP4): Channel or EndPoint 4<br>• 0x1 (CHEP1): Channel or EndPoint 1<br>Value After Reset: 0x0 |

# 22.2.10 GRXFSIZ: Receive FIFO size register

The application can program the RAM size that must be allocated to the RxFIFO.

#### GRXSIZ =0x5000\_0024

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 | 10 9 8 7 6 5 4 3 2 1 0 |
|----------------------------------------------------------------|------------------------|
| Reserved                                                       | RxFDep                 |
| -                                                              | 0x200                  |
|                                                                | RW                     |

| 10 | RxFDep | RxFIFO Depth (RxFDep)                                                                            |
|----|--------|--------------------------------------------------------------------------------------------------|
| 0  |        | This value is in terms of 32-bit words.                                                          |
|    |        | • Minimum value is 16                                                                            |
|    |        | • Maximum value is 32,768                                                                        |
|    |        | The power-on reset value of this register is specified as the Largest                            |
|    |        | Rx Data FIFO Depth during configuration.                                                         |
|    |        | You can write a new value in this field. Programmed values mus<br>not exceed the power-on value. |



## 22.2.11 GNPTXFSIZ: Non-periodic transmit FIFO size register

The application can program the RAM size and the memory start address for the Non-periodic TxFIFO.

|                              |                  |                                                           |                                                                                            |                                                                     |                                                                    |                                                         |                                                   |                                   | (                                     | GNI                                       | РТХ                           | (FS                              | IZ =                     | :0x                    | 500        | 0_0                 | 028            |
|------------------------------|------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------|---------------------------------------------------|-----------------------------------|---------------------------------------|-------------------------------------------|-------------------------------|----------------------------------|--------------------------|------------------------|------------|---------------------|----------------|
| 31 30 29 28 27 26 25 24 23 2 | 22 21 20 19 18 1 | 17 16                                                     | 15 1                                                                                       | 4 13                                                                | 12                                                                 | 11                                                      | 10                                                | 9                                 | 8                                     | 7                                         | 6                             | 5                                | 4                        | 3                      | 2          | 1                   | 0              |
| INEPTxF0D                    | юр               |                                                           |                                                                                            |                                                                     |                                                                    |                                                         | IN                                                | IEP <sup>.</sup>                  | TxF                                   | <sup>:</sup> 0St                          | tAdo                          | dr                               |                          |                        |            |                     |                |
| 0x0040                       |                  |                                                           |                                                                                            |                                                                     |                                                                    |                                                         |                                                   | (                                 | )x02                                  | 200                                       | )                             |                                  |                          |                        |            |                     |                |
| RW                           |                  |                                                           |                                                                                            |                                                                     |                                                                    |                                                         |                                                   |                                   | RV                                    | Ν                                         |                               |                                  |                          |                        |            |                     |                |
|                              | EPTxF0Dep        | Thi<br>• M<br>• M<br>The<br>val<br>Th<br>coi<br>De<br>(pa | Endpo<br>s value<br>inimur<br>aximu<br>e appli<br>ues m<br>e pov<br>eCons<br>pth<br>ramete | e is in<br>n valu<br>m valu<br>catior<br>ust no<br>ver-on<br>sultan | term<br>ue is<br>ue is<br>n car<br>ot exe<br>n res<br>t co<br>G_T. | ns o<br>16<br>32,<br>n wr<br>ceec<br>set<br>nfig<br>X_D | f 32-l<br>768<br>ite a<br>d the<br>valu<br>uratio | nev<br>pow<br>ie o<br>on a<br>P_D | v va<br>ver-c<br>f th<br>as L<br>FIFC | s.<br>alue<br>on va<br>nis<br>_arg<br>O_D | in th<br>alue<br>field<br>est | his f<br>set<br>is<br>IN<br>TH_0 | in c<br>sp<br>Enc<br>0). | oreC<br>ecifi<br>Ipoir | Cons<br>ed | ulta<br>duri<br>IFO | nt.<br>ng<br>0 |
| 19 IN                        | EPTxF0StAddr     | Thi<br>Tra                                                | E<br>dress(<br>s field<br>ansmit<br>gramr                                                  | cont<br>FIFO                                                        | TxF0<br>tains<br># 0.                                              | )StA<br>the                                             | e mé                                              | emor                              | y st                                  | tart                                      |                               | lres                             | s fo                     |                        |            | -                   | art<br>int     |

## 22.2.12 GHWCFG1: User HW config1 register

#### GHWCFG1=0x5000\_0032

|    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |     |    |    |    |    |    |   |   | - |   |   | - · | • |   |   |   |
|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|-----|---|---|---|---|
| 31 | 3( | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 3 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3 | 2 | 1 | 0 |
|    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |     |   |   |   |   |
|    |    |    |    |    |    |    |    |    |      |    |    |    |    |    | Ep | Dir |    |    |    |    |    |   |   |   |   |   |     |   |   |   |   |
|    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |     |   |   |   |   |
|    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |     |   |   |   |   |
|    |    |    |    |    |    |    |    |    |      |    |    |    |    |    | (  | )   |    |    |    |    |    |   |   |   |   |   |     |   |   |   |   |
|    |    |    |    |    |    |    |    |    |      |    |    |    |    |    | F  | {   |    |    |    |    |    |   |   |   |   |   |     |   |   |   |   |
|    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |     |   |   |   |   |
|    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |     |   |   |   |   |

| 2'b11: Reserved |
|-----------------|
|-----------------|



# 22.2.13 GHWCFG2: User HW config2 register

#### GHWCFG2=0x5000\_0048

| 31 30 29 28 27 26 25 24 23 22 21 20 | 19            | 18 17 | ′ 16     | 15 14 | 1 13 | 12 11     | 10 | 9 | 8         | 7 | 6 | 5 | 4        | 3 | 2 | 1 | 0 |
|-------------------------------------|---------------|-------|----------|-------|------|-----------|----|---|-----------|---|---|---|----------|---|---|---|---|
| Reserved                            | DynFifoSizing |       | Reserved |       |      | NumDevEps |    |   | гагиутуре |   |   |   | Decented |   |   |   |   |
| -                                   | 1             |       | -        |       |      | 0x4       |    |   | 1         |   |   |   | -        |   |   |   |   |
|                                     | R             |       |          |       |      | R         |    | F | 2         |   |   |   |          |   |   |   |   |

| 19       | DynFifoSizing | Dynamic FIFO Sizing Enabled (DynFifoSizing)<br>• 1'b0: No<br>• 1'b1: Yes<br>Values:<br>• 0x0 (DISABLED): Dynamic FIFO Sizing Disabled<br>• 0x1 (ENABLED): Dynamic FIFO Sizing Enabled                                                                                                                              |
|----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13<br>10 | NumDevEps     | Number of Device Endpoints (NumDevEps)<br>Indicates the number of device endpoints supported by the core.<br>The range of this field is 0-4.<br>Values:<br>• 0x1 (ENDPT1): End point 1<br>• 0x4 (ENDPT4): End point 4<br>• 0x0 (ENDPT0): End point 0<br>• 0x2 (ENDPT2): End point 2<br>• 0x3 (ENDPT3): End point 3 |
| 9<br>8   | FSPhyType     | Full-Speed PHY Interface Type (FSPhyType)<br>• 2'b01: Dedicated full-speed interface<br>Values:<br>• 0x1 (FS): Dedicated full-speed interface is supported<br>Value After Reset: 2'b01                                                                                                                             |

# 22.2.14 GHWCFG3: User HW config2 register

#### GHWCFG3=0x5000\_004C

|      |       |    |    |    |    |            |     |    |    |    |    |    |    |    |        |           |          |         |    |          |   |   |   |              |   |   |              | - |
|------|-------|----|----|----|----|------------|-----|----|----|----|----|----|----|----|--------|-----------|----------|---------|----|----------|---|---|---|--------------|---|---|--------------|---|
| 31 3 | 30 29 | 28 | 27 | 26 | 25 | 24         | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15     | 14        | 13 12    | 11      | 10 | 9        | 8 | 7 | 6 | 5            | 4 | 3 | 2            | 1 |
|      |       |    |    |    |    | DfifoDanth |     |    |    |    |    |    |    |    | PMMMde | BCSupport | Reserved | RstType |    | Decented |   |   |   | PktSizeWidth |   |   | XferSizeWidt | ۲ |
|      |       |    |    |    | 0  | x0         | 1D8 |    |    |    |    |    |    |    | 0      | 1         | -        | 0       |    | -        | • |   |   | 0x6          |   |   | 0x           | 8 |
|      |       |    |    |    |    | R          |     |    |    |    |    |    |    |    | R      | R         |          | R       |    |          |   |   |   | R            |   |   | R            |   |

| 31<br>16 | DfifoDepth | DFIFO Depth (DfifoDepth – EP_LOC_CNT)<br>This value is in terms of 32-bit words.<br>• Minimum value is 32<br>• Maximum value is 32,768 |  |
|----------|------------|----------------------------------------------------------------------------------------------------------------------------------------|--|
| 15       | LPMMode    | LPM mode specified for Mode of Operation.<br>Values:<br>• 0x0 (DISABLED): LPM disabled<br>• 0x1 (ENABLED): LPM enabled                 |  |



| 14     | BCSupport     | This bit indicates the controller support for Battery Charger.<br>• 0 – No Battery Charger Support<br>• 1 – Battery Charger support present<br>Values:<br>• 0x0 (DISABLED): No Battery Charger Support<br>• 0x1 (ENABLED): Battery Charger Support present                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11     | RstType       | Reset Style for Clocked always Blocks in RTL (RstType)<br>• 1'b0: Asynchronous reset is used in the controller<br>• 1'b1: Synchronous reset is used in the controller<br>Values:<br>• 0x0 (ASYNCRST): Asynchronous reset is used in the core<br>• 0x1 (SYNCRST): Synchronous reset is used in the core                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6<br>4 | PktSizeWidth  | Width of Packet Size Counters (PktSizeWidth)<br>• 3'b000: 4 bits<br>• 3'b011: 5 bits<br>• 3'b010: 6 bits<br>• 3'b101: 7 bits<br>• 3'b100: 8 bits<br>• 3'b101: 9 bits<br>• 3'b101: 9 bits<br>• 3'b110: 10 bits<br>• Others: Reserved<br>Values:<br>• 0x2 (BITS6): Width of Packet Size Counter 6<br>• 0x1 (BITS6): Width of Packet Size Counter 5<br>• 0x6 (BITS6): Width of Packet Size Counter 10<br>• 0x5 (BITS9): Width of Packet Size Counter 7<br>• 0x4 (BITS7): Width of Packet Size Counter 7<br>• 0x4 (BITS8): Width of Packet Size Counter 8<br>• 0x0 (BITS4): Width of Packet Size Counter 4                                                                                                                                                                                                                                             |
| 3<br>0 | XferSizeWidth | <ul> <li>Width of Transfer Size Counters (XferSizeWidth)</li> <li>4'b0000: 11 bits</li> <li>4'b0001: 12 bits</li> <li>4'b1000: 19 bits</li> <li>Others: Reserved</li> <li>Values:</li> <li>0x2 (WIDTH13): Width of Transfer Size Counter 13 bits</li> <li>0x3 (WIDTH14): Width of Transfer Size Counter 14 bits</li> <li>0x1 (WIDTH12): Width of Transfer Size Counter 12 bits</li> <li>0x8 (WIDTH19): Width of Transfer Size Counter 11 bits</li> <li>0x8 (WIDTH19): Width of Transfer Size Counter 11 bits</li> <li>0x7 (WIDTH11): Width of Transfer Size Counter 11 bits</li> <li>0x7 (WIDTH18): Width of Transfer Size Counter 18 bits</li> <li>0x6 (WIDTH17): Width of Transfer Size Counter 17 bits</li> <li>0x5 (WIDTH16): Width of Transfer Size Counter 16 bits</li> <li>0x4 (WIDTH15): Width of Transfer Size Counter 15 bits</li> </ul> |



# 22.2.15 GHWCFG4: User hardware config4 register

#### GHWCFG4=0x5000\_0050

|         | 0.0           |            |    | 05 01         | 00 00    | 4 00  | 40 1      | 0.4- | 4.0                                                | 45 4                                                                                                                                                                                                                                                                                             | 40                                            | 40                                   |                              |                          |                                 | -                       | ~                  |              |       | _             |     | _    |   |
|---------|---------------|------------|----|---------------|----------|-------|-----------|------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--------------------------------------|------------------------------|--------------------------|---------------------------------|-------------------------|--------------------|--------------|-------|---------------|-----|------|---|
| 31      |               | 29 28 27 2 | 26 | 25 24         | 23 22 2  | 21 20 | 19 1      | 8 17 | 16                                                 | 15 14                                                                                                                                                                                                                                                                                            | 13                                            | 12 1                                 | 1 1                          | ) 9                      | 8                               | 7                       | 6                  | 5            | 4     | 3             | 2   | 1    | 0 |
| DescDMA | DescDMAEnable | INEps      |    |               | Reserved |       | NumCtlEps |      | Reserved                                           |                                                                                                                                                                                                                                                                                                  |                                               |                                      |                              |                          |                                 | Hibernation             | AhbFreq            | PartialPwrDn |       | NumDevPerioEp | S   |      |   |
| 1       | 1             | 0x4        |    |               | -        |       |           | 0    |                                                    |                                                                                                                                                                                                                                                                                                  |                                               |                                      | -                            |                          |                                 |                         | 0                  | 1            | 1     |               | 0   |      |   |
| R       | R             | R          |    |               | •        |       |           | R    |                                                    |                                                                                                                                                                                                                                                                                                  |                                               |                                      | -                            |                          |                                 |                         | R                  | R            | R     |               | R   |      |   |
|         |               |            |    | 31            | DescDM   | ЛА    |           |      | • 1'b<br>• 1'b<br>Valu<br>• 0x(                    | tter/Ga<br>00: Non<br>01: Dyn<br>1es:<br>0 (CON<br>1 (CON                                                                                                                                                                                                                                        | Dyna<br>amic<br>IFIG1                         | amic<br>confi<br>I): No              | confi<br>gurat<br>n Dy       | gurat<br>ion<br>nami     | ion<br>c con                    |                         |                    | 'n           |       |               |     |      |   |
|         |               |            |    | 30            | DescD    | /AEna | bled      |      | Scat<br>• 1'b<br>• 1'b<br>Valu<br>• 0x(            | tter/Ga<br>0: Non<br>01: Sca                                                                                                                                                                                                                                                                     | ther [<br>-Scat<br>tter/G                     | DMA of<br>tter/G<br>Gather<br>): Nor | config<br>athe<br>DM         | gurati<br>r DM/<br>A cor | ion<br>A con<br>figura<br>Gathe | nfigu<br>atior<br>ər Dl | ratic<br>n<br>MA ( | confi        |       | ation         |     |      |   |
|         |               |            |    | 29<br>26      |          |       |           |      |                                                    | Number of Device Mode IN Endpoints Including Control Endpoints<br>(INEps)<br>• 0: 1 IN Endpoint<br>• 1: 2 IN Endpoints<br><br>• 4: 5 IN Endpoints<br>Values:<br>• 0x0 (ENDPT1): In Endpoint 1<br>• 0x1 (ENDPT2): In Endpoint 2<br>• 0x2 (ENDPT3): In Endpoint 3<br>• 0x3 (ENDPT4): In Endpoint 4 |                                               |                                      |                              |                          |                                 |                         |                    |              |       | 8             |     |      |   |
|         |               |            |    | 19<br>16      | NumCtl   | Eps   |           |      | Num<br>0 (N<br>Ran<br>Valu<br>• 0x<br>• 0x<br>• 0x | nber of<br>lumCtl<br>ge: 0-4                                                                                                                                                                                                                                                                     | Devid<br>Eps)<br>PT1)<br>PT4)<br>PT0)<br>PT2) | : End<br>: End<br>: End<br>: End     | poin<br>poin<br>poin<br>poin | t 1<br>t 4<br>t 0<br>t 2 | ol Enc                          | 1poir                   | nts ii             | n Ad         | ditio | n to          | End | poin | t |
|         |               |            | (  | 6 Hibernation |          |       |           |      | • 1'b<br>• 1'b<br>Valu<br>• 0x(                    | ble Hib<br>0: Hibe<br>01: Hibe<br>les:<br>0 (DISA<br>1 (ENA                                                                                                                                                                                                                                      | ernati<br>ernati<br>\BLE                      | on fea<br>on fea<br>D): H            | ature<br>ature<br>ibern      | not e<br>enat<br>ation   | enabl<br>bled<br>featu          | ure c                   |                    |              |       |               |     |      |   |



| 5      | AhbFreq        | Minimum AHB Frequency Less Than 60 MHz (AhbFreq)<br>• 1'b0: No<br>• 1'b1: Yes<br>Values:<br>• 0x0 (DISABLED): Minimum AHB Frequency More Than 60 MHz<br>• 0x1 (ENABLED): Minimum AHB Frequency Less Than 60 MHz                     |
|--------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4      | PartialPwrDn   | Enable Partial Power Down (PartialPwrDn)<br>• 1'b0: Partial Power Down Not Enabled<br>• 1'b1: Partial Power Down Enabled<br>Values:<br>• 0x0 (DISABLED): Partial Power Down disabled<br>• 0x1 (ENABLED): Partial Power Down enabled |
| 3<br>0 | NumDevPerioEps | Number of Device Mode Periodic IN Endpoints<br>(NumDevPerioEps)<br>Range: 0-15                                                                                                                                                      |

# 22.2.16 GLPMCFG: LPM config register

#### GLPMCFG =0x5000\_0054

| 31 | 30       | 29                | 28         | 27 | 26               | 25 | 24       | 23 | 22            | 21 | 20 | 19 | 18       | 17 | 16         | 15     | 14          | 13          | 12 | 11 | 10                | 9 | 8 | 7        | 6           | 5 | 4 | 3    | 2 | 1        | 0      |
|----|----------|-------------------|------------|----|------------------|----|----------|----|---------------|----|----|----|----------|----|------------|--------|-------------|-------------|----|----|-------------------|---|---|----------|-------------|---|---|------|---|----------|--------|
|    | Reserved | LPM_RestoreSlpSts | LPM_EnBESL |    | LPM_RetryCnt_Sts |    | Reserved |    | LPM_Retry_Cnt |    |    |    | Keserved |    | L1ResumeOK | SIpSts | Corol 1 Doo | שבו<br>- בי |    |    | <b>HIRD_Thres</b> |   |   | EnblSlpM | bRemoteWake |   |   | חצוע |   | AppL1Res | LPMCap |
|    | 1        | 0                 | 0          |    | 0                |    | -        |    | 0             |    |    |    | -        |    | 0          | 0      | (           | )           |    |    | 0                 |   |   | 0        | 0           |   | ( | )    |   | 0        | 0      |
|    | •        | RW                | RW         |    | R                |    | •        |    | RW            |    |    |    | -        |    | R          | R      | F           | {           |    |    | RW                |   |   | RW       | R           |   | F | ۲    |   | RW       | RW     |

| 20 | DM Destare She Sta | L DM Dectors Sleep Status (LDM, Dectors SinSta)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29 | LPM_RestoreSlpSts  | <ul> <li>LPM Restore Sleep Status (LPM_RestoreSlpSts)</li> <li>When the application power gates the core (Partial Power Down /<br/>Hibernation) the application needs to program this bit to restore<br/>the LPM status in the core.</li> <li>The application needs to program this bit, during restore process,<br/>based on whether it had decided to go into Shallow Sleep (Clock<br/>Gating Only) or Deep Sleep (Power Gating) based on the BESL<br/>value received from the Host</li> <li>1'b0: The application puts the core in Shallow Sleep based on<br/>BESL value from the Host</li> <li>1'b1: The application puts the core in Deep Sleep based on<br/>BESL value from the Host</li> <li>0x0 (DISABLED): Puts the core in Shallow Sleep mode based<br/>on the BESL value from the Host</li> <li>0x1 (ENABLED): Puts the core in Deep Sleep mode based on<br/>the BESL value from the Host</li> </ul> |
| 28 | LPM_EnBESL         | LPM Enable BESL (LPM_EnBESL)<br>This bit enables the BESL feature as defined in LPM Errata<br>• 1'b0: The core works as per USB 2.0 Link Power Management<br>Addendum Engineering Change Notice to the USB 2.0<br>specification as of July 16, 2007<br>• 1'b1: The core works as per the LPM Errata<br>Values:<br>• 0x0 (DISABLED): BESL is disabled<br>• 0x1 (ENABLED): BESL is enabled as defined in LPM Errata<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |



| 27<br>25 | LPM_RetryCnt_Sts | LPM Retry Count Status (LPM_RetryCnt_Sts)<br>Number of LPM Host Retries still remaining to be transmitted for<br>the current LPM sequence.<br>Values:<br>• 0x3 (RETRY_REM3): Three LPM retries remaining<br>• 0x4 (RETRY_REM4): Four LPM retries remaining<br>• 0x2 (RETRY_REM2): Two LPM retries remaining<br>• 0x1 (RETRY_REM2): One LPM retries remaining<br>• 0x6 (RETRY_REM6): Six LPM retries remaining<br>• 0x5 (RETRY_REM6): Six LPM retries remaining<br>• 0x7 (RETRY_REM5): Five LPM retries remaining<br>• 0x0 (RETRY_REM7): Seven LPM retries remaining<br>• 0x0 (RETRY_REM0): Zero LPM retries remaining<br>Value After Reset: 0x0                                                                                                                                                                               |
|----------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23<br>21 | LPM_Retry_Cnt    | LPM Retry Count (LPM_Retry_Cnt)<br>Number of additional LPM retries that the HOST would perform if<br>the Device Response was an ERROR until a valid device<br>response is received (STALL/NYET/ACK).<br>Values:<br>• 0x3 (RETRY3): Three LPM retries<br>• 0x1 (RETRY1): One LPM retry<br>• 0x2 (RETRY2): Two LPM retries<br>• 0x0 (RETRY0): Zero LPM retries<br>• 0x7 (RETRY7): Seven LPM retries<br>• 0x4 (RETRY4): Four LPM retries<br>• 0x6 (RETRY6): Six LPM retries<br>• 0x5 (RETRY5): Five LPM retries<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                       |
| 16       | L1ResumeOK       | <ul> <li>Sleep State Resume OK (L1ResumeOK)</li> <li>Indicates that the application or host can start resume from Sleep state. This bit is valid in LPM sleep (L1) state. It is set in sleep mode after a delay of 50 micro sec (TL1Residency). The bit is reset when SlpSts is 0.</li> <li>1'b0: The application/core cannot start resume from Sleep state.</li> <li>1'b1: The application/core can start resume from Sleep state. Values:</li> <li>0x0 (NOTOK): The application/core can start Resume from Sleep state</li> <li>0x1 (OK): The application/core can start Resume from Sleep state</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                 |
| 15       | SlpSts           | <ul> <li>Port Sleep Status (SlpSts)</li> <li>This bit is set as long as a Sleep condition is present on the USB bus.</li> <li>The core enters the Sleep state when an ACK response is sent to an LPM transaction and the expiry of timer TL1TokenRetry.</li> <li>The core comes out of sleep:</li> <li>When there is any activity on the USB line_state</li> <li>When the application writes to the Remote Wakeup Signaling bit in the Device Control register (DCTL.RmtWkUpSig) or when the application resets or soft-disconnects the device.</li> <li>Values:</li> <li>0x1 (CORE_IN_L1): In Device mode, the core enters the Sleep state when an ACK response is sent to an LPM transaction</li> <li>0x0 (CORE_NOT_IN_L1): In Device mode, this bit indicates core is not in L1</li> <li>Value After Reset: 0x0</li> </ul> |



| 14<br>13 | CoreL1Res   | LPM response (CoreL1Res)<br>The response of the core to LPM transaction received is reflected<br>in these two bits.<br>Values:<br>• 0x0 (LPMRESP1): ERROR : No handshake response<br>• 0x1 (LPMRESP2): STALL response<br>• 0x2 (LPMRESP3): NYET response<br>• 0x3 (LPMRESP4): ACK response<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                               |
|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12<br>8  | HIRD_Thres  | <ul> <li>BESL/HIRD Threshold (HIRD_Thres)</li> <li>EnBESL = 1'b0: The core puts the PHY into deep low power mode in L1 (by core asserting L1SuspendM) when HIRD value is greater than or equal to the value defined in this field HIRD_Thres[3:0] and HIRD_Thres[4] is set to 1b1.</li> <li>EnBESL = 1'b1: The core puts the PHY into deep low power mode in L1 (by core asserting L1SuspendM) when BESL value is greater than or equal to the value defined in this field BESL_Thres[3:0] and BESL_Thres [4] is set to 1'b1.</li> <li>Value After Reset: 0x0</li> </ul>                                                           |
| 7        | EnblSlpM    | <ul> <li>Enable utmi_sleep_n (EnblSlpM)</li> <li>The application uses this bit to control utmi_sleep_n assertion to the PHY in the L1 state.</li> <li>1'b0: utmi_sleep_n assertion from the core is not transferred to the external PHY.</li> <li>1'b1: utmi_sleep_n assertion from the core is transferred to the external PHY when utmi_l1_suspend_n cannot be asserted. Values:</li> <li>0x0 (DISABLED): utmi_sleep_n assertion from the core is not transferred to the external PHY</li> <li>0x1 (ENABLED): utmi_sleep_n assertion from the core is transferred to the external PHY</li> <li>Value After Reset: 0x0</li> </ul> |
| 6        | bRemoteWake | RemoteWakeEnable (bRemoteWake)<br>This field is read only. It is updated with the Received LPM Toker<br>bRemoteWake bmAttribute when an ACK/NYET/STALL<br>response is sent to an LPM transaction.<br>Values:<br>• 0x0 (DISABLED): Remote Wakeup is disabled<br>• 0x1 (ENABLED): In device mode, this field takes the value of<br>remote wake up<br>Value After Reset: 0x0                                                                                                                                                                                                                                                          |
| 5<br>2   | HIRD        | <ul> <li>Host-Initiated Resume Duration (HIRD)</li> <li>EnBESL = 1'b0</li> <li>Host Initiated Resume Duration.</li> <li>This field is read only and is updated with the Received LPM Token HIRD bmAttribute when an ACK/NYET/STALL response is sent to an LPM transaction.</li> <li>EnBESL = 1'b1</li> <li>Best Effort Service Latency (BESL).</li> <li>This field is updated with the Received LPM Token BESL bmAttribute when an ACK/NYET/STALL response is sent to an LPM transaction.</li> </ul>                                                                                                                               |



| 1 | AppL1Res | LPM response programmed by application (AppL1Res)<br>Handshake response to LPM token pre-programmed by device<br>application software. The response depends on<br>GLPMCFG.LPMCap. If GLPMCFG.LPMCap is 1'b0, the core<br>always responds with a NYET. If GLPMCFG.LPMCap is 1'b1, the<br>core responds as follows:<br>• 1: ACK<br>Even though an ACK is pre-programmed, the core responds with<br>an ACK only on a successful LPM transaction. The LPM<br>transaction is successful if:<br>•There are no PID/CRC5 errors in both the EXT token and the<br>LPM token (else ERROR)<br>•A valid bLinkState = 0001B (L1) is received in the LPM<br>transaction (else STALL)<br>•No data is pending in the Transmit queue (else NYET)<br>•0: NYET<br>The pre-programmed software bit is overridden for response to<br>LPM token when:<br>•The received bLinkState is not L1 (STALL response)<br>•An error is detected in either of the LPM token packets due to<br>corruption (ERROR response).<br>Values: |
|---|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |          | <ul> <li>• 0x1 (ACK_RESP): The core responds with an ACK only on a successful LPM transaction</li> <li>• 0x0 (NYET_RESP): The core responds with a NYET when an error is detected in either of the LPM token packets due to corruption</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0 | LPMCap   | LPM-Capable (LPMCap)<br>The application uses this bit to control the controller LPM<br>capabilities. If the core operates as a non-LPM-capable host, it<br>cannot request the connected device/hub to activate LPM mode.<br>If the core operates as a non-LPM-capable device, it cannot<br>respond to any LPM transactions.<br>• 1'b0: LPM capability is not enabled.<br>• 1'b1: LPM capability is enabled.<br>Values:<br>• 0x0 (DISABLED): LPM capability is not enabled<br>• 0x1 (ENABLED): LPM capability is enabled<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                    |



# 22.2.17 GPWRDN: Global power down register

#### GPWRDN =0x5000\_0058

| 24 22 22    | 00.07.00.05.04                    | 00       | 00       | 0.4      | 00.40     | 40            | 47                                                 | 4045                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 4.4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 40                                                                                                                                                                                                                    | 40                                                                                                           | 44                                                                              | 40                                                                                              | <u>^</u>                                                                                                | 0                                                                                  | 7                                                                               | 0                                                  |                                        |                               |             |         | <u></u>      |    |
|-------------|-----------------------------------|----------|----------|----------|-----------|---------------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------------------|----------------------------------------|-------------------------------|-------------|---------|--------------|----|
| 31 30 29    | 28 27 26 25 24                    | 23       | 22       | 21       | 20 19     |               | 17                                                 | 16 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 13                                                                                                                                                                                                                    |                                                                                                              |                                                                                 | 10                                                                                              | 9                                                                                                       | 8<br>0                                                                             | 7                                                                               | 6                                                  | 5                                      | 4                             | 3           | 2       | 1            | 0  |
| Reserved    | MultValIdBC                       | Reserved | BsessVld | Reserved | LineState | StsChngIntMsk | Reserved                                           | ConnDetMsk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ConnectDet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | DisconnectDetect                                                                                                                                                                                                      | DisconnectDetect                                                                                             | ResetDetMsk                                                                     | ResetDetected                                                                                   | LineStageChange                                                                                         | LnStsChng                                                                          | Reserved                                                                        | PwrDnSwtch                                         | PwrDnRst_n                             | PwrDnClmp                     | Restore     | PMUActv | PMUIntSel    |    |
| -           | 0                                 | -        | 0        | -        | 0         | 0             | 0                                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                     | 0                                                                                                            | 0                                                                               | 0                                                                                               | 0                                                                                                       | 0                                                                                  | 0                                                                               | -                                                  | 0                                      | 0                             | 0           | 0       | 0            | 0  |
| -           | R                                 | -        | R        | -        | R         | RW            | RW                                                 | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW                                                                                                                                                                                                                    | RW                                                                                                           | RW                                                                              | RW                                                                                              | RW                                                                                                      | RW                                                                                 | RW                                                                              | -                                                  | RW                                     | RW                            | RW          | RW      | RW           | RW |
|             | 28                                | 1        |          |          | /alldBC   |               |                                                    | Mult\<br>Batte<br>• Bit :<br>• Oxto<br>• Ox | ery C<br>26 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - 225 - | harg<br>rid_1<br>rid_i<br>rid_i<br>rid_i<br>rid_i<br>rid_i<br>rid_i<br>s ari<br>eser<br>D_A<br>D_1<br>i<br>S_0)<br>D_1<br>i<br>D_1<br>i<br>S_0)<br>C_0<br>C_0<br>C_0<br>C_0<br>C_0<br>C_0<br>C_0<br>C_0<br>C_0<br>C_0 | float<br>gnd<br>a<br>b<br>c<br>e pre<br>ved a<br>: OT<br>ND): OT<br>-B=1<br>C_RII<br>I RID<br>I RID<br>I RID | eseni<br>and \<br>)_GN<br>G de<br>ID_(<br>G de<br>RID_<br>L anc<br>D_FL<br>G de | t onl<br>will r<br>ND):<br>vice<br>evice<br>OTG<br>evice<br>FLO<br>d RIE<br>LOA<br>OAT<br>evice | y if I<br>ead<br>OT(<br>e as /<br>e as /<br>DTG<br>as E<br>pin<br>∈ as I<br>AT):<br>C_FL<br>T): C<br>=1 | 3C_3<br>5'h0<br>G de<br>A-de<br>pin is<br>3-de<br>is gr<br>3-de<br>OT<br>OT<br>OTG | SUP<br>evice<br>evice<br>s floa<br>vice<br>ounc<br>vice,<br>iG c<br>I=1<br>devi | POR<br>as<br>ating<br>led<br>can<br>levic<br>ce as | RT =<br>A-de<br>not c<br>e a:<br>s B-c | 1. C<br>evice<br>conn<br>s B· | ect<br>devi | D_A     | =1 a<br>canr | nd |
|             | 22 BsessVld<br>20 LineState<br>19 |          |          |          |           |               |                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <ul> <li>B Session Valid (BsessVld)</li> <li>This field reflects the B session valid status signal from the PHY.</li> <li>1'b0: B-Valid is 0.</li> <li>1'b1: B-Valid is 1.</li> <li>This bit is valid only when GPWRDN.PMUActv is 1.</li> <li>Values:</li> <li>0x0 (NOTVALID): B_Valid is 0</li> <li>0x1 (VALID): B_Valid is 1</li> <li>Value After Reset: 0x0</li> <li>LineState</li> <li>This field indicates the current linestate on USB as seen by the PMU module.</li> <li>2'b00: DM = 0, DP = 0.</li> <li>2'b01: DM = 0, DP = 1.</li> <li>2'b11: Not-defined.</li> <li>This bit is valid only when GPWRDN.PMUActv is 1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                       |                                                                                                              |                                                                                 |                                                                                                 |                                                                                                         |                                                                                    |                                                                                 |                                                    |                                        | ΠU                            |             |         |              |    |
| •<br>•<br>• |                                   |          |          |          |           |               | Value<br>• 0x0<br>• 0x2<br>• 0x1<br>• 0x3<br>Value | (LS<br>(LS<br>(LS<br>(LS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3): L<br>2): L<br>4): L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | inest<br>inest<br>inest                                                                                                                                                                                               | ate o<br>ate o<br>ate o                                                                                      | on U<br>on U<br>on U                                                            | SB:<br>SB:                                                                                      | DM<br>DM                                                                                                | = 1,  <br>= 0,                                                                     | DP =<br>DP =                                                                    | = 0                                                |                                        |                               |             |         |              |    |



| 18 | StsChngIntMsk           | StsChngIntMsk<br>Mask for StsChng Interrupt<br>Values:<br>• 0x1 (MASK): Mask for Status Change Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |                         | <ul> <li>0x0 (NOMASK): No Status Change Interrupt Mask<br/>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 17 | StsChngInt              | <ul> <li>Status Change Interrupt (StsChngInt)</li> <li>This field indicates a status change in either the IDDIG or BsessVld signal.</li> <li>1'b0: No Status change</li> <li>1'b1: Status change detected</li> <li>After receiving this interrupt the application should read the GPWRDN register and interpret the change in BsesVld with respect to the previous value stored by the application.</li> <li>Values:</li> <li>0x0 (DISABLED): No Status change</li> <li>0x1 (ENABLED): Status change detected</li> </ul> |
| 14 | ConnDetMsk              | ConnDetMsk<br>Mask for ConnectDet interrupt<br>Values:<br>• 0x1 (MASK): Mask for ConnectDet Interrupt<br>• 0x0 (NOMASK): No ConnectDet Interrupt Mask<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                          |
| 13 | ConnectDet              | ConnectDet<br>This field indicates that a new connect has been detected<br>• 1'b0: Connect not detected<br>• 1'b1: Connect detected<br>Values:<br>• 0x0 (DISABLED): Connect not detected<br>• 0x1 (ENABLED): Connect detected<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                  |
| 12 | DisconnectDetect<br>Msk | DisconnectDetectMsk<br>Mask For DisconnectDetect Interrupt<br>Values:<br>• 0x1 (MASK): Mask for DisconnectDetect Interrupt<br>• 0x0 (NOMASK): No DisconnectDetect Interrupt Mask<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                               |
| 11 | DisconnectDetect        | DisconnectDetect<br>This field indicates that Disconnect has been detected by the PMU.<br>This field generates an interrupt. After detecting disconnect during<br>hibernation the application must not restore the core, but instead start<br>the initialization process.<br>• 1'b0: Disconnect not detected<br>• 1'b1: Disconnect detected<br>Values:<br>• 0x0 (DISABLED): Disconnect not detected<br>• 0x1 (ENABLED): Disconnect detected<br>Value After Reset: 0x0                                                    |
| 10 | ResetDetMsk             | ResetDetMsk<br>Mask for ResetDetected interrupt<br>Values:<br>• 0x1 (MASK): Mask for ResetDetect Interrupt<br>• 0x0 (NOMASK): No ResetDetect Interrupt Mask<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                    |



| 9 | ResetDetected          | ResetDetected<br>This field indicates that Reset has been detected by the PMU module.<br>This field generates an interrupt.<br>• 1'b0: Reset Not Detected<br>• 1'b1: Reset Detected<br>Values:<br>• 0x0 (DISABLED): Reset not detected<br>• 0x1 (ENABLED): Reset detected<br>Value After Reset: 0x0                                                                                                                                                                           |
|---|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8 | LineStageChange<br>Msk | LineStageChangeMsk<br>Mask for LineStateChange interrupt.<br>Values:<br>• 0x1 (MASK): Mask for LineStateChange Interrupt<br>• 0x0 (NOMASK): No LineStateChange Interrupt Mask<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                       |
| 7 | LnStsChng              | Line State Change (LnStsChng)<br>This interrupt is asserted when there is a Linestate Change detected<br>by the PMU. The application should read GPWRDN.Linestate to<br>determine the current linestate on USB.<br>• 1'b0: No LineState change on USB<br>• 1'b1: LineState change on USB<br>This bit is valid only when GPWRDN.PMUActv is 1.<br>Values:<br>• 0x0 (DISABLED): No LineState change on USB<br>• 0x1 (ENABLED): LineState change on USB<br>Value After Reset: 0x0 |
| 5 | PwrDnSwtch             | Power Down Switch (PwrDnSwtch)<br>This bit indicates to the controller whether the VDD switch is in<br>ON/OFF state.<br>• 1'b0: The controller is in ON state<br>• 1'b1: The controller is in OFF state<br>Note: This bit must not be written to during normal mode of operation.<br>Values:<br>• 0x1 (OFF): The controller is in OFF state<br>• 0x0 (ON): The controller is in ON state<br>Value After Reset: 0x0                                                            |
| 4 | PwrDnRst_n             | Power Down ResetN (PwrDnRst_n)<br>The application must program this bit to reset the core during the<br>Hibernation exit process.<br>• 1'b1: The controller is in normal operation<br>• 1'b0: reset the controller<br>Note: This bit must not be written to during normal mode of operation.<br>Values:<br>• 0x0 (DISABLE): Reset the controller<br>• 0x1 (ENABLE): The controller is in normal operation<br>Value After Reset: 0x1                                           |
| 3 | PwrDnClmp              | Power Down Clamp (PwrDnClmp)<br>The application must program this bit to enable or disable the clamps<br>to all the outputs of the core module to prevent the corruption of other<br>active logic.<br>• 1'b0: Disable PMU power clamp<br>• 1'b1: Enable PMU power clamp<br>Values:<br>• 0x0 (DISABLE): Disable PMU power clamp<br>• 0x1 (ENABLE): Enable PMU power clamp<br>Value After Reset: 0x0                                                                            |



| 2 | Restore   | Restore<br>The application should program this bit to enable or disable restore<br>mode from the PMU module.<br>• 1'b0: The controller in normal mode of operation<br>• 1'b1: The controller in restore mode<br>Note: This bit must not be written to during normal mode of operation.<br>Values:<br>• 0x0 (DISABLE): The controller in normal mode of operation<br>• 0x1 (ENABLE): The controller in Restore mode<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                   |
|---|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | PMUActv   | <ul> <li>PMU Active (PMUActv)</li> <li>This is bit is to enable or disable the PMU logic.</li> <li>1'b0: Disable PMU module</li> <li>1'b1: Enable PMU module</li> <li>Note: This bit must not be written to during normal mode of operation.</li> <li>Values:</li> <li>0x0 (DISABLE): Disable PMU module</li> <li>0x1 (ENABLE): Enable PMU module</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                   |
| 0 | PMUIntSel | <ul> <li>PMU Interrupt Select (PMUIntSel)</li> <li>A write to this bit with 1'b1 enables the PMU to generate interrupts to the application. During this state all interrupts from the DWC_usb11_device_core module are blocked to the application. Note: This bit must be set to 1'b1 before the core is put into hibernation.</li> <li>1'b0: Internal DWC_usb11_device_core interrupt is selected</li> <li>1'b1: External DWC_usb11_device_pmu interrupt is selected Note: This bit must not be written to during normal mode of operation. Values:</li> <li>0x0 (DISABLE): Internal DWC_usb11_device_core interrupt is selected</li> <li>0x1 (ENABLE): External DWC_usb11_device_pmu interrupt is selected Value After Reset: 0x0</li> </ul> |



#### 22.2.18 GDFIFOCFG: Global DFIFO configuration register

#### GDFIFOCFG =0x5000\_005C

|                                     |            |        |    |      |      |      |      |     |     |   |   |   |   |   | _ |   |
|-------------------------------------|------------|--------|----|------|------|------|------|-----|-----|---|---|---|---|---|---|---|
| 31 30 29 28 27 26 25 24 23 22 21 20 | 19 18 17 1 | 6 15   | 14 | 13 ´ | 12 1 | 1 10 | 9    | 8   | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| EPInfoBaseAdd                       |            |        |    |      |      | G    | DFIF | =00 | Cfg |   |   |   |   |   |   |   |
| 0x01D8                              |            | 0x0200 |    |      |      |      |      |     |     |   |   |   |   |   |   |   |
| RW                                  |            |        |    |      |      |      | R    | W   |     |   |   |   |   |   |   |   |

| 31<br>16 | EPInfoBaseAddr | EPInfoBaseAddr<br>This field provides the start address of the EP info controller                                                                                                                                                                                                                                                                                    |
|----------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>0  | GDFIFOCfg      | GDFIFOCfg<br>This field is for dynamic programming of the DFIFO Size. This<br>value takes effect only when the application programs a non-zero<br>value to this register. The value programmed must conform to the<br>guidelines described in 'FIFO RAM Allocation'. The core does not<br>have any corrective logic if the FIFO sizes are programmed<br>incorrectly. |

#### 22.2.19 DIEPTXFi: Device IN endpoint transmit FIFO size register i

For I = 1; I <= OTG\_NUM\_IN\_EPS

#### DIEPTXFi =0x5000\_013C

| 31 30 29 28 | 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------------|-------------------------------------|---------------------------------------|
| Reserved    | INEPnTxFDep                         | INEPnTxFStAddr                        |
| -           | 0                                   | 0                                     |
| -           | RW                                  | RW                                    |

| 27<br>16 | INEPnTxFDep    | <ul> <li>IN Endpoint TxFIFO Depth (INEPnTxFDep)</li> <li>This value is in terms of 32-bit words.</li> <li>Minimum value is 16</li> <li>Maximum value is 32,768</li> <li>The power-on reset value of this register is specified as the Largest</li> <li>IN Endpoint FIFO number Depth. Programmed values must not exceed the power-on value</li> </ul> |
|----------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>0  | INEPnTxFStAddr | IN Endpoint FIFOn Transmit RAM Start Address<br>(INEPnTxFStAddr)<br>This field contains the memory start address for IN endpoint<br>Transmit FIFOn (0 <n< 15).="" =="" of="" power-on="" reset="" the="" this<br="" value="">register is specified as the Largest Rx Data FIFO Depth.<br/>Programmed values must not exceed the power-on value.</n<>  |



# 22.2.20 DCFG: Device configuration register

### DCFG =0x5000\_0800

| 31 30 29 28 27 26 | 25 24                | 23      | 22 21    | 20 19    | 18 | 17 16                                                                                                                                                                                                         | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 13                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 12 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 10 9                                                                                                                                                                                                               | 8 7                                                                                                                                                                      | 6                                                                               | 5 4                                                                  | 4 3                                                                    | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 10                                                    |
|-------------------|----------------------|---------|----------|----------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------------|------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| ResValid          | PerSchIntvl          | DescDMA |          | Reserved |    |                                                                                                                                                                                                               | ErraticIntMsk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | EnDevOutNa                                                                                                                                                                                                                                                                                                                                                                                                                                                | PerFrInt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                    | DevAddr                                                                                                                                                                  |                                                                                 |                                                                      | Ena32KhzSu                                                             | NZStsOUTHS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | DevSpd                                                |
| 0x02              | 0                    | 0       |          | -        |    |                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                    | 0                                                                                                                                                                        |                                                                                 |                                                                      | 0                                                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0                                                     |
| RW                | RW                   | RW      |          | -        |    |                                                                                                                                                                                                               | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                    | RW                                                                                                                                                                       |                                                                                 |                                                                      | RW                                                                     | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW                                                    |
|                   | 31<br>26<br>25<br>24 |         | erSchInt | vI       |    | This<br>cont<br>The<br>valid<br>Perio<br>Perio<br>This<br>alloo<br>num<br>50 c<br>• Wh<br>alloo<br>end<br>• Wh<br>eng<br>• Aft<br>to fe<br>-2'b0<br>-2'b'<br>-2'b'<br>Reso<br>Valu<br>• 0x0<br>• 0x1<br>• 0x2 | field from the core of the cor | is efficience of the second se | fectives<br>sum<br>nts f<br>when<br>eset:<br>dulir<br>ust t<br>ifies<br>fetch<br>riodi<br>(miccleriodi<br>es no<br>ecifie<br>non<br>f (mi<br>f (mi<br>f (mi<br>f (mi<br>f (mi<br>f (mi<br>f (mi<br>f (mi<br>f (mi<br>f f f (mi<br>f f (mi<br>f f (mi<br>f f f (mi<br>f f f f f f f f f f f f f f f f f f f | e period<br>for Res\<br>n this is<br>0x2<br>g Interv<br>be progr<br>the amo<br>ing per<br>c endpo<br>ro) fram<br>lic endp<br>ecified a<br>ic endp<br>on-period<br>d time v<br>-periodi<br>cro) frar<br>cro) fra | when E<br>I when<br>/alid no<br>set<br>al (Per-<br>ammed<br>bunt of f<br>iodic II<br>ints, th<br>e.<br>bints an<br>dic end<br>vithin a<br>c endpo<br>ne.<br>ne.<br>ne.<br>ne.<br>ne.<br>ro)fram<br>rved<br>ro)fram | DCFG.En<br>the con-<br>umber of<br>SchIntvl<br>I for Sca<br>time the<br>N endpuis value<br>of time<br>re active<br>of time<br>re active<br>dpoints,<br>(micro)<br>oints. | e res<br>f clo<br>)<br>ttter//<br>Inter<br>pint<br>mus<br>, the<br>e in<br>fram | Gathernal DI<br>data.<br>st be s<br>interr<br>fetchinen thering the  | r DM/<br>MA er<br>Base<br>specifinal DN<br>ng pi<br>e inte<br>is field | A model<br>a mode | de.<br>must<br>a the<br>s 25,<br>ngine<br>c IN<br>DMA |
|                   | 23                   | De      | escDMA   |          |    | Whe<br>of th<br>enal<br>Note<br>com<br>• GA<br>• GA<br>• GA<br>• G<br>DM/<br>Valu<br>• 0x(<br>• 0x^                                                                                                           | n the<br>ble th<br>: This<br>binat<br>HBC<br>HBC<br>ABC<br>AHB<br>A mo<br>es:<br>) (DIS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | e Sca<br>TL, tl<br>ie Sc<br>s bit i<br>FG.I<br>FG.I<br>FG.I<br>FG.I<br>CFG<br>de<br>SABL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | LED):                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Gather I<br>pplicatic<br>(Gather<br>be mod<br>available<br>En=0,00<br>En=0,00<br>En=1,00<br>AEn=1,1<br>: Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | DMA op<br>on can<br>DMA of<br>ified or<br>of for pr<br>CFG.D<br>CFG.D<br>CFG.D<br>DCFG.I<br>DCFG.I                                                                                                                 | vice mo<br>btion sel<br>Set this<br>operation<br>ly once<br>ogramm<br>escDMA<br>escDMA<br>DescDM<br>er/Gather                                                            | ected<br>bit of<br>after<br>ing:<br>=0 =<br>=1 =<br>=0 =<br>A=1<br>er DN        | d during<br>a rese<br>> Inva<br>> Inva<br>> Inva<br>=> Inva<br>=> MA | ng cor<br>initia<br>et. The<br>alid<br>alid<br>alid                    | lizati<br>e follo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | on to<br>owing                                        |



| 15       | ErraticIntMsk | Erratic Error Interrupt Mask<br>• 1'b1: Mask early suspend interrupt on erratic error<br>• 1'b0: Early suspend interrupt is generated on erratic error<br>Values:<br>• 0x1 (MASK): Mask early suspend interrupt on erratic error<br>• 0x0 (NOMASK): Early suspend interrupt is generated on erratic<br>error<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                |
|----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13       | EnDevOutNak   | <ul> <li>Enable Device OUT NAK (EnDevOutNak)</li> <li>This bit enables setting NAK for Bulk OUT endpoints after the transfer is completed for Device mode Descriptor DMA</li> <li>1'b0 : The core does not set NAK after Bulk OUT transfer complete</li> <li>1'b1 : The core sets NAK after Bulk OUT transfer complete It is one time programmable after reset like any other DCFG register bits.</li> <li>Values:</li> <li>0x0 (DISABLED):</li> <li>The core does not set NAK after Bulk OUT transfer complete</li> <li>0x1 (ENABLED): The core sets NAK after Bulk OUT transfer complete</li> <li>Value After Reset: 0x0</li> </ul>                                                                                 |
| 12<br>11 | PerFrInt      | <ul> <li>Periodic Frame Interval (PerFrInt)</li> <li>Indicates the time within a (micro) frame at which the application must be notified using the End Of Periodic Frame Interrupt. This can be used to determine If all the isochronous traffic for that (micro) frame is complete.</li> <li>2'b00: 80% of the (micro)frame interval</li> <li>2'b01: 85%</li> <li>2'b10: 90%</li> <li>2'b11: 95%</li> <li>Values:</li> <li>0x0 (EOPF80): 80% of the (micro)frame interval</li> <li>0x1 (EOPF85): 85% of the (micro)frame interval</li> <li>0x3 (EOPF95): 95% of the (micro)frame interval</li> <li>0x2 (EOPF90): 90% of the (micro)frame interval</li> <li>0x2 (EOPF90): 90% of the (micro)frame interval</li> </ul> |
| 10<br>4  | DevAddr       | Device Address (DevAddr)<br>The application must program this field after every SetAddress<br>control command.<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3        | Ena32KhzSusp  | <ul> <li>Enable 32 KHz Suspend mode (Ena32KhzSusp)</li> <li>As FS PHY interface is chosen, when this bit is set, the core expects that the PHY clock during Suspend is switched from 48 MHz to 32 KHz.</li> <li>Values:</li> <li>0x0 (DISABLED): USB 1.1 Full-Speed Serial Transceiver not selected</li> <li>0x1 (ENABLED):</li> <li>USB 1.1 Full-Speed Serial Transceiver Interface selected Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                       |



| 2      | NZStsOUTHShk | <ul> <li>Non-Zero-Length Status OUT Handshake (NZStsOUTHShk)<br/>The application can use this field to select the handshake the core<br/>sends on receiving a nonzero-length data packet during the OUT<br/>transaction of a control transfer's Status stage.</li> <li>1'b1: Send a STALL handshake on a nonzero-length status OUT<br/>transaction and do not send the received OUT packet to the<br/>application.</li> <li>1'b0: Send the received OUT packet to the application (zero-length)<br/>or nonzero-length) and send a handshake based on the NAK and<br/>STALL bits for the endpoint in the Device Endpoint Control register.<br/>Values:</li> <li>0x0 (SENDOUT):<br/>Send the received OUT packet to the application (zero-length or<br/>non-zero length) and send a handshake based on NAK and STALL<br/>bits for the endpoint in the Device Endpoint Control Register</li> <li>0x1 (SENDSTALL):<br/>Send a STALL handshake on a nonzero-length status OUT<br/>transaction and do not send the received OUT packet to the<br/>application</li> </ul> |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>0 | DevSpd       | <ul> <li>Device Speed (DevSpd)</li> <li>Indicates the speed at which the application requires the core to enumerate, or the maximum speed the application can support. However, the actual bus speed is determined only after the connect sequence is completed, and is based on the speed of the USB host to which the core is connected.</li> <li>Values:</li> <li>0x0 (Reserved0): Reserved</li> <li>0x1 (Reserved1): Reserved</li> <li>0x3 (USBFS1148): Full speed USB 1.1 transceiver clock is 48 MHz</li> <li>0x2 (USBLS116): Low speed USB 1.1 transceiver clock is 6 MHz</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                        |



# 22.2.21 DCTL: Device control register

#### DCTL =0x5000\_0804

| 31 30 29 28 27 26 2 | 5 24 23  | 3 22 21 | 20 19   | 18             | 17          | 16        | 15                                                                         | 14 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 12                                                                                                                                      | 11                                                                                                                                            | 10                                                                                                                                                | 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 8                                                                                                                                | 7                                                                                               | 6                                                                                                                            | 54                                                                                                                                            | 3                                                                                                                                        | 2                                                                                                                  | 1                                                                                                             | 0                                                                         |
|---------------------|----------|---------|---------|----------------|-------------|-----------|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| 0.00202021202       |          |         | 20 10   |                |             | .0        | .0                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 12                                                                                                                                      |                                                                                                                                               | .0                                                                                                                                                | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 5                                                                                                                                |                                                                                                 |                                                                                                                              | <del>с</del> т                                                                                                                                |                                                                                                                                          |                                                                                                                    |                                                                                                               |                                                                           |
|                     | Keserved |         |         | DeepSleepBESLR | EnContOnBNA | NakOnBble | lgnrFrmNum                                                                 | GMC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reserved                                                                                                                                | PWROnPrgDone                                                                                                                                  | CGOUTNak                                                                                                                                          | SGOUTNak                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | CGNPInNak                                                                                                                        | SGNPInNak                                                                                       | Ĭ                                                                                                                            | Istuti                                                                                                                                        | GOUTNakSts                                                                                                                               | GNPINNakSts                                                                                                        | SftDiscon                                                                                                     | RmtWkUpSig                                                                |
|                     | -        |         |         | 0              | 0           | 0         | 0                                                                          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -                                                                                                                                       | 0                                                                                                                                             | 0                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0                                                                                                                                | 0                                                                                               |                                                                                                                              | 0                                                                                                                                             | 0                                                                                                                                        | 0                                                                                                                  | 1                                                                                                             | 0                                                                         |
|                     | •        |         |         | RW             | RW          | RW        | RW                                                                         | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                         | W                                                                                                                                             | W                                                                                                                                                 | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | W                                                                                                                                | RW                                                                                              | F                                                                                                                            | RM                                                                                                                                            | R                                                                                                                                        | R                                                                                                                  | RW                                                                                                            | RW                                                                        |
|                     | 18       |         | SleepB  |                |             |           | •<br>W<br>g<br>s<br>th<br>d<br>V<br>•<br>(<br>V                            | eepSlee<br>1: Deep<br>0: Deep<br>/hen er<br>reater t<br>ent for<br>nreshold<br>isabled.<br>alues:<br>0x0 (DIS<br>0x1 (EN<br>alue Aft<br>nable C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Slee<br>Slee<br>han<br>LPN<br>J. By<br>SABI<br>IABL<br>er R                                                                             | EP B<br>EP B<br>Ed C<br>HIRI<br>M to<br>defa<br>LED):<br>ED):<br>ESEt:<br>nue c                                                               | ESL<br>ESL<br>ore<br>D thr<br>kens<br>ault,<br>: Dee<br>: 0x0<br>on Bl                                                                            | Reje<br>Reje<br>rejec<br>esho<br>wit<br>the<br>ep Si<br>ep Si                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ect fe<br>cts L<br>old p<br>h Hi<br>Deep<br>leep<br>EnCo                                                                         | eature<br>PM<br>rogra<br>IRD<br>o Sle<br>BES<br>BES                                             | e is d<br>requ<br>amme<br>value<br>ep B<br>L Re<br>L Re<br>nBN/                                                              | isable<br>lest wed. N<br>e gre<br>ESL<br>ject fe<br>ject fe                                                                                   | ed<br>vith<br>YET<br>ater<br>Reje<br>eature                                                                                              | resp<br>thar<br>ct fe<br>e is d<br>e is e                                                                          | onse<br>ature<br>lisabl                                                                                       | e is<br>RD<br>e is<br>led<br>led                                          |
|                     | -16      | Nalo    | 20 Dela |                |             |           | e<br>e<br>th<br>r<br>e<br>th<br>B<br>a<br>V<br>·<br>B<br>s<br>s<br>ir<br>V | his bit of<br>ndpoint<br>ndpoint<br>ne desc<br>e-enable<br>1'b0: A<br>ndpoint<br>ne core<br>1'b1: A<br>ndpoint<br>ne core<br>1'b1: A<br>ndpoint<br>ne core<br>NA inte<br>tarts pro<br>0x0 (DI<br>NA inte<br>tarts pro<br>terrupt.<br>alue Att<br>alue | s. V<br>rece<br>ripto<br>es th<br>fter<br>. Wh<br>start<br>fter<br>. Wh<br>start<br>rrup<br>oces<br>SAB<br>SAB<br>errup<br>oces<br>er R | Vith<br>eives<br>r tha<br>e en<br>rece<br>een ti<br>s prot<br>t. It is<br>strL re<br>LED<br>t. Wh<br>ssing<br>LED)<br>t. Wh<br>ssing<br>eset: | this is a E<br>t caudo in the e<br>docess<br>biving<br>the e<br>occess<br>is a o<br>egist<br>): Coonen a<br>from<br>): Coonen a<br>from<br>: 0x00 | fear<br>sNA<br>used<br>nt.<br>g BN<br>ndpc<br>sing<br>g BN<br>ndpc<br>si<br>si<br>si<br>g BN<br>ndpc<br>si<br>si<br>si<br>si<br>si<br>si<br>si<br>si<br>si<br>si<br>si<br>si<br>si | ture<br>inter<br>the I<br>JA ir<br>bint is<br>from<br>JA ir<br>bint is<br>from<br>pts.<br>lisab<br>catio<br>DOE<br>catio<br>e de | ena<br>rupt<br>BNA<br>hterru<br>s re-<br>the<br>the<br>the<br>orogr<br>les th<br>n re-<br>Scrip | bled,<br>the c<br>inter<br>upt, t<br>enab<br>DOE<br>upt, t<br>enab<br>desc<br>amm<br>he er<br>enab<br>MA de<br>ne er<br>enab | whe<br>core s<br>rupt a<br>he co<br>led by<br>PDMA<br>he co<br>led by<br>riptor<br>able a<br>ndpoir<br>bles th<br>escrip<br>ndpoir<br>bles th | in a starts<br>fiter f<br>pre c<br>/ the<br>A des<br>Dre c<br>/ the<br>that<br>after<br>tor<br>t aff<br>ne en<br>t aff<br>ne en<br>t aff | Bul<br>pro-<br>he e<br>disab<br>appl<br>script<br>disab<br>appl<br>recei<br>rese<br>er re<br>dpoi<br>er re<br>dpoi | k O<br>cessi<br>ndpc<br>les t<br>licatio<br>tor.<br>les t<br>licatio<br>ved t<br>t bit l<br>ecceivi<br>nt, cc | UT<br>ing<br>bint<br>the<br>on,<br>the<br>on,<br>the<br>ike<br>ing<br>ore |
|                     | 16       | NakO    | nBble   |                |             |           | S<br>N<br>V<br>•                                                           | AK on E<br>et NAK<br>IAK auto<br>alues:<br>0x0 (DIS<br>0x1 (EN<br>alue Aft                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | auto<br>omat<br>SABI<br>IABL                                                                                                            | omati<br>ically<br>LED)<br>.ED):                                                                                                              | ically<br>/ for<br>): Dis<br>: NAI                                                                                                                | r on<br>the e<br>able<br>K on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | babb<br>endpo<br>e NAI                                                                                                           | ole (N<br>pint c<br>K on                                                                        | on wh<br>Babl                                                                                                                | ich ba                                                                                                                                        | abble                                                                                                                                    |                                                                                                                    |                                                                                                               |                                                                           |



| 15       | IgnrFrmNum   | <ul> <li>Ignore Frame number for Isochronous End points (IgnrFrmNum)</li> <li>Do not program IgnrFrmNum bit to 1'b1 when the core is operating in threshold mode.</li> <li>When this bit is enabled, there must be only one packet per descriptor.</li> <li>• 0: The core transmits the packets only in the frame number in which they are intended to be transmitted.</li> <li>• 1: The core ignores the frame number, sending packets immediately as the packets are ready.</li> <li>In Scatter/Gather DMA mode, if this bit is enabled, the packets are not flushed when an ISOC IN token is received for an elapsed frame.</li> <li>Values:</li> <li>• 0x0 (DISABLED):</li> <li>The core ignores the frame number, sending packets inwhich they are intended to be transmitted</li> <li>• 0x1 (ENABLED):</li> <li>The core ignores the frame number, sending packets immediately as the packets are ready.</li> </ul> |
|----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14<br>13 | GMC          | <ul> <li>Global Multi Count (GMC)</li> <li>GMC must be programmed only once after initialization. This field indicates the number of packets to be serviced for that end point before moving to the next end point. It is only for non-periodic endpoints.</li> <li>2'b00: Invalid.</li> <li>2'b01: 1 packet.</li> <li>2'b10: 2 packets.</li> <li>2'b11: 3 packets.</li> <li>Values:</li> <li>0x0 (NOTVALID): Invalid</li> <li>0x1 (ONEPACKET): 1 packet</li> <li>0x2 (TWOPACKET): 2 packets</li> <li>0x3 (THREEPACKET): 2 packets</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                             |
| 11       | PWROnPrgDone | Power-On Programming Done (PWROnPrgDone)<br>The application uses this bit to indicate that register<br>programming is completed after a wake-up from Power Down<br>mode.<br>Values:<br>• 0x1 (DONE): Power-On Programming Done<br>• 0x0 (NOTDONE): Power-On Programming not done<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 10       | CGOUTNak     | Clear Global OUT NAK (CGOUTNak)<br>A write to this field clears the Global OUT NAK.<br>Values:<br>• 0x0 (DISABLED): Disable Clear Global OUT NAK<br>• 0x1 (ENABLED): Clear Global OUT NAK<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 9        | SGOUTNak     | <ul> <li>Set Global OUT NAK (SGOUTNak)</li> <li>A write to this field sets the Global OUT NAK. The application uses this bit to send a NAK handshake on all OUT endpoints. The application must set this bit only after making sure that the Global OUT NAK Effective bit in the Core Interrupt Register (GINTSTS.GOUTNakEff) is cleared.</li> <li>Values:</li> <li>0x0 (DISABLED): Disable Global OUT NAK</li> <li>0x1 (ENABLED): Set Global OUT NAK</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                          |



| 8      | CGNPInNak   | Clear Global Non-periodic IN NAK (CGNPInNak)<br>A write to this field clears the Global Non-periodic IN NAK.<br>Values:<br>• 0x0 (DISABLE): Disable Global Non-periodic IN NAK<br>• 0x1 (ENABLE): Clear Global Non-periodic IN NAK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | SGNPInNak   | Value After Reset: 0x0<br>Set Global Non-periodic IN NAK (SGNPInNak)<br>A write to this field sets the Global Non-periodic IN NAK.The<br>application uses this bit to send a NAK handshake on all non-<br>periodic IN endpoints. The core can also Set this bit when a<br>timeout condition is detected on a non-periodic endpoint in<br>shared FIFO operation. The application must Set this bit only<br>after making sure that the Global IN NAK Effective bit in the<br>Core Interrupt Register (GINTSTS.GINNakEff) is cleared<br>Values:<br>• 0x0 (DISABLE): Disable Global Non-periodic IN NAK<br>• 0x1 (ENABLE): Set Global Non-periodic IN NAK<br>Value After Reset: 0x0                                                                                                                                                                                                                                                         |
| 6<br>4 | TstCtl      | Test Control (TstCtl)<br>• 3'b000: Test mode disabled<br>• 3'b001: Test_J mode<br>• 3'b010: Test_K mode<br>• 3'b101: Test_SE0_NAK mode<br>• 3'b100: Test_Packet mode<br>• 3'b101: Test_Force_Enable<br>• Others: Reserved<br>Values:<br>• 0x2 (TESTK): Test_K mode<br>• 0x4 (TESTPM): Test_Packet mode<br>• 0x4 (TESTPM): Test_Packet mode<br>• 0x4 (TESTPM): Test_Packet mode<br>• 0x5 (TESTFE): Test_force_Enable<br>• 0x1 (TESTJ): Test_J mode<br>• 0x3 (TESTSN): Test_SE0_NAK mode<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3      | GOUTNakSts  | <ul> <li>Global OUT NAK Status (GOUTNakSts)</li> <li>1'b0: A handshake is sent based on the FIFO Status and the NAK and STALL bit settings.</li> <li>1'b1: No data is written to the RxFIFO, irrespective of space availability. Sends a NAK handshake on all packets, except on SETUP transactions. All isochronous OUT packets are dropped.</li> <li>Values:</li> <li>0x1 (ACTIVE): No data is written to the RxFIFO, irrespective of space availability. Sends a NAK handshake on all packets, except on SETUP transactions. All isochronous OUT packets are dropped.</li> <li>0x1 (ACTIVE): No data is written to the RxFIFO, irrespective of space availability. Sends a NAK handshake on all packets, except on SETUP transactions. All isochronous OUT packets are dropped.</li> <li>0x0 (INACTIVE): A handshake is sent based on the FIFC Status and the NAK and STALL bit settings.</li> <li>Value After Reset: 0x0</li> </ul> |
| 2      | GNPINNakSts | <ul> <li>Global Non-periodic IN NAK Status (GNPINNakSts)</li> <li>1'b0: A handshake is sent out based on the data availability in the transmit FIFO.</li> <li>1'b1: A NAK handshake is sent out on all non-periodic IN endpoints, irrespective of the data availability in the transmit FIFO.</li> <li>Values:</li> <li>0x1 (ACTIVE): A NAK handshake is sent out on all non-periodic IN endpoints, irrespective of the data availability in the transmit FIFO.</li> <li>0x1 (ACTIVE): A NAK handshake is sent out on all non-periodic IN endpoints, irrespective of the data availability in the transmit FIFO.</li> <li>0x0 (INACTIVE): A handshake is sent out based on the data availability in the transmit FIFO Value After Reset: 0x0</li> </ul>                                                                                                                                                                                 |



| 1 SftDiscon  | Soft Disconnect (SftDiscon)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | <ul> <li>The application uses this bit to signal the controller to do a sof disconnect. As long as this bit is Set, the host does not see tha the device is connected, and the device does not receive signals on the USB. The core stays in the disconnected state until the application clears this bit.</li> <li>1'b0: Normal operation. When this bit is cleared after a sof disconnect, the core generates a device connect event to the USB host. When the device is reconnected, the USB host restarts device enumeration.</li> <li>1'b1: The core generates a device disconnect event to the USE host. Note:</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              | <ul> <li>This bit is not impacted by a soft reset.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|              | Values:<br>• 0x1 (DISCONNECT): The core generates a device disconnec<br>event to the USB host<br>• 0x0 (NODISCONNECT): The core generates a device connec<br>event to the USB host<br>Value After Reset: 0x1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0 RmtWkUpSig | <ul> <li>Remote Wakeup Signaling (RmtWkUpSig)</li> <li>When the application sets this bit, the core initiates remote signaling to wake up the USB host. The application must Set this bit to instruct the core to exit the Suspend state. As specified in the USB 2.0 specification, the application must clear this bit 1-15 ms after setting it.</li> <li>Remote Wakeup Signaling (RmtWkUpSig) When LPM is enabled, In L1 state the behavior of this bit is as follows: When the application sets this bit, the core initiates L1 remote signaling to wake up the USB host. The application must set this bit to instruct the core to exit the Sleep state. As specified in the LPM specification, the hardware will automatically cleat this bit after a time of 50 micro sec (TL1DevDrvResume) after set by application. Application should not set this bit wher GLPMCFG bRemoteWake from the previous LPM transaction was zero.</li> <li>Values:</li> <li>0x0 (DISABLEDRMWKUP): Core does not send Remote Wakeup Signaling</li> <li>0x1 (ENABLERMWKUP): Core sends Remote Wakeup</li> </ul> |



### 22.2.22 DSTS: Device status register

### DSTS =0x5000\_0808

| 31 30 29 28 27 26 25 24 | 23 22    | 21 | 20 19 | 18 | 17 | 16 | 15    | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6        | 5        | 4 | 3         | 2       | 1   | 0       |
|-------------------------|----------|----|-------|----|----|----|-------|----|----|----|----|----|---|---|---|----------|----------|---|-----------|---------|-----|---------|
| Reserved                | DevLnSts |    |       |    |    |    | SOFFN | )  |    |    |    |    |   |   |   | Doconiod | Naviasan |   | ErrticErr | Enimond | Ini | SuspSts |
| -                       | 0        |    |       |    |    |    | 0     |    |    |    |    |    |   |   |   | -        | -        |   | 0         | 1       |     | 0       |
| -                       | R        |    |       |    |    |    | R     |    |    |    |    |    |   |   |   |          |          |   | R         | F       | {   | R       |

| 23<br>22 | DevLnSts  | Device Line Status (DevLnSts)<br>Indicates the current logic level USB data lines<br>• DevLnSts[1]: Logic level of D+<br>• DevLnSts[0]: Logic level of D-<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21<br>8  | SOFFN     | Number of the Received SOF (SOFFN)<br>Note: This register may return a non-zero value if read immediately after<br>power-on reset. In case the register bit reads non-zero immediately<br>after power-on reset, it does not indicate that SOF has been received<br>from the host. The read value of this interrupt is valid only after a valid<br>connection between host and device is established.<br>Value After Reset: 0x0                                                                                                                                                                                                                                         |
| 3        | ErrticErr | <ul> <li>Erratic Error (ErrticErr)</li> <li>The core sets this bit to report any erratic errors due to PHY error).</li> <li>Because of erratic errors, the controller goes into Suspended state and an interrupt is generated to the application with Early Suspend bit of the Core Interrupt register (GINTSTS.ErlySusp). If the early suspend is asserted due to an erratic error, the application can only perform a soft disconnect recover.</li> <li>Values:</li> <li>0x1 (ACTIVE): Erratic Error</li> <li>0x0 (INACTIVE): No Erratic Error</li> <li>Value After Reset: 0x0</li> </ul>                                                                            |
| 2<br>1   | EnumSpd   | <ul> <li>Enumerated Speed (EnumSpd)</li> <li>Indicates the speed at which the controller has come up after speed detection through a chirp sequence.</li> <li>2'b10: Low speed (PHY clock is running at 6 MHz)</li> <li>2'b11: Full speed (PHY clock is running at 48 MHz)</li> <li>Values:</li> <li>0x3 (FS48): Full speed (PHY clock is running at 48 MHz)</li> <li>0x0 (Reserved0): Reserved</li> <li>0x2 (LS6): Low speed (PHY clock is running at 6 MHz)</li> <li>0x1 (Reserved1): Reserved</li> <li>Value After Reset: 0x1</li> </ul>                                                                                                                            |
| 0        | SuspSts   | Suspend Status (SuspSts)<br>In Device mode, this bit is set as long as a Suspend condition is detected<br>on the USB. The core enters the Suspended state when there is no<br>activity on the phy_line_state_i signal for an extended period of time.<br>The core comes out of the suspend<br>• When there is any activity on the phy_line_state_i signal, or<br>• When the application writes to the Remote Wakeup Signaling bit in the<br>Device Control register (DCTL.RmtWkUpSig).<br>When the core comes out of the suspend, this bit is set to 1'b0.<br>Values:<br>• 0x1 (ACTIVE): Suspend state<br>• 0x0 (INACTIVE): No suspend state<br>Value After Reset: 0x0 |



# 22.2.23 DIEPMSK: Device IN endpoint common interrupt mask register

### DIEPMSK =0x5000\_0810

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 | 13     | 12 11 1  | 09           | 8              | 7        | 6             | 5             | 4            | 3          | 2         | 1           | 0            |
|-------------------------------------------------------|--------|----------|--------------|----------------|----------|---------------|---------------|--------------|------------|-----------|-------------|--------------|
| Reserved                                              | NAKMsk | Reserved | BNAInIntrMsk | TxfifoUndrnMsk | Reserved | INEPNakEffMsk | INTknEPMisMsk | INTknTXFEmpM | TimeOUTMsk | AHBErrMsk | EPDisbldMsk | XferCompIMsk |
| -                                                     | 0      | -        | 0            | 0              | -        | 0             | 0             | 0            | 0          | 0         | 0           | 0            |
|                                                       | RW     | •        | RW           | RW             | •        | RW            | RW            | RW           | RW         | RW        | RW          | RW           |

| 13 | NAKMsk         | NAK interrupt Mask (NAKMsk)<br>Values:<br>• 0x0 (MASK): Mask NAK Interrupt<br>• 0x1 (NOMASK): No Mask NAK Interrupt<br>Value After Reset: 0x0                                                                                                   |
|----|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9  | BNAInIntrMsk   | BNA interrupt Mask (BNAInIntrMsk)<br>Values:<br>• 0x0 (MASK): Mask BNA Interrupt<br>• 0x1 (NOMASK): No BNA Interrupt Mask<br>Value After Reset: 0x0                                                                                             |
| 8  | TxfifoUndrnMsk | Fifo Underrun Mask (TxfifoUndrnMsk)<br>Values:<br>• 0x0 (MASK): Mask Fifo Underrun Interrupt<br>• 0x1 (NOMASK): No Fifo Underrun Interrupt Mask<br>Value After Reset: 0x0                                                                       |
| 6  | INEPNakEffMsk  | IN Endpoint NAK Effective Mask (INEPNakEffMsk)<br>Values:<br>• 0x0 (MASK): Mask IN Endpoint NAK Effective Interrupt<br>• 0x1 (NOMASK): No IN Endpoint NAK Effective Interrupt Mask<br>Value After Reset: 0x0                                    |
| 5  | INTknEPMisMsk  | IN Token received with EP Mismatch Mask (INTknEPMisMsk)<br>Values:<br>• 0x0 (MASK): Mask IN Token received with EP Mismatch Interrupt<br>• 0x1 (NOMASK):<br>No Mask IN Token received with EP Mismatch Interrupt<br>Value After Reset: 0x0      |
| 4  | INTknTXFEmpMsk | IN Token Received When TxFIFO Empty Mask<br>(INTknTXFEmpMsk)<br>Values:<br>• 0x0 (MASK): Mask IN Token Received When TxFIFO Empty<br>Interrupt<br>• 0x1 (NOMASK):<br>No IN Token Received When TxFIFO Empty Interrupt<br>Value After Reset: 0x0 |
| 3  | TimeOUTMsk     | Timeout Condition Mask (TimeOUTMsk) (Non-isochronous<br>endpoints)<br>Values:<br>• 0x0 (MASK): Mask Timeout Condition Interrupt<br>• 0x1 (NOMASK): No Timeout Condition Interrupt Mask<br>Value After Reset: 0x0                                |



| 2 | AHBErrMsk    | AHB Error Mask (AHBErrMsk)                                            |
|---|--------------|-----------------------------------------------------------------------|
|   |              | Values:<br>• 0x0 (MASK): Mask AHB Error Interrupt                     |
|   |              | • 0x1 (NOMASK): No AHB Error Interrupt Mask                           |
|   |              | Value After Reset: 0x0                                                |
| 1 | EPDisbldMsk  | Endpoint Disabled Interrupt Mask (EPDisbldMsk)                        |
|   |              | Values:                                                               |
|   |              | <ul> <li>0x0 (MASK): Mask Endpoint Disabled Interrupt</li> </ul>      |
|   |              | <ul> <li>0x1 (NOMASK): No Endpoint Disabled Interrupt Mask</li> </ul> |
|   |              | Value After Reset: 0x0                                                |
| C | XferComplMsk | Transfer Completed Interrupt Mask (XferComplMsk)                      |
|   |              | Values:                                                               |
|   |              | <ul> <li>0x0 (MASK): Mask Transfer Completed Interrupt</li> </ul>     |
|   |              | • 0x1 (NOMÁSK): No Transfer Completed Interrupt Mask                  |
|   |              | Value After Reset: 0x0                                                |

# 22.2.24 DOEPMSK: Device OUT endpoint common interrupt mask register

### DOEPMSK =0x5000\_0814

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 | 14      | 13     | 12         | 11 10    | 9             | 8            | 7        | 6           | 5           | 4           | 3        | 2         | 1           | 0            |
|----------------------------------------------------|---------|--------|------------|----------|---------------|--------------|----------|-------------|-------------|-------------|----------|-----------|-------------|--------------|
| Reserved                                           | NYETMsk | NAKMSK | BbleErrMsk | Reserved | BnaOutIntrMsk | OutPktErrMsk | Reserved | Back2BackSE | StsPhseRcvd | OUTTknEPdis | SetUPMsk | AHBErrMsk | EPDisbldMsk | XferCompIMsk |
| -                                                  | 0       | 0      | 0          | -        | 0             | 0            | -        | 0           | 0           | 0           | 0        | 0         | 0           | 0            |
|                                                    | RW      | RW     | RW         |          | RW            | RW           | •        | RW          | RW          | RW          | RW       | RW        | RW          | RW           |

| 14 | NYETMsk       | NYET interrupt Mask (NYETMsk)<br>Values:<br>• 0x0 (MASK): Mask NYET Interrupt<br>• 0x1 (NOMASK): No NYET Interrupt Mask<br>Value After Reset: 0x0                                |
|----|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13 | NAKMsk        | NAK interrupt Mask (NAKMsk)<br>Values:<br>• 0x0 (MASK): Mask NAK Interrupt<br>• 0x1 (NOMASK): No NAK Interrupt Mask<br>Value After Reset: 0x0                                    |
| 12 | BbleErrMsk    | Babble Error interrupt Mask (BbleErrMsk)<br>Values:<br>• 0x0 (MASK): Mask Babble Error Interrupt<br>• 0x1 (NOMASK): No Babble Error Interrupt Mask<br>Value After Reset: 0x0     |
| 9  | BnaOutIntrMsk | BNA interrupt Mask (BnaOutIntrMsk)<br>Values:<br>• 0x0 (MASK): Mask BNA Interrupt<br>• 0x1 (NOMASK): No BNA Interrupt Mask<br>Value After Reset: 0x0                             |
| 8  | OutPktErrMsk  | OUT Packet Error Mask (OutPktErrMsk)<br>Values:<br>• 0x0 (MASK): Mask OUT Packet Error Interrupt<br>• 0x1 (NOMASK): No OUT Packet Error Interrupt Mask<br>Value After Reset: 0x0 |



| 6 | Back2BackSETup | Back-to-Back       SETUP       Packets       Received       Mask         (Back2BackSETup)       Applies to control OUT endpoints only.       Values:       Values:       0x0 (MASK): Mask Back-to-Back SETUP Packets Received Interrupt         • 0x0 (MASK):       Mask Back-to-Back SETUP Packets Received Interrupt       No Back-to-Back SETUP Packets Received Interrupt Mask Value After Reset: |
|---|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 | StsPhseRcvdMsk | Status Phase Received Mask (StsPhseRcvdMsk)<br>Applies to control OUT endpoints only.<br>Values:<br>• 0x0 (MASK): Status Phase Received Mask<br>• 0x1 (NOMASK): No Status Phase Received Mask<br>Value After Reset: 0x0                                                                                                                                                                               |
| 4 | OUTTknEPdisMsk | OUT Token Received when Endpoint Disabled Mask<br>(OUTTknEPdisMsk)<br>Applies to control OUT endpoints only.<br>Values:<br>• 0x0 (MASK):<br>Mask OUT Token Received when Endpoint Disabled Interrupt<br>• 0x1 (NOMASK):<br>No OUT Token Received when Endpoint Disabled Interrupt Mask<br>Value After Reset: 0x0                                                                                      |
| 3 | SetUPMsk       | SETUP Phase Done Mask (SetUPMsk)<br>Applies to control endpoints only.<br>Values:<br>• 0x0 (MASK): Mask SETUP Phase Done Interrupt<br>• 0x1 (NOMASK): No SETUP Phase Done Interrupt Mask<br>Value After Reset: 0x0                                                                                                                                                                                    |
| 2 | AHBErrMsk      | AHB Error (AHBErrMsk)<br>Values:<br>• 0x0 (MASK): Mask AHB Error Interrupt<br>• 0x1 (NOMASK): No AHB Error Interrupt Mask<br>Value After Reset: 0x0                                                                                                                                                                                                                                                   |
| 1 | EPDisbldMsk    | Endpoint Disabled Interrupt Mask (EPDisbldMsk)<br>Values:<br>• 0x0 (MASK): Mask Endpoint Disabled Interrupt<br>• 0x1 (NOMASK): No Endpoint Disabled Interrupt Mask<br>Value After Reset: 0x0                                                                                                                                                                                                          |
| 0 | XferComplMsk   | Transfer Completed Interrupt Mask (XferCompIMsk)<br>Values:<br>• 0x0 (MASK): Mask Transfer Completed Interrupt<br>• 0x1 (NOMASK): No Transfer Completed Interrupt Mask<br>Value After Reset: 0x0                                                                                                                                                                                                      |



# 22.2.25 DAINT: Device all endpoints interrupt register

#### DAINT =0x5000\_0818

|                                  |           |           |           |           |           | —                                            |          |
|----------------------------------|-----------|-----------|-----------|-----------|-----------|----------------------------------------------|----------|
| 31 30 29 28 27 26 25 24 23 22 21 | 20        | 19        | 18        | 17        | 16        | 5 14 13 12 11 10 9 8 7 6 5 4 3 2 1           | 0        |
| Reserved                         | OutEPInt4 | OutEPInt3 | OutEPInt2 | OutEPInt1 | OutEPInt0 | Reserved<br>InEplnt4<br>InEplnt2<br>InEplnt1 | InEpInt0 |
| -                                | 0         | 0         | 0         | 0         | 0         | - 0 0 0 0                                    | 0        |
| -                                | R         | R         | R         | R         | R         | - R R R                                      | R        |

| 20 | OutEPInt4 | OUT Endpoint 4 Interrupt Bit<br>Value After Reset: 0x0                                                                                          |
|----|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 19 | OutEPInt3 | OUT Endpoint 3 Interrupt Bit<br>Value After Reset: 0x0                                                                                          |
| 18 | OutEPInt2 | OUT Endpoint 2 Interrupt Bit<br>Value After Reset: 0x0                                                                                          |
| 17 | OutEPInt1 | OUT Endpoint 1 Interrupt Bit<br>Value After Reset: 0x0                                                                                          |
| 16 | OutEPInt0 | OUT Endpoint 0 Interrupt Bit<br>Values:<br>• 0x1 (ACTIVE): OUT Endpoint 0 Interrupt<br>• 0x0 (INACTIVE): No Interrupt<br>Value After Reset: 0x0 |
| 4  | InEpInt4  | IN Endpoint 4 Interrupt Bit<br>Value After Reset: 0x0                                                                                           |
| 3  | InEpInt3  | IN Endpoint 3 Interrupt Bit<br>Value After Reset: 0x0                                                                                           |
| 2  | InEpInt2  | IN Endpoint 2 Interrupt Bit<br>Value After Reset: 0x0                                                                                           |
| 1  | InEpInt1  | IN Endpoint 1 Interrupt Bit<br>Value After Reset: 0x0                                                                                           |
| 0  | InEpInt0  | IN Endpoint 0 Interrupt Bit<br>Values:<br>• 0x1 (ACTIVE): IN Endpoint 0 Interrupt<br>• 0x0 (INACTIVE): No Interrupt<br>Value After Reset: 0x0   |



# 22.2.26 DAINTMSK: Device all endpoints interrupt mask register

#### DAINTMSK =0x5000\_081C

| 31 30 29 28 27 26 25 24 23 22 21 | 20        | 19        | 18        | 17        | 16        | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                    |
|----------------------------------|-----------|-----------|-----------|-----------|-----------|----------------------------------------------------------|
| Reserved                         | OutEPInt4 | OutEPInt3 | OutEPInt2 | OutEPInt1 | OutEPInt0 | Reserved<br>InEpInt4<br>InEpInt3<br>InEpInt1<br>InEpInt1 |
| -                                | 0         | 0         | 0         | 0         | 0         | - 0 0 0 0 0                                              |
|                                  | RW        | RW        | RW        | RW        | RW        | - RW RW RW RW RW                                         |

| 20 | OutEPMsk4 | OUT Endpoint 4 Interrupt mask Bit<br>Value After Reset: 0x0                                                                                                |
|----|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19 | OutEPMsk3 | OUT Endpoint 3 Interrupt mask Bit<br>Value After Reset: 0x0                                                                                                |
| 18 | OutEPMsk2 | OUT Endpoint 2 Interrupt mask Bit<br>Value After Reset: 0x0                                                                                                |
| 17 | OutEPMsk1 | OUT Endpoint 1 Interrupt mask Bit<br>Value After Reset: 0x0                                                                                                |
| 16 | OutEPMsk0 | OUT Endpoint 0 Interrupt mask Bit<br>Values:<br>• 0x0 (MASK): OUT Endpoint 0 Interrupt mask<br>• 0x1 (NOMASK): No Interrupt mask<br>Value After Reset: 0x0 |
| 4  | InEpMsk4  | IN Endpoint 4 Interrupt mask Bit<br>Value After Reset: 0x0                                                                                                 |
| 3  | InEpMsk3  | IN Endpoint 3 Interrupt mask Bit<br>Value After Reset: 0x0                                                                                                 |
| 2  | InEpMsk2  | IN Endpoint 2 Interrupt mask Bit<br>Value After Reset: 0x0                                                                                                 |
| 1  | InEpMsk1  | IN Endpoint 1 Interrupt mask Bit<br>Value After Reset: 0x0                                                                                                 |
| 0  | InEpMsk0  | IN Endpoint 0 Interrupt mask Bit<br>Values:<br>• 0x0 (MASK): IN Endpoint 0 Interrupt mask<br>• 0x1 (NOMASK): No Interrupt mask<br>Value After Reset: 0x0   |



# 22.2.27 DTHRCTL: Device threshold control register

|   |          |    |          |          |    |    |    |    |          |    |    |    |    |         |    |          |    |             |    |     |   |   |          |    |    | -0 | ~ )( |          | 0000        | , |
|---|----------|----|----------|----------|----|----|----|----|----------|----|----|----|----|---------|----|----------|----|-------------|----|-----|---|---|----------|----|----|----|------|----------|-------------|---|
| 3 | 1 30 29  | 28 | 27       | 26       | 25 | 24 | 23 | 22 | 21       | 20 | 19 | 18 | 17 | 16      | 15 | 14       | 13 | 12 11       | 10 | ) 9 | 8 | 7 | 6        | 5  | 4  | 3  | 2    | . 1      | 0           | T |
|   | Reserved |    | ArbPrkEn | Reserved |    |    |    |    | RxThrLen |    |    |    |    | RxThrEn |    | Reserved |    | AHBThrRatio |    |     |   |   | TxThrLen |    |    |    |      | ISOThrEn | NonISOThrEn |   |
|   | -        |    | 1        | -        |    |    |    | 0  | x00      | 8  |    |    |    | 0       |    | -        |    | 0           |    |     |   | C | )x00     | )8 |    |    |      | 0        | 0           |   |
|   |          |    | RW       | -        | RW |    |    |    |          | RW |    |    |    | RW      |    |          |    |             | RW |     |   |   |          | RW | RW |    |      |          |             |   |

# DTHRCTL =0x5000 0830

| 27       | ArbPrkEn | <ul> <li>Arbiter Parking Enable (ArbPrkEn)</li> <li>This bit controls internal DMA arbiter parking for IN endpoints.</li> <li>When thresholding is enabled and this bit is Set to one, Then the arbiter parks on the IN endpoint for which there is a token received on the USB. This is done to avoid getting into underrun conditions.</li> <li>By Default the parking is enabled.</li> <li>Values:</li> <li>0x0 (DISABLED): Disable DMA arbiter parking for IN endpoints Value After Reset: 0x1</li> </ul> |
|----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25<br>17 | RxThrLen | Receive Threshold Length (RxThrLen)<br>This field specifies Receive thresholding size in DWORDS. This<br>field also specifies the amount of data received on the USB before<br>the core can start transmitting on the AHB. The threshold length<br>has to be at least eight DWORDS. The recommended value for<br>ThrLen is to be the same as the programmed AHB Burst Length<br>(GAHBCFG.HbstLen).<br>Value After Reset: 0x8                                                                                  |
| 16       | RxThrEn  | <ul> <li>Receive Threshold Enable (RxThrEn)</li> <li>When this bit is set, the core enables thresholding in the receive direction.</li> <li>Note: We recommends that you do not enable RxThrEn, because it may cause issues in the RxFIFO especially during error conditions such as RxError and Babble.</li> <li>Values:</li> <li>0x0 (DISABLED): Disable thresholding</li> <li>0x1 (ENABLED): Enable thresholding in the receive direction Value After Reset: 0x0</li> </ul>                                |



| 12<br>11 | AHBThrRatio | AHB Threshold Ratio (AHBThrRatio)<br>These bits define the ratio between the AHB threshold and the<br>MAC threshold for the transmit path only. The AHB threshold<br>always remains less than or equal to the USB threshold, because<br>this does not increase overhead. Both the AHB and the MAC<br>threshold must be DWORD-aligned. The application needs to<br>program TxThrLen and the AHBThrRatio to make the AHB<br>Threshold value DWORD aligned. If the AHB threshold value is<br>not DWORD aligned, the core might not behave correctly. When<br>programming the TxThrLen and AHBThrRatio, the application<br>must ensure that the minimum AHB threshold value does not go<br>below 8 DWORDS to meet the USB turnaround time<br>requirements.<br>• 2'b00: AHB threshold = MAC threshold<br>• 2'b01: AHB threshold = MAC threshold / 2<br>• 2'b10: AHB threshold = MAC threshold / 4<br>• 2'b11: AHB threshold = MAC threshold / 8<br>Values:<br>• 0V4 (THRESONE): AHB threshold = MAC threshold / 8 |
|----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |             | <ul> <li>0x1 (THRESONE): AHB threshold = MAC threshold /2</li> <li>0x2 (THRESTWO): AHB threshold = MAC threshold /4</li> <li>0x3 (THRESTHREE): AHB threshold = MAC threshold /8</li> <li>0x0 (THRESZERO): AHB threshold = MAC threshold Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10<br>2  | TxThrLen    | Transmit Threshold Length (TxThrLen)<br>This field specifies Transmit thresholding size in DWORDS. This<br>also forms the MAC threshold and specifies the amount of data in<br>bytes to be in the corresponding endpoint transmit FIFO, before<br>the core can start transmit on the USB. The threshold length has<br>to be at least eight DWORDS when the value of AHBThrRatio is<br>2'h00. In case the AHBThrRatio is non zero the application needs<br>to ensure that the AHB Threshold value does not go below the<br>recommended eight DWORD. This field controls both isochronous<br>and non-isochronous IN endpoint thresholds. The recommended<br>value for ThrLen is to be the same as the programmed AHB Burst<br>Length (GAHBCFG.HbstLen).<br>Value After Reset: 0x8                                                                                                                                                                                                                              |
| 1        | ISOThrEn    | <ul> <li>ISO IN Endpoints Threshold Enable. (ISOThrEn) When this bit is Set, the core enables thresholding for isochronous IN endpoints. Values:</li> <li>0x0 (DISABLED): No thresholding</li> <li>0x1 (ENABLED): Enables thresholding for isochronous IN endpoints Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0        | NonISOThrEn | <ul> <li>Non-ISO IN Endpoints Threshold Enable. (NonISOThrEn)</li> <li>When this bit is Set, the core enables thresholding for Non Isochronous IN endpoints.</li> <li>Values:</li> <li>0x0 (DISABLED): No thresholding</li> <li>0x1 (ENABLED): Enable thresholding for non-isochronous IN endpoints</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |



## 22.2.28 DIEPEMPMSK: Device IN endpoint FIFO empty interrupt mask register

|    |                                                             |    |    |    |    |    |      |      |      |      |    |    |    |    |    |    |    |     |      |    |     |    | DI | EPI | EMF | PMS | 6K = | =0x | 500 | 0_0 | 834 |
|----|-------------------------------------------------------------|----|----|----|----|----|------|------|------|------|----|----|----|----|----|----|----|-----|------|----|-----|----|----|-----|-----|-----|------|-----|-----|-----|-----|
| 31 | 30                                                          | 29 | 28 | 27 | 26 | 25 | 5 24 | 1 23 | 3 22 | 2 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12   | 11 | 10  | 9  | 8  | 7   | 6   | 5   | 4    | 3   | 2   | 1   | 0   |
|    | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16<br>Reserved |    |    |    |    |    |      |      |      |      |    |    |    |    |    |    | Ir | ηΕp | oTxf | Em | pMs | sk |    |     |     |     |      |     |     |     |     |
|    |                                                             |    |    |    |    |    |      | -    |      |      |    |    |    |    |    |    |    |     |      |    |     |    | (  | 0   |     |     |      |     |     |     |     |
|    |                                                             |    |    |    |    |    |      | •    |      |      |    |    |    |    |    |    |    |     |      |    |     |    | R  | W   |     |     |      |     |     |     |     |
|    |                                                             |    |    |    | _  |    |      |      |      |      |    |    |    |    |    |    |    |     |      |    |     |    |    |     |     |     |      |     |     |     |     |

| 0 | InEpTxfEmpMsk | <ul> <li>IN EP Tx FIFO Empty Interrupt Mask Bits (InEpTxfEmpMsk)<br/>These bits acts as mask bits for DIEPINTn.TxFEmp interrupt, one<br/>bit per IN Endpoint:</li> <li>Bit 0 for IN EP 0, bit 4 for IN EP 4<br/>Values:</li> <li>• 0x8 (EP3_MASK): Mask IN EP3 Tx FIFO Empty Interrupt</li> <li>• 0x10 (EP4_MASK): Mask IN EP4 Tx FIFO Empty Interrupt</li> <li>• 0x1 (EP0_MASK): Mask IN EP0 Tx FIFO Empty Interrupt</li> <li>• 0x2 (EP1_MASK): Mask IN EP1 Tx FIFO Empty Interrupt</li> <li>• 0x4 (EP2_MASK): Mask IN EP2 Tx FIFO Empty Interrupt</li> <li>Value After Reset: 0x0</li> </ul> |
|---|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

### 22.2.29 DIEPCTL0: Device control IN endpoint 0 control register

#### DIEPCTL0=0x5000\_0900

| 31    | 30    | 29 28    | 27   | 26   | 25 2 | 4 23   | 22   | 21    | 20       | 19 18  | 17     | 16       | 15       | 14    | 13  | 12 | 11 | 10 | 9 | 8        | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 |
|-------|-------|----------|------|------|------|--------|------|-------|----------|--------|--------|----------|----------|-------|-----|----|----|----|---|----------|---|---|---|---|---|---|-----|
| EPEna | EPDis | Reserved | SNAK | CNAK |      | TxFNum |      | Stall | Reserved | EPType | NAKSts | Reserved | USBActEP |       |     |    |    |    |   | Reserved |   |   |   |   |   |   | MPS |
| 0     | 0     | -        | 0    | 0    |      | 0      |      | 0     | -        | 0      | 0      | -        | 1        |       |     |    |    |    |   | -        |   |   |   |   |   |   | 0   |
| RW    | RW    | -        | W    | W    |      | RW     |      | RW    | -        | R      | R      | -        | R        |       |     |    |    |    |   |          |   |   |   |   |   |   | RW  |
|       |       |          |      | 3    | 81   | EF     | PEna | •<br> | •        | En     | dpoii  | nt Er    | able     | e (EP | Ena | a) |    |    |   |          |   |   |   |   |   |   |     |

|  | 31 | EPEna | Endpoint Enable (EPEna)<br>When Scatter/Gather DMA mode is enabled, for IN endpoints this bit<br>indicates that the descriptor structure and data buffer with data ready to<br>transmit is setup.<br>Values:<br>• 0x1 (ACTIVE): Enable Endpoint<br>• 0x0 (INACTIVE): No action<br>Value After Reset: 0x0 |
|--|----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|--|----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|



| 30       | EPDis  | <ul> <li>Endpoint Disable (EPDis)</li> <li>The application sets this bit to stop transmitting data on an endpoint, even before the transfer for that endpoint is complete. The application must wait for the Endpoint Disabled interrupt before treating the endpoint as disabled. The core clears this bit before setting the Endpoint Disabled Interrupt. The application must Set this bit only if Endpoint Enable is already set for this endpoint.</li> <li>Values:</li> <li>0x1 (ACTIVE): Disabled Endpoint</li> <li>0x0 (INACTIVE): No action Value After Reset: 0x0</li> </ul>                                                                                                                                 |
|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27       | SNAK   | Set NAK (SNAK) A write to this bit sets the NAK bit for the endpoint.<br>Using this bit, the application can control the transmission of NAK<br>handshakes on an endpoint. The core can also set this bit for an<br>endpoint after a SETUP packet is received on that endpoint.<br>Values:<br>• 0x0 (NOSET): No action<br>• 0x1 (SET): Set NAK<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                               |
| 26       | CNAK   | Clear NAK (CNAK) A write to this bit clears the NAK bit for the endpoint.<br>Values:<br>• 0x1 (CLEAR): Clear NAK<br>• 0x0 (NOCLEAR): No action<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 25<br>22 | TxFNum | TxFIFO Number (TxFNum)<br>• For Dedicated FIFO operation, this value is set to the FIFO number<br>that is assigned to IN Endpoint.<br>Values:<br>• 0x3 (TXFIFO3): Tx FIFO 3<br>• 0x4 (TXFIFO4): Tx FIFO 4<br>• 0x0 (TXFIFO0): Tx FIFO 4<br>• 0x0 (TXFIFO0): Tx FIFO 0<br>• 0x1 (TXFIFO1): Tx FIFO 1<br>• 0x2 (TXFIFO2): Tx FIFO 2<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                            |
| 21       | Stall  | <ul> <li>STALL Handshake (Stall)</li> <li>The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit, Global Nonperiodic IN NAK, or Global OUT NAK is set along with this bit, the STALL bit takes priority.</li> <li>Values:</li> <li>0x1 (ACTIVE): Stall Handshake</li> <li>0x0 (INACTIVE): No Stall Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                            |
| 19<br>18 | ЕРТуре | Endpoint Type (EPType)<br>Hardcoded to 00 for control.<br>Values:<br>• 0x0 (ACTIVE): Endpoint Control 0<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 17       | NAKSts | <ul> <li>NAK Status (NAKSts)<br/>Indicates the following:</li> <li>1'b0: The core is transmitting non-NAK handshakes based on the FIFO status</li> <li>1'b1: The core is transmitting NAK handshakes on this endpoint.<br/>When this bit is set, either by the application or core, the core stops transmitting data, even If there is data available in the TxFIFO.<br/>Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.<br/>Values:</li> <li>0x1 (ACTIVE):<br/>The core is transmitting NAK handshakes on this endpoint</li> <li>0x0 (INACTIVE):<br/>The core is transmitting non-NAK handshakes based on the FIFO status Value After Reset: 0x0</li> </ul> |



| 15     | USBActEP | USB Active Endpoint (USBActEP)<br>This bit is always SET to 1, indicating that control endpoint 0 is always<br>active in all configurations and interfaces.<br>Values:<br>• 0x1 (ACTIVE0): Control endpoint is always active<br>Value After Reset: 0x1                                                                                                                                                               |
|--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>0 | MPS      | Maximum Packet Size (MPS)<br>Applies to IN and OUT endpoints.<br>The application must program this field with the maximum packet size<br>for the current logical endpoint.<br>• 2'b00: 64 bytes<br>• 2'b01: 32 bytes<br>• 2'b10: 16 bytes<br>• 2'b11: 8 bytes<br>Values:<br>• 0x2 (BYTES16): 16 bytes<br>• 0x1 (BYTES32): 32 bytes<br>• 0x0 (BYTES64): 64 bytes<br>• 0x3 (BYTES8): 8 bytes<br>Value After Reset: 0x0 |

# 22.2.30 DIEPINT0: Device IN endpoint 0 interrupt register

## DIEPINT0=0x5000\_0908

| 31 30 29 28 27 26 25 24 23 22 21 20 | 19 18 17 16 15 14 | 13        | 12      | 11 10    | 9       | 8           | 7      | 6          | 5          | 4          | 3        | 2      | 1        | 0         |
|-------------------------------------|-------------------|-----------|---------|----------|---------|-------------|--------|------------|------------|------------|----------|--------|----------|-----------|
| Reserved                            | NYETIntrpt        | NAKIntrpt | BbleErr | Reserved | BNAIntr | TxfifoUndrn | TxFEmp | INEPNakEff | INTknEPMis | INTknTXFEm | Reserved | AHBErr | EPDisbld | XferCompl |
| -                                   | 0                 | 0         | 0       | -        | 0       | 0           | 1      | 0          | 0          | 0          | -        | 0      | 0        | 0         |
| -                                   | RW                | RW        | RW      |          | RW      | RW          | R      | RW         | RW         | RW         | •        | RW     | RW       | RW        |

| 14 | NYETIntrpt | NYET Interrupt (NYETIntrpt)<br>The core generates this interrupt when a NYET response is<br>transmitted for a non isochronous OUT endpoint.<br>Values:<br>• 0x1 (ACTIVE): NYET Interrupt<br>• 0x0 (INACTIVE): No interrupt<br>Value After Reset: 0x0                                             |
|----|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13 | NAKIntrpt  | NAK Interrupt (NAKInterrupt)<br>The core generates this interrupt when a NAK is transmitted or<br>received by the device.<br>brln case of isochronous IN endpoints<br>the interrupt gets generated when a zero length packet is<br>transmitted due to un-availability of data in the TXFifo.<br> |
| 12 | BbleErr    | NAK Interrupt (BbleErr)<br>The core generates this interrupt when babble is received for the<br>endpoint.<br>Values:<br>• 0x1 (ACTIVE): BbleErr interrupt<br>• 0x0 (INACTIVE): No interrupt<br>Value After Reset: 0x0                                                                            |



| 9 | BNAIntr     | <ul> <li>BNA (Buffer Not Available) Interrupt (BNAIntr)</li> <li>The core generates this interrupt when the descriptor accessed is not ready for the Core to process, such as DMA done.</li> <li>Values:</li> <li>0x1 (ACTIVE): BNA interrupt</li> <li>0x0 (INACTIVE): No BNA interrupt</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8 | TxfifoUndrn | Fifo Underrun (TxfifoUndrn)<br>Applies to IN endpoints only.<br>The core generates this interrupt when it detects a transmit FIFC<br>underrun condition in threshold mode for this endpoint.<br>Values:<br>• 0x1 (ACTIVE): Fifo Underrun interrupt<br>• 0x0 (INACTIVE): No Fifo Underrun interrupt<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7 | TxFEmp      | Transmit FIFO Empty (TxFEmp)<br>This bit is valid only for IN Endpoints<br>This interrupt is asserted when the TxFIFO for this endpoint is<br>either half or completely empty. The half or completely empty<br>status is determined by the TxFIFO Empty Level bit in the Core<br>AHB Configuration register (GAHBCFG.NPTxFEmpLvI)).<br>Values:<br>• 0x1 (ACTIVE): Transmit FIFO Empty interrupt<br>• 0x0 (INACTIVE): No Transmit FIFO Empty interrupt<br>Value After Reset: 0x1                                                                                                                                                                                                                                                                            |
| 6 | INEPNakEff  | <ul> <li>IN Endpoint NAK Effective (INEPNakEff)<br/>Applies to periodic IN endpoints only.<br/>This bit can be cleared when the application clears the IN endpoint<br/>NAK by writing to DIEPCTLn.CNAK.<br/>This interrupt indicates that the core has sampled the NAK bit<br/>Set (either by the application or by the core).<br/>The interrupt indicates that the IN endpoint NAK bit Set by the<br/>application has taken effect in the core.<br/>This interrupt does not guarantee that a NAK handshake is sent on<br/>the USB. A STALL bit takes priority over a NAK bit.<br/>Values:</li> <li>• 0x1 (ACTIVE): IN Endpoint NAK Effective interrupt<br/>• 0x0 (INACTIVE): No IN Endpoint NAK Effective interrupt<br/>Value After Reset: 0x0</li> </ul> |
| 5 | INTknEPMis  | <ul> <li>IN Token Received with EP Mismatch (INTknEPMis)<br/>Applies to non-periodic IN endpoints only.</li> <li>Indicates that the data in the top of the non-periodic TxFIFC<br/>belongs to an endpoint other than the one for which the IN token<br/>was received. This interrupt is asserted on the endpoint for which<br/>the IN token was received.</li> <li>Values:         <ul> <li>0x1 (ACTIVE): IN Token Received with EP Mismatch interrupt</li> <li>0x0 (INACTIVE): No IN Token Received with EP Mismatch<br/>interrupt</li> </ul> </li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                 |
| 4 | INTknTXFEmp | <ul> <li>IN Token Received When TxFIFO is Empty (INTknTXFEmp)<br/>Applies to non-periodic IN endpoints only.</li> <li>Indicates that an IN token was received when the associated<br/>TxFIFO (periodic/non-periodic) was empty. This interrupt is<br/>asserted on the endpoint for which the IN token was received.</li> <li>Values:</li> <li>• 0x1 (ACTIVE): IN Token Received when TxFIFO Empty Interrupt</li> <li>• 0x0 (INACTIVE): No IN Token Received when TxFIFO Empty<br/>interrupt</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                     |



| 2 | AHBErr    | <ul> <li>AHB Error (AHBErr)</li> <li>Applies to IN and OUT endpoints.</li> <li>This is generated only in Internal DMA mode when there is an AHE error during an AHB read/write. The application can read the corresponding endpoint DMA address register to get the error address.</li> <li>Values:</li> <li>0x1 (ACTIVE): AHB Error interrupt</li> <li>0x0 (INACTIVE): No AHB Error Interrupt</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                             |
|---|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | EPDisbld  | Endpoint Disabled Interrupt (EPDisbld)<br>Applies to IN and OUT endpoints.<br>This bit indicates that the endpoint is disabled per the application's<br>request.<br>Values:<br>• 0x1 (ACTIVE): Endpoint Disabled Interrupt<br>• 0x0 (INACTIVE): No Endpoint Disabled Interrupt<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0 | XferCompl | <ul> <li>Transfer Completed Interrupt (XferCompl)</li> <li>Applies to IN and OUT endpoints.</li> <li>When Scatter/Gather DMA mode is enabled</li> <li>For IN endpoint this field indicates that the requested data from the descriptor is moved from external system memory to interna FIFO.</li> <li>For OUT endpoint this field indicates that the requested data from the internal FIFO is moved to external system memory. This interrupt is generated only when the corresponding endpoin descriptor is closed, and the IOC bit for the corresponding descriptor is set.</li> <li>Values:</li> <li>0x1 (ACTIVE): Transfer Completed Interrupt</li> <li>0x0 (INACTIVE): No Transfer Complete Interrupt</li> <li>Value After Reset: 0x0</li> </ul> |

## 22.2.31 DIEPDMA0: Device IN endpoint 0 DMA address register

#### DIEPDMA0=0x5000\_0914

|          |    |      |       |    |      |      |    |                          |                                          |                                          |                                          |                                          |                                          |                                          |                                          |                                 |                                          |                                          |                                 |                                          | _     |                                          |
|----------|----|------|-------|----|------|------|----|--------------------------|------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|---------------------------------|------------------------------------------|------------------------------------------|---------------------------------|------------------------------------------|-------|------------------------------------------|
| 27 26 25 | 24 | 23 2 | 2 21  | 20 | 19 1 | 8 17 | 16 | 15 14                    | 13                                       | 12                                       | 11                                       | 10                                       | 9                                        | 8                                        | 7                                        | 6                               | 5                                        | 4                                        | 3                               | 2                                        | 1     | 0                                        |
|          |    |      |       |    |      |      |    |                          |                                          |                                          |                                          |                                          |                                          |                                          |                                          |                                 |                                          |                                          |                                 |                                          |       |                                          |
|          |    |      |       |    |      | D    | MA | Addr                     |                                          |                                          |                                          |                                          |                                          |                                          |                                          |                                 |                                          |                                          |                                 |                                          |       |                                          |
|          |    |      |       |    |      |      |    |                          |                                          |                                          |                                          |                                          |                                          |                                          |                                          |                                 |                                          |                                          |                                 |                                          |       |                                          |
|          |    |      |       |    |      |      | 0  |                          |                                          |                                          |                                          |                                          |                                          |                                          |                                          |                                 |                                          |                                          |                                 |                                          |       |                                          |
|          |    |      |       |    |      |      | RV | I                        |                                          |                                          |                                          |                                          |                                          |                                          |                                          |                                 |                                          |                                          |                                 |                                          |       |                                          |
|          |    |      |       |    |      |      |    |                          |                                          |                                          |                                          |                                          |                                          |                                          |                                          |                                 |                                          |                                          |                                 |                                          |       |                                          |
| 31<br>0  |    | DN   | IAAdd | r  |      |      |    |                          | ndica                                    | ates                                     | the                                      | base                                     | e poi                                    | nter                                     | for                                      | the                             | des                                      | cript                                    | or lis                          | st                                       |       |                                          |
|          |    |      |       |    |      |      | D  | 0<br>0<br>31 DMAAddr DM/ | DMAAddr<br>0<br>RW<br>31 DMAAddr DMAAddr | DMAAddr O RW 31 DMAAddr DMAAddr | DMAAddr<br>0<br>RW<br>31 DMAAddr DMAAddr | DMAAddr<br>0<br>RW<br>31 DMAAddr DMAAddr | DMAAddr O RW 31 DMAAddr DMAAddr | DMAAddr<br>0<br>RW<br>31 DMAAddr DMAAddr | 0<br> | DMAAddr<br>0<br>RW<br>31 DMAAddr DMAAddr |



# 22.2.32 DTXFSTS0: Device IN endpoint transmit FIFO status register 0

#### DTXFSTS0=0x5000\_0918

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-------------------------------------------------|---------------------------------------|
| Reserved                                        | INEPTxFSpcAvail                       |
| -                                               | 0x0040                                |
|                                                 | R                                     |

| 15 | INEPTxFSpcAvail | IN Endpoint TxFIFO Space Avail (INEPTxFSpcAvail)                    |
|----|-----------------|---------------------------------------------------------------------|
| 0  |                 | Indicates the amount of free space available in the Endpoin TxFIFO. |
|    |                 | Values are in terms of 32-bit words.                                |
|    |                 | <ul> <li>16'h0: Endpoint TxFIFO is full</li> </ul>                  |
|    |                 | 16'h1: 1 word available                                             |
|    |                 | <ul> <li>16'h2: 2 words available</li> </ul>                        |
|    |                 | <ul> <li>16'hn: n words available (where 0 n 32,768)</li> </ul>     |
|    |                 | • 16'h8000: 32,768 words available                                  |
|    |                 | Others: Reserved                                                    |

### 22.2.33 DIEPDMAB0: Device IN endpoint 16 buffer address register

### DIEPDMAB0=0x5000\_091C

| 31       30       29       28       27       26       25       24       23       22       21       20       19       18       17       16       15       14       13       12       11       10       9       8       7       6       5       4       3       2       1         DMABufferAddr         0 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMABufferAddr<br>0                                                                                                                                                                                                                                                                                      |
| DMABufferAddr<br>0                                                                                                                                                                                                                                                                                      |
| 0<br>P                                                                                                                                                                                                                                                                                                  |
| 0<br>D                                                                                                                                                                                                                                                                                                  |
| <u> </u>                                                                                                                                                                                                                                                                                                |
| P                                                                                                                                                                                                                                                                                                       |
| Л                                                                                                                                                                                                                                                                                                       |

| 31<br>0 | DMABufferAddr | Holds the current buffer address. This register is updated as and when the data transfer for the corresponding end point is in |
|---------|---------------|--------------------------------------------------------------------------------------------------------------------------------|
|         |               | progress.                                                                                                                      |



# 22.2.34 DIEPCTLi : Device control IN endpoint i control register

For I = 1; I <= OTG\_NUM\_IN\_EPS

# DIEPCTLi =0x5000\_0920

| 31    | 30    | 29 28    | 27   | 26   | 25 24   | 23 2 | 22 21 | 20       | 19 18  | 17     | 16   | 15       | 14 13 <sup>-</sup> | 2 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2 | 1 | 0 |
|-------|-------|----------|------|------|---------|------|-------|----------|--------|--------|------|----------|--------------------|------|----|---|---|---|---|-----|---|---|---|---|---|
| EPEna | EPDis | Reserved | SNAK | CNAK | TVENIUM |      | Stall | Reserved | EPType | NAKSts | DPID | USBActEP | Reserved           |      |    |   |   |   |   | MPS |   |   |   |   |   |
| 0     | 0     | -        | 0    | 0    | C       | )    | 0     | -        | 0      | 0      | 0    | 0        | -                  |      |    |   |   |   |   | 0   |   |   |   |   |   |
| RW    | RW    |          | W    | W    | RV      | N    | RW    | -        | R      | R      | R    | R        | -                  |      |    |   |   |   |   | RW  |   |   |   |   |   |

| 04 | EDE   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 | EPEna | <ul> <li>Endpoint Enable (EPEna)</li> <li>Applies to IN and OUT endpoints.</li> <li>When Scatter/Gather DMA mode is enabled,</li> <li>-For IN endpoints this bit indicates that the descriptor structure and data buffer with data ready to transmit is setup.</li> <li>-For OUT endpoint it indicates that the descriptor structure and data buffer to receive data is setup.</li> <li>The core clears this bit before setting any of the following interrupts on this endpoint:</li> <li>-SETUP Phase Done</li> <li>-Endpoint Disabled</li> <li>-Transfer Completed</li> <li>Note: For control endpoints in DMA mode, this bit must be set to be able to transfer SETUP data packets in memory.</li> <li>Values:</li> <li>0x1 (ACTIVE): Enable Endpoint</li> <li>0x0 (INACTIVE): No Action</li> <li>Value After Reset: 0x0</li> </ul> |
| 30 | EPDis | Endpoint Disable (EPDis)<br>Applies to IN and OUT endpoints.<br>The application sets this bit to stop transmitting/receiving data or<br>an endpoint, even before the transfer for that endpoint is complete<br>The application must wait for the Endpoint Disabled interrup<br>before treating the endpoint as disabled. The core clears this b<br>before setting the Endpoint Disabled interrupt. The application<br>must set this bit only if Endpoint Enable is already set for thi<br>endpoint.<br>Values:<br>• 0x1 (ACTIVE): Disable Endpoint<br>• 0x0 (INACTIVE): No Action<br>Value After Reset: 0x0                                                                                                                                                                                                                             |
| 27 | SNAK  | Set NAK (SNAK)<br>A write to this bit sets the NAK bit for the endpoint.<br>Using this bit, the application can control the transmission of NA<br>handshakes on an endpoint. The core can also Set this bit for a<br>endpoint after a SETUP packet is received on that endpoint.<br>Values:<br>• 0x1 (ACTIVE): Set NAK<br>• 0x0 (INACTIVE): No Set NAK<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                        |



| 26       | CNAK   | Clear NAK (CNAK)<br>A write to this bit clears the NAK bit for the endpoint.<br>Values:<br>• 0x1 (ACTIVE): Clear NAK<br>• 0x0 (INACTIVE): No Clear NAK<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25<br>22 | TxFNum | <ul> <li>TxFIFO Number (TxFNum)</li> <li>Dedicated FIFO Operation: These bits specify the FIFO number associated with this endpoint. Each active IN endpoint must be programmed to a separate FIFO number. This field is valid only for IN endpoints.</li> <li>Values:</li> <li>0x3 (TXFIFO3): Tx FIFO 3</li> <li>0x4 (TXFIFO4): Tx FIFO 4</li> <li>0x0 (TXFIFO0): Tx FIFO 0</li> <li>0x1 (TXFIFO1): Tx FIFO 1</li> <li>0x2 (TXFIFO2): Tx FIFO 2</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 21       | Stall  | <ul> <li>STALL Handshake (Stall)</li> <li>Applies to non-control, non-isochronous IN and OUT endpoints only.</li> <li>The application sets this bit to stall all tokens from the USB host to this endpoint. If a NAK bit, Global Non-periodic IN NAK, or Global OUT NAK is set along with this bit, the STALL bit takes priority. Only the application can clear this bit, never the core.</li> <li>Applies to control endpoints only.</li> <li>The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit, Global Non-periodic IN NAK, or Global OUT NAK is set along with this bit, the STALL bit takes priority. Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.</li> <li>Values: <ul> <li>0x1 (ACTIVE): STALL All Active Tokens</li> <li>0x0 (INACTIVE): STALL All non-active tokens Value After Reset: 0x0</li> </ul> </li> </ul> |
| 19<br>18 | ЕРТуре | Endpoint Type (EPType) This is the transfer type supported by this<br>logical endpoint.<br>• 2'b00: Control<br>• 2'b01: Isochronous<br>• 2'b10: Bulk<br>• 2'b11: Interrupt<br>Values:<br>• 0x2 (BULK): Bulk<br>• 0x3 (INTERRUP): Interrupt<br>• 0x0 (CONTROL): Control<br>• 0x1 (ISOCHRONOUS): Isochronous<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |



| 17      | NAKSts   | NAK Status (NAKSts)<br>Indicates the following:<br>• 1'b0: The core is transmitting non-NAK handshakes based on the<br>FIFO status.                                                                                                                                                                                                                                                                                                                                             |
|---------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |          | <ul> <li>1'b1: The core is transmitting NAK handshakes on this endpoint.</li> <li>When either the application or the core sets this bit:</li> <li>The core stops receiving any data on an OUT endpoint, even it there is space in the RxFIFO to accommodate the incoming packet.</li> </ul>                                                                                                                                                                                     |
|         |          | <ul> <li>For non-isochronous IN endpoints: The core stops transmitting<br/>any data on an IN endpoint, even if there data is available in the<br/>TxFIFO.</li> </ul>                                                                                                                                                                                                                                                                                                            |
|         |          | <ul> <li>For isochronous IN endpoints: The core sends out a zero-lengt<br/>data packet, even if there data is available in the TxFIFO.<br/>Irrespective of this bit's setting, the core always responds t<br/>SETUP data packets with an ACK handshake.<br/>Values:</li> <li>0x1 (NAK):</li> </ul>                                                                                                                                                                              |
|         |          | The core is transmitting NAK handshakes on this endpoint • 0x0 (NONNAK):                                                                                                                                                                                                                                                                                                                                                                                                        |
|         |          | The core is transmitting non-NAK handshakes based on the FIF(<br>status<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                               |
| 16      | DPID     | Endpoint Data PID (DPID)<br>Applies to interrupt/bulk IN and OUT endpoints only.<br>Contains the PID of the packet to be received or transmitted on thi<br>endpoint. The application must program the PID of the first packe<br>to be received or transmitted on this endpoint, after the endpoir<br>is activated. The applications use the SetD1PID and SetD0PII<br>fields of this register to program either DATA0 or DATA1 PID.<br>• 1'b0: DATA0<br>• 1'b1: DATA1<br>Values: |
|         |          | <ul> <li>0x0 (DATA0EVENFRM): DATA0 or Even Frame</li> <li>0x1 (DATA10DDFRM): DATA1 or Odd Frame</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                      |
| 15      | USBActEP | USB Active Endpoint (USBActEP)<br>Indicates whether this endpoint is active in the currer<br>configuration and interface. The core clears this bit for a<br>endpoints (other than EP 0) after detecting a USB reset. After<br>receiving the SetConfiguration and SetInterface commands, th<br>application must program endpoint registers accordingly and set<br>this bit.<br>Values:<br>• 0x0 (DISABLED): Not Active                                                           |
|         |          | • 0x1 (ENABLED): USB Active Endpoint Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 10<br>0 | MPS      | Maximum Packet Size (MPS)<br>The application must program this field with the maximum packet<br>size for the current logical endpoint. This value is in bytes.<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                        |



# 22.2.35 DIEPINTi: Device IN endpoint I interrupt register

For I = 1; I <= OTG\_NUM\_IN\_EPS

### DIEPINT0=0x5000\_0928

| 31 30 29 28 27 26 25 24 23 22 21 | 20 19 18 17 16 15 | 14         | 13        | 12      | 11 10    | 9       | 8           | 7      | 6          | 5          | 4          | 3        | 2      | 1        | 0         |
|----------------------------------|-------------------|------------|-----------|---------|----------|---------|-------------|--------|------------|------------|------------|----------|--------|----------|-----------|
| Reserved                         |                   | NYETIntrpt | NAKIntrpt | BbleErr | Reserved | BNAIntr | TxfifoUndrn | TxFEmp | INEPNakEff | INTknEPMis | INTknTXFEm | Reserved | AHBErr | EPDisbld | XferCompl |
| -                                |                   | 0          | 0         | 0       | -        | 0       | 0           | 1      | 0          | 0          | 0          | -        | 0      | 0        | 0         |
| -                                |                   | RW         | RW        | RW      | -        | RW      | RW          | R      | RW         | RW         | RW         | -        | RW     | RW       | RW        |

| 14 | NYETIntrpt  | NYET Interrupt (NYETIntrpt)<br>The core generates this interrupt when a NYET response is<br>transmitted for a non isochronous OUT endpoint.<br>Values:<br>• 0x1 (ACTIVE): NYET Interrupt<br>• 0x0 (INACTIVE): No NYET interrupt<br>Value After Reset: 0x0                                                                                                                                                                                |
|----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13 | NAKIntrpt   | <ul> <li>NAK Interrupt (NAKInterrupt)</li> <li>The core generates this interrupt when a NAK is transmitted or received by the device. In case of isochronous IN endpoints the interrupt gets generated when a zero length packet is transmitted due to un-availability of data in the TXFifo.</li> <li>Values:</li> <li>0x1 (ACTIVE): NAK Interrupt</li> <li>0x0 (INACTIVE): No NAK interrupt</li> <li>Value After Reset: 0x0</li> </ul> |
| 12 | BbleErr     | NAK Interrupt (BbleErr)<br>The core generates this interrupt when babble is received for the<br>endpoint.<br>Values:<br>• 0x1 (ACTIVE): BbleErr interrupt<br>• 0x0 (INACTIVE): No interrupt<br>Value After Reset: 0x0                                                                                                                                                                                                                    |
| 9  | BNAIntr     | <ul> <li>BNA (Buffer Not Available) Interrupt (BNAIntr)</li> <li>The core generates this interrupt when the descriptor accessed is not ready for the Core to process, such as Host busy or DMA done. Values:</li> <li>0x1 (ACTIVE): BNA interrupt</li> <li>0x0 (INACTIVE): No BNA interrupt Value After Reset: 0x0</li> </ul>                                                                                                            |
| 8  | TxfifoUndrn | <ul> <li>Fifo Underrun (TxfifoUndrn)</li> <li>Applies to IN endpoints Only</li> <li>This bit is valid only If thresholding is enabled. The core generates this interrupt when it detects a transmit FIFO underrun condition for this endpoint.</li> <li>Values:</li> <li>• 0x1 (ACTIVE): TxFIFO Underrun interrupt</li> <li>• 0x0 (INACTIVE): No Tx FIFO Underrun interrupt</li> <li>Value After Reset: 0x0</li> </ul>                   |



| 7 | TxFEmp      | Transmit FIFO Empty (TxFEmp)<br>This bit is valid only for IN endpoints<br>This interrupt is asserted when the TxFIFO for this endpoint is<br>either half or completely empty. The half or completely empty<br>status is determined by the TxFIFO Empty Level bit in the Core<br>AHB Configuration register (GAHBCFG.NPTxFEmpLvI)).<br>Values:<br>• 0x1 (ACTIVE): Transmit FIFO Empty interrupt<br>• 0x0 (INACTIVE): No Transmit FIFO Empty interrupt                                                                                                                                                                                                                                                                                       |
|---|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6 | INEPNakEff  | Value After Reset: 0x1<br>IN Endpoint NAK Effective (INEPNakEff)<br>Applies to periodic IN endpoints only.<br>This bit can be cleared when the application clears the IN endpoint<br>NAK by writing to DIEPCTLn.CNAK.<br>This interrupt indicates that the core has sampled the NAK bit<br>Set (either by the application or by the core). The interrupt indicates<br>that the IN endpoint NAK bit Set by the application has taken effect<br>in the core.<br>This interrupt does not guarantee that a NAK handshake is sent or<br>the USB. A STALL bit takes priority over a NAK bit.<br>Values:<br>• 0x1 (ACTIVE): IN Endpoint NAK Effective interrupt<br>• 0x0 (INACTIVE): No Endpoint NAK Effective interrupt<br>Value After Reset: 0x0 |
| 5 | INTknEPMis  | <ul> <li>IN Token Received with EP Mismatch (INTknEPMis)<br/>Applies to non-periodic IN endpoints only.</li> <li>Indicates that the data in the top of the non-periodic TxFIFC<br/>belongs to an endpoint other than the one for which the IN toker<br/>was received. This interrupt is asserted on the endpoint for which<br/>the IN token was received.</li> <li>Values: <ul> <li>0x1 (ACTIVE): IN Token Received with EP Mismatch interrupt</li> <li>0x0 (INACTIVE): No IN Token Received with EP Mismatch<br/>interrupt</li> <li>Value After Reset: 0x0</li> </ul> </li> </ul>                                                                                                                                                          |
| 4 | INTknTXFEmp | <ul> <li>IN Token Received When TxFIFO is Empty (INTknTXFEmp)<br/>Applies to non-periodic IN endpoints only.</li> <li>Indicates that an IN token was received when the associated<br/>TxFIFO (periodic/non-periodic) was empty. This interrupt is<br/>asserted on the endpoint for which the IN token was received.</li> <li>Values:</li> <li>0x1 (ACTIVE): IN Token Received Interrupt</li> <li>0x0 (INACTIVE): No IN Token Received interrupt</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                  |
| 2 | AHBErr      | <ul> <li>AHB Error (AHBErr)</li> <li>Applies to IN and OUT endpoints.</li> <li>This is generated only in Internal DMA mode when there is an AHE error during an AHB read/write. The application can read the corresponding endpoint DMA address register to get the error address.</li> <li>Values:</li> <li>0x1 (ACTIVE): AHB Error interrupt</li> <li>0x0 (INACTIVE): No AHB Error Interrupt</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                   |



| 1 | EPDisbld  | Endpoint Disabled Interrupt (EPDisbld)<br>Applies to IN and OUT endpoints.<br>This bit indicates that the endpoint is disabled per the application's<br>request.<br>Values:<br>• 0x1 (ACTIVE): Endpoint Disabled Interrupt<br>• 0x0 (INACTIVE): No Endpoint Disabled Interrupt<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | XferCompl | <ul> <li>Transfer Completed Interrupt (XferCompl)</li> <li>Applies to IN and OUT endpoints.</li> <li>When Scatter/Gather DMA mode is enabled</li> <li>For IN endpoint this field indicates that the requested data from the descriptor is moved from external system memory to internal FIFO.</li> <li>For OUT endpoint this field indicates that the requested data from the internal FIFO is moved to external system memory. This interrupt is generated only when the corresponding endpoin descriptor is closed, and the IOC bit for the corresponding descriptor is set.</li> <li>Values:</li> <li>0x1 (ACTIVE): Transfer Complete Interrupt</li> <li>0x0 (INACTIVE): No Transfer Complete Interrupt</li> <li>Value After Reset: 0x0</li> </ul> |

### 22.2.36 DIEPDMAi: Device IN endpoint I DMA address register

For I = 1; I <= OTG\_NUM\_IN\_EPS

|    |    |      |    |    |    |         |    |    |      |      |    |    |    |    |    |     |    |              |    |    |    |      |      | -     |       |     |      | •/   |     |      |     |
|----|----|------|----|----|----|---------|----|----|------|------|----|----|----|----|----|-----|----|--------------|----|----|----|------|------|-------|-------|-----|------|------|-----|------|-----|
| 31 | 30 | ) 29 | 28 | 27 | 26 | 25      | 24 | 23 | 3 22 | 21   | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13           | 12 | 11 | 10 | 9    | 8    | 7     | 6     | 5   | 4    | 3    | 2   | 1    | 0   |
|    |    |      |    |    |    |         |    |    |      |      |    |    |    |    |    |     |    |              |    |    |    |      |      |       |       |     |      |      |     |      |     |
|    |    |      |    |    |    |         |    |    |      |      |    |    |    | D  | MA | Ado | dr |              |    |    |    |      |      |       |       |     |      |      |     |      |     |
|    |    |      |    |    |    |         |    |    |      |      |    |    |    |    |    |     |    |              |    |    |    |      |      |       |       |     |      |      |     |      |     |
|    |    |      |    |    |    |         |    |    |      |      |    |    |    |    | (  | )   |    |              |    |    |    |      |      |       |       |     |      |      |     |      |     |
|    |    |      |    |    |    |         |    |    |      |      |    |    |    |    | R  | W   |    |              |    |    |    |      |      |       |       |     |      |      |     |      |     |
|    |    |      |    |    | -  |         |    |    |      |      |    |    |    |    |    |     |    |              |    |    |    |      |      |       |       |     |      |      |     |      |     |
|    |    |      |    |    |    | 31<br>0 |    | I  | DMA  | Addı | r  |    |    |    |    |     |    | stari<br>dpo |    |    |    | f th | e ex | xterr | nal r | nem | nory | for  | sto | ring | or  |
|    |    |      |    |    |    | Ũ       |    |    |      |      |    |    |    |    |    |     |    |              |    |    |    | c t  | hie  | fiold | eto   | roc | con  | trol |     | T da | ota |

| 0 fr<br>N<br>tt<br>C<br>T<br>a<br>a<br>•<br>• | lolds the start address of the external memory for storing or<br>etching endpoint data.<br>lote: For control endpoints, this field stores control OUT data<br>backets as well as SETUP transaction data packets. When more<br>han three SETUP packets are received back-to-back, the SETUP<br>lata packet in the memory is overwritten.<br>This register is incremented on every AHB transaction. The<br>application can give only a DWORD-aligned address.<br>When Scatter/Gather DMA mode is not enabled, the application<br>programs the start address value in this field.<br>When Scatter/Gather DMA mode is enabled, this field indicates<br>he base pointer for the descriptor list. |
|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|



# DIEPDMAi =0x5000\_0934

DTXFSTSi =0x5000 0938

## 22.2.37 DTXFSTSi: Device IN endpoint transmit FIFO status register i

Device IN Endpoint Transmit FIFO Status Register i. Device IN Endpoint I DMA Address Register

|    |      |    |    |    |    |        |    |     |     |      |     |     |      |    |    |                                           |                                                                   |                                        |                                       |                                             |                                               |    |                    |            |           |     |      |     |   | 0.00 |      | °_°  | 550  |
|----|------|----|----|----|----|--------|----|-----|-----|------|-----|-----|------|----|----|-------------------------------------------|-------------------------------------------------------------------|----------------------------------------|---------------------------------------|---------------------------------------------|-----------------------------------------------|----|--------------------|------------|-----------|-----|------|-----|---|------|------|------|------|
| 31 | 30 2 | 92 | 28 | 27 | 26 | 62     | 5  | 24  | 23  | 3 22 | 21  | 20  | 19   | 18 | 17 | 16                                        | 15                                                                | 14                                     | 13                                    | 12                                          | 11                                            | 10 | 9                  | 8          | 7         | 6   | 5    | 5   | 4 | 3    | 2    | 1    | 0    |
|    |      |    |    |    |    |        | Re | ese | erv | ed   |     |     |      |    |    |                                           |                                                                   |                                        |                                       |                                             |                                               | IN | 1EF                | PTx        | =Sp       | cAv | 'ail |     |   |      |      |      |      |
|    |      |    |    |    |    |        |    |     | -   |      |     |     |      |    |    |                                           |                                                                   |                                        |                                       |                                             |                                               |    |                    | 0x0        | 004       | C   |      |     |   |      |      |      |      |
|    |      |    |    |    |    |        |    |     |     |      |     |     |      |    |    |                                           |                                                                   |                                        |                                       |                                             |                                               |    |                    |            | R         |     |      |     |   |      |      |      |      |
|    |      |    |    |    |    | 1<br>0 | 5  |     |     | INEF | ͲxϜ | Spc | Avai | il |    | Ind<br>Txl<br>Val<br>• 16<br>• 16<br>• 16 | icate<br>FIFC<br>ues<br>S'h0:<br>S'h1:<br>S'h2:<br>S'h2:<br>S'hn: | es t<br>are<br>En<br>1 w<br>2 w<br>n w | in te<br>dpoi<br>vord<br>vord<br>vord | amo<br>erms<br>int T<br>ava<br>s av<br>s av | unt<br>of :<br>xFIF<br>ilab<br>ailal<br>ailal |    | it w<br>fui<br>whe | ords<br>Il | ace<br>s. | ava | ilat | ble |   |      | e Er | ndpo | bint |

• 16'h8000: 32,768 words available

Others: Reserved

## 22.2.38 DIEPDMABi: Device IN endpoint I buffer address register

Device IN Endpoint I Buffer Address Register.

For I = 1; I <= OTG\_NUM\_IN\_EPS

### DIEPDMABi =0x5000\_093C

|    |                                                                                                     |      |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | UNU |   |   |   |
|----|-----------------------------------------------------------------------------------------------------|------|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----|---|---|---|
| 31 | 30                                                                                                  | ) 29 | 28 | 27 | 26 | 25 | 24 | 23 | 3 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
|    | 1 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1<br>DMABufferAddr |      |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     |   |   |   |
|    | DMABufferAddr                                                                                       |      |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     |   |   |   |
|    | DMABufferAddr                                                                                       |      |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     |   |   |   |
|    | DMABufferAddr                                                                                       |      |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     |   |   |   |
|    |                                                                                                     |      |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     |   |   |   |
|    |                                                                                                     |      |    |    |    |    |    |    |      |    |    |    |    |    | (  | )  |    |    |    |    |    |   |   |   |   |   |   |     |   |   |   |
|    |                                                                                                     |      |    |    |    |    |    |    |      |    |    |    |    |    | F  | {  |    |    |    |    |    |   |   |   |   |   |   |     |   |   |   |
|    |                                                                                                     |      |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     |   |   |   |

| 31<br>0 | DMABufferAddr | Holds the current buffer address. This register is updated as and<br>when the data transfer for the corresponding end point is in |
|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------|
|         |               | progress.<br>This register is present only in Scatter/Gather DMA mode.<br>Otherwise this field is reserved.                       |



# 22.2.39 DOEPCTL0: Device control OUT endpoint 0 control register

|       |       |          |      |      |       |          |    |    |    |        |        |          |          |    |    |    |    |    |   | D        | OE | PC | TLO | =0> | <b>x50</b> | 00_ | 0800 |
|-------|-------|----------|------|------|-------|----------|----|----|----|--------|--------|----------|----------|----|----|----|----|----|---|----------|----|----|-----|-----|------------|-----|------|
| 31    | 30    | 29 28    | 27   | 26   | 25 24 | 23       | 22 | 21 | 20 | 19 18  | 17     | 16       | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8        | 7  | 6  | 5   | 4   | 3          | 2   | 1 C  |
| EPEna | EPDis | Reserved | SNAK | CNAK |       | Reserved |    |    |    | EPType | NAKSts | Reserved | USBActEP |    |    |    |    |    |   | Reserved |    |    |     |     |            |     | MPS  |
| 0     | 0     | -        | 0    | 0    |       | - (      |    |    |    | 0      | 0      | -        | 1        |    |    |    |    |    |   | -        |    |    |     |     |            |     | 0    |
| RW    | RW    | -        | W    | W    |       |          |    | RW | RW | R      | R      | -        | R        |    |    |    |    |    |   |          |    |    |     |     |            |     | R    |

| 31 | EPEna | <ul> <li>Endpoint Enable (EPEna)</li> <li>When Scatter/Gather DMA mode is enabled, for OUT endpoints this bit indicates that the descriptor structure and data buffer to receive data is setup.</li> <li>The core clears this bit before setting any of the following interrupts on this endpoint:</li> <li>SETUP Phase Done</li> <li>Endpoint Disabled</li> <li>Transfer Completed</li> <li>Note: This bit must be set for the core to transfer SETUP data packets into memory.</li> <li>Values:</li> <li>0x1 (ACTIVE): Enable Endpoint</li> <li>0x0 (INACTIVE): No action</li> </ul> |
|----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30 | EPDis | Value After Reset: 0x0<br>Endpoint Disable (EPDis)<br>The application cannot disable control OUT endpoint 0.<br>Values:<br>• 0x0 (INACTIVE): No Endpoint disable<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                             |
| 27 | SNAK  | Set NAK (SNAK)<br>A write to this bit sets the NAK bit for the endpoint. Using this bit,<br>the application can control the transmission of NAK handshakes<br>on an endpoint. The core can also set bit on a Transfer Completed<br>interrupt, or after a SETUP is received on the endpoint.<br>Values:<br>• 0x0 (NOSET): No action<br>• 0x1 (SET): Set NAK<br>Value After Reset: 0x0                                                                                                                                                                                                   |
| 26 | CNAK  | Clear NAK (CNAK)<br>A write to this bit clears the NAK bit for the endpoint.<br>Values:<br>• 0x1 (CLEAR): Clear NAK<br>• 0x0 (NOCLEAR): No action<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                            |
| 21 | Stall | <ul> <li>STALL Handshake (Stall)</li> <li>The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit or Global OUT NAK is Set along with this bit, the STALL bit takes priority. Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.</li> <li>Values: <ul> <li>0x1 (ACTIVE): Stall Handshake</li> <li>0x0 (INACTIVE): No Stall Value After Reset: 0x0</li> </ul> </li> </ul>                                                                                  |



| 20       | Snp      | Snoop Mode (Snp)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |          | This bit configures the endpoint to Snoop mode. In Snoop mode,<br>the core does not check the correctness of OUT packets before<br>transferring them to application memory.<br>Values:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|          |          | • 0x0 (DISABLED): Snoop Mode disabled<br>• 0x1 (ENABLED): Snoop Mode enabled<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 19<br>18 | EPType   | Endpoint Type (EPType)<br>Hardcoded to 2'b00 for control.<br>Values:<br>• 0x0 (ACTIVE): Endpoint Control 0<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 17       | NAKSts   | <ul> <li>NAK Status (NAKSts)<br/>Indicates the following:</li> <li>1'b0: The core is transmitting non-NAK handshakes based on the<br/>FIFO status.</li> <li>1'b1: The core is transmitting NAK handshakes on this endpoint.<br/>When either the application or the core sets this bit, the core stops<br/>receiving data, even If there is space in the RxFIFO to<br/>accommodate the incoming packet. Irrespective of this bit's<br/>setting, the core always responds to SETUP data packets with an<br/>ACK handshake.<br/>Values:</li> <li>0x1 (ACTIVE):<br/>The core is transmitting NAK handshakes on this endpoint</li> <li>0x0 (INACTIVE):<br/>The core is transmitting non-NAK handshakes based on the FIFO<br/>status</li> <li>Value After Reset: 0x0</li> </ul> |
| 15       | USBActEP | USB Active Endpoint (USBActEP)<br>This bit is always set to 1, indicating that a control endpoint 0 is<br>always active in all configurations and interfaces.<br>Values:<br>• 0x1 (ACTIVE): USB Active Endpoint 0<br>Value After Reset: 0x1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1<br>0   | MPS      | Maximum Packet Size (MPS)<br>The maximum packet size for control OUT endpoint 0 is the same<br>as what is programmed in control IN Endpoint 0.<br>• 2'b00: 64 bytes<br>• 2'b01: 32 bytes<br>• 2'b10: 16 bytes<br>• 2'b11: 8 bytes<br>Values:<br>• 0x2 (BYTE16): 16 bytes<br>• 0x3 (BYTE8): 8 bytes<br>• 0x1 (BYTE32): 32 bytes<br>• 0x0 (BYTE64): 64 bytes<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                      |



# 22.2.40 DOEPINT0: Device OUT endpoint 0 interrupt register

#### DOEPINT0=0x5000\_0B08

| 31 30 29 28 27 26 25 24 | 123 22 21 20 10 18 1 | 7 16 15                                              | 14                                                          | 1२                                        | 12                                             | 11 10                                                                                   | ۵                                        | 8                                       | 7                                         | 6                                   | 5              | 4                       | 3           | 2             | 1             | 0         |
|-------------------------|----------------------|------------------------------------------------------|-------------------------------------------------------------|-------------------------------------------|------------------------------------------------|-----------------------------------------------------------------------------------------|------------------------------------------|-----------------------------------------|-------------------------------------------|-------------------------------------|----------------|-------------------------|-------------|---------------|---------------|-----------|
| 01 00 20 20 21 20 20 24 |                      |                                                      |                                                             |                                           | 12                                             |                                                                                         | 9                                        |                                         |                                           |                                     |                |                         | 5           | 2             |               |           |
|                         | Reserved             |                                                      | NYETIntrpt                                                  | NAKIntrpt                                 | BbleErr                                        | Reserved                                                                                | BNAIntr                                  | OutPktErr                               | Reserved                                  | Back2BackS                          | StsPhseRcvd    | OUTTknEPdi              | SetUp       | AHBErr        | EPDisbld      | XferCompl |
|                         | -                    |                                                      | 0                                                           | 0                                         | 0                                              | -                                                                                       | 0                                        | 0                                       | -                                         | 0                                   | 0              | 0                       | 0           | 0             | 0             | 0         |
|                         |                      |                                                      | RW                                                          | RW                                        | RW                                             | -                                                                                       | RW                                       | RW                                      | -                                         | RW                                  | RW             | RW                      | RW          | RW            | RW            | RW        |
|                         |                      |                                                      |                                                             |                                           |                                                |                                                                                         |                                          |                                         |                                           |                                     |                |                         |             |               |               |           |
| 14                      | NYETIntrpt           | The<br>tran<br>Valu<br>• 0x <sup>2</sup><br>• 0x(    | cor<br>nsmit<br>ues:<br>1 (A<br>0 (IN                       | re g<br>tted<br>CTIV<br>NAC               | iene<br>for a<br>VE):<br>TIVE                  | (NYETIr<br>rates th<br>a non iso<br>NYET I<br>E): No N<br>et: 0x0                       | nis ii<br>ochro<br>Interi                | nterr<br>onou<br>rupt                   | is OL                                     | JT e                                |                |                         | ET r        | espo          | onse          | is        |
| 13                      | NAKIntrpt            | The<br>rece<br>inte<br>due<br>Valu<br>• 0x<br>• 0x   | eiveo<br>errupt<br>to u<br>ues:<br>1 (Al                    | e ge<br>d by<br>t ge<br>un-a<br>CTIV      | the<br>ts ge<br>vaila<br>ve:):<br>TIVE         | IAKInte<br>ates thi<br>device<br>enerated<br>bility of<br>NAK In<br>E): No N<br>et: 0x0 | s int<br>. In d<br>d wh<br>data<br>terru | érrup<br>case<br>en a<br>a in ti        | of is<br>zero<br>he T)                    | och<br>Ien                          | rono<br>gth p  | us II                   | N en        | idpoi         | nts t         | he        |
| 12                      | BbleErr              | The<br>end<br>Valu<br>• 0x <sup>-</sup><br>• 0x(     | core<br>lpoin<br>ues:<br>1 (A<br>0 (IN                      | e ge<br>nt.<br>CTIV<br>NAC                | ve):<br>TIVE                                   | BbleErr)<br>ates this<br>BbleErr<br>E): No B<br>et: 0x0                                 | r inte                                   | errup                                   | t                                         |                                     | abbl           | e is                    | rece        | ived          | for t         | he        |
| 9                       | BNAIntr              | The<br>not<br>Valu<br>• 0x <sup>2</sup><br>• 0x(     | read<br>read<br>ues:<br>1 (Al<br>0 (IN                      | e ge<br>dy fo<br>CTIV<br>NAC              | nera<br>the<br>VE):<br>TIVE                    | Availat<br>ates this<br>core to<br>BNA in<br>E): No B<br>et: 0x0                        | inte<br>proc<br>terru                    | rrupi<br>cess<br>pt                     | whe<br>sucl                               | en th                               | ie de          | scrip                   |             |               |               |           |
| 8                       | OutPktErr            | Appl<br>This<br>This<br>CRO<br>Valu<br>• 0x<br>• 0x( | lies<br>s inte<br>s inte<br>C err<br>ues:<br>1 (At<br>0 (IN | to C<br>errup<br>errup<br>ror f<br>CTIV   | OUT<br>ot is<br>ot is<br>or no<br>VE):<br>TIVE | or (OutF<br>endpoin<br>valid on<br>asserte<br>on-Isocl<br>OUT P<br>E): No C<br>et: 0x0  | its O<br>ily wl<br>d wl<br>nrone<br>acke | nÍy<br>hen f<br>hen f<br>ous (<br>t Err | he c<br>OUT<br>or                         | ore<br>pac                          | dete           |                         |             |               | o wo          | r a       |
| 6                       | Back2BackSETup       | Appl<br>This<br>to-b<br>info<br>Valu<br>• 0x<br>• 0x | lies<br>bit i<br>back<br>ormatues:<br>1 (Au<br>0 (IN        | to C<br>indic<br>SI<br>tion<br>CTI<br>JAC | contr<br>cates<br>ETU<br>abo<br>VE):<br>TIVE   | ETUP P<br>ol OUT<br>s that th<br>P pack<br>ut hand<br>Back-to<br>E): No B<br>et: 0x0    | endp<br>e col<br>kets<br>ling t<br>o-Ba  | ooint<br>re ha<br>for<br>his i<br>ck S  | s onl<br>is rec<br>this<br>nterro<br>ETUF | y.<br>ceive<br>s pa<br>upt,<br>P Pa | ed m<br>artici | iore f<br>ular<br>ts Re | than<br>enc | thre<br>dpoir | e ba<br>nt. F |           |



| 5 | StsPhseRcvd | <ul> <li>Status Phase Received for Control Write (StsPhseRcvd)</li> <li>This interrupt is valid only for Control OUT endpoints.</li> <li>This interrupt is generated only after the core has transferred all the data that the host has sent during the data phase of a control write transfer, to the system memory buffer.</li> <li>The interrupt indicates to the application that the host has switched from data phase to the status phase of a Control Write transfer.</li> <li>The application can use this interrupt to ACK or STALL the Status phase, after it has decoded the data phase.</li> <li>Values:</li> <li>0x1 (ACTIVE): Status Phase Received for Control Write</li> <li>0x0 (INACTIVE): No Status Phase Received for Control Write Value After Reset: 0x0</li> </ul> |
|---|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4 | OUTTknEPdis | <ul> <li>OUT Token Received When Endpoint Disabled (OUTTknEPdis)<br/>Applies only to control OUT endpoints.<br/>Indicates that an OUT token was received when the endpoint was<br/>not yet enabled. This interrupt is asserted on the endpoint for<br/>which the OUT token was received.<br/>Values:</li> <li>• 0x1 (ACTIVE): OUT Token Received When Endpoint Disabled</li> <li>• 0x0 (INACTIVE): No OUT Token Received When Endpoint<br/>Disabled</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                            |
| 3 | SetUp       | <ul> <li>SETUP Phase Done (SetUp)</li> <li>Applies to control OUT endpoints only.</li> <li>Indicates that the SETUP phase for the control endpoint is complete and no more back-to-back SETUP packets were received for the current control transfer. On this interrupt, the application can decode the received SETUP data packet.</li> <li>Values:</li> <li>0x1 (ACTIVE): SETUP Phase Done</li> <li>0x0 (INACTIVE): No SETUP Phase Done</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                      |
| 2 | AHBErr      | <ul> <li>AHB Error (AHBErr)</li> <li>Applies to IN and OUT endpoints.</li> <li>This is generated when there is an AHB error during an AHB read/write. The application can read the corresponding endpoint DMA address register to get the error address.</li> <li>Values:</li> <li>• 0x1 (ACTIVE): AHB Error interrupt</li> <li>• 0x0 (INACTIVE): No AHB Error Interrupt</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                       |
| 1 | EPDisbld    | Endpoint Disabled Interrupt (EPDisbld)<br>Applies to IN and OUT endpoints.<br>This bit indicates that the endpoint is disabled per the application's<br>request.<br>Values:<br>• 0x1 (ACTIVE): Endpoint Disabled Interrupt<br>• 0x0 (INACTIVE): No Endpoint Disabled Interrupt<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0 | XferCompl   | <ul> <li>Transfer Completed Interrupt (XferCompl)<br/>Applies to IN and OUT endpoints.</li> <li>For IN endpoint this field indicates that the requested data from<br/>the descriptor is moved from external system memory to internal<br/>FIFO.</li> <li>For OUT endpoint this field indicates that the requested data from<br/>the internal FIFO is moved to external system memory. This<br/>interrupt is generated only when the corresponding endpoint<br/>descriptor is closed, and the IOC bit for the corresponding<br/>descriptor is Set.<br/>Values:</li> <li>0x1 (ACTIVE): Transfer Complete Interrupt</li> <li>0x0 (INACTIVE): No Transfer Complete Interrupt<br/>Value After Reset: 0x0</li> </ul>                                                                            |



### 22.2.41 DOEPDMA0: Device OUT endpoint 0 DMA address register

#### DOEPDMA0=0x5000\_0B14

|    |    |      |    |    |    |    |    |    |      |     |    |    |    |    |      |       |      |     |       |      |      |      |      |       |       |     |      |     |     | _    |    |
|----|----|------|----|----|----|----|----|----|------|-----|----|----|----|----|------|-------|------|-----|-------|------|------|------|------|-------|-------|-----|------|-----|-----|------|----|
| 31 | 30 | ) 29 | 28 | 27 | 26 | 25 | 24 | 23 | 3 22 | 21  | 20 | 19 | 18 | 17 | 16   | 15    | 14   | 13  | 12    | 11   | 10   | 9    | 8    | 7     | 6     | 5   | 4    | 3   | 2   | 1    | 0  |
|    |    |      |    |    |    |    |    |    |      |     |    |    |    |    |      |       |      |     |       |      |      |      |      |       |       |     |      |     |     |      |    |
|    |    |      |    |    |    |    |    |    |      |     |    |    |    | D  | MA   | Add   | lr   |     |       |      |      |      |      |       |       |     |      |     |     |      |    |
|    |    |      |    |    |    |    |    |    |      |     |    |    |    |    |      |       |      |     |       |      |      |      |      |       |       |     |      |     |     |      |    |
|    |    |      |    |    |    |    |    |    |      |     |    |    |    |    |      |       |      |     |       |      |      |      |      |       |       |     |      |     |     |      |    |
|    |    |      |    |    |    |    |    |    |      |     |    |    |    |    | (    | )     |      |     |       |      |      |      |      |       |       |     |      |     |     |      |    |
|    |    |      |    |    |    |    |    |    |      |     |    |    |    |    | R    | W     |      |     |       |      |      |      |      |       |       |     |      |     |     |      |    |
|    |    |      |    |    |    |    |    |    |      |     |    |    |    |    |      |       |      |     |       |      |      |      |      |       |       |     |      |     |     |      |    |
|    |    |      |    |    |    | 31 |    |    | DMA  | Add | r  |    |    |    |      |       |      |     |       |      | SS 0 | f th | e ex | kteri | nal r | men | nory | for | sto | ring | or |
|    |    |      |    |    |    | 0  |    |    |      |     |    |    |    |    | fete | ching | g en | dpo | int c | lata |      |      |      |       |       |     |      |     |     |      |    |

| 31<br>0 | DMAAddr | Holds the start address of the external memory for storing or fetching endpoint data.                                                                                                                                                |
|---------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |         | Note: For control endpoints, this field stores control OUT data packets as well as SETUP transaction data packets. When more than three SETUP packets are received back-to-back, the SETUP data packet in the memory is overwritten. |
|         |         | This register is incremented on every AHB transaction. The application can give only a DWORD-aligned address. When Scatter/Gather DMA mode is enabled, this field indicates the base pointer for the descriptor list.                |

### 22.2.42 DOEPDMAB0: Device OUT Endpoint 16 Buffer Address Register

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4<br>DMABufferAddr | 3 | 2 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |
|------------------------------------------------------------------------------------------------|---|-----|---|--|--|--|--|--|--|--|--|--|--|--|
|                                                                                                |   |     |   |  |  |  |  |  |  |  |  |  |  |  |
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0          |   |     |   |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                |   |     |   |  |  |  |  |  |  |  |  |  |  |  |
| DMABufferAddr                                                                                  |   |     |   |  |  |  |  |  |  |  |  |  |  |  |
| DMABufferAddr                                                                                  |   |     |   |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                                |   |     |   |  |  |  |  |  |  |  |  |  |  |  |
| 0                                                                                              |   |     |   |  |  |  |  |  |  |  |  |  |  |  |
| R                                                                                              |   |     |   |  |  |  |  |  |  |  |  |  |  |  |

| 31<br>0 | DMABufferAddr | Holds the current buffer address. This register is updated as and<br>when the data transfer for the corresponding end point is in<br>progress. This register is present only in Scatter/Gather DMA |
|---------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |               | mode. Otherwise this field is reserved.                                                                                                                                                            |



# 22.2.43 DOEPCTLi: Device control OUT endpoint I control register

Device Control OUT Endpoint I Control Register.

For I = 1; I <= OTG\_NUM\_IN\_EPS

### DOEPCTLi =0x5000\_0B20

| 31    | 30    | 29       | 28       | 27   | 26   | 25 24 | 123      | 22 | 21    | 20  | 19 18  | 17     | 16   | 15       | 14 | 13 12    | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2 | 1 | 0 |
|-------|-------|----------|----------|------|------|-------|----------|----|-------|-----|--------|--------|------|----------|----|----------|----|----|---|---|---|---|-----|---|---|---|---|---|
| EPEna | EPDis | SetD1PID | SetD0PID | SNAK | CNAK |       | Reserved |    | Stall | Snp | EPType | NAKSts | DPID | USBActEP |    | Reserved |    |    |   |   |   |   | MPS |   |   |   |   |   |
| 0     | 0     | 0        | 0        | 0    | 0    |       | -        |    |       | 0   | 0      | 0      | 0    | 0        |    | -        |    |    |   |   |   |   | 0   |   |   |   |   |   |
| RW    | RW    | W        | W        | W    | W    |       | - C      |    |       | RW  | R      | R      | R    | R        |    |          |    |    |   |   |   |   | RW  |   |   |   |   |   |

| 31 | EPEna    | <ul> <li>Endpoint Enable (EPEna)</li> <li>Applies to IN and OUT endpoints.</li> <li>For IN endpoints this bit indicates that the descriptor structure and data buffer with data ready to transmit is setup.</li> <li>For OUT endpoint it indicates that the descriptor structure and data buffer to receive data is setup.</li> <li>The core clears this bit before setting any of the following interrupts on this endpoint:</li> <li>SETUP Phase Done</li> <li>Endpoint Disabled</li> <li>Transfer Completed</li> <li>Note: For control endpoints in DMA mode, this bit must be set to be able to transfer SETUP data packets in memory.</li> <li>Values:</li> <li>0x1 (ACTIVE): Enable Endpoint</li> <li>0x0 (INACTIVE): No Action</li> <li>Value After Reset: 0x0</li> </ul> |
|----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30 | EPDis    | <ul> <li>Endpoint Disable (EPDis)<br/>Applies to IN and OUT endpoints.</li> <li>The application sets this bit to stop transmitting/receiving data on<br/>an endpoint, even before the transfer for that endpoint is complete.<br/>The application must wait for the Endpoint Disabled interrupt<br/>before treating the endpoint as disabled. The core clears this bit<br/>before setting the Endpoint Disabled interrupt. The application<br/>must set this bit only if Endpoint Enable is already set for this<br/>endpoint.</li> <li>Values:</li> <li>0x1 (ACTIVE): Disable Endpoint</li> <li>0x0 (INACTIVE): No Action<br/>Value After Reset: 0x0</li> </ul>                                                                                                                 |
| 29 | SetD1PID | <ul> <li>Set DATA1 PID (SetD1PID)</li> <li>Applies to interrupt and bulk IN and OUT endpoints only.</li> <li>Writing to this field sets the Endpoint Data PID (DPID) field in this register to DATA1.</li> <li>Values:</li> <li>0x0 (DISABLED): Disables Set DATA1 PID or Do not force Odd Frame</li> <li>0x1 (ENABLED): Set Endpoint Data PID to DATA1 or Sets EO_FrNum field to odd (micro)frame</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                    |



| 28       | SetD0PID | <ul> <li>Set DATA0 PID (SetDOPID)</li> <li>Applies to interrupt/bulk IN and OUT endpoints only.</li> <li>Writing to this field sets the Endpoint Data PID (DPID) field in this register to DATA0.</li> <li>Values:</li> <li>0x0 (DISABLED): Disables Set DATA0 PID or Do not force Even Frame</li> <li>0x1 (ENABLED): Set Endpoint Data PID to DATA0 or Sets EO_FrNum field to odd (micro)frame</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27       | SNAK     | Set NAK (SNAK)<br>A write to this bit sets the NAK bit for the endpoint.<br>Using this bit, the application can control the transmission of NAK<br>handshakes on an endpoint. The core can also set this bit for an<br>endpoint after a SETUP packet is received on that endpoint.<br>Values:<br>• 0x1 (ACTIVE): Set NAK<br>• 0x0 (INACTIVE): No Set NAK<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 26       | CNAK     | Clear NAK (CNAK) A write to this bit clears the NAK bit for the<br>endpoint.<br>Values:<br>• 0x1 (ACTIVE): Clear NAK<br>• 0x0 (INACTIVE): No Clear NAK<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21       | Stall    | <ul> <li>STALL Handshake (Stall)</li> <li>Applies to non-control, non-isochronous IN and OUT endpoints only.</li> <li>The application sets this bit to stall all tokens from the USB host to this endpoint. If a NAK bit, Global Non-periodic IN NAK, or Global OUT NAK is set along with this bit, the STALL bit takes priority. Only the application can clear this bit, never the core.</li> <li>Applies to control endpoints only.</li> <li>The application can only set this bit, and the core clears it, when a SETUP token is received for this endpoint. If a NAK bit, Global Non-periodic IN NAK, or Global OUT NAK is set along with this bit, the STALL bit takes priority. Irrespective of this bit's setting, the core always responds to SETUP data packets with an ACK handshake.</li> <li>Values:</li> <li>0x1 (ACTIVE): STALL All Active Tokens</li> <li>0x0 (INACTIVE): STALL All non-active tokens Value After Reset: 0x0</li> </ul> |
| 20       | Snp      | <ul> <li>Snoop Mode (Snp)</li> <li>Applies to OUT endpoints only.</li> <li>This bit configures the endpoint to Snoop mode. In Snoop mode, the core does not check the correctness of OUT packets before transferring them to application memory.</li> <li>Values:</li> <li>0x0 (DISABLE): Disable Snoop Mode</li> <li>0x1 (ENABLE): Enable Snoop Mode</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 19<br>18 | ЕРТуре   | Endpoint Type (EPType)<br>This is the transfer type supported by this logical endpoint.<br>• 2'b00: Control<br>• 2'b01: Isochronous<br>• 2'b10: Bulk<br>• 2'b11: Interrupt<br>Values:<br>• 0x2 (BULK): Bulk<br>• 0x3 (INTERRUPT): Interrupt<br>• 0x0 (CONTROL): Control<br>• 0x1 (ISOCHRONOUS): Isochronous<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



| 17      | NAKSts   | <ul> <li>NAK Status (NAKSts)<br/>Indicates the following:</li> <li>1'b0: The core is transmitting non-NAK handshakes based on the<br/>FIFO status.</li> <li>1'b1: The core is transmitting NAK handshakes on this endpoint<br/>When either the application or the core sets this bit:</li> <li>The core stops receiving any data on an OUT endpoint, even i<br/>there is space in the RxFIFO to accommodate the incoming<br/>packet.</li> <li>For non-isochronous IN endpoints: The core stops transmitting<br/>any data on an IN endpoint, even if there data is available in the<br/>TxFIFO.</li> <li>For isochronous IN endpoints: The core sends out a zero-length<br/>data packet, even if there data is available in the TxFIFO.<br/>Irrespective of this bit's setting, the core always responds to<br/>SETUP data packets with an ACK handshake.<br/>Values:</li> </ul> |
|---------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |          | <ul> <li>0x1 (NAK):<br/>The core is transmitting NAK handshakes on this endpoint</li> <li>0x0 (NONNAK):<br/>The core is transmitting non-NAK handshakes based on the FIFC<br/>status</li> <li>Value After Reset: 0x0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 16      | DPID     | Endpoint Data PID (DPID)<br>Applies to interrupt/bulk IN and OUT endpoints only.<br>Contains the PID of the packet to be received or transmitted on thi<br>endpoint. The application must program the PID of the first packe<br>to be received or transmitted on this endpoint, after the endpoir<br>is activated. The applications use the SetD1PID and SetD0PII<br>fields of this register to program either DATA0 or DATA1 PID.<br>• 1'b0: DATA0<br>• 1'b1: DATA1<br>Values:<br>• 0x1 (ACTIVE): Endpoint Data PID active                                                                                                                                                                                                                                                                                                                                                     |
| 15      | USBActEP | • 0x0 (INACTIVE): Endpoint Data PID not active Value After Reset: 0x0  USB Active Endpoint (USBActED)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 10      | USDALLEF | USB Active Endpoint (USBActEP)<br>Indicates whether this endpoint is active in the currer<br>configuration and interface. The core clears this bit for a<br>endpoints (other than EP 0) after detecting a USB reset. After<br>receiving the SetConfiguration and SetInterface commands, the<br>application must program endpoint registers accordingly and set<br>this bit.<br>Values:<br>• 0x0 (DISABLED): Not Active<br>• 0x1 (ENABLED): USB Active Endpoint<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                        |
| 10<br>0 | MPS      | Maximum Packet Size (MPS)<br>The application must program this field with the maximum packe<br>size for the current logical endpoint. This value is in bytes.<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |



## 22.2.44 DOEPINTi: Device OUT endpoint I interrupt register

For I = 1; I <= OTG\_NUM\_IN\_EPS

#### DOEPINTi =0x5000\_0B28

| 31 30 29 28 27 26 25 24 23 23 | 2 21 20 19 18 17 16 <mark>1</mark> 5 | 14         | 13        | 12      | 11        | 10       | 9       | 8         | 7        | 6          | 5           | 4          | 3     | 2      | 1        | 0         |
|-------------------------------|--------------------------------------|------------|-----------|---------|-----------|----------|---------|-----------|----------|------------|-------------|------------|-------|--------|----------|-----------|
| Reserved                      |                                      | NYETIntrpt | NAKIntrpt | BbleErr | PktDrpSts | Reserved | BNAIntr | OutPktErr | Reserved | Back2BackS | StsPhseRcvd | OUTTknEPdi | SetUp | AHBErr | EPDisbld | XferCompl |
| -                             |                                      | 0          | 0         | 0       | 0         | -        | 0       | 0         | -        | 0          | 0           | 0          | 0     | 0      | 0        | 0         |
|                               |                                      | RW         | RW        | RW      | RW        | -        | RW      | RW        | -        | RW         | RW          | RW         | RW    | RW     | RW       | RW        |

| 14 | NYETIntrpt | NYET Interrupt (NYETIntrpt)<br>The core generates this interrupt when a NYET response is<br>transmitted for a non isochronous OUT endpoint.<br>Values:<br>• 0x1 (ACTIVE): NYET Interrupt<br>• 0x0 (INACTIVE): No NYET interrupt<br>Value After Reset: 0x0                                                                                                                                                                                                 |
|----|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13 | NAKIntrpt  | <ul> <li>NAK Interrupt (NAKInterrupt)</li> <li>The core generates this interrupt when a NAK is transmitted or received by the device.</li> <li>In case of isochronous IN endpoints the interrupt gets generated when a zero length packet is transmitted due to un-availability of data in the TXFifo.</li> <li>Values:</li> <li>0x1 (ACTIVE): NAK Interrupt</li> <li>0x0 (INACTIVE): No NAK interrupt</li> <li>Value After Reset: 0x0</li> </ul>         |
| 12 | BbleErr    | NAK Interrupt (BbleErr)<br>The core generates this interrupt when babble is received for the<br>endpoint.<br>Values:<br>• 0x1 (ACTIVE): BbleErr interrupt<br>• 0x0 (INACTIVE): No BbleErr interrupt<br>Value After Reset: 0x0                                                                                                                                                                                                                             |
| 11 | PktDrpSts  | Packet Drop Status (PktDrpSts)<br>This bit indicates to the application that an ISOC OUT packet has<br>been dropped. This bit does not have an associated mask bit and<br>does not generate an interrupt.<br>Dependency: This bit is valid in non Scatter/Gather DMA mode<br>when periodic transfer interrupt feature is selected.<br>Values:<br>• 0x1 (ACTIVE): Packet Drop Status interrupt<br>• 0x0 (INACTIVE): No interrupt<br>Value After Reset: 0x0 |
| 9  | BNAIntr    | <ul> <li>BNA (Buffer Not Available) Interrupt (BNAIntr)</li> <li>This bit is valid only when Scatter/Gather DMA mode is enabled.</li> <li>The core generates this interrupt when the descriptor accessed is not ready for the Core to process, such as Host busy or DMA done Values:</li> <li>0x1 (ACTIVE): BNA interrupt</li> <li>0x0 (INACTIVE): No BNA interrupt</li> <li>Value After Reset: 0x0</li> </ul>                                            |



| • |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8 | OutPktErr      | OUT Packet Error (OutPktErr)<br>Applies to OUT endpoints Only<br>This interrupt is valid only when thresholding is enabled. This<br>interrupt is asserted when the core detects an overflow or a CRC<br>error for non-Isochronous OUT packet.<br>Values:<br>• 0x1 (ACTIVE): OUT Packet Error<br>• 0x0 (INACTIVE): No OUT Packet Error<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6 | Back2BackSETup | <ul> <li>Back-to-Back SETUP Packets Received (Back2BackSETup)<br/>Applies to Control OUT endpoints only.</li> <li>This bit indicates that the core has received more than three back<br/>to-back SETUP packets for this particular endpoint. Fo<br/>information about handling this interrupt,<br/>Values:</li> <li>0x1 (ACTIVE): Back-to-Back SETUP Packets Received</li> <li>0x0 (INACTIVE): No Back-to-Back SETUP Packets Received</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                      |
| 5 | StsPhseRcvd    | Value After Reset: 0x0<br>Status Phase Received for Control Write (StsPhseRcvd)<br>This interrupt is valid only for Control OUT endpoints.<br>This interrupt is generated only after the core has transferred al<br>the data that the host has sent during the data phase of a control<br>write transfer, to the system memory buffer.<br>The interrupt indicates to the application that the host has switched<br>from data phase to the status phase of a Control Write transfer<br>The application can use this interrupt to ACK or STALL the Status<br>phase, after it has decoded the data phase. This is applicable only<br>in Case of Scatter Gather DMA mode.<br>Values:<br>• 0x1 (ACTIVE): Status Phase Received for Control Write<br>• 0x0 (INACTIVE): No Status Phase Received for Control Write<br>Value After Reset: 0x0 |
| 4 | OUTTknEPdis    | <ul> <li>OUT Token Received When Endpoint Disabled (OUTTknEPdis)<br/>Applies only to control OUT endpoints.</li> <li>Indicates that an OUT token was received when the endpoint was<br/>not yet enabled. This interrupt is asserted on the endpoint fo<br/>which the OUT token was received.</li> <li>Values:         <ul> <li>0x1 (ACTIVE): OUT Token Received When Endpoint Disabled</li> <li>0x0 (INACTIVE): No OUT Token Received When Endpoint<br/>Disabled</li> <li>Value After Reset: 0x0</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                               |
| 3 | SetUp          | SETUP Phase Done (SetUp)<br>Applies to control OUT endpoints only.<br>Indicates that the SETUP phase for the control endpoint is<br>complete and no more back-to-back SETUP packets were<br>received for the current control transfer. On this interrupt, the<br>application can decode the received SETUP data packet.<br>Values:<br>• 0x1 (ACTIVE): SETUP Phase Done<br>• 0x0 (INACTIVE): No SETUP Phase Done<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                             |
| 2 | AHBErr         | AHB Error (AHBErr)<br>Applies to IN and OUT endpoints.<br>This is generated only in Internal DMA mode when there is an AHE<br>error during an AHB read/write. The application can read the<br>corresponding endpoint DMA address register to get the erro<br>address.<br>Values:<br>• 0x1 (ACTIVE): AHB Error interrupt<br>• 0x0 (INACTIVE): No AHB Error Interrupt<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                         |



| 1 E | PDisbld   | Endpoint Disabled Interrupt (EPDisbld)<br>Applies to IN and OUT endpoints.<br>This bit indicates that the endpoint is disabled per the application's<br>request.<br>Values:<br>• 0x1 (ACTIVE): Endpoint Disabled Interrupt<br>• 0x0 (INACTIVE): No Endpoint Disabled Interrupt<br>Value After Reset: 0x0                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 > | iferCompl | <ul> <li>Transfer Completed Interrupt (XferCompl)</li> <li>Applies to IN and OUT endpoints.</li> <li>When Scatter/Gather DMA mode is enabled</li> <li>For IN endpoint this field indicates that the requested data from the descriptor is moved from external system memory to internal FIFO.</li> <li>For OUT endpoint this field indicates that the requested data from the internal FIFO is moved to external system memory. This interrupt is generated only when the corresponding endpoin descriptor is Set.</li> <li>Values:</li> <li>0x1 (ACTIVE): Transfer Complete Interrupt</li> <li>0x0 (INACTIVE): No Transfer Complete Interrupt</li> <li>Value After Reset: 0x0</li> </ul> |

## 22.2.45 DOEPDMAi: Device OUT Endpoint I DMA Address Register

For I = 1; I <= OTG\_NUM\_IN\_EPS

|    |    |    |    |    |    |         |    |   |      |     |    |    |    |    |     |               |    |      |     |     |       |       |      |       |       | 51117 |      | U.    |     |      | 50  |
|----|----|----|----|----|----|---------|----|---|------|-----|----|----|----|----|-----|---------------|----|------|-----|-----|-------|-------|------|-------|-------|-------|------|-------|-----|------|-----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25      | 24 | 2 | 3 22 | 21  | 20 | 19 | 18 | 17 | 16  | 15            | 14 | 13   | 12  | 11  | 10    | 9     | 8    | 7     | 6     | 5     | 4    | 3     | 2   | 1    | 0   |
|    |    |    |    |    |    |         |    |   |      |     |    |    |    |    |     |               |    |      |     |     |       |       |      |       |       |       |      |       |     |      |     |
|    |    |    |    |    |    |         |    |   |      |     |    |    |    | D  | MA  | Ado           | dr |      |     |     |       |       |      |       |       |       |      |       |     |      |     |
|    |    |    |    |    |    |         |    |   |      |     |    |    |    |    |     |               |    |      |     |     |       |       |      |       |       |       |      |       |     |      |     |
|    |    |    |    |    |    |         |    |   |      |     |    |    |    |    |     | )             |    |      |     |     |       |       |      |       |       |       |      |       |     |      |     |
|    |    |    |    |    |    |         |    |   |      |     |    |    |    |    |     | J             |    |      |     |     |       |       |      |       |       |       |      |       |     |      |     |
|    |    |    |    |    |    |         |    |   |      |     |    |    |    |    | R   | W             |    |      |     |     |       |       |      |       |       |       |      |       |     |      |     |
|    |    |    |    |    |    |         |    |   |      |     |    |    |    |    |     |               |    |      |     |     |       |       |      |       |       |       |      |       |     |      |     |
|    |    |    |    |    | -  | 31<br>0 |    |   | DMA  | Add | r  |    |    |    |     | ds t<br>ching |    |      |     |     |       | f th  | e ex | xterr | nal r | nen   | nory | for   | sto | ring | or  |
|    |    |    |    |    |    |         |    |   |      |     |    |    |    |    | Not | e: F          | or | cont | rol | end | point | ts, t | his  | field | sto   | res   | cor  | ntrol | OU  | T da | ata |

| 31<br>0 | DMAAddr | Holds the start address of the external memory for storing or fetching endpoint data.                                                                                                                                                           |
|---------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |         | Note: For control endpoints, this field stores control OUT data packets as well as SETUP transaction data packets. When more than three SETUP packets are received back-to-back, the SETUP data packet in the memory is overwritten.            |
|         |         | <ul><li>This register is incremented on every AHB transaction. The application can give only a DWORD-aligned address.</li><li>When Scatter/Gather DMA mode is enabled, this field indicates the base pointer for the descriptor list.</li></ul> |



DOEPDMAi =0x5000\_0B34

## 22.2.46 DOEPDMABi: Device OUT Endpoint I Buffer Address Register

For I = 1; I <= OTG\_NUM\_IN\_EPS

## DOEPDMABi =0x5000\_0B3C

| 31 | 3 | 0 29 | 28 | 27 | 26 | 25 | 24 | 23 | 3 22 | 21        | 20 | 19 | 18 | 17 | 16  | 15   | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3     | 2     | 1 | 0 |
|----|---|------|----|----|----|----|----|----|------|-----------|----|----|----|----|-----|------|-----|----|----|----|----|---|---|---|---|---|---|-------|-------|---|---|
|    |   |      |    |    |    |    |    |    |      |           |    |    |    |    |     |      |     |    |    |    |    |   |   |   |   |   |   |       |       |   |   |
|    |   |      |    |    |    |    |    |    |      |           |    |    |    |    |     |      |     |    |    |    |    |   |   |   |   |   |   |       |       |   |   |
|    |   |      |    |    |    |    |    |    |      |           |    |    | D  | MA | But | ffer | Add | r  |    |    |    |   |   |   |   |   |   |       |       |   |   |
|    |   |      |    |    |    |    |    |    |      |           |    |    |    |    |     |      |     |    |    |    |    |   |   |   |   |   |   |       |       |   |   |
|    |   |      |    |    |    |    |    |    |      |           |    |    |    |    |     |      |     |    |    |    |    |   |   |   |   |   |   |       |       |   |   |
|    |   |      |    |    |    |    |    |    |      |           |    |    |    |    | C   | )    |     |    |    |    |    |   |   |   |   |   |   |       |       |   |   |
|    |   |      |    |    |    |    |    |    |      |           |    |    |    |    | R   | l    |     |    |    |    |    |   |   |   |   |   |   |       |       |   |   |
| -  |   |      |    |    |    |    |    |    |      |           |    |    |    |    |     |      |     |    |    |    |    |   |   |   |   |   |   |       |       |   |   |
|    |   |      |    |    | -  | 04 |    |    |      | - <i></i> |    |    |    |    |     |      |     |    |    |    |    |   | - |   |   |   | • | a dad | ( l . |   |   |

| 31 | DMABufferAddr | Holds the current buffer address. This register is updated as and |
|----|---------------|-------------------------------------------------------------------|
| 0  |               | when the data transfer for the corresponding end point is in      |
|    |               | progress.                                                         |

## 22.2.47 PCGCCTL: Power and Clock Gating Control Register

#### PCGCCTL =0x5000\_0E00

|                                                       |             |          |             |          |             |          | -            |          | -          |         | -        |          |
|-------------------------------------------------------|-------------|----------|-------------|----------|-------------|----------|--------------|----------|------------|---------|----------|----------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 | 13          | 12 11 10 | 9           | 8        | 7           | 6        | 5            | 4        | 3          | 2       | 1        | 0        |
| RestoreValue                                          | EssRegResto | Reserved | RestoreMode | Reserved | L1Suspended | PhySleep | Enbl_L1Gatin | Reserved | RstPdwnMod | PwrClmp | GateHclk | StopPclk |
| 0                                                     | 0           | -        | 0           | -        | 0           | 0        | 0            | -        | 0          | 0       | 0        | 0        |
| RW                                                    | RW          | -        | RW          | -        | R           | R        | RW           | -        | RW         | RW      | RW       | RW       |

| 1 RestoreValue | Restore Value (RestoreValue)<br>When Hibernation mode is enabled, the RestoreValue needs to be<br>read at SAVE_POINT to store in non-volatile memory and at<br>RESTORE_POINT restored before PCGCCTL.EssRegRestored<br>field is set.<br>• [31] if_dev_mode<br>-1: core restored as device<br>• [30:29] p2hd_prt_spd (PRT speed)<br>-01: FS<br>-10: LS<br>-11: Reserved<br>• [28:27] p2hd_dev_enum_spd (Device enumerated speed)<br>-10: LS<br>-11: FS (48 MHz clk)<br>• [26:20] mac_dev_addr (MAC device address) Device address<br>• [19] mac_termselect (Termination selection)<br>-1: FS_TERM (Program for Full Speed)<br>• [18:17] mac_xcvrselect (Transceiver select)<br>-01: FS_XCVR (Full Speed)<br>-10: LS_XCVR (Reserved)<br>• [15:14] prt_clk_sel (Refer prt_clk_sel table) Defines port clock<br>select for different speeds. |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|



| 13 | EssRegRestored | <ul> <li>Essential Register Values Restored (EssRegRestored)</li> <li>A write of one into this field indicates that register values of essential registers have been restored. For definition of essential registers, refer programming flow section for Hibernation. Values:</li> <li>• 0x0 (NOT_RESTORED): Register values of essential registers are not restored</li> <li>• 0x1 (RESTORED): Register values of essential registers have been restored</li> </ul>                                                                                                                                                                                    |
|----|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9  | RestoreMode    | Restore Mode (RestoreMode)<br>The application should program this bit to specify the restore mode<br>during RESTORE POINT before programming<br>PCGCCTL.EssRegRest bit is set.<br>• Device Mode:<br>-1'b0: Device-initiated Remote Wakeup<br>-1'b1: Host-initiated Resume, Host-initiated Reset<br>Values:<br>• 0x0 (DISABLED): In Device mode, this bit indicates Device-<br>initiated Remote Wakeup<br>• 0x1 (ENABLED): In Device mode, this bit indicates Host-initiated<br>Resume and Reset                                                                                                                                                         |
| 7  | L1Suspended    | L1 Deep Sleep<br>Indicates that the PHY is in deep sleep when in L1 state.<br>Values:<br>• 0x1 (ACTIVE): Deep Sleep<br>• 0x0 (INACTIVE): Non Deep Sleep                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6  | PhySleep       | PHY In Sleep<br>Indicates that the PHY is in Sleep State.<br>Values:<br>• 0x1 (ACTIVE): Phy in Sleep state<br>• 0x0 (INACTIVE): Phy not in Sleep state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5  | Enbl_L1Gating  | <ul> <li>Enable Sleep Clock Gating</li> <li>If this bit is set, core internal clock gating is enabled sleep state if utmi_l1_suspend_n cannot be asserted by the core.</li> <li>The PHY clock will not be gated in sleep state if Enbl_L1Gating is not set.</li> <li>Values:</li> <li>0x0 (DISABLED): The PHY clock is not gated in Sleep state</li> <li>0x1 (ENABLED): The Core internal clock gating is enabled in Sleep state</li> </ul>                                                                                                                                                                                                             |
| 3  | RstPdwnModule  | <ul> <li>Reset Power-Down Modules (RstPdwnModule)</li> <li>This bit is valid only in Partial Power-Down mode.</li> <li>The application sets this bit when the power is turned off.</li> <li>The application clears this bit after the power is turned on and the PHY clock is up.</li> <li>Note: The R/W of all core registers are possible only when this bit is set to 1b0.</li> <li>Values:</li> <li>0x1 (OFF): Power is turned off</li> <li>0x0 (ON): Power is turned on</li> </ul>                                                                                                                                                                 |
| 2  | PwrClmp        | <ul> <li>Power Clamp (PwrCImp)</li> <li>This bit is valid only in Partial Power-Down mode</li> <li>The application sets this bit before the power is turned off to clamp the signals between the power-on modules and the power-off modules.</li> <li>The application clears the bit to disable the clamping before the power is turned on.</li> <li>Values:</li> <li>0x0 (DISABLED): Clears this bit to disable the clamping before the power is turned on</li> <li>0x1 (ENABLED): In only Partial Power-Down mode, sets this bit to clamp the signals between the power-on modules and the power-off modules before the power is turned on</li> </ul> |



| 1 | GateHclk | <ul> <li>Gate Hclk (GateHclk)</li> <li>The application sets this bit to gate hclk to modules other than the AHB Slave and Master and wakeup logic when the USB is suspended or the session is not valid.</li> <li>The application clears this bit when the USB is resumed or a new session starts.</li> <li>Values:</li> <li>0x0 (DISABLED): Clears this bit when the USB is resumed or a new session starts</li> <li>0x1 (ENABLED): Sets this bit to gate hclk to modules when the USB is suspended or the session is not valid</li> </ul> |
|---|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | StopPclk | <ul> <li>Stop Pclk (StopPclk)</li> <li>The application sets this bit to stop the PHY clock (phy_clk) wher the USB is suspended, the session is not valid, or the device is disconnected.</li> <li>The application clears this bit when the USB is resumed or a new session starts.</li> <li>Values:</li> <li>0x0 (DISABLED): Disable Stop Pclk</li> <li>0x1 (ENABLED): Enable Stop Pclk</li> </ul>                                                                                                                                          |



## 22.3 Functional description

#### 22.3.1 USB device

USB devices are peripherals communicated to a USB Host. Devices are implemented by adding USB Software Stack. USB Device peripherals can have one or more of the following USB Device Classes.

- Human Interface Device (HID) is typically used for devices such as keyboards, mouse, or joysticks.
- Communication Device Class (CDC) provides virtual communication port functionality to the USB Host.
- Mass Storage Class (MSC) is used to allow access to various storage devices to the USB Host.
- Custom Class provides a vendor specific USB Device Class.
- For more information about USB Device Classes, it can be found on USB-IF homepage.

USB Host initiates all data of USB Communication. USB consist of one or more transactions. The data sends and receives from Endpoints.

Starting transaction, USB need to make Pipes between Device and Host logically. Host sends data from OUT Endpoint. Host receives data from IN Endpoint.

An endpoint acts as a kind of buffer. It can be configured to support four transfer types defined in the USB specification.

- Control Transfer is typically used to setup an USB device. It always uses IN/OUT Endpoint 0.
- Interrupt Transfer can be used where data is sent regularly, for example for status updates.
- Isochronous Transfer transmits real-time data such as audio and video. It has a guaranteed, fixed bandwidth, but no error detection.
- Bulk Transfer can be used to send data where timing is not important, for example to a printer.

Data is transferred in so called transactions. Normally, they consist of three packets:

- Token packet is the header defining the transaction type and direction, the device address, and the endpoint.
- Data is transferred in a data packet.
- Final status of the transaction is acknowledges in the handshake packet.



USB packet format is describes in Figure 153.



## Figure 153. USB Packet Field

| Table | 87  | USB | Packet PID   |  |
|-------|-----|-----|--------------|--|
| Table | 01. | 000 | I acket I ID |  |

| Token packets |       |                                            |
|---------------|-------|--------------------------------------------|
| OUT           | 0001b | Beginning of OUT transaction               |
| IN            | 1001b | Start of an IN transaction                 |
| SETUP         | 0101b | Signals beginning of a Control Transaction |
| SOF           | 1101b | Start of Frame packet                      |
| Data packets  |       |                                            |
| DATA0         | 0010b | Clears the toggle bit in the data packet   |
| DATA1         | 1011b | Sets the toggle bit in the data packet     |
| Handshake     |       |                                            |
| ACK           | 0110b | Transmission successfully completed        |
| NACK          | 1010b | Transmission unsuccessful                  |
| STALL 1110b   |       | delayed response, retry needed             |



### 22.3.2 USB descriptors

USB devices report their attributes by using descriptors, which are data structures with a defined format.

When a USB device is attached to the USB bus, a host uses a process known as bus enumeration to identify and configure the device. If the enumeration is finished, the device can service the active endpoints to exchange data with the USB Host.

Following is the most commonly used descriptors:

- Device Descriptor
- Configuration Descriptor
- Interface Descriptor
- Endpoint Descriptor
- String Descriptor



Figure 154. USB Descriptor Hierarchy



## 22.3.3 USB operation

Reliable operation of USB requires the followings:

- 1. USB power system: There are 2 way of supplying USB power.
  - First, integrated 3.3V LDO can be supplied to USB module. SCU\_VDCCON register is set to 0xA3000000.
  - Second, 3.3V VDDIO2 can be supplied to USB module. SCU\_VDCCON register is set to 0xAA00200 and 21bit of PCU\_USBCON register is set to 1.
- USB clock speed: 48MHz clock speed is required for full speed USB. For reliable communication, USB recommends to use the clock which is a tolerance of ±2500 ppm(0.25%). For more information, please refer to Chapter 4.2 Clock System.
- USB port control (D+, D-): A user needs to configure PCU\_USBCON register for corresponding USB function. The register regards to characteristics of USB port such as pull up/down and drive strength option.
  - Example code for the device using full speed USB: PCU\_USBCON will be set as shown below:

```
USBCON = (0x7 << 28) | (0x7 << 24) //Drive Strengthen

| (0x1 << 23) | (0x0 << 22) | (0x1 << 21) //CONTROL_EN//PHY_SUSPEND//VREF_SEL

| (0x0 << 19) | (0x0 << 18) //PD_ENDN, DP

| (0x0 << 17) | (0x1 << 16) //PU_ENDN, DP

| (0x0 << 12) | (0x0 << 8) //VIH_CON//VIL_CON

| (0x7 << 4) | (0x7 << 0); //PD_CON//PU_CON
```

- 4. Device initialization, connection, and disconnection: The application must perform the following steps to initialize the controller at a device.
  - Program the following fields in DCFG register.
    - i. DescDMA bit
    - ii. Device Speed
    - iii. NonZero Length Status OUT Handshake
    - iv. Periodic Frame Interval (If Periodic Endpoints are supported)
  - Program the Device threshold control register. This is required only if you are planning to enable thresholding.
  - Clear the DCTL.SftDiscon bit. The controller issues a connection after this bit is cleared.



- Program the GINTMSK register to unmask the following interrupts.
  - i. USB Reset
  - ii. Enumeration Done
  - iii. Early Suspend
  - iv. USB SuspenD
  - v. SOF
- Wait for the GINTSTS.USBReset interrupt, which indicates a reset has been detected on the USB and lasts for about 10 ms. Initialization on USB Reset.
  - i. DOEPCTLn.SNAK = 1 (for all OUT endpoints)
  - ii. DAINTMSK.INEP0 = 1 (control 0 IN endpoint)
  - iii. DAINTMSK.OUTEP0 = 1 (control 0 OUT endpoint)
  - iv. DOEPMSK.SETUP = 1
  - v. DOEPMSK.XferCompl = 1
  - vi. DIEPMSK.XferCompl = 1
- vii. DIEPMSK.TimeOut = 1
- Reset the Device Address field in Device Configuration Register (DCFG).
  - i. USB->DCFG &= ~(0x7f << 4); //clear
- Wait for the GINTSTS.EnumerationDone interrupt. This interrupt indicates the end of reset on the USB. Initialization on Enumeration Completion.
  - i. On the Enumeration done interrupt (GINTSTS.EnumDone, read the DSTS register to determine the enumeration speed.
  - ii. Program the DIEPCTL0.MPS field to set the maximum packet size. This step configures control endpoint 0. The maximum packet size for a control endpoint depends on the enumeration speed.
  - iii. The descriptors must be set up in memory before enabling the endpoint.
    - DOEPCTL0.EPEna = 1
  - iv. Unmask the SOF interrupt.



If VBUS is on when the device is connected to the USB cable, the device connection flow is as follows:

- 1. The device triggers the GINTSTS.SessReqInt [bit 30] interrupt bit.
- 2. When the device application detects the GINTSTS.SessReqInt interrupt, it programs the required bits in the DCFG register.
- 3. When the Host drives Reset, the Device triggers GINTSTS.USBRst [bit 12] on detecting the Reset.

The device session ends when the USB cable is disconnected or if the VBUS is switched off by the Host. The device disconnect flow is as follows:

- 1. When the USB cable is unplugged or when the VBUS is switched off by the Host, the Device controller triggers GINTSTS.USBRst [bit 12] interrupt bit.
- 2. When the device application detects GINTSTS.USBRst, the application sets a time-out check for SET ADDRESS Control Xfer from Host.
- 3. If application does not receive SET ADDRESS Control Xfer from Host before the time-out period, it is treated as a device disconnection.

## 22.3.4 USB transfer

In this section, a sequence that an application must do when it receives a command from Host.

The application must do the followings when it receives a SetAddress command in a SETUP packet:

- 1. Program the DCFG register with the device address received in the SetAddress command.
- 2. Program the controller to send out a status IN packet.

The application must do the followings when it receives a SetConfiguration or SetInterface command in a SETUP packet.

- 1. The application must program the endpoint registers of the endpoints affected by this command.
- 2. After all required endpoints are configured, the application must program the controller to send a status IN packet.

Following procedure describes how the application initializes the channel and provides information on transfers IN/OUT EndPoint. Data buffers are presented through descriptor structures:

- 1. The application prepares the descriptors, and sets the DIEPCTLn/DOEPCTLn.EPEna bit.
- 2. The DMA fetches the corresponding descriptor (initially determined by DIEPDMAn/DOEPDMAn).
- 3. The DMA internally sets the transfer size from descriptor back to DIEPTSIZn/DOEPTSIZn.



- 4. From this point onwards, the current device flow executes.
- 5. Once the transfer size data is moved by the DMA, the DMA checks for further links in the descriptor chain.
- 6. If this is the last descriptor, the DMA sets the DIOEPINTn.XferCompl interrupt.

#### 22.3.5 USB software example

This section describes how to implement USB software and how to use USB application between host and a device.

1) CDC(Virtual Comport)

Assuming that CDC (Communications Device Class) provides the developer with a simple data exchange interface, as a brief example of this interface, a simple application can be introduced in the followings. It (ACM class) results in a virtual COM port on the host.

Refer to VCP (Virtual COM port) example project. This application sends and receives a string over USB to a virtual COM port on the host. Terminal emulator program such as Tera Term and Putty will be required for users.



Figure 155. USB Communication using Software

### Application example

- 1. Open USB VCP test example project. Compile and download the project.
- 2. PC (Host) USB connect to MCU (Device) USB port.
- 3. After PC (Host) recognize USB Device, user need to set up Com Port Driver (inf file).



4. Open Windows OS - Device Manager console



Figure 156 Application Example: Open Windows OS

- 5. Update manually the driver software. ABOV provides G324\_Comport\_Driver.inf file.
- 6. Check the Com port to recognize USB Device properly.



Figure 157. Application Example: Check COM Port

- 7. Open Tera Term for Serial to USB (UART) and USB.
- 8. After setting the connection, the user sends a character from USB to UART. Tera Term (UART) prints the character after receiving. Conversely, the user sends a character from UART to USB. Tera Term (USB) prints the character.
- 9. Following figures are examples, printing a string "ABOV From xxx DATA".



Figure 158. Application Example: Printing Characters



## 2) HID(Custom Data-pipe)

It is possible to use custom data exchange based on the HID class.

Refer to HID(HID\_Custom) example project. This application sends and receive a string over USB to a HID GUI tool(Including USB example project -> PC\_Tool folder) on the host.



## Figure 159. HID Block Diagram

- A. Open USB VCP test example project. Complie and download the project.
- B. PC(Host) USB connect to MCU(Device) usb port.
- C. Open Windows OS Device Manager console
- D. Check the HID device to recognize USB Device properly.
- E. Open HID PC GUI Tool for communicating via USB.
- F. As shown in the Figure 160 below. (For example, receive a string "0x55 0xAA...")

| USB HID PIPE Example GUI                                                             |                                              |                                 | -                              |                                   | × |
|--------------------------------------------------------------------------------------|----------------------------------------------|---------------------------------|--------------------------------|-----------------------------------|---|
| ☑ Keep Send Data<br>AA 55                                                            |                                              | Data Format<br>● HEX<br>○ ASCII | Sen                            | d(Enter)                          |   |
| USB HOST (PC)                                                                        | USB DEVICE (MCU)                             |                                 |                                |                                   |   |
| 2019-10-28 오후 2:14:45 My device was<br>fund.<br>************************************ | 50 50 10 10 10 10 10 10 10 10 10 10 10 10 10 |                                 | 1A29<br>PID (P<br>7002<br>Disc | 'endor ID<br>'roduct IC<br>onnect |   |
| ~                                                                                    | 55 AA 55 AA 55 AA 55 AA                      | ¥ SE                            |                                |                                   | - |

Figure 160. USB HID PIPE Example GUI



## ■ Hardware

As shown in a detailed reference design.

- 1. D+, D- line : 33Ω
- 2. VDDIO2 : There are 2 options.

Internal USB power(VDD33) -> Floating, or External USB power -> supply 3.3V

3. For reliable communication, the USB specification requires the clock have a tolerance of ±2500 ppm.

In order to meet this condition, It is recommended to use a crystal and PLL.



Figure 161. Crystal Design Guide



# 23. Real-time clock (RTC)

Real-time clock (RTC) of A31G32x series provides an automatic wakeup function to manage all low-power modes.

The RTC is an independent BCD timer/counter. It provides a time-of-day clock/calendar with programmable alarm interrupt. In addition, it includes a periodic programmable wakeup flag with interrupt capability. Eight RTC counters contain the sub-seconds, seconds, minutes, hours, week, day, month, and year expressed in binary coded decimal format (BCD). Compensations for 28-, 29- (leap year), 30-, and 31-day months are performed automatically. An error correction is available to compensate for variations in crystal oscillator accuracy.

In any mode of operation, the sub-second counter is never accessible. In normal operating mode, seven RTC counters are protected from read and write access. Read and write operation is possible only in RW mode. As long as the supply voltage remains in the operating range, the RTC never stops, regardless of the device status (run mode, low-power mode or under reset).

The RTC features the followings:

- LSI40KHz and MCCR5 clock as RTC clock (fRTC)
- Counters of year, month, week, day, hour, minute, and second (up to 99 years)
- Constant-period matching interrupt function (period: 0.5 seconds, 1 second, 1 minute, 1 hour, 1 day, 1 month)
- Alarm interrupt function (alarm: week, hour, minute)
- Timestamp interrupt and function
- Pin output of 1Hz clock
- Error correction by 1.53ppm resolution when using 32768Hz LSE
- Backup power mode operation support
- Four 32-bit backup registers (BKUR1~4) implemented in the RTC domain (remaining powered-on by VBAT when the VDD power is switched off)

Internal clock frequency for the RTC clock is detailed in electrical characteristic.



# 23.1 RTC block diagram





Figure 162. RTC Block Diagram



## 23.2 Registers

Base address of RTC block is introduced in the followings:

#### Table 88. Base Address of RTC Interface

| Name | Base address |
|------|--------------|
| RTC  | 0x4000_6100  |

| Name    | Offset | Туре | Description                             | Reset value | Reference      |
|---------|--------|------|-----------------------------------------|-------------|----------------|
| RTCCR   | 0x0000 | RW   | RTC Control Register                    | 0x0000_0000 | 23.2.1         |
| ERRCOR  | 0x0008 | RW   | Watch Error Correction Register         | 0x0000_0000 | 23.2.2         |
| SEC     | 0x000C | RW   | Second Counter Register                 | 0x0000_0000 | 23.2.3         |
| MIN     | 0x0010 | RW   | Minute Counter Register                 | 0x0000_0000 | 23.2.4         |
| HOUR    | 0x0014 | RW   | Hour Counter Register                   | 0x0012_0000 | 23.2.5         |
| DAY     | 0x0018 | RW   | Day Counter Register                    | 0x0001_0000 | 23.2.6         |
| WEEK    | 0x001C | RW   | Week Counter Register                   | 0x0000_0000 | 23.2.7         |
| MONTH   | 0x0020 | RW   | Month Counter Register                  | 0x0001_0000 | <u>23.2.8</u>  |
| YEAR    | 0x0024 | RW   | Year Counter Register                   | 0x0000_0000 | 23.2.9         |
| ALARMW  | 0x0028 | RW   | Alarm Minute Register                   | 0x0000_0000 | <u>23.2.10</u> |
| SUBDR   | 0x002C | RW   | Sub-second counter compare register     | 0x0001-FFFF | <u>23.2.11</u> |
| TIME_TS | 0x0030 | RW   | TimeStamp time register                 | 0x0000_0000 | <u>23.2.12</u> |
| DATE_TS | 0x0034 | RW   | TimeStamp date register                 | 0x0000_0000 | <u>23.2.13</u> |
| BKUR1   | 0x0038 | RW   | Backup register 1                       | 0x0000_0000 | <u>23.2.14</u> |
| BKUR2   | 0x003C | RW   | Backup register 2                       | 0x0000_0000 |                |
| BKUR3   | 0x0040 | RW   | Backup register 3                       | 0x0000_0000 | ]              |
| BKUR4   | 0x0044 | RW   | Backup register 4                       | 0x0000_0000 | ]              |
| RTCPFCR | 0x0048 | RW   | RTC Pin Function Configuration register | 0x0000_0000 | 23.2.15        |

## Table 89. RTC Register Map



## 23.2.1 RTCCR: RTC control register

RTCCR is a 32-bit register for controlling the RTC. You can set the alarm, constant-period matching, timestamp, etc. before activating the RTC. Changing this register during RTC operation may cause malfunction, so be sure to change while RTCE=0.

#### RTCCR=0x4000\_6100

| 31    | 30   | 29 28 27 2 | 6 25 24  | 23 22 21            | 20     | 19 18                                       | 17                                         | 16    | 15    | 14 13                          | 12    | 11     | 10 9                 | 8     | 7        | 6    | 5     | 4    | 3     | 2        | 1     | 0        |
|-------|------|------------|----------|---------------------|--------|---------------------------------------------|--------------------------------------------|-------|-------|--------------------------------|-------|--------|----------------------|-------|----------|------|-------|------|-------|----------|-------|----------|
| RTCEN | RTCE | F          | Reserved |                     | AMPM   | СТ                                          |                                            | RIFG  | TSEN  | TS_EDGE_SEL                    | TSFG  | WAIE   | Reserved             | WAFG  | Reserved |      |       |      |       |          | RWST  | RWAIT    |
| 0     | 0    |            | -        |                     | 0      | 0                                           |                                            | 0     | 0     | 0                              | 0     | 0      | -                    | 0     |          |      | -     | -    |       |          | 0     | 0        |
| RW    | RW   |            | -        |                     | RW     | RW                                          |                                            | RW    | RW    | RW                             | RW    | RW     |                      | RW    |          |      |       |      |       |          | RW    | RW       |
|       |      |            | 31       | RTCEN               |        | R<br>0<br>1                                 | TC (                                       | cloc  | RT    | out enab<br>C clock<br>C clock | inpu  |        |                      |       |          |      |       |      |       |          |       |          |
|       |      |            | NOTE:    | If RTCE<br>values a |        | ead. (SE                                    | Č to                                       | ) YE  | EAR,  | ĂLARM                          |       |        |                      | ie re | egist    | ers  | are   | read | d, or | nly d    | efau  | ult      |
|       |      |            | 30       | RTCE                |        |                                             | TC o                                       | cour  | nter  |                                |       |        |                      |       |          |      |       |      |       |          |       |          |
|       |      |            |          |                     |        | 0                                           |                                            |       |       | C count                        |       | · ·    |                      |       |          |      |       |      |       |          |       |          |
|       |      |            | 20       | AMPM                |        |                                             | 1 RTC counter run<br>Hour system selection |       |       |                                |       |        |                      |       |          |      |       |      |       |          |       |          |
|       |      |            | 20       |                     |        | 0                                           | our                                        | Syst  |       |                                |       | ı (a   | m and i              | o m   | are      | disr | olave | ( he |       |          |       |          |
|       |      |            |          |                     |        | 1                                           |                                            |       |       |                                |       |        |                      |       |          |      |       |      |       |          |       |          |
|       |      |            | NOTE:    | AMPM o<br>hour sys  |        |                                             |                                            |       |       |                                | e. H  | OUF    | R value f            | or th | ne 1:    | 2-ho | ours  | yste | em a  | nd tł    | ne 24 | 4-       |
|       |      |            | 19       | СТ                  |        | Р                                           | erio                                       | d se  | lecti | on of co                       | onsta | ant-p  | period m             | atch  | ing      |      |       |      |       |          |       |          |
|       |      |            | 17       |                     |        |                                             | 00                                         |       | Co    | nstant-p                       | erio  | d m    | atching              | disa  | blec     | 1    |       |      |       |          |       |          |
|       |      |            |          |                     |        |                                             | )1                                         |       |       |                                |       |        | nchroniz             |       |          |      |       |      | nt up | <b>)</b> |       |          |
|       |      |            |          |                     |        |                                             | 10                                         |       |       |                                |       |        | e time a             |       |          |      |       | up)  |       |          |       |          |
|       |      |            |          |                     |        |                                             | 11<br>00                                   |       |       |                                |       |        | ond 0 of<br>ninute 0 |       | -        |      |       | four | any h |          |       |          |
|       |      |            |          |                     |        |                                             | )0<br>)1                                   |       |       |                                |       |        | our 0, mii           |       |          |      |       |      |       |          |       | V)       |
|       |      |            |          |                     |        |                                             | 10                                         |       | On    | · ·                            | mo    | nth    | (Day 1, I            |       |          |      |       |      |       |          | -     | <u> </u> |
|       |      |            |          |                     |        | 1                                           | 11                                         |       | res   | erved                          |       |        |                      |       |          |      |       |      |       |          |       |          |
|       |      |            | 16       | RIFG                |        | С                                           | onst                                       | ant   | peri  | od mato                        | hing  | , flag | g                    |       |          |      |       |      |       |          |       |          |
|       |      |            |          |                     |        | 0 Constant-period matching is not generated |                                            |       |       |                                |       |        |                      |       |          |      |       |      |       |          |       |          |
|       |      |            |          |                     |        | 1                                           |                                            |       | Co    | nstant-p                       | erio  | d m    | atching              | is ge | ener     | ated |       |      |       |          |       |          |
|       |      |            | NOTE:    | This flag           | g is r | eset wh                                     | en "(                                      | 0" is | writ  | tten to it                     | . Wr  | iting  | "1" to it            | is ir | ivali    | d.   |       |      |       |          |       |          |



| 15    | TSEN                                                           | Timesta     | mp enable                                                                                                                                                                                      |
|-------|----------------------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                                                                | 0           | Timestamp disabled                                                                                                                                                                             |
|       |                                                                | 1           | Timestamp enabled                                                                                                                                                                              |
| NOTE: |                                                                |             |                                                                                                                                                                                                |
|       | lf timestamp wa<br>run mode.                                   | keup is use | ed in standby mode, PC13 must be set to timestamp function in                                                                                                                                  |
| 14    | TS_EDGE_SEL                                                    | Timesta     | mp event active edge selection                                                                                                                                                                 |
| 13    |                                                                | 00          | Falling edge                                                                                                                                                                                   |
|       |                                                                | 01          | Rising edge                                                                                                                                                                                    |
|       |                                                                | 10          | Falling/rising                                                                                                                                                                                 |
|       |                                                                | 11          | Reserved                                                                                                                                                                                       |
| 12    | TSFG                                                           | Time sta    | amp event flag                                                                                                                                                                                 |
|       |                                                                | 0           | Timestamp event is not generated                                                                                                                                                               |
|       |                                                                | 1           | Timestamp event is generated                                                                                                                                                                   |
| NOTE: |                                                                |             |                                                                                                                                                                                                |
|       | This flag is rese                                              | t when "0"  | is written to it. Writing "1" to it is invalid.                                                                                                                                                |
| 11    | WAIE                                                           | Alarm ei    | nable                                                                                                                                                                                          |
|       |                                                                | 0           | Alarm is disabled                                                                                                                                                                              |
|       |                                                                | 1           | Alarm is enabled                                                                                                                                                                               |
| 8     | WAFG                                                           | Alarm fla   | ag                                                                                                                                                                                             |
|       |                                                                | 0           | Alarm is not generated                                                                                                                                                                         |
|       |                                                                | 1           | Alarm is generated                                                                                                                                                                             |
| NOTE: |                                                                |             |                                                                                                                                                                                                |
|       | This flag is rese                                              | t when "0"  | is written to it. Writing "1" to it is invalid.                                                                                                                                                |
| 1     | RWST                                                           |             | de status flag                                                                                                                                                                                 |
| •     | itter i                                                        | 0           | Run mode                                                                                                                                                                                       |
|       |                                                                | 1           | RW mode                                                                                                                                                                                        |
|       |                                                                | •           | NW mode                                                                                                                                                                                        |
| NOTE: |                                                                |             |                                                                                                                                                                                                |
|       | RW mode for re                                                 | eading and  | ronizes RWAIT to RTC clock (f <sub>RTC</sub> ). This indicates that it is in the<br>writing the RTC counter. Before reading and writing the RTC<br>alue of this flag is "1".                   |
| 0     | RWAIT                                                          | RW mod      | de set                                                                                                                                                                                         |
|       |                                                                | 0           | RW mode is unset                                                                                                                                                                               |
|       |                                                                | 1           | RW mode is set                                                                                                                                                                                 |
| NOTES | •                                                              |             |                                                                                                                                                                                                |
| 1.    |                                                                |             | interrupts, alarm match interrupts and timestamp interrupts use                                                                                                                                |
| 2.    | be judged by c                                                 | hecking th  | pes of interrupts at the same time, which interrupt occurred car<br>e Constant-period matching flag (RIFG), the alarm detection<br>e timestamp event flag (TSFG) upon RTC interrupt occurrence |
| 3.    | 25us delay requ<br>Example code)<br>RTCCR =  0x01<br>NOP; NOP; |             |                                                                                                                                                                                                |



## 23.2.2 ERRCOR: Error correction register

ERRCOR is a 32-bit register. This register is used to correct the watch with high accuracy when it is slow or fast by changing the value that overflows from the sub-second counter register to the second counter register (SEC).

## ERRCOR=0x4000\_6108

| 31  | 30  | 29       | 28    | 27 2 | 6 25 | 5 24 | 23 | 22   | 21  | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|-----|----------|-------|------|------|------|----|------|-----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|---|---|---|---|---|---|---|
| DEV | DIR | Reserved | COREN |      |      |      | Re | serv | /ed |    |    |    |    |    |    |    |    |    |    |    | со | RD  | ATA |   |   |   |   |   |   |   |
| 0   | 0   | -        | 0     |      |      |      |    | -    |     |    |    |    |    |    |    |    |    |    |    |    | 0x | 000 | 000 |   |   |   |   |   |   |   |
| RW  | RW  | •        | RW    |      |      |      |    | -    |     |    |    |    |    |    |    |    |    |    |    |    |    | RW  |     |   |   |   |   |   |   |   |
|     |     |          |       |      |      |      |    |      |     |    |    |    |    |    |    |    |    |    |    |    |    |     |     |   |   |   |   |   |   |   |

| 31      | DEV     | Setting of watch error correction timing.                                                   |
|---------|---------|---------------------------------------------------------------------------------------------|
|         |         | 0 Corrects watch error when the second digits are at 00, 20, or 40 (every 20 seconds).      |
|         |         | 1 Corrects watch error only when the second digits are at 00 (every 60 seconds).            |
| 30      | DIR     | Setting of watch error correction direction                                                 |
|         |         | 0 Decreases by CORDATA.                                                                     |
|         |         | 1 Increases by CORDATA.                                                                     |
| 28      | COREN   | Enable watch error correction                                                               |
|         |         | 0 Disable                                                                                   |
|         |         | 1 Enable                                                                                    |
| 16<br>0 | CORDATA | Setting of watch error correction data<br>When CORDATA=0, the watch error is not corrected. |



SEC -0-4000 640C

## 23.2.3 SEC: Second counter register

SEC is a 7-bit register that takes a value of '00' to '59' (decimal) and indicates the count value of seconds. It counts up when the sub-second counter register overflows. When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'.

Set a decimal value of '00' to '59' to this register in BCD code. If a value that is not a BCD code is written, it is ignored. If a value outside the range is written, the reset value is written.

|                                                                         | $SEC = 0x4000_{6100}$ |
|-------------------------------------------------------------------------|-----------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 | 6 5 4 3 2 1 0         |
|                                                                         |                       |
| Reserved                                                                | SEC                   |
|                                                                         |                       |
|                                                                         |                       |
| -                                                                       | 0x00                  |
| •                                                                       | RW                    |
|                                                                         |                       |
| 6 SEC Second Counter Register                                           |                       |
| 0                                                                       |                       |

### 23.2.4 MIN: Minute counter register

MIN is a 7-bit register that takes a value of '00' to '59' (decimal) and indicates the count value of minutes. It counts up when the second counter overflows. When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'. Even if the second counter register overflows while this register is being written, the overflow is ignored and MIN register is set to the value written.

Set a decimal value of '00' to '59' to this register in BCD code. If a value that is not a BCD code is written, it is ignored. If a value outside the range is written, the reset value is written.

#### MIN =0x4000\_6110

|                                                                       |   |   |    |      |   | - | - |
|-----------------------------------------------------------------------|---|---|----|------|---|---|---|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 | 7 | 6 | 54 | 3    | 2 | 1 | 0 |
| Reserved                                                              |   |   |    | MIN  | I |   |   |
| -                                                                     |   |   |    | 0x00 | ) |   |   |
|                                                                       |   |   |    | RW   |   |   |   |

| - |   |     |                         |
|---|---|-----|-------------------------|
|   | 6 | MIN | Minute Counter Register |
|   | 0 |     | -                       |



### 23.2.5 HOUR: Hour counter register

0

HOUR is a 6-bit register that takes a value of '00' to '23' ('01' to '12' and '21' to '32' when AMPM=0, decimal) and indicates the count value of hours. It counts up when the minute counter overflows. When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'. Even if the minute counter register overflows while this register is being written, the overflow is ignored and HOUR register is set to the value written.

Specify a decimal value of '00' to '23' ('01' to '12' and '21' to '32' when AMPM=0) by using BCD code according to the time system specified using bit 20 (AMPM) of real-time clock control register (RTCCR).

If the AMPM bit value is changed, the values of the HOUR register and ALARMWH register change according to the specified time system. If a value that is not a BCD code is written, it is ignored. If a value outside the range is written, the reset value is written. Reset signal clears this register to 12H.

HOUR =0x4000\_6114

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21 | 20 | 19  | 18   | 17  | 16   | 15   | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2  | 1 | 0 |
|----|----|----|----|----|----|----|----|----|-----|----|----|-----|------|-----|------|------|------|----|----|----|----|---|---|---|---|---|---|-----|----|---|---|
|    |    |    |    |    |    |    |    |    |     |    |    |     |      |     |      |      |      |    |    |    |    |   |   |   |   |   |   |     |    |   |   |
|    |    |    |    |    |    |    |    |    |     |    | R  | ese | erve | d   |      |      |      |    |    |    |    |   |   |   |   |   |   | НΟΙ | JR |   |   |
|    |    |    |    |    |    |    |    |    |     |    |    |     |      |     |      |      |      |    |    |    |    |   |   |   |   |   |   |     |    |   |   |
|    |    |    |    |    |    |    |    |    |     |    |    |     |      |     |      |      |      |    |    |    |    |   |   |   |   |   |   |     |    |   |   |
|    |    |    |    |    |    |    |    |    |     |    |    | -   | -    |     |      |      |      |    |    |    |    |   |   |   |   |   |   | 0x′ | 12 |   |   |
|    |    |    |    |    |    |    |    |    |     |    |    |     |      |     |      |      |      |    |    |    |    |   |   |   |   |   |   | RV  | I  |   |   |
|    |    |    |    |    |    |    |    |    |     |    |    |     |      |     |      |      |      |    |    |    |    |   |   |   |   |   |   |     |    |   |   |
|    |    |    |    |    |    | 5  |    | H  | OUR | 2  |    | F   | lour | cou | unte | r Re | igst | er |    |    |    |   |   |   |   |   |   |     |    |   |   |

Table 90 shown below introduces relationship between the setting value of the AMPM bit, the hour count register (HOUR) value, and time.

| 24-hour d | lisplay (AMI | PM = 1) |      | 12-hour di | isplay (AMP | M = 0)  |      |
|-----------|--------------|---------|------|------------|-------------|---------|------|
| Time      | HOUR         | Time    | HOUR | Time       | HOUR        | Time    | HOUR |
| 12 a.m.   | 00H          | 12 p.m. | 12H  | 12 a.m.    | 12H         | 12 p.m. | 32H  |
| 1 a.m.    | 01H          | 1 p.m.  | 13H  | 1 a.m.     | 01H         | 1 p.m.  | 21H  |
| 2 a.m.    | 02H          | 2 p.m.  | 14H  | 2 a.m.     | 02H         | 2 p.m.  | 22H  |
| 3 a.m.    | 03H          | 3 p.m.  | 15H  | 3 a.m.     | 03H         | 3 p.m.  | 23H  |
| 4 a.m.    | 04H          | 4 p.m.  | 16H  | 4 a.m.     | 04H         | 4 p.m.  | 24H  |
| 5 a.m.    | 05H          | 5 p.m.  | 17H  | 5 a.m.     | 05H         | 5 p.m.  | 25H  |
| 6 a.m.    | 06H          | 6 p.m.  | 18H  | 6 a.m.     | 06H         | 6 p.m.  | 26H  |

Table 90. Specified time system by AMPM



| 24-hour di | isplay (AMP | M = 1)  |     | 12-hour di | splay (AMP | M = 0)  |     |
|------------|-------------|---------|-----|------------|------------|---------|-----|
| 7 a.m.     | 07H         | 7 p.m.  | 19H | 7 a.m.     | 07H        | 7 p.m.  | 27H |
| 8 a.m.     | 08H         | 8 p.m.  | 20H | 8 a.m.     | 08H        | 8 p.m.  | 28H |
| 9 a.m.     | 09H         | 9 p.m.  | 21H | 9 a.m.     | 09H        | 9 p.m.  | 29H |
| 10 a.m.    | 10H         | 10 p.m. | 22H | 10 a.m.    | 10H        | 10 p.m. | 30H |
| 11 a.m.    | 11H         | 11 p.m. | 23H | 11 a.m.    | 11H        | 11 p.m. | 31H |

| Table 90. | Specified | time s | vstem bv      | (continued) |    |
|-----------|-----------|--------|---------------|-------------|----|
|           | opeomea   | time 5 | y 3 t 5 m 8 y | (continued) | ι. |

## 23.2.6 DAY: Day counter register

DAY is a 6-bit register that takes a value ranging from '01' to '31' (decimal) and indicates the count value of days. It counts up when the hour counter overflows. This counter counts the followings:

- '01' to '31' (January, March, May, July, August, October, December)
- '01' to '30' (April, June, September, November)
- '01' to '29' (February, leap year)
- '01' to '28' (February, normal year)

When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'. Even if the hour counter register overflows while this register is being written, this overflow is ignored and DAY register is set to the value written. Set a decimal value of '01' to '31' (corresponding to the month) to this register in BCD code. If a value that is not a BCD code is written, it is ignored. If a value outside the range is written, the reset value is written.

#### DAY =0x4000\_6118

|                |          |          |         |      |       |    |    |    |    |    |   |   |   |   |   |   |     |    | - |   |
|----------------|----------|----------|---------|------|-------|----|----|----|----|----|---|---|---|---|---|---|-----|----|---|---|
| 31 30 29 28 27 | 26 25 24 | 23 22 21 | 20 19 1 | 8 17 | 16 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2  | 1 | 0 |
|                |          |          | Reserv  | ved  |       |    |    |    |    |    |   |   |   |   |   |   | DA  | ٩Y |   |   |
|                |          |          | -       |      |       |    |    |    |    |    |   |   |   |   |   |   | 0x0 | 00 |   |   |
|                |          |          |         |      |       |    |    |    |    |    |   |   |   |   |   |   | RV  | N  |   |   |
|                |          |          |         |      |       |    |    |    |    |    |   |   |   |   |   |   |     |    |   |   |

| 5 | DAY | Day Counter Register |
|---|-----|----------------------|
| 0 |     | , ,                  |



## 23.2.7 WEEK: Week counter register

WEEK is a 3-bit register that takes a value ranging from '0' to '6' (decimal) and indicates the count value of weekdays.

It counts up in synchronization with the day counter. When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'. Set a decimal value of 0 to 6 to this register. If a value outside the range is written, the reset value is written.

There is no corresponding WEEK value according to DAY. Select a value from '0' to '6' that corresponds to the day of the week and use it sequentially. After reset release, set the week counter register as you selected.

|    |    |    |    |    |    |    |    |    |      |    |    |    |     |      |      |      |       |      |    |    |    |   |   |   |   | DA | Y = | 0x4 | 000 | _611C |
|----|----|----|----|----|----|----|----|----|------|----|----|----|-----|------|------|------|-------|------|----|----|----|---|---|---|---|----|-----|-----|-----|-------|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21 | 20 | 19 | 18  | 17   | 16   | 15   | 14    | 13   | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4   | 3   | 2   | 1 0   |
|    |    |    |    |    |    |    |    |    |      |    |    |    | Re  | eser | ved  | I    |       |      |    |    |    |   |   |   |   |    |     |     | w   | 'EEK  |
|    |    |    |    |    |    |    |    |    |      |    |    |    |     | -    |      |      |       |      |    |    |    |   |   |   |   |    |     |     | (   | 0x0   |
|    |    |    |    |    |    |    |    |    |      |    |    |    |     |      |      |      |       |      |    |    |    |   |   |   |   |    |     |     |     | RW    |
|    |    |    |    |    |    |    |    |    |      |    |    |    |     |      |      |      |       |      |    |    |    |   |   |   |   |    |     |     |     |       |
|    |    |    |    |    |    | 2  |    | W  | /EEł | <  |    | ١  | Nee | k Co | ount | er F | Regis | ster |    |    |    |   |   |   |   |    |     |     |     |       |

## 23.2.8 MONTH: Month counter register

0

MONTH is a 5-bit register that takes a value ranging from '01' to '12' (decimal) and indicates the count value of months. It counts up when the day counter overflows. When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'. Even if the day counter register overflows while this register is being written, the overflow is ignored and MONTH register is set to the value written.

Set a decimal value of '01' to '12' to this register in BCD code. If a value that is not a BCD code is written, it is ignored. If a value outside the range is written, the reset value is written.

#### SEC =0x4000\_6120

|    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |    |    |    |    |    |    |    |   |   |   |   |   |   |    |      | - |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|----|------|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2    | 1 | 0 |
|    |    |    |    |    |    |    |    |    |    |    |    | Re | ser\ | /ed |    |    |    |    |    |    |    |   |   |   |   |   |   | MC | тис  | Ή |   |
|    |    |    |    |    |    |    |    |    |    |    |    |    | -    |     |    |    |    |    |    |    |    |   |   |   |   |   |   | C  | )x0C | ) |   |
|    |    |    |    |    |    |    |    |    |    |    |    |    | •    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |    | RW   |   |   |



| 4 | MONTH | Month Counter Register |  |
|---|-------|------------------------|--|
| 0 |       | -                      |  |

## 23.2.9 YEAR: Year counter register

YEAR is an 8-bit register that takes a value ranging from '00' to '99' (decimal) and indicates the count value of years. It counts up when the month counter register overflows. Values 00, 04, 08, ..., 92, and 96 indicate a leap year.

When data is written to this register, it is written to a buffer and then to the counter when RWST bit is changed to '0'. Even if the MONTH register overflows while this register is being written, the overflow is ignored and YEAR register is set to the value written.

Set a decimal value of '00' to '99' to this register in BCD code. If a value that is not a BCD code is written, it is ignored.

|    |    |      |    |    |    |    |    |    |     |    |     |     |      |      |      |      |       |    |    |    |    |   |   |   | ١ | ΈA | R = | 0x4 | 1000 | _6 <sup>,</sup> | 124 |
|----|----|------|----|----|----|----|----|----|-----|----|-----|-----|------|------|------|------|-------|----|----|----|----|---|---|---|---|----|-----|-----|------|-----------------|-----|
| 31 | 30 | ) 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21 | 20  | 19  | 18   | 17   | 16   | 15   | 14    | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4   | 3   | 2    | 1               | 0   |
|    |    |      |    |    |    |    |    |    |     |    |     |     |      |      |      |      |       |    |    |    |    |   |   |   |   |    |     |     |      |                 |     |
|    |    |      |    |    |    |    |    |    |     | R  | ese | rve | Ь    |      |      |      |       |    |    |    |    |   |   |   |   |    | YE  | ΔR  |      |                 |     |
|    |    |      |    |    |    |    |    |    |     |    | 000 | 100 | u    |      |      |      |       |    |    |    |    |   |   |   |   |    |     |     |      |                 |     |
|    |    |      |    |    |    |    |    |    |     |    |     |     |      |      |      |      |       |    |    |    |    |   |   |   |   |    |     |     |      |                 |     |
|    |    |      |    |    |    |    |    |    |     |    | -   |     |      |      |      |      |       |    |    |    |    |   |   |   |   |    | 0x  | 00  |      |                 |     |
|    |    |      |    |    |    |    |    |    |     |    | -   |     |      |      |      |      |       |    |    |    |    |   |   |   |   |    | R   | N   |      |                 |     |
|    |    |      |    |    |    |    |    |    |     |    |     |     |      |      |      |      |       |    |    |    |    |   |   |   |   |    |     |     |      |                 |     |
|    |    |      |    |    | -  | 7  |    | YE | EAR |    |     | )   | Yeaı | · Co | unte | r Re | eigst | er |    |    |    |   |   |   |   |    |     |     |      |                 |     |

#### 23.2.10 ALARMW: Alarm register

0

ALARMW sets alarm time by configuring minute, hour and week of alarm.

#### ALARMWM =0x4000\_6128

| 31 30 29 28 27 26 25 24 23 | 22 21 20 19 18 17 16 | 15 14    | 13 12 11 10 9 8 | 7        | 6 | 54  | 3    | 2  | 1 |
|----------------------------|----------------------|----------|-----------------|----------|---|-----|------|----|---|
| Reserved                   | ALARMWW              | Reserved | ALARMWH         | Reserved |   | ALA | .RM\ | νM |   |
| -                          | 0x00                 | -        | 0x00            | -        |   | (   | )x00 |    |   |
|                            | RW                   | -        | RW              | -        |   |     | RW   |    |   |



| 22<br>16 | ALARMWW | This register is used to set day of the week for the alarm. Each of the seven bits represents a day of the week, so that duplicate days of the week can be selected.                                                    |
|----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13<br>8  | ALARMWH | This register is used to set hours of the alarm. Set a decimal value of 00 to 23, 01 to 12, or 21 to 32 to this register according to AMPM in BCD code. If a value outside the range is set, the alarm is not detected. |
| 6<br>0   | ALARMWM | This register is used to set minutes of the alarm. Set a decimal value of 00 to 59 to this register in BCD code. If a value outside the range is set, the alarm is not detected.                                        |

## 23.2.11 SUBDR: Sub-second counter compare register

SUBDR is a 32-bit register. This register determines the sub-second counter matching value and provides the desired frequency clock to the second counter register.

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 | 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|----------------------------------------------|------------------------------------------|
|                                              |                                          |
| Reserved                                     | SUBDR                                    |
|                                              |                                          |
|                                              |                                          |
| -                                            | 0x1FFFF                                  |
|                                              | RW                                       |
|                                              |                                          |

16 SUBDR Sub-second counter Compare Reigster 0

## 23.2.12 TIME\_TS: TimeStamp time register

TIME\_TS automatically saves the current time when a timestamp event occurs.

|                         |                         |                       | ALARMWW =0x4000_6130 |
|-------------------------|-------------------------|-----------------------|----------------------|
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0      |
| Reserved                | HOUR_TS                 | MIN_TS                | SEC_TS               |
| -                       | 0x00                    | 0x00                  | 0x00                 |
| · ·                     | R                       | R                     | R                    |

| 23<br>16 | HOUR_TS | HOUR stored when the timestamp event occurred |
|----------|---------|-----------------------------------------------|
| 15<br>8  | MIN_TS  | MIN stored when the timestamp event occurred  |
| 7<br>0   | SEC_TS  | SEC stored when the timestamp event occurred  |



## 23.2.13 DATE\_TS: TimeStamp date register

DATE\_TS automatically saves the current date when a timestamp event occurs.

|      |      |      |     |     |    |    |     |     |    |    |    |     |    |    |    |    |    |    |    |     |     |    |   | 4 | ALA | ARN | ١W | w = | 0x4 | 000 | )_6 <sup>,</sup> | 134 |
|------|------|------|-----|-----|----|----|-----|-----|----|----|----|-----|----|----|----|----|----|----|----|-----|-----|----|---|---|-----|-----|----|-----|-----|-----|------------------|-----|
| 31 3 | 80 2 | 29 2 | 28  | 27  | 26 | 25 | 5 2 | 4 2 | 23 | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11  | 10 | 9 | 8 | 7   | 6   | 5  | 4   | 3   | 2   | 1                | 0   |
|      |      | YE   | EAF | R_T | S  |    |     |     |    |    | MC | DNT | Ή_ | TS |    |    |    |    | W  | 'EE | K_1 | S  |   |   |     |     | [  | DAY |     | 6   |                  |     |
|      |      |      | 0x( | 00  |    |    |     |     |    |    |    | 0x  | 00 |    |    |    |    |    |    | 0x  | 00  |    |   |   |     |     |    | 0x  | 00  |     |                  |     |
|      |      |      | R   |     |    |    |     |     |    |    |    | F   | {  |    |    |    |    |    |    |     | 2   |    |   |   |     |     |    | F   | {   |     |                  |     |

| 31<br>34 | YEAR_TS  | YEAR stored when the timestamp event occurred  |
|----------|----------|------------------------------------------------|
| 23<br>16 | MONTH_TS | MONTH stored when the timestamp event occurred |
| 15<br>8  | WEEK_TS  | WEEK stored when the timestamp event occurred  |
|          |          |                                                |

### 23.2.14 BKUPDR: Backup register 1 to 4

BKUPDR is a 32-bit register. This register is used to store the necessary data in the backup power mode.

| DKUD4 -0-4000  | C420 DKUD2 -0.40   |                       | 00 C440 DKUD4 -0-4000 C444  |
|----------------|--------------------|-----------------------|-----------------------------|
| DRUR1 -0X4000_ | _0130, DRURZ -0X40 | JUU_013C, DRUK3 -0X40 | 00_6140, BKUR4 =0x4000_6144 |

| 31 | З | 80 29 | 28 | 3 2 | 7 26 | 6 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  | 15 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|---|-------|----|-----|------|------|----|----|----|----|----|----|----|-----|-----|-------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |   |       |    |     |      |      |    |    |    |    |    |    |    |     |     |       |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |       |    |     |      |      |    |    |    |    |    |    |    | BI  | KUP | PDR   |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |       |    |     |      |      |    |    |    |    |    |    |    |     |     |       |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |       |    |     |      |      |    |    |    |    |    |    |    |     |     |       |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |       |    |     |      |      |    |    |    |    |    |    |    | 0x0 | 000 | 00000 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |       |    |     |      |      |    |    |    |    |    |    |    |     | RV  | V     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|    |   |       |    |     |      |      |    |    |    |    |    |    |    |     |     |       |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| 31 BKUPDR<br>0 | Backup Register |  |  |
|----------------|-----------------|--|--|
|----------------|-----------------|--|--|



## 23.2.15 RTCPFCR: RTC pin function configuration register

RTCPFCR defines function and status of the PC13, PC14 and PC15. Controls the status of PC13, PC14, and PC15 ports in all modes (RUN, IDLE, STOP, STANDBY, BACKUP POWER). When set to OUTPUT, the value of the PCU (Port Control Unit) register is ignored. When set to INPUT (Floating), the PCU.MODE register must also be set to Input.

BKUR1 =0x4000\_6138, BKUR2 =0x4000\_613C, BKUR3 =0x4000\_6140, BKUR4 =0x4000\_6144

| 31 | 3 | 30 2 | 9 | 28 | 2 | 7 | 26 | 25 | 24 | 2 | 23 | 22 | 21  | 20  | 19 | 9 | 18 | 17 | 1 | 6 | 15 | 14 | - 1 | 3 | 12 | 11 | 10 | 9        | 8        | 7        | 6         | 5        | 4         | 3 | 2        | 1         | 0         |
|----|---|------|---|----|---|---|----|----|----|---|----|----|-----|-----|----|---|----|----|---|---|----|----|-----|---|----|----|----|----------|----------|----------|-----------|----------|-----------|---|----------|-----------|-----------|
|    |   |      |   |    |   |   |    |    |    |   |    | Re | ser | vec |    |   |    |    |   |   |    |    |     |   |    |    |    | PCI3WKEN | Reserved | PC15MODE | PC15VALUE | PC14MODE | PC14VALUE |   | PC13MODE | PC13VALUE | PC13WKUEN |
|    |   |      |   |    |   |   |    |    |    |   |    |    | -   |     |    |   |    |    |   |   |    |    |     |   |    |    |    | 0        | -        | 0        | 0         | 0        | 0         | C | 00       | 0         | 0         |
|    |   |      |   |    |   |   |    |    |    |   |    |    | •   |     |    |   |    |    |   |   |    |    |     |   |    |    | F  | W        | •        | RW       | RW        | RW       | RW        | F | W        | RW        | RW        |

| 10   | WKUPEN              | PC13 wakeup event enable                                                                                                                                                                                                     |
|------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9    |                     | XX Disable wakeup event                                                                                                                                                                                                      |
|      |                     | 11 Enable wakeup event                                                                                                                                                                                                       |
| 7    | PC15MODE            | PC15 mode                                                                                                                                                                                                                    |
|      |                     | 0 Floating.                                                                                                                                                                                                                  |
|      |                     | 1 Push-pull output if LSE is disabled                                                                                                                                                                                        |
| 6    | PC15VALUE           | PC15 value<br>If the LSE is disabled and PC15MODE=1, PC15VALUE configures the<br>PC15 output data                                                                                                                            |
| 5    | PC14MODE            | PC14 mode                                                                                                                                                                                                                    |
|      |                     | 0 Floating.                                                                                                                                                                                                                  |
|      |                     | 1 Push-pull output if LSE is disabled                                                                                                                                                                                        |
| 4    | PC14VALUE           | PC14 value<br>If the LSE is disabled and PC14MODE=1, PC14VALUE configures the<br>PC14 output data                                                                                                                            |
| 3    | PC13MODE            | PC13 mode                                                                                                                                                                                                                    |
| 2    |                     | 000 Floating.                                                                                                                                                                                                                |
|      |                     | 01 RTC_TS input<br><b>NOTE</b> : If timestamp wakeup is used in standby mode, PC13<br>must be set to timestamp function (AF7) in run mode.                                                                                   |
|      |                     | 10 Push-pull output                                                                                                                                                                                                          |
|      |                     | 11 RTC_OUT push-pull output                                                                                                                                                                                                  |
| 1    | PC13VALUE           | PC13 value<br>If PC13MODE=10, PC13VALUE configures the PC13 output data                                                                                                                                                      |
| 0    | PC13WKUPEN          | Wakeup pin enable                                                                                                                                                                                                            |
|      |                     | 0 PC13 is not used as wakeup pin.                                                                                                                                                                                            |
|      |                     | 1 PC13 is used as wakeup pin. (Only Rising Edge wakeup)                                                                                                                                                                      |
|      |                     | <b>NOTE:</b><br>When this bit is set to 1, PC13 enters the input state, and PC13MODE setting is ignored. RTC time stamp operation is possible if it is enabled. PC13 wakeup event is enabled when PC13WKUPEN=1 and WKUPEN=1. |
| NOTE | : When PC13 is used | as Standby mode wakeup Pin, RTCPFCR must be initialized                                                                                                                                                                      |
|      |                     |                                                                                                                                                                                                                              |



## 23.3 Functional description

RTC clock (fRTC) input to the sub-second counter is determined by MCCR5 and PPCLKSR.5. By setting the SUBDR register value corresponding to the RTC clock, the sub-second counter output, that is, input clock of the SEC, can be 1Hz.

In Standby mode or backup power mode, only LSE and LSI40kHz operate, so the clock source must be changed.

| RTCCSEL         | RTCDIV | fRTC      | SUBDR           | ERROR |
|-----------------|--------|-----------|-----------------|-------|
| LSI (40KHz)     | 1      | 40KHz     | 0x0000_9C40 - 1 | -     |
| LSE (32.768KHz) | 1      | 32.768KHz | 0x0000_8000 - 1 | _     |

## 23.3.1 Starting the RTC Operation

To start the RTC, a user should follow the procedure below:

- 1. Set the system configure register to enable RTC peripherals (PER2.29, PCER2.29, PRER2.29).
- 2. Select the RTC clock source by configuring MCCR5 and PPCLKSR.
- 3. Set the RTCEN bit to 1, while the oscillation of the clock is stable.
- 4. Set the necessary control registers such as alarm, timestamp, and constant-period matching etc. before activating the RTC counter.
- 5. Set the AMPM register for specified time system. If error correction is required, set the ERRCOR register.
- 6. After all the settings are completed, when the RTC counter is read for run, activate RTC by setting RTCE to 1.
- 7. Wait at least a clock of RTC after setting the counter when RTCEN = 1 and RTCE = 0.





Figure 163. Start Operation Sequence of RTC

## 23.3.2 RTC RW mode (read and write mode)

RTC counter read and write operations are not allowed in the RTC run state. Only RTC counters can be read and written in RW mode only. The RWAIT bit must be set to 1 to enter RW mode. RWST indicates that it is in RW mode and synchronized to the RTC clock. In order to perform read or write operation, be sure to check RWST = '1' before proceeding. To exit RW mode, set RWAIT to '0'.





### Figure 164. Read Operation Sequence of RTC

The value written in RW mode is loaded into the RTC counter at the end of RW mode. In RW mode, the SEC to YEAR counters stop counting and only the sub-second counter is continuing to count.

Therefore, even if the sub-second counter match is repeated several times in RW mode, it will be applied only once at the end of RW mode. For this reason, RW mode operation should be done in 1 second. When writing to the SEC in RW mode, even if a sub-second counter overflow occurs, it is ignored.

#### NOTES:

- 1. Complete the series of process of setting the RWAIT bit to '1' to clearing the RWAIT bit to '0' within '1' second.
- 2. The second counter register (SEC), minute counter register (MIN), hour counter register (HOUR), week counter register (WEEK), day counter register (DAY), month counter register (MONTH), and year counter register (YEAR) may be read/written in any sequence.
- 3. All registers do not have to be read and only some registers may be read or written.
- 4. When changing the values of the SEC, MIN, HOUR, WEEK, DAY, MONTH, and YEAR register while the counter operates (RTCE = 1), rewrite the values of the MIN register after disabling interrupt servicing INTRTC by using the interrupt mask flag register. Furthermore, clear the WAFG, RIFG and RTCIF flags after rewriting the MIN register.





Figure 165. Sub-second Counter Match in RW Mode



Figure 166. Sub-second Counter Match in RW Mode when Writing to SEC



## 23.3.3 RTC alarm setting

To activate the alarm function of RTC, write '1' to WALIE of RTCCR. Alarm time can be set with three registers ALARMWM, ALARMWH and ALARMWW. The alarm week register (ALARMWW), alarm hour register (ALARMWH), and alarm week register (ALARMWW) may be written in any sequence.

Check the WAFG of RTCCR to see that an alarm has occurred. Constant-period matching interrupts, alarm match interrupts and timestamp interrupts use the same interrupt source. When using these three types of interrupts at the same time, which interrupt occurred can be judged by checking the Constant-period matching flag (RIFG), the alarm detection status flag (WAFG), and the timestamp event flag (TSFG) upon RTC interrupt occurrence.



Figure 167. Alarm Operation Sequence of RTC

There is an ALARMWW bit corresponding to the Week counter register, and each bit of ALARMWW indicates the day of the week. Therefore, it is possible to set an alarm for a duplicate day of the week. Refer to Table 92 and Table 93.

| WEEK | ALARMWW |      |      |      |      |      |      |  |
|------|---------|------|------|------|------|------|------|--|
|      | Bit6    | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |  |
| 0    | 0       | 0    | 0    | 0    | 0    | 0    | 1    |  |
| 1    | 0       | 0    | 0    | 0    | 0    | 1    | 0    |  |
| 2    | 0       | 0    | 0    | 0    | 1    | 0    | 0    |  |

Table 92. WEEK and ALARMWW Registers



| WEEK | ALARMWW |      |      |      |      |      |      |  |
|------|---------|------|------|------|------|------|------|--|
|      | Bit6    | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |  |
| 3    | 0       | 0    | 0    | 1    | 0    | 0    | 0    |  |
| 4    | 0       | 0    | 1    | 0    | 0    | 0    | 0    |  |
| 5    | 0       | 1    | 0    | 0    | 0    | 0    | 0    |  |
| 6    | 1       | 0    | 0    | 0    | 0    | 0    | 0    |  |

## Table 92. WEEK and ALARMWW Registers (continued)

| Time of alarm                       | Day (ALARMWW)         |                       |                        |                          |                         |                       |                         | 12-hour display |                   | 24-hour display |                   |
|-------------------------------------|-----------------------|-----------------------|------------------------|--------------------------|-------------------------|-----------------------|-------------------------|-----------------|-------------------|-----------------|-------------------|
|                                     | Sunday<br>W<br>W<br>O | Monday<br>W<br>W<br>1 | Tuesday<br>W<br>W<br>2 | Wednesday<br>W<br>W<br>3 | Thursday<br>W<br>W<br>4 | Friday<br>W<br>W<br>5 | Saturday<br>W<br>W<br>6 | Hour<br>Alarmwh | Minute<br>Alarmwm | Hour<br>alarmwh | Minute<br>Alarmwm |
| Every day, 0:00 a.m.                | 1                     | 1                     | 1                      | 1                        | 1                       | 1                     | 1                       | 12              | 00                | 00              | 00                |
| Every day, 1:30 a.m.                | 1                     | 1                     | 1                      | 1                        | 1                       | 1                     | 1                       | 01              | 30                | 01              | 30                |
| Every day, 11:59 a.m.               | 1                     | 1                     | 1                      | 1                        | 1                       | 1                     | 1                       | 11              | 59                | 11              | 59                |
| Monday through<br>Friday, 0:00 p.m. | 0                     | 1                     | 1                      | 1                        | 1                       | 1                     | 0                       | 32              | 00                | 12              | 00                |
| Sunday, 1:30 p.m.                   | 1                     | 0                     | 0                      | 0                        | 0                       | 0                     | 0                       | 21              | 30                | 13              | 30                |
| Monday, Wednesday,<br>11:59 p.m.    | 0                     | 1                     | 0                      | 1                        | 0                       | 0                     | 0                       | 31              | 59                | 23              | 59                |

## Table 93. Example of Setting the Alarm

## 23.3.4 RTC Constant-period matching

You can cause the flag (RIFG) to occur at regular intervals. Depending on the CT value of RTCCR, a flag is generated once every 0.5 second, 1 second, 1 minute, 1 hour, 1 day, 1month. However, this period is the value when the sub-second counter outputs 1 Hz. Constant-period matching does not occur when the RTC value is zero. If the RTC interrupt is enabled on the NVIC, the Constant-period matching flag is used as the interrupt source. In this case, you can wakeup periodically in standby mode. Since the RTC interrupt and RTC alarm and RTC time stamp are also assigned together with the constant-period matching, if the RTC interrupt occurs, the interrupt handler can check the FLAG to see which interrupt has been occurred.

## 23.3.5 RTC Timestamp

Timestamp function is provided when external pin input occurs. Timestamp can be activated by writing 1 to TSEN in the RTCCR register, and TS\_EDGE\_SEL determines the edge of the timestamp input. When the Timestamp input is received, the value of the RTC counter register at that time is stored in TIME\_TS, DATA\_TS, and the RTC continues counting.



#### 23.3.6 RTC 1Hz output

RTC supports 1Hz clock output to RTC\_OUT pin. PC13MODE of RTCPFCR[3:2] must be set to RTCOUT. The 1Hz clock is the frequency when using LSE 32.768KHz as RTC clock and SUBDR is written 0x00007FFF. The RTC 1 Hz output can be used for error correction of the RTC counter.

#### 23.3.7 Error correction of RTC

The watch can be corrected with high accuracy when it is slow or fast, by configuring a value to the error correction register (ERRCOR). The correction value is 1, 2, 3, 4, ...  $2^{32}$ -3,  $2^{32}$ -2,  $2^{32}$ -1 or -1, -2, -3, -4, ...  $-2^{32}$ -3,  $-2^{32}$ -2,  $-2^{32}$ -1.

Target frequency is resulted after performing the correction. The range of value that can be corrected by using the watch error correction register (ERRCOR) is shown below in Table 94 and Table 95.

|                    | f <sub>RTC</sub> = 32,768 | Ηz         | f <sub>RTC</sub> = 48MHz |             | f <sub>RTC</sub> = 40,000 | )Hz        |
|--------------------|---------------------------|------------|--------------------------|-------------|---------------------------|------------|
| Correction<br>Data | DEV = 0                   | DEV = 1    | DEV = 0                  | DEV = 1     | DEV = 0                   | DEV = 1    |
| Minimum resolution | ±1.53ppm                  | ±0.51ppm   | ±0.001ppm                | ±0.0003ppm  | ±1.25ppm                  | ±0.41ppm   |
| 1                  | ±1.53 ppm                 | ±0.51 ppm  | ±0.0010 ppm              | ±0.0003 ppm | ±1.25 ppm                 | ±0.41 ppm  |
| 2                  | ±3.05 ppm                 | ±1.02 ppm  | ±0.0021 ppm              | ±0.0007 ppm | ±2.50ppm                  | ±0.83 ppm  |
| 3                  | ±4.58 ppm                 | ±1.52 ppm  | ±0.0031 ppm              | ±0.0010 ppm | ±3.75ppm                  | ±1.25 ppm  |
| 122                | ±186.2 ppm                | ±62.1 ppm  | ±0.1271 ppm              | ±0.0423 ppm | ±152.5 ppm                | ±50.8 ppm  |
| 123                | ±187.7 ppm                | ±62.6 ppm  | ±0.1281 ppm              | ±0.0427 ppm | ±153.7 ppm                | ±51.2ppm   |
| 124                | ±189.2 ppm                | ±63.0 ppm  | ±0.1292 ppm              | ±0.0431 ppm | ±155.0 ppm                | ±51.7 ppm  |
| 1024               | ±1562.5 ppm               | ±520 ppm   | ±1.0667 ppm              | ±0.3556 ppm | ±1280.0 ppm               | ±427 ppm   |
| 32768              | ±50000 ppm                | ±16667 ppm | ±34.133 ppm              | ±11.378 ppm | ±40960 ppm                | ±13653 ppm |
| 1048576            | _                         | _          | ±1092.27 ppm             | ±364.09 ppm | _                         | _          |
| 28800000           | —                         |            | ±30000 ppm               | ±10000 ppm  | _                         | _          |

 Table 94. Correction Resolution by Frequency



### Example of calculating the correction value

Following expression is used for calculation of the correction value which is used when correcting the count value of internal counter (32-bit):

- (DEV = 0): Correction value = Number of correction counts in 1 minute ÷ 3 = (fRTC ÷ 32768 1) x (32768 x 60 ÷ 3)
- (DEV = 1): Correction value = Number of correction counts in 1 minute = (fRTC ÷ 32768 1) x (32768 x 60)

### Correction example

Example procedure to correct from 32772.3Hz to 32768Hz (32772.3 Hz – 131.2 ppm) is shown below:

- 1. Measuring the oscillation frequency: The fRTC is measured by outputting to RTC\_OUT pin when the ERRCOR register is set to its initial value (0x00000000).
- 2. Calculating the correction value: Assume the target frequency to be 32768 Hz (32772.3Hz-131.2ppm) and DEV to be 0.
  - Correction value = (fRTC ÷ 32768 1) × 32768 × 60 ÷ 3 = (32772.3 ÷ 32768 1) × 32768
     × 60 ÷ 3 = 86
- 3. Calculating the values to be set to (ERRCOR): If the correction value is 0 or larger (when slowing), assume DIR to be 1.

Consequently, when correcting from 32772.3 Hz to 32768 Hz (32772.3 Hz - 131.2 ppm), setting the error correction register such that DEV is 0 and the correction value is 86 results in 32768 Hz (0 ppm)

– ERRCOR = 0x5000\_0056

**NOTE**: If the CORDATA value exceeds the clock frequency range, it may malfunction.



#### 23.3.8 BKUPDR and RTCPFCR registers

BKUPDR Register use only backup power mode. This register is retained when wakeup in backup power mode. In Backup power mode, it is wakeup after storing the value in BKUPDR register. If BKUPDR register value is held in Run state, it can be confirmed that wakeup is normally performed in backup power mode. For example can change the Timer Duty. See the picture below.

When wakeup in backup power mode, the timer register is initialized and must be set again.



Figure 168. Configuring Sequence of BKUPDR Register

In Standby & Backup power mode, GPIO ports except PC13, PC14 and PC15 cannot be used. Therefore, it is used to check RTC output (PC13) and PC14 and PC15 pins operating in standby & backup power mode, and Wakeup (PC13) in STANDBY mode.

PC14, PC15 cannot be used as push pull output when LSE is used with SXIN SXOUT pin of LSE. Must not use LSE to use PC14, PC15 as PUSH PULL OUTPUT.



|      | Floating | Push-Pull output | RTC_TS | RTC_OUT | *Standby Wake-up<br>Source |
|------|----------|------------------|--------|---------|----------------------------|
| PC13 | 0        | 0                | 0      | 0       | 0                          |
| PC14 | 0        | 0                | х      | Х       | Х                          |
| PC15 | 0        | 0                | Х      | Х       | Х                          |

Table 95. PC13, PC14, PC15 Function in RTCPFCR register

PC13 pin wakeup of the RTCPFCR is used only in Standby mode and is not related to the wakeup of the RTC block. Figure 169 shows sequence of PC13 pin wakeup operation.



Figure 169. PC13 wakeup in Standby Mode



## 24. Temp sensor

Temp sensor is to use the internal oscillator LSITS by default, which has a large temperature variation. The temperature-dependent LSITS frequency can be calculated based on a precisely trimmed internal oscillator or an external clock. Reference clock and sense clock of the temp sensor can be changed by configuring TSENSECON register. When selecting the clock, frequency of the reference clock must be faster than the sense clock frequency. In SCU, each clock must be activated by configuring corresponding register. If value of TSREFCNT using REF clock matches the TSREFPERIOD set by the user, a match flag is generated and frequency of the sense clock is calculated by reading the value of TSSENSECNT at this time. Match flags can be used as interrupt sources.

Note) In order to use the sensor properly, it should be set **the reference clock of temperature sensor is minimum 8MHz.** 

#### **Glossary for this chapter**

- HSI\_I: HSI clock set by CSCR
- MCLK: System clock set by SCCR
- LSE: External sub oscillator
- LSITS: Internal temp sense oscillator
- LSI750KHz: Internal 750KHz oscillator
- LSI40KHz: Internal 40KHz oscillator

## 24.1 Temp sensor block diagram



Figure 170. Temp Sensor Block Diagram



## 24.2 Registers

Base address of a temp sensor block is introduced in the followings:

#### Table 96. Base Address of TSENSE Interface

| Name   | Base address |
|--------|--------------|
| TSENSE | 0x4000_6300  |

#### Table 97. TSENSE Register Map

| Name        | Offset | Туре | Description                                    | Reset value | Reference     |
|-------------|--------|------|------------------------------------------------|-------------|---------------|
| TSENSECON   | 0x0000 | RW   | Temp Sensor Control<br>Register                | 0x0000_0000 | <u>24.2.1</u> |
| TSREFPERIOD | 0x0004 | RW   | Temp Sensor Reference<br>Clock period Register | 0x000F_FFFF | <u>24.2.2</u> |
| TSSENSECNT  | 0x0008 | R    | Temp Sensor Sense Clock<br>Count Register      | 0x0000_0000 | <u>24.2.3</u> |

#### 24.2.1 TSENSECON: Temp sensor control register

#### TSENSECON =0x4000\_6300

| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 | 3        | 2       | 1       | 0     |
|-------------------------------------------------------------------------------|----------|---------|---------|-------|
| Reserved                                                                      | TSSINTEN | TSSFLAG | TSSTART | TSSEN |
| -                                                                             | 0        | 0       | 0       | 0     |
|                                                                               | RW       | RW      | RW      | RW    |

| 3 | TSSINTEN | Temp Sensor interrupt enable                                                                 |
|---|----------|----------------------------------------------------------------------------------------------|
|   |          | 0 Temp sensor interrupt disabled                                                             |
|   |          | 1 Temp sensor interrupt enabled                                                              |
| 2 | TSSFLAG  | Temp Sensor CNT match flag                                                                   |
|   |          | 0 Temp sensor CNT match flag is not generated                                                |
|   |          | 1 Temp sensor CNT match flag not generated                                                   |
|   |          | <b>NOTE</b> :<br>This flag is reset when "1" is written to it. Writing "0" to it is invalid. |
| 1 | TSSTART  | Temp Sensor start                                                                            |
|   |          | 0 Wait                                                                                       |
|   |          | 1 Clear & start                                                                              |
| 0 | TSSEN    | Temp Sensor enable                                                                           |
|   |          | 0 Temp Sensor disabled                                                                       |
|   |          | 1 Temp Sensor enabled                                                                        |



#### 24.2.2 TSREFPEROID: Temp sensor reference clock period register

#### TSENSECON =0x4000\_6304

|                                       | _                                             | -   |
|---------------------------------------|-----------------------------------------------|-----|
| 31 30 29 28 27 26 25 24 23 22 21 20   | 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 | 1 0 |
| Reserved                              | TSREFPERIOD                                   |     |
| -                                     | 0xFFFF                                        |     |
| -                                     | RW                                            |     |
| · · · · · · · · · · · · · · · · · · · |                                               |     |

19 TSREFPERIOD Temp Sensor Reference Clock Period Register 0

#### 24.2.3 TSSENSECNT: Temp sensor sense clock count register

|                                                 | TSENSECON =0x4000_6308                |  |  |  |  |  |  |
|-------------------------------------------------|---------------------------------------|--|--|--|--|--|--|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |
| Reserved TSSENSECNT                             |                                       |  |  |  |  |  |  |
| -                                               | 0x00                                  |  |  |  |  |  |  |
|                                                 | R                                     |  |  |  |  |  |  |

| 4 - |                                      |  |
|-----|--------------------------------------|--|
| 15  | Temp Sensor Reference Count Register |  |
|     |                                      |  |
| Ο   |                                      |  |
| 0   |                                      |  |



## 24.3 Functional discription

#### 24.3.1 How to calculate and convert to temperature

To convert to temperature, two temperature values in the region of OTP should be read.

The region of OTP includes the specific value of two temperature(85°C and 30°C). These value calculate to slope and offset of temperature. There is a guide related to converting to temperature. Refer to the Table 98

| Variable          | Temperature | Address of OTP | Note                                 |
|-------------------|-------------|----------------|--------------------------------------|
| Specific<br>value | 85°C        | 0x3F0103F4     | Value abaractoristics vary by comple |
|                   | 30°C        | 0x3F0103F8     | Value characteristics vary by sample |

#### Table 98. Specific temperature value in the region of OTP

Convert the temperature as shown below.

- A. Read two specific values about temperature(85°C and 30°C)
- B. Divide each value by 8192(0x2000) and multiply system clock / TSREFPEROID register.
- C. 85°C is X, 30°C is Y. (8192 is a fixed value)
- D. Slope = (85 30) / (X Y), Offset = 30 (Slope x Y)
- E. Temperature(°C) = Slope x TSSENSECNT + offset

For example, Reference period of temperature is 1kHz. TSREFPEROID is system clock / 1000.



## 25. Electrical characteristics

## 25.1 Absolute maximum ratings

Absolute maximum ratings are limiting values of operating and environmental conditions which should not be exceeded under the worst possible conditions.

| Parameter                  | Symbol         | Ratings        | Unit | Note                                                   |
|----------------------------|----------------|----------------|------|--------------------------------------------------------|
| Supply<br>Voltage          | VDD            | -0.3 - +6.5    | V    | —                                                      |
| Normal Pin                 | VI             | -0.3 – VDD+0.3 | V    | Voltage on any pin with respect to VSS                 |
|                            | Vo             | -0.3 – VDD+0.3 | V    |                                                        |
|                            | Іон            | 25             | mA   | Maximum current output sourced by (I_{OH} per I/O pin) |
|                            | ΣΙοн           | 100            | mA   | Maximum current (ΣI <sub>OH</sub> )                    |
|                            | Iol            | 22             | mA   | Maximum current sunk by (IoL per I/O pin)              |
|                            | ΣΙοι           | 88             | mA   | Maximum current (ΣI₀∟)                                 |
| Total Power<br>Dissipation | Τ <sub>Ρ</sub> | 300            | mW   | _                                                      |
| Storage<br>Temperature     | Tstg           | -55 – +125     | °C   | —                                                      |

Table 99. Absolute maximum rating



## 25.2 Recommended operating conditions

|                          |                   |                  |       | (Tempera | ature: -40°C t | o +85℃) |
|--------------------------|-------------------|------------------|-------|----------|----------------|---------|
| Parameter                | Symbol            | Condition        | Min   | Тур.     | Max            | Unit    |
| Supply Voltage           | VDD               | —                | 1.8   | —        | 5.5            | V       |
|                          |                   | Use USB function | 3.0   | _        | 5.5            | V       |
| Operating<br>Frequency   | FREQ              | HSE              | 2     | _        | 16             | MHz     |
|                          |                   | LSE              | _     | 32.768   | _              | KHz     |
|                          |                   | HSI              | 46.56 | 48       | 49.44          | MHz     |
|                          |                   | LSI750kHz        | 600   | 750      | 900            | KHz     |
|                          |                   | LSI40kHz         | 22.8  | 40       | 62.6           | KHz     |
| Operating<br>Temperature | Тор               | Тор              | -40   | _        | +85            | °C      |
| Supply Rise Rate         | t <sub>rVDD</sub> | —                | _     | _        | 10             | V/ms    |
| Supply Fall Rate         | t <sub>fVDD</sub> | —                | _     | —        | 10             | V/ms    |

### Table 100. Recommended Operating Condition

NOTE: AVDD must always be equal to or greater than VDDEXT

## 25.3 ADC characteristics

#### Table 101. ADC Electrical Characteristics

| (Temperature: -40°C to +8 |        |                                           |     |      |      |      |
|---------------------------|--------|-------------------------------------------|-----|------|------|------|
| Parameter                 | Symbol | Condition                                 | Min | Тур. | Max  | unit |
| Operating voltage         | AVDD   |                                           | 2.7 | 5    | 5.5  | V    |
| Resolution                |        |                                           |     |      | 12   | Bit  |
| Operating current         | IDDA   | AVDD = 5.0V<br>@f <sub>MCLK</sub> = 24MHz |     | 1.6  |      | mA   |
| Analog input range        | Van    |                                           | VSS |      | AVDD | V    |
| Conversion rate           | FCONV  | @AVDD > 3.6V                              |     | —    | 1.5  | MHz  |
|                           |        | @AVDD > 3.0V                              |     |      | 1    | MHz  |
|                           |        | @AVDD > 2.7V                              |     |      | 0.5  | MHz  |
| Operating frequency       | ACLK   |                                           |     |      | 25   | MHz  |
| DC accuracy               | INL    | AVDD = 5.0V                               |     | ±3   | ±6   | LSB  |
|                           | DNL    | AVDD = 5.0V                               |     | ±2   | ±3   | LSB  |
| Error Of Bottom           | EOB    |                                           |     | ±4   |      | LSB  |
| Error Of Top              | EOT    |                                           |     | ±4   |      | LSB  |

NOTE) AVDD must always be equal to or greater than VDDEXT



## 25.4 DAC characteristics

| Parameter                          | Symbol                | Condition                                                                                              | Min | Тур. | Max           | unit |
|------------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------|-----|------|---------------|------|
| Operating voltage                  | AVDD                  |                                                                                                        | 2.7 | 5    | 5.5           | V    |
| Resolution                         | -                     | -                                                                                                      | -   | 10   |               | BIT  |
| Load Resistance                    | Deser                 | Load connected to VSS                                                                                  | 5   | -    | -             | kΩ   |
| with Buffer                        | Rload                 | Load connected to VAVDD                                                                                | 25  | -    | -             | kΩ   |
| Output Impedance<br>Without Buffer | Ro                    |                                                                                                        | -   | -    | 130           | kΩ   |
| DAC Output<br>Voltage              | Daout                 |                                                                                                        | 0.2 | -    | AVDD<br>- 0.2 | V    |
| Operating Current                  | I <sub>AVDD,rms</sub> | No load, middle code(0x200)                                                                            | -   | 1.48 | 0.95          | mA   |
|                                    | -                     | No R-Load, DAC Output                                                                                  | -   | ±1   | ±2            |      |
| DNL                                | -                     | R-Load=5kΩ, C-Load=50pF,<br>DAC Output                                                                 | -   | ±2   | ±8            | LSB  |
|                                    | -                     | No R-Load, DAC Output                                                                                  | -   | ±3   | ±5            |      |
| INL                                | -                     | R-Load=5kΩ, C-Load=50pF,<br>DAC Output                                                                 | -   | ±4   | ±8            | LSB  |
| Offset                             | -                     | Offset Error is difference<br>between measured value at<br>Code (0x200) and the ideal<br>value(AVDD/2) | -   | -    | 8             | LSB  |
| Gain Error                         | -                     |                                                                                                        | -   | 1.0  | -             | %    |
| Conversion Time                    | <b>t</b> SETTLINB     |                                                                                                        | -   | 2    | 4             | us   |
| Stop Current                       |                       |                                                                                                        | -   | 2    | 400           | nA   |

### Table 102. DAC Electrical Characteristics

NOTE

1. AVDD must always be equal to or greater than VDDEXT

2. Data based on characterization results, not tested in production

## 25.5 Power on reset characteristics

### Table 103. POR Electrical Characteristics

| (Temperature: -40°C t |                    |            |      |     |      | to +85°C) |
|-----------------------|--------------------|------------|------|-----|------|-----------|
| Parameter             | Symbol             | Conditions | Min  | Тур | Max  | Units     |
| POR set level         | V <sub>set</sub>   | _          | 1.05 | 1.2 | 1.35 | V         |
| POR reset level       | V <sub>reset</sub> | _          | 0.9  | 1.1 | 1.3  | V         |



## 25.6 Low voltage reset/indicator characteristics

|                         |                         |         |                 | 0℃ to +85 |      |      |       |
|-------------------------|-------------------------|---------|-----------------|-----------|------|------|-------|
| Parameter               | Symbol                  |         | Conditions      | Min       | Тур  | Max  | Units |
| Operating voltage       | VDD                     |         |                 | 1.5       | 5    | 5.5  | V     |
| Detection level         | V <sub>LVR</sub>        | Level0  | Rising voltage  | 1.56      | 1.68 | 1.80 | V     |
|                         |                         | Levelu  | Falling voltage | -         | 1.63 | 1.74 |       |
|                         |                         | Level1  | Rising voltage  | 1.65      | 1.77 | 1.89 |       |
|                         |                         | Leven   | Falling voltage | 1.60      | 1.72 | 1.84 |       |
|                         |                         | Level2  | Rising voltage  | 1.74      | 1.87 | 2.00 |       |
|                         |                         | Leveiz  | Falling voltage | 1.70      | 1.82 | 1.94 |       |
|                         |                         |         | Rising voltage  | 1.85      | 1.99 | 2.13 |       |
|                         |                         | Level3  | Falling voltage | 1.81      | 1.94 | 2.07 |       |
|                         |                         |         | Rising voltage  | 1.95      | 2.09 | 2.23 |       |
|                         |                         | Level4  | Falling voltage | 1.89      | 2.03 | 2.17 |       |
|                         |                         | Louis   | Rising voltage  | 2.07      | 2.22 | 2.37 | 7     |
|                         |                         | Level5  | Falling voltage | 2.01      | 2.16 | 2.31 | 7     |
|                         |                         |         | Rising voltage  | 2.23      | 2.40 | 2.57 |       |
|                         |                         | Level6  | Falling voltage | 2.19      | 2.35 | 2.51 |       |
|                         |                         |         | Rising voltage  | 2.41      | 2.59 | 2.77 | _     |
|                         |                         | Level7  | Falling voltage | 2.35      | 2.52 | 2.69 |       |
|                         |                         | Level8  | Rising voltage  | 2.61      | 2.80 | 2.99 |       |
|                         |                         |         | Falling voltage | 2.53      | 2.72 | 2.91 |       |
|                         |                         | 1       | Rising voltage  | 2.96      | 3.18 | 3.40 |       |
|                         |                         | Level9  | Falling voltage | 2.89      | 3.10 | 3.31 |       |
|                         |                         | 1       | Rising voltage  | 3.10      | 3.33 | 3.56 |       |
|                         |                         | Level10 | Falling voltage | 3.02      | 3.24 | 3.46 |       |
|                         |                         |         | Rising voltage  | 3.50      | 3.76 | 4.02 |       |
|                         |                         | Level11 | Falling voltage | 3.41      | 3.66 | 3.91 | 7     |
|                         |                         |         | Rising voltage  | 3.63      | 3.90 | 4.17 |       |
|                         |                         | Level12 | Falling voltage | 3.53      | 3.79 | 4.05 | 7     |
|                         |                         |         | Rising voltage  | 3.93      | 4.22 | 4.51 |       |
|                         |                         | Level13 | Falling voltage | 3.83      | 4.11 | 4.39 | 1     |
|                         |                         |         | Rising voltage  | 4.09      | 4.40 | 4.71 |       |
|                         |                         | Level14 | Falling voltage | 3.99      | 4.28 | 4.57 | 1     |
|                         |                         |         | Rising voltage  | 4.37      | 4.69 | 5.01 | 1     |
|                         |                         | Level15 | Falling voltage | 4.26      | 4.57 | 4.88 |       |
| Hysteresis              | -                       | - I     |                 | -         | 100  | 200  | mV    |
| Noise cancelling time   | _                       |         |                 | _         | 2    | -    | us    |
| Operation current       | I <sub>DD</sub>         |         |                 | _         | 3.5  | 5    | uA    |
| Operation current(STOP) | ) I <sub>DD, STOP</sub> |         |                 | _         | 2.5  | 3    | nA    |

## Table 104. Low Voltage Reset/Indicator Characteristics



## 25.7 High frequency internal RC oscillator characteristics

| Table 105. High Frequency Internal RC Oscillato | r Characteristics |
|-------------------------------------------------|-------------------|
|-------------------------------------------------|-------------------|

|                   |                   |                               |       | (Tempera | ature: -40°C | to +85°C) |
|-------------------|-------------------|-------------------------------|-------|----------|--------------|-----------|
| Parameter         | Symbol            | Conditions                    | Min   | Тур      | Max          | Units     |
| Operating current | <b>I</b> HIRC     | Enable                        | _     | 350      | 450          | uA        |
|                   |                   | Disable                       | _     | 0.6      | 70           | nA        |
| Frequency         | f <sub>HIRC</sub> | VDD = 1.8V to 5.5V            | 46.56 | 48       | 49.44        | MHz       |
|                   |                   | $T_A = -40^{\circ}C$ to +85°C |       |          |              |           |
|                   |                   | VDD = 1.8V to 5.5V            | 47.28 | 48       | 48.72        | MHz       |
|                   |                   | $T_A = 0^{\circ}C$ to +50°C   |       |          |              |           |

## 25.8 Low frequency internal RC oscillator characteristics

### Table 106. Low Frequency (750KHz) Internal RC Oscillator Characteristics

|                    |        |                    |     | (Temperature: -40°C to +85° |     |       |
|--------------------|--------|--------------------|-----|-----------------------------|-----|-------|
| Parameter          | Symbol | Conditions         | Min | Тур                         | Max | Units |
| Operating voltage  | VDD    |                    | 1.8 | 5                           | 5.5 | V     |
| Operating current  | ILIRC  | Enable             | _   | 1.5                         | 2   | uA    |
|                    |        | Disable            | _   | 1                           | 20  | nA    |
| Frequency          | flirc  | VDD = 1.8V to 5.5V | 600 | 750                         | 900 | kHz   |
| Stabilization time | tlfs   | _                  | _   | 100                         |     | us    |

### Table 107. Low Frequency (40KHz) Internal RC Oscillator Characteristics

|                    |        |                    |      | (Temperature: -40℃ to +85℃ |       |       |
|--------------------|--------|--------------------|------|----------------------------|-------|-------|
| Parameter          | Symbol | Conditions         | Min  | Тур                        | Max   | Units |
| Operating voltage  | VDD    |                    | 1.8  | 5                          | 5.5   | V     |
| Operating          | ILIRC  | Enable             | —    | 305                        | 588.2 | nA    |
| current            |        | Disable            | —    | _                          | 1     | nA    |
| Frequency          | flirc  | VDD = 1.8V to 5.5V | 22.8 | 40                         | 62.6  | KHz   |
| Stabilization time | tlfs   | —                  | —    | 100                        |       | us    |



## 25.9 DC electrical characteristics

| Table 108. DC Electrical Characteristic |
|-----------------------------------------|
|-----------------------------------------|

|                                  |                  |                                                                                                        |                                   | (Temper | ature: -40°C | to +85℃) |
|----------------------------------|------------------|--------------------------------------------------------------------------------------------------------|-----------------------------------|---------|--------------|----------|
| Parameter                        | Symbol           | Conditions                                                                                             | Min                               | Тур     | Мах          | Units    |
| Input high<br>voltage            | VIH              | PA,PB,PC,PF, nRESET, nBOOT                                                                             | PA,PB,PC,PF, nRESET, nBOOT 0.8VDD |         | VDD          | V        |
| Input low<br>voltage             | VIL              | PA,PB,PC,PF, nRESET, nBOOT                                                                             | _                                 | _       | 0.2VDD       | V        |
| Input<br>hysteresis              | riangle V        | All input pins, nRESET, nBOOT<br>VDD=3V                                                                | 100                               | 200     | -            | mV       |
| Output high<br>voltage           | V <sub>OH1</sub> | VDD=5V, I <sub>OH1</sub> = - 2.64mA;<br>PA[15:11],PA[4:0],PB[12:6],<br>PB[2],PC[12:4],PC[1:0], PF[2:0] | 0.8VDD                            | _       | _            | V        |
|                                  | V <sub>OH2</sub> | VDD=5V, I <sub>OH2</sub> = – 4mA;<br>PA[10:5], PB[15:13, 5:3, 1:0], PC[3:2]                            | 0.8VDD                            | -       | -            | V        |
|                                  | Vонз             | VDD=5V, I <sub>OH3</sub> = – 1mA;<br>PC[15:13]                                                         | VDD-0.5                           | -       | -            | V        |
| Output low<br>voltage            | V <sub>OL1</sub> | VDD=5V, I <sub>OL1</sub> =3.6mA;<br>PA[15:11],PA[4:0],PB[12:6],<br>PB[2],PC[15:4],PC[1:0],PF[2:0]      | -                                 | _       | 0.2VDD       | V        |
| Output low<br>voltage            | Vol2             | VDD=5V, I <sub>OL2</sub> =3.6mA;<br>PA[10:5], PB[15:13, 5:3, 1:0],<br>PC[3:2]                          | -                                 | -       | 0.2VDD       | V        |
| Input high<br>leakage<br>current | Ін               | All Input ports                                                                                        | -                                 | _       | 1            | uA       |
| Input low<br>leakage<br>current  | lı∟              | All Input ports                                                                                        | - 1                               | -       | -            | uA       |
| Pull-up<br>resistor              | Rpu              | VI=0V, TA=25°C, VDD=5V<br>PA,PB,PC,PF                                                                  | 25                                | 50      | 100          | KΩ       |
|                                  |                  | VI=0V, TA=25°C, VDD=5V<br>nRESET, nBOOT                                                                | 150                               | 250     | 400          |          |
| Pull-down<br>resistor            | Rpd              | VI=VDD, TA=25°C, VDD=5V<br>PA,PB,PC,PF                                                                 | 25                                | 50      | 100          | ΚΩ       |



## 25.10 Supply current characteristics

| Table | 109. | Supply | Current | Characteristics |
|-------|------|--------|---------|-----------------|
|-------|------|--------|---------|-----------------|

|           |                                     |                              |                     | (Temper | ature: -40 | to +85℃ |
|-----------|-------------------------------------|------------------------------|---------------------|---------|------------|---------|
| Parameter | Symbol                              | Conditions                   |                     | Тур     | Max        | Units   |
| Supply    | I <sub>DD1</sub>                    | f <sub>XIN</sub> = 8MHz      | VDD=5V±10%          | 3       | —          | mA      |
| current   | (Run)                               | fнırc = 12MHz                | All peripherals off | 2.5     | —          |         |
|           |                                     | fнırc = 48MHz                |                     | 8       | _          |         |
|           |                                     | F <sub>LIRC</sub> = 750KHz   |                     | 250     | —          | uA      |
|           |                                     | FLSE = 32.768KHz             |                     | 1       | _          |         |
|           | I <sub>DD2</sub>                    | f <sub>XIN</sub> = 8MHz      | VDD=5V±10%          | 2.5     | _          | mA      |
|           | (Sleep)                             | fнirc = 12MHz                | All peripherals off | 2       | _          |         |
|           |                                     | fнirc = 48MHz                |                     | 6       | _          |         |
|           |                                     | FLIRC = 750KHz               |                     | 250     | _          | uA      |
|           |                                     | F <sub>LSE</sub> = 32.768KHz |                     | 1       | _          |         |
|           | IDD3 All Oscillators Off VDD=5V±109 | VDD=5V±10%                   | 2                   | _       | uA         |         |
|           | (Stop)                              | Only LSE on                  | -                   | 3.5     | _          |         |
|           |                                     | Only LSI40K on               |                     | 3.5     | —          |         |
|           |                                     | Only LVR on                  |                     | 6       | —          |         |
|           | I <sub>DD4</sub>                    | All Oscillators Off          | VDD=5V±10%          | 1.5     | —          | uA      |
| (Standby) | (Standby)                           | Only LSE on                  |                     | 2       | —          |         |
|           |                                     | Only LSI40K on               |                     | 2       | —          |         |
|           |                                     | Only LVR on                  |                     | 5       | —          |         |
|           | I <sub>DD5</sub>                    | All Oscillators Off          | VDD=5V±10%          | 1.3     | _          | uA      |
|           | (Backup<br>power)                   | Only LSE on                  |                     | 1.6     | _          |         |
|           | homer)                              | Only LSE + RTC on            |                     | 1.7     | _          |         |
|           |                                     | Only LSI40K on               |                     | 1.5     | _          |         |

NOTES:

1. Where the  $f_{XIN}$  is an external main oscillator, the  $f_{SUB}$  is an external sub oscillator, the  $f_{HIRC}$  is a high frequency internal RC oscillator, and the  $f_x$  is the selected system clock.

2. All supply current items don't include the current of a low frequency internal RC oscillator and a peripheral block.

3. All supply current items include the current of the power-on reset (POR) block.



## 25.11 AC characteristics

| Table | 110. A | C Ch | aracter | istics |
|-------|--------|------|---------|--------|
| IUNIO |        |      | araotor | 101100 |

|                                                   |                                     |                                             |     | (Temperat | ure: -40°C | to +85℃) |
|---------------------------------------------------|-------------------------------------|---------------------------------------------|-----|-----------|------------|----------|
| Parameter                                         | Symbol                              | Conditions                                  | Min | Тур       | Max        | Units    |
| RESETB input low width                            | trst                                | VDD = 5V                                    | 10  | —         | —          | us       |
| Interrupt input high<br>low width                 | tıw⊢, tıw∟                          | All interrupts, VDD = 5V                    | 100 | _         | _          | ns       |
| External counter<br>input high low pulse<br>width | tecwн,<br>tecwL                     | VDD = 5V<br>All external counter input      | 100 | _         | —          |          |
| External counter transition time                  | t <sub>REC</sub> , t <sub>FEC</sub> | Ecn, VDD = 5V<br>All external counter input | —   | _         | 20         |          |



Figure 171. AC Timing



## 25.12 USART SPI characteristics

#### Table 111. SPI Characteristics with High Voltage

(Temperature: -40°C to +85°C, VDD = 3V to 5.5V)

| Parameter                          | Symbol                | Conditions                   | Min | Тур | Max | Units  |
|------------------------------------|-----------------------|------------------------------|-----|-----|-----|--------|
| SPI Clock frequency                | f <sub>scк</sub>      | Master mode                  | _   | —   | 12  | MHz    |
| SPI Clock frequency                | 1/f <sub>c(SCK)</sub> | Slave mode                   | _   | —   | 6   | IVITIZ |
| Output clock pulse period          | tscк                  | Internal SCK source          | 80  | _   | _   | ns     |
| Input clock pulse period           |                       | External SCK source          | 80  | —   | —   |        |
| Output clock high, low pulse width | tsскн,<br>tscк∟       | Internal SCK source          | 16  | —   | —   |        |
| Input clock high, low pulse width  |                       | External SCK source          | 16  | _   | _   |        |
| First output clock delay time      | t <sub>FOD</sub>      | Internal/external SCK source | 40  | _   | —   |        |
| Output clock delay time            | t <sub>DS</sub>       | —                            | _   | _   | 25  |        |
| Input setup time                   | t <sub>DIS</sub>      | _                            | 36` | —   | _   |        |
| Input hold time                    | t <sub>DIH</sub>      | —                            | 36  | _   | —   |        |

Note) The speed of support for SPI clock frequency depends on the VDD value.

### Table 112. SPI Characteristics with Low Voltage

| Parameter                          | Symbol                      | (Temperature:                | Min | Тур | Max | Units |
|------------------------------------|-----------------------------|------------------------------|-----|-----|-----|-------|
|                                    | Cymson                      | Conditions                   |     | קעי | Max | Units |
| SPI Clock frequency                | fscк                        | Master mode                  | —   | —   | 6   | MHz   |
| SPT Clock frequency                | 1/f <sub>c(SCK)</sub>       | Slave mode                   | —   | —   | 6   |       |
| Output clock pulse period          | tscк                        | Internal SCK source          | 160 | —   | _   | ns    |
| Input clock pulse period           |                             | External SCK source          | 160 | _   | _   |       |
| Output clock high, low pulse width | tsскн,<br>t <sub>scк∟</sub> | Internal SCK source          | 32  | _   | _   |       |
| Input clock high, low pulse width  |                             | External SCK source          | 32  | _   | _   |       |
| First output clock delay time      | tfod                        | Internal/external SCK source | 80  | _   | —   |       |
| Output clock delay time            | t <sub>DS</sub>             | —                            | _   | —   | 50  |       |
| Input setup time                   | t <sub>DIS</sub>            | —                            | 72  | _   | _   |       |
| Input hold time                    | t <sub>DIH</sub>            | _                            | 72  | _   | _   |       |

(Temperature: -40°C to +85°C, VDD = 1.8V to 3V)





Figure 172. SPI Timing



## 25.13 I2C characteristics

|                            |                   |     |      | (Temperature: -40℃ to +85℃, VDD = 1.8 to 5.5V) |           |      |       |       |
|----------------------------|-------------------|-----|------|------------------------------------------------|-----------|------|-------|-------|
| Parameter                  | Symbol Standard   |     | Fast |                                                | Fast Plus |      | Units |       |
|                            |                   | Min | Max  | Min                                            | Мах       | Min  | Max   | Units |
| Clock frequency            | tscl              | 0   | 100  | 0                                              | 400       | 0    | 1000  | KHz   |
| Clock high pulse width     | tsclh             | 4.0 | _    | 0.6                                            | —         | 0.26 | —     | us    |
| clock low pulse width      | tscll             | 4.7 | _    | 1.3                                            | —         | 0.5  | _     |       |
| Bus free time              | t <sub>BF</sub>   | 4.7 | —    | 1.3                                            | —         | 0.5  | _     |       |
| Start condition setup time | t <sub>stsu</sub> | 4.7 | _    | 0.6                                            | —         | 0.26 | —     |       |
| Start condition hold time  | tsтнD             | 4.0 | —    | 0.6                                            | —         | 0.26 | _     |       |
| Stop condition setup time  | tspsu             | 4.0 | —    | 0.6                                            | —         | 0.26 | _     |       |
| Stop condition hold time   | t <sub>SPHD</sub> | 4.0 | —    | 0.6                                            | —         | 0.26 | _     |       |
| Output valid from clock    | t <sub>VD</sub>   | 0   | —    | 0                                              | _         | 0    | —     |       |
| Data input hold time       | tын               | 0   | —    | 0                                              | 1.0       | 0    | 0.45  |       |
| Data input setup time      | t <sub>DIS</sub>  | 250 | —    | 100                                            | _         | 50   | _     | ns    |

### Table 113. I2C Characteristics



Figure 173. I2C Timing



## 25.14 USART UART timing characteristics

## Table 114. UART Timing Characteristics

(Temperature:  $-40^{\circ}$ C to  $+85^{\circ}$ C, VDD = 1.8 to 5.5V)

|                                          | (                       |                       |                       | C, VDD = 1.0 |       |
|------------------------------------------|-------------------------|-----------------------|-----------------------|--------------|-------|
| Parameter                                | Symbol                  | Min                   | Тур                   | Мах          | Units |
| Serial port clock cycle time             | tscк                    | 1250                  | t <sub>СРU</sub> х 16 | 1650         | ns    |
| Output data setup to clock rising edge   | t <sub>S1</sub>         | 590                   | t <sub>СРU</sub> х 13 | —            |       |
| Clock rising edge to input data valid    | ts2                     | —                     | —                     | 590          |       |
| Output data hold after clock rising edge | t <sub>H1</sub>         | t <sub>СРU</sub> — 50 | tcpu                  | —            |       |
| Input data hold after clock rising edge  | t <sub>H2</sub>         | 0                     | —                     | —            |       |
| Serial port clock High, Low level width  | tнıgн <sub>,</sub> t∟ow | 470                   | t <sub>CPU</sub> x 8  | 970          |       |



Figure 174. Waveform of UART Timing Characteristics



Figure 175. UART Module Timing



## 25.15 Data retention voltage in STOP mode

## Table 115. Data Retention Voltage in STOP mode

|                                  |        |                                                                       |     | (Temperat | ure: -40°C t | o +85℃) |
|----------------------------------|--------|-----------------------------------------------------------------------|-----|-----------|--------------|---------|
| Parameter                        | Symbol | Conditions                                                            | Min | Тур       | Max          | Units   |
| Data retention<br>supply voltage | Vdddr  | -                                                                     | 1.8 | _         | 5.5          | V       |
| Data retention supply current    | Idddr  | V <sub>DDDR</sub> = 1.8V, (T <sub>A</sub> = 25°C),<br>Deep sleep mode | _   | _         | 1            | uA      |

## 25.16 Internal Flash ROM characteristics

## Table 116. Internal Flash ROM Characteristics

|                          |                  |                                  |         | (Temperat | ure: -40°C | to +85°C) |
|--------------------------|------------------|----------------------------------|---------|-----------|------------|-----------|
| Parameter                | Symbol           | Conditions                       | Min     | Тур       | Max        | Units     |
| Page write time          | t <sub>FSW</sub> | -                                | —       | 30        | _          | us        |
| Page erase time          | t <sub>FSE</sub> | —                                | —       | 4         | _          | ms        |
| Chip erase time          | t <sub>FCE</sub> | _                                | —       | 8         | _          | ms        |
| Read Access Time         | t <sub>FRA</sub> | —                                | 30      | _         | 80         | ns        |
| Flash program<br>voltage | Vpgm             | On erase/write                   | 1.65    | _         | 5.5        | V         |
| Endurance of write/erase | NFWE             | T <sub>A</sub> =25 °C, Page unit | 100,000 | _         | _          | Times     |
| Retention time           | t <sub>FRT</sub> |                                  | 10      | _         | _          | Years     |



## 25.17 Main oscillator characteristics

|                      |                         |                                                                              |        | (Tempe | erature: -40° | C to +85℃) |
|----------------------|-------------------------|------------------------------------------------------------------------------|--------|--------|---------------|------------|
| Oscillator           | Parameter               | Conditions                                                                   | Min    | Тур    | Max           | Units      |
| Operating voltage    | VDD                     | —                                                                            | 1.8    | 5.0    | 5.5           | V          |
| Operating current    | IDD                     | _                                                                            | _      | _      | 2.5           | mA         |
| Power down current   | ISTOP                   | _                                                                            | _      | 0.2    | 30            | nA         |
| Output frequency     | XOUT input<br>frequency | VDDEXT≥1.8V<br>ISEL_I<1:0>=2'b11                                             | 2.0    | -      | 4.0           | MHz        |
|                      |                         | VDDEXT≥2.0V<br>ISEL_I<1:0>=2'b10                                             | 2.0    | -      | 8.0           | MHz        |
|                      |                         | VDDEXT≥2.2V<br>ISEL_I<1:0>=2'b01                                             | 2.0    | -      | 12.0          | MHz        |
|                      |                         | VDDEXT≥2.4V<br>ISEL_I<1:0>=2'b00                                             | 2.0    | _      | 16            | MHz        |
| Start-up time        | T <sub>start</sub>      | _                                                                            | _      | 2      | _             | ms         |
| Crystal input (low)  | VIL                     | _                                                                            | _      | _      | 0.2VDD        | V          |
| Crystal input (high) | VIH                     | _                                                                            | 0.8VDD | _      | _             | V          |
| Crystal out (low)    | V <sub>OL</sub>         | _                                                                            | _      | _      | 0.2VDD        | V          |
| Crystal out (high)   | Vон                     | _                                                                            | 0.8VDD | _      | _             | V          |
| External load cap    | CL                      | 2M <fout<4m< td=""><td>18</td><td>30</td><td>35</td><td>pf</td></fout<4m<>   | 18     | 30     | 35            | pf         |
|                      |                         | 4M <fout<12m< td=""><td>10</td><td>22</td><td>30</td><td>pf</td></fout<12m<> | 10     | 22     | 30            | pf         |
|                      |                         | 12M <fouт<16м< td=""><td>7</td><td>18</td><td>22</td><td>pf</td></fouт<16м<> | 7      | 18     | 22            | pf         |
| Feedback resistance  | R <sub>FB</sub>         | VDDEXT=5V                                                                    | 0.7    | 1.0    | 1.3           | MΩ         |

### Table 117. Main Oscillator Characteristics





Figure 176. Crystal/Ceramic Oscillator







Figure 178. Clock Timing Measurement at XIN



## 25.18 Sub oscillator characteristics

|                        |                    |                                             |        | (Temperature: -40℃ to +85℃) |        |       |  |
|------------------------|--------------------|---------------------------------------------|--------|-----------------------------|--------|-------|--|
| Oscillator             | Parameter          | Conditions                                  | Min    | Тур                         | Max    | Units |  |
| Operating voltage      | VDD                | —                                           | 2.7    | 5.0                         | 5.5    | V     |  |
| Operating current      | IDD                | ISEL_I[1:0]=2'b11<br>CL=6pf, Schmitt Off    | _      | 0.26                        | 0.82   | uA    |  |
|                        |                    | ISEL_I[1:0]=2'b10<br>CL=7pf, Schmitt Off    |        | 0.3                         | 0.94   | uA    |  |
|                        |                    | ISEL_I[1:0]=2'b01<br>CL=7pf, Schmitt Off    |        | 0.34                        | 1.13   | uA    |  |
|                        |                    | ISEL_I[1:0]=2'b00<br>CL=12.5pf, Schmitt Off |        | 0.49                        | 1.44   | uA    |  |
| Power down current     | I <sub>STOP</sub>  | —                                           | _      | _                           | 15     | nA    |  |
| Output frequency       | f <sub>SUB</sub>   | _                                           | _      | 32.768                      | _      | kHz   |  |
| Start-up time          | T <sub>start</sub> | —                                           | _      | 2                           | _      | s     |  |
| Crystal input (low)    | VIL                | _                                           | _      | _                           | 0.2VDD | V     |  |
| Crystal input (High)   | VIH                | —                                           | 0.8VDD | _                           | _      | V     |  |
| Crystal out (low)      | V <sub>OL</sub>    | _                                           | _      | _                           | 0.2VDD | V     |  |
| Crystal out (high)     | Vон                | —                                           | 0.8VDD | _                           | —      | V     |  |
| External load cap      | Rfb                |                                             | 6      | 7                           | 12.5   | pF    |  |
| Feedback<br>resistance | CL                 |                                             | 5.5    | 11.2                        | 22.8   | MΩ    |  |

## Table 118. Sub Oscillator Characteristics



Figure 179. Crystal Oscillator





Figure 180. Clock Timing Measurement at SXIN

## 25.19 Operating voltage range



Figure 181. Operating Voltage Range

## 25.20 PLL electrical characteristics

## Table 119. PLL Electrical Characteristics

|                   |                   |            |     | (Tempe | rature: -40° | C to +85°C |
|-------------------|-------------------|------------|-----|--------|--------------|------------|
| Parameter         | Symbol            | Conditions | Min | Тур    | Max          | Units      |
| Operating voltage | VDD               |            | 1.8 | 5      | 5.5          | V          |
| Operating current | IDD               | Enable     | —   | —      | 1            | mA         |
|                   |                   | Disable    | _   | 5      | 500          | nA         |
| Output frequency  | fouт              | -          | _   | _      | 144          | MHz        |
| Duty              | fduty             |            | 40  | _      | 60           | %          |
| Input frequency   | <b>f</b> PLLINCLK |            | 4   | 8      | 16           | MHz        |
| Locking time*     | tьоск             |            | 190 | _      | _            | us         |



## 25.21 Comparator characteristics

The measured value for the parameters and conditions listed below were confirmed by simulaion

| Parameter                | Symbol                 | Conditions                                                                                          | Min | Тур | Max | Units |
|--------------------------|------------------------|-----------------------------------------------------------------------------------------------------|-----|-----|-----|-------|
| Operating voltage        | VDD                    |                                                                                                     | 2.0 | 5   | 5.5 | V     |
| Comparator offset        |                        |                                                                                                     | —   | ±5  | ±10 |       |
| error                    | V <sub>Offset</sub>    | Using internal VREF                                                                                 |     | ±20 | ±70 | — mV  |
| Hysteresis               | Vhys <sub>(None)</sub> | _                                                                                                   | —   | 0   |     |       |
|                          |                        | High speed mode                                                                                     | 3   | 8   | 13  |       |
|                          | Vhys <sub>(Low)</sub>  | All other power modes                                                                               | 5   | 8   | 10  |       |
|                          | Vhys <sub>(Mid)</sub>  | High speed mode                                                                                     | 7   | 15  | 26  | mV    |
|                          | VIIYS(Mid)             | All other power modes                                                                               | 9   | 15  | 19  |       |
|                          | Vhyometry              | High speed mode                                                                                     | 18  | 31  | 49  |       |
|                          | Vhys <sub>(High)</sub> | All other power modes                                                                               | 19  | 31  | 40  |       |
| Propagation delay for    |                        | Ultra-low power mode                                                                                |     | 2   | 4.5 | us    |
| 200mv<br>Step with 100mv |                        | Low power mode                                                                                      |     | 0.7 | 1.5 |       |
| overdrive                |                        | Medium power mode                                                                                   |     | 0.3 | 0.6 |       |
|                          |                        | High speed mode<br>VDDEXT≥2.7V                                                                      |     | 50  | 100 | ns    |
|                          |                        | High speed mode<br>2V <vddext<2.7v< td=""><td></td><td>100</td><td>240</td><td></td></vddext<2.7v<> |     | 100 | 240 |       |
| Propagation delay for    | t <sub>PD</sub>        | Ultra-low power mode                                                                                |     | 2   | 7   | us    |
| full<br>Range step with  |                        | Low power mode                                                                                      |     | 0.7 | 2.1 |       |
| 100mv                    |                        | Medium power mode                                                                                   |     | 0.3 | 1.2 |       |
| Overdrive                |                        | High speed mode<br>VDDEXT≥2.7V                                                                      |     | 90  | 180 | ns    |
|                          |                        | High speed mode<br>2V <vddext<2.7v< td=""><td></td><td>110</td><td>300</td><td></td></vddext<2.7v<> |     | 110 | 300 |       |
| Comparator current       | IDD <sub>(COMP)</sub>  | Ultra-low power mode<br>(COMP1 only)                                                                | —   | 1.2 | 1.5 | uA    |

## Table 120. Comparator Characteristics



| Parameter          | Symbol                | Conditions                                      | Min | Тур | Мах | Units |
|--------------------|-----------------------|-------------------------------------------------|-----|-----|-----|-------|
| Comparator current | IDD <sub>(COMP)</sub> | Ultra-low power<br>mode<br>(COMP1 and<br>COMP2) | _   | 2.4 |     | uA    |
|                    |                       | Low power mode<br>(COMP1 only)                  | —   | 3   | 5   |       |
|                    |                       | Low power mode<br>(COMP1 and<br>COMP2)          | _   | 6   | _   |       |
|                    |                       | Medium power mode<br>(COMP1 only)               |     | 10  | 15  |       |
|                    |                       | Medium power mode<br>(COMP1 and<br>COMP2)       | _   | 20  | _   |       |
|                    |                       | High Speed mode<br>(COMP1 only)                 | —   | 75  | 100 |       |
|                    |                       | High Speed mode<br>(COMP1 and<br>COMP2)         | _   | 150 |     |       |

| Table 120. | Comparator | Characteristics | (continued) | ) |
|------------|------------|-----------------|-------------|---|
|            |            |                 |             |   |

| Parameter         | Symbol   | Conditions | Min   | Тур   | Max   | Units |
|-------------------|----------|------------|-------|-------|-------|-------|
| Operating voltage | VDD      |            | 2.7   | 5     | 5.5   |       |
|                   | Vout1.2V |            | 1.162 | 1.223 | 1.284 |       |
| Output Voltage    | Vout0.9V |            | 0.871 | 0.917 | 0.963 | V     |
|                   | Vout0.6V |            | 0.580 | 0.611 | 0.642 |       |
|                   | Vout0.3V |            | 0.290 | 0.305 | 0.320 |       |



## 25.22 USB characteristics

|                                |                  |                          |      | (Temper | ature: -40 | °C to +85° |
|--------------------------------|------------------|--------------------------|------|---------|------------|------------|
| Parameter                      | Symbol           | Conditions               | Min  | Тур     | Max        | Units      |
| Operating voltage              | VDD              |                          | 3.0  | -       | 5.5        | V          |
|                                | VDD33            |                          | 2.97 | 3.3     | 3.63       | V          |
|                                | VDDIO2           |                          | 2.97 | 3.3     | 3.63       |            |
| Pull down resistance on DP/DN  | R <sub>PD</sub>  | Enable internal resistor | 12   | -       | 17         | ΚΩ         |
| Pull up<br>resistance on DP/DN | Rpu              | Enable internal resistor | 1.1  | -       | 1.9        | ΚΩ         |
| Output driver impedance        | Z <sub>DRV</sub> | Driving high and low     | 10   | -       | 35         | Ω          |

### Table 122. USB Characteristics

# 25.23 Temperature Sensor characteristics

#### Table 123. Temperature Sensor Characteristics

(Temperature: -40°C to +85°C)

| Parameter                  | Symbol   | Condition | Min | Тур | Мах | Units |
|----------------------------|----------|-----------|-----|-----|-----|-------|
| Operating Voltage          | VDD      |           | 1.8 | -   | 5.5 | V     |
| Temperature Accuracy error | TSENSACC |           |     | ±10 |     | °C    |

The measured value for the parameters and conditions listed below were confirmed by simulaion



## 26. Development tools

This chapter introduces wide range of development tools for A31G32x. ABOV offers software tools, debuggers, and programmers to help a user in generating right results to match target applications. ABOV supports entire development ecosystem of the customers.

## 26.1 Compiler

ABOV semiconductor does not provide any compiler for A31G32x. However, since A31G32x have ARM's high-speed 32-bit Cortex-M0+ Cores for their CPU, you can use all kinds of third party's standard compiler such as Keil C Compiler. These compilers' output debug information can be integrated with our A-Link and A-Link Pro. Please visit our website <u>www.abovsemi.com</u> for more information regarding the A-Link and A-Link Pro.

## 26.2 Debugger

The A-Link and A-Link Pro support ABOV Semiconductor's A31G32x MCU emulation in SWD Interface. The A-Link and A-Link Pro use two wires interfacing between PC and MCU, which is attached to user's system. The A-Link and A-Link Pro can read or change the value of MCU's internal memory and I/O peripherals. In addition, the A-Link and A-Link Pro control MCU's internal debugging logic. This means A-Link and A-Link Pro control emulation, step run, monitoring and many more functions regarding debugging.

The A-Link and A-Link Pro run underneath MS operating system such as MS-Windows NT/ 2000/ XP/ Vista/ 7/ 8/ 8.1/ 10 (32-bit, 64-bit).

Programming information using the A-Link and A-Link Pro are provided in Figure 185. More detailed information about the A-Link and A-Link Pro, please visit our website <u>www.abovsemi.com</u> and download the debugger S/W and documents.



Figure 182. A-Link and Pin Descriptions



## 26.3 Programmer

#### E-PGM+

E-PGM+ is a single programmer, and allows a user to program on the device directly.

- Support ABOV devices
- 2~5 times faster than S-PGM+
- Main controller: 32-bit MCU @ 72MHz
- Buffer memory: 1MB



Figure 183. E-PGM+ (Single Writer) and Pin Descriptions

### Gang programmer

E-Gang4 and E-Gang6 allows a user to program on multiple devices at a time. They run not only in PC controlled mode but also in standalone mode without PC control. USB interface is available and it is easy to connect to the handler.



Figure 184. E-Gang4 and E-Gang6 (for Mass Production)



## 27. Circuit Design Guide





Figure 185. PCB Design Guide for On-Board Programming



## 28. Package information

This chapter provides A31G32x series package information.

## 28.1 64 LQFP package information



Figure 186. 64 LQFP Package Outline



| Ourseland L | Dimension (mm | Dimension (mm) |       |  |  |  |
|-------------|---------------|----------------|-------|--|--|--|
| Symbol      | Min.          | Nom.           | Max.  |  |  |  |
| A           | —             | —              | 1.60  |  |  |  |
| A1          | 0.05          | —              | 0.15  |  |  |  |
| A2          | 1.35          | 1.40           | 1.45  |  |  |  |
| b           | 0.17          | 0.22           | 0.27  |  |  |  |
| b1          | 0.17          | 0.20           | 0.23  |  |  |  |
| с           | 0.09          | —              | 0.20  |  |  |  |
| c1          | 0.09          | —              | 0.16  |  |  |  |
| D           | 11.80         | 12.00          | 12.20 |  |  |  |
| D1          | 9.80          | 10.00          | 10.20 |  |  |  |
| E           | 11.80         | 12.00          | 12.20 |  |  |  |
| E1          | 9.80          | 10.00          | 10.20 |  |  |  |
| е           | 0.50 BSC      |                |       |  |  |  |
| L           | 0.45          | 0.60           | 0.75  |  |  |  |
| L1          | 1.00 REF      |                |       |  |  |  |
| θ           | 0°            | 3.5°           | 7°    |  |  |  |

| Table 124 | 64 LQFP | Package  | Mechanical Data |
|-----------|---------|----------|-----------------|
|           |         | i uonugo | meenumeur Dutu  |

#### NOTES:

1. All dimension refer to JEDEC standard MS-026-BCD.

2. Dimensions 'D1' and 'E1' do not include MOLD PROTRUSION. Allowable PROTRUSION is 0.25 mm per side. 'D1' and 'E1' are maximum plastic body size dimensions including MOLD MISMATCH.

3. Dimension 'b' does not include DAMBAR PROTRUSION. Allowable DAMBAR PROTRUSION shall not cause the LEAD width to exceed the maximum 'b' dimension by more than 0.08 mm.

4. 'A1' is defined as the distance from the seating plane to the lowest point on the package body.





#### 48 LQFP package information 28.2

Figure 187. 48 LQFP Package Outline



| Ourseland | Dimension (mn | Dimension (mm) |      |  |  |  |
|-----------|---------------|----------------|------|--|--|--|
| Symbol    | Min.          | Nom.           | Max. |  |  |  |
| А         | —             | —              | 1.60 |  |  |  |
| A1        | 0.05          | —              | 0.15 |  |  |  |
| A2        | 1.35          | 1.40           | 1.45 |  |  |  |
| b         | 0.17          | 0.22           | 0.27 |  |  |  |
| b1        | 0.17          | 0.20           | 0.23 |  |  |  |
| с         | 0.09          | —              | 0.20 |  |  |  |
| c1        | 0.09          | —              | 0.16 |  |  |  |
| D         | 8.80          | 9.00           | 9.20 |  |  |  |
| D1        | 6.80          | 7.00           | 7.20 |  |  |  |
| E         | 8.80          | 9.00           | 9.20 |  |  |  |
| E1        | 6.80          | 7.00           | 7.20 |  |  |  |
| е         | 0.50 BSC      |                |      |  |  |  |
| L         | 0.45          | 0.60           | 0.75 |  |  |  |
| L1        | 1.00 REF      |                |      |  |  |  |
| θ         | 0°            | 3.5°           | 7°   |  |  |  |

| Table 125. 48 LQFP Package | Mechanical Data |
|----------------------------|-----------------|
|----------------------------|-----------------|

#### NOTES:

1. All dimension refer to JEDEC standard MS-026-BBC.

2. Dimensions 'D1' and 'E1' do not include MOLD PROTRUSION. Allowable PROTRUSION is 0.25 mm per side. 'D1' and 'E1' are maximum plastic body size dimensions including MOLD MISMATCH.

3. Dimension 'b' does not include DAMBAR PROTRUSION. Allowable DAMBAR PROTRUSION shall not cause the LEAD width to exceed the maximum 'b' dimension by more than 0.08 mm.

4. 'A1' is defined as the distance from the seating plane to the lowest point on the package body.







Figure 188. 48 QFN Package Outline



|        |                | -    |      |  |  |
|--------|----------------|------|------|--|--|
| Symbol | Dimension (mm) |      |      |  |  |
| Symbol | Min.           | Nom. | Max. |  |  |
| A      | 0.50           | 0.55 | 0.60 |  |  |
| A1     | 0.00           | 0.02 | 0.05 |  |  |
| b      | 0.10           | 0.15 | 0.20 |  |  |
| с      | 0.10           | 0.15 | 0.20 |  |  |
| D      | 4.90           | 5.00 | 5.10 |  |  |
| D2     | 3.60           | 3.70 | 3.80 |  |  |
| E      | 4.90           | 5.00 | 5.10 |  |  |
| E2     | 3.60           | 3.70 | 3.80 |  |  |
| е      | 0.35 BSC       |      |      |  |  |
| L      | 0.30           | 0.35 | 0.40 |  |  |
| h      | 0.30           | 0.35 | 0.40 |  |  |

#### Table 126. 48 QFN Package Mechanical Data

NOTES:

1. Dimension 'b' applies to metallized terminal and is measured between 0.15mm and 0.3mm from the TERMINAL TIP. If the TERMINAL has the optinal radius on the other end of the TERMINAL, the Dimension 'b' should not be measured in that radius area.



# 29. Ordering information

| Table 127 | ∆31G32x | Device | Ordering | Information |
|-----------|---------|--------|----------|-------------|
|           | AUIOUZA | Device | ordening | mormation   |

| Device name | Flash | SRAM | SPI | USART | I2C | Timer               | PWM | ADC | I/O<br>ports | Package |
|-------------|-------|------|-----|-------|-----|---------------------|-----|-----|--------------|---------|
| A31G324RLN  | 128KB | 16KB | 2   | 4     | 2   | 6(16-bit)/2(32-bit) | 8   | 16  | 51           | LQFP 64 |
| A31G324CLN* | 128KB | 16KB | 2   | 3     | 2   | 6(16-bit)/2(32-bit) | 8   | 10  | 37           | LQFP 48 |
| A31G324CUN* | 128KB | 16KB | 2   | 3     | 2   | 6(16-bit)/2(32-bit) | 8   | 10  | 37           | QFN 48  |
| A31G323RLN* | 64KB  | 16KB | 2   | 4     | 2   | 6(16-bit)/2(32-bit) | 8   | 16  | 51           | LQFP 64 |
| A31G323CLN* | 64KB  | 16KB | 2   | 3     | 2   | 6(16-bit)/2(32-bit) | 8   | 10  | 37           | LQFP 48 |
| A31G323CUN* | 64KB  | 16KB | 2   | 3     | 2   | 6(16-bit)/2(32-bit) | 8   | 10  | 37           | QFN 48  |

\* For available options or further information on the devices with "\*" marks, please contact the ABOV Sales Office



Figure 189. A31G32x Device Numbering Nomenclature



# **Revision history**

| Date          | Revision | Description                                                                                                                                    |  |
|---------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Dec. 04, 2020 | 1.00     | First creation                                                                                                                                 |  |
| Jan. 08, 2021 | 1.01     | Add caution statement to ADC CCR register                                                                                                      |  |
| Jan. 11, 2021 | 1.02     | Updated Introduction                                                                                                                           |  |
| Feb. 23, 2021 | 1.03     | Updated Recommended operating conditions and Main oscillator characteristics<br>Updated How to calculate and convert to temperature            |  |
| Nov. 1, 2021  | 1.04     | Updated caution statement to SPI BR register                                                                                                   |  |
| Apr. 18, 2022 | 1.05     | Removed Industrial Grade<br>Updated Ordering information<br>Added the Figure 188. 48 QFN Package Outline<br>Added the Figure 4. QFN 48 Pinouts |  |
| Aug. 19, 2022 | 1.06     | Updated the Figure 4. QFN 48 Pinouts<br>Updated the 14.2.6                                                                                     |  |
| Oct. 14, 2022 | 1.07     | Revised the font of this document                                                                                                              |  |



Korea

Regional Office, Seoul R&D, Marketing & Sales 8th Fl., 330, Yeongdong-daero, Gangnam-gu, Seoul, 06177, Korea

Tel: +82-2-2193-2200 Fax: +82-2-508-6903 www.abovsemi.com

Domestic Sales Manager Tel: +82-2-2193-2206 Fax: +82-2-508-6903 Email: <u>sales\_kr@abov.co.kr</u>

#### HQ, Ochang

R&D, QA, and Test Center 93, Gangni 1-gil, Ochang-eup, Cheongwon-gun, Chungcheongbuk-do,28126, Korea

Tel: +82-43-219-5200 Fax: +82-43-217-3534 www.abovsemi.com

#### **Global Sales Manager** Tel: +82-2-2193-2281 Fax: +82-2-508-6903 Email: <u>sales\_gl@abov.co.kr</u>

#### China Sales Manager

Tel: +86-755-8287-2205 Fax: +86-755-8287-2204 Email: <u>sales\_cn@abov.co.kr</u>

#### ABOV Disclaimer IMPORTANT NOTICE – PLEASE READ CAREFULLY

ABOV Semiconductor ("ABOV") reserves the right to make changes, corrections, enhancements, modifications, and improvements to ABOV products and/or to this document at any time without notice. ABOV does not give warranties as to the accuracy or completeness of the information included herein. Purchasers should obtain the latest relevant information of ABOV products before placing orders. Purchasers are entirely responsible for the choice, selection, and use of ABOV products and ABOV assumes no liability for application assistance or the design of purchasers' products. No license, express or implied, to any intellectual property rights is granted by ABOV herein. ABOV disclaims all express and implied warranties and shall not be responsible or liable for any injuries or damages related to use of ABOV products in such unauthorized applications. ABOV and the ABOV logo are trademarks of ABOV. All other product or service names are the property of their respective owners. Information in this document supersedes and replaces the information previously supplied in any former versions of this document.