# **NutoChips**

# AC781x Reference Manual

Version: 1.2 Release date: 2022-01-06

© 2013 AutoChips Inc.

This document contains information that is proprietary to AutoChips Inc. Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

Specifications are subject to change without notice.

# **VutoChips**

# **Document Revision History**

| 1.1     2021-06-16     AutoChips     1. Add description of whi chapter 1.1 and 9.1       2.     Add description of MPU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ter bit attribute from R to RW<br>ich UART module supporting LIN in<br>in chapter2.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.1     2021-06-16     AutoChips     1.     Add description of whi<br>chapter 1.1 and 9.1       2.     Add description of MPU       3.     Update option byte end                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ter bit attribute from R to RW<br>ich UART module supporting LIN in<br>in chapter2.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| chapter 1.1 and 9.1<br>2. Add description of MPU<br>3. Update option byte end                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | in chapter2.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <ul> <li>4. Add description of Chip</li> <li>5. Add description of Chip</li> <li>6. Update the description of T.5</li> <li>7. Change description for U</li> <li>9. Modify the register of bit</li> <li>10. Modify the description of</li> <li>11. Update the description of ADC</li> <li>13. Modify mode5 sequence</li> <li>14. Modify "timer channel" to</li> <li>15. Modify "timer channel" to</li> <li>16. Update the description of</li> <li>17. 5</li> <li>18. Add description of typics</li> <li>in chapter 17.5</li> <li>19. Modify the description of</li> <li>19.14</li> <li>20. Update the description of</li> <li>20.4</li> <li>23. Modify the description of</li> <li>20.4</li> <li>23. Modify the description of</li> <li>24. Add the description of</li> <li>25. Add description of</li> <li>26. Add the description of</li> <li>27. Add the description of</li> <li>28. Add the description of</li> <li>29. Add the description of</li> <li>20.4</li> <li>23. Modify the description of</li> <li>20.4</li> <li>23. Modify the description of</li> <li>24. Add the description of</li> <li>25. Add description of</li> <li>26. Add the description of</li> <li>27. Add the description of</li> <li>28. Add the description of</li> <li>29. Add the description of</li> <li>20.6</li> <li>25. Add description of "The modify searches" in chapter 23.1.2</li> </ul> | of RS485 delay in chapter 9.12<br>for IDLE flag in chapter 9.12<br>conversion format in chapter 10<br>e figure error in chapter 10.3<br>description in chapter 12<br>o "timer" in chapter 14<br>of GPIO_ODR register in table 17-5<br>of GPIO_E4_E2 register in chapter<br>cal value for pull-up, pull-down resistor<br>ue of SPI_CFG1 register in chapter<br>of SPI_STATUS register in chapter<br>of DMA operation mode in chapter<br>of DMA_MEM_END_ADDR register in<br>of disable DMA in circular mode in<br>ninimum programming bit width is 32<br>ing address needs to be aligned with 4 |

© 2013 - 2021 AutoChips Inc.

|     |            |           |     | bit in chapter 23.5                                       |
|-----|------------|-----------|-----|-----------------------------------------------------------|
| 1.2 | 2022-01-06 | AutoChips | 1.  | Add description of ISP download pin in chapter 2.3 11     |
|     |            |           | 2.  | Modify description of BUSOFF bit in chapter 7.4           |
|     |            |           | 3.  | Add description of UART baud rate range in chapter 9.2    |
|     |            |           | 4.  | Add chapter 12.3.11 for PWM registers updated from write  |
|     |            |           |     | buffers                                                   |
|     |            |           | 5.  | Add chapter 12.3.22 for PWM features priority             |
|     |            |           | 6.  | Add chapter 17.3 for GPIO block diagram                   |
|     |            |           | 7.  | Add description of SPI baud rate range in chapter 19.2    |
|     |            |           | 8.  | Add description of SPI TXEIO, RXFIE in chapter 19.14      |
|     |            |           | 9.  | Update description of DMA priority in chapter 20.5.2      |
|     |            |           | 10. | Update description of DMA end address in chapter 20.5.3.3 |
|     |            |           |     | and chapter 20.6                                          |

# **NutoChips**

# Legal Notice

This reference manual contains information that is confidential to AUTOCHIPS Inc. Unauthorized use or disclosure of the information contained herein is prohibited. You may be held responsible for any loss or damages suffered by Autochips Inc. for your unauthorized disclosure hereof, in whole or in part.

Information herein is subject to change without noticed. AUTOCHIPS Inc. does not assume any responsibility for any use of, or reliance on, the information contained herein.

THIS REFERENCE MANUAL AND ALL INFORMATION CONTAINED HEREIN IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND, WHETHER EXPRESS, IMPLIED, STATUTORY, OR OTHERWISE. AUTOCHIPS INC. SPECIFICALLY DISCLAIMS ALL IMPLIED WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE. NEITHER DOES AUTOCHIPS INC. PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR SUPPLIED WITH THIS REFERENCE MANUAL, AND USER AGREES TO LOOK ONLY TO SUCH THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. AUTOCHIPS INC. SHALL ALSO NOT BE RESPONSIBLE FOR ANY AUTOCHIPS DELIBERABLES MADE TO USER'S SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.

# **NutoChips**

# **Table of Contents**

| Doc   | umen    | t Revisi             | on History                                  | 2             |
|-------|---------|----------------------|---------------------------------------------|---------------|
| Lega  | al Not  | tice                 |                                             | 4             |
| Tabl  | e of (  | Contents             | 5                                           | 5             |
| List  | of Fig  | gures                |                                             | 16            |
| List  | of Ta   | bles                 |                                             | 19            |
| 1     | Intro   | oduction             | ۱                                           | 21            |
|       | 1.1     | Overview             | ,                                           | 21            |
|       | 1.2     | Module d             | escription                                  | 21            |
| 2     | Men     | ory and              | Bus Architecture                            | 22            |
|       | 2.1     | System a             | rchitecture                                 | 22            |
|       | 2.2     | Memory of            | organization                                | 24            |
|       |         | 2.2.1                | Memory map                                  | 24            |
|       | 2.3     | Detail fun           | ction description                           | 25            |
|       |         | 2.3.1                | Internal SRAM                               | 25            |
|       |         | 2.3.2                | Bit banding                                 | 25            |
|       |         | 2.3.3                | Fast IO memory map                          | 26            |
|       |         | 2.3.4                | Internal flash memory                       | 26            |
|       |         | 2.3.5                | Read internal flash memory                  | 26            |
|       |         | 2.3.6                | Chip Model                                  | 27            |
|       |         | 2.3.7                | Chip UUID                                   | 27            |
|       |         | 2.3.8                | I-Cache and D-Cache                         | 27            |
|       |         | 2.3.9                | AHB to APB bridge                           | 27            |
|       |         | 2.3.10               | Nested Vectored Interrupt Controller (NVIC) | 27            |
|       |         | 2.3.11               | Boot configuration                          | 29            |
|       | 2.4     | Address <sup>-</sup> | Table                                       |               |
| 3     | Rese    | et                   |                                             | 32            |
|       | 3.1     | Introducti           | on                                          | 32            |
| AutoC | Chips C | onfidential          | © 2013 - 2021 AutoChips Inc.                | Page 5 of 360 |



|        | 3.2                                                                                                   | Block dia                                                                                                              | igram                                                                                                                           |          |
|--------|-------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|----------|
|        | 3.3                                                                                                   | Reset de                                                                                                               | tail function description                                                                                                       | 33       |
|        |                                                                                                       | 3.3.1                                                                                                                  | Power On Reset (POR)                                                                                                            | 33       |
|        |                                                                                                       | 3.3.2                                                                                                                  | System reset source                                                                                                             |          |
|        | 3.4                                                                                                   | Register                                                                                                               | mapping                                                                                                                         |          |
| 4      | Cloc                                                                                                  | : <b>k</b>                                                                                                             |                                                                                                                                 | 36       |
|        | 4.1                                                                                                   | Introduct                                                                                                              | ion                                                                                                                             |          |
|        | 4.2                                                                                                   | Clock co                                                                                                               | ntrol diagram                                                                                                                   |          |
|        | 4.3                                                                                                   | System (                                                                                                               | Clock                                                                                                                           |          |
|        | 4.4                                                                                                   | Register                                                                                                               | mapping                                                                                                                         |          |
| 5      | Pow                                                                                                   | ver Mode                                                                                                               | es                                                                                                                              | 46       |
|        | 5.1                                                                                                   | Introduct                                                                                                              | ion                                                                                                                             | 46       |
|        | 5.2                                                                                                   | Power m                                                                                                                | odes                                                                                                                            | 46       |
|        | 5.3                                                                                                   | Entering                                                                                                               | and exiting power modes                                                                                                         | 46       |
|        | 5.4                                                                                                   | Module of                                                                                                              | operation in low-power modes                                                                                                    | 46       |
|        |                                                                                                       |                                                                                                                        | <b>M</b> .                                                                                                                      |          |
| 6      | Sys                                                                                                   | tem Pov                                                                                                                | ver Management                                                                                                                  | 48       |
| 6      | <b>Sys</b><br>6.1                                                                                     |                                                                                                                        | ion                                                                                                                             |          |
| 6      | -                                                                                                     | Introduct                                                                                                              | -                                                                                                                               | 48       |
| 6      | 6.1                                                                                                   | Introduct<br>Feature                                                                                                   | ion                                                                                                                             | 48<br>48 |
| 6      | 6.1<br>6.2                                                                                            | Introduct<br>Feature<br>Block dia                                                                                      | ion                                                                                                                             |          |
| 6      | 6.1<br>6.2<br>6.3                                                                                     | Introduct<br>Feature<br>Block dia                                                                                      | ion<br>ist                                                                                                                      |          |
| 6      | 6.1<br>6.2<br>6.3                                                                                     | Introduct<br>Feature<br>Block dia<br>Applicati                                                                         | ion<br>ist<br>Igram<br>on notes                                                                                                 |          |
| 6      | 6.1<br>6.2<br>6.3                                                                                     | Introduct<br>Feature<br>Block dia<br>Applicati<br>6.4.1<br>6.4.2                                                       | ion<br>ist<br>ogram<br>on notes<br>SPM power control program guide                                                              |          |
| 6<br>7 | <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.5</li> </ul>                           | Introduct<br>Feature<br>Block dia<br>Applicati<br>6.4.1<br>6.4.2<br>Register                                           | ion<br>ist<br>or notes<br>SPM power control program guide<br>XOSC/SYSPLL power control                                          |          |
|        | <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.5</li> </ul>                           | Introduct<br>Feature<br>Block dia<br>Applicati<br>6.4.1<br>6.4.2<br>Register                                           | ion<br>ist<br>on notes<br>SPM power control program guide<br>XOSC/SYSPLL power control<br>mapping                               |          |
|        | <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.5</li> <li>CAN</li> </ul>              | Introduct<br>Feature<br>Block dia<br>Applicati<br>6.4.1<br>6.4.2<br>Register                                           | ion<br>ist<br>on notes<br>SPM power control program guide<br>XOSC/SYSPLL power control<br>mapping                               |          |
|        | <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.5</li> <li>CAN</li> </ul>              | Introduct<br>Feature<br>Block dia<br>Applicati<br>6.4.1<br>6.4.2<br>Register                                           | ionist<br>Igram<br>on notes<br>SPM power control program guide<br>XOSC/SYSPLL power control<br>mapping<br>ion                   |          |
|        | <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.5</li> <li>CAN</li> </ul>              | Introduct<br>Feature<br>Block dia<br>Applicati<br>6.4.1<br>6.4.2<br>Register<br>Introduct<br>7.1.1<br>7.1.2            | ion<br>ist<br>agram<br>on notes<br>SPM power control program guide<br>XOSC/SYSPLL power control<br>mapping<br>The CAN-CTRL core |          |
|        | <ul> <li>6.1</li> <li>6.2</li> <li>6.3</li> <li>6.4</li> <li>6.5</li> <li>CAN</li> <li>7.1</li> </ul> | Introduct<br>Feature<br>Block dia<br>Applicati<br>6.4.1<br>6.4.2<br>Register<br>Introduct<br>7.1.1<br>7.1.2<br>Feature | ionist<br>agram                                                                                                                 |          |



|     | 7.3.1     | Message buffers concept          | 59  |
|-----|-----------|----------------------------------|-----|
|     | 7.3.2     | Receive buffer                   | .60 |
|     | 7.3.3     | Transmit buffer                  | .60 |
| 7.4 | Register  | definition                       | .61 |
| 7.5 | General   | operation                        | 73  |
|     | 7.5.1     | The bus off state                | 73  |
|     | 7.5.2     | Acceptance filters               | 73  |
|     | 7.5.3     | Message reception                | .74 |
|     | 7.5.4     | Handling message receptions      | .74 |
|     | 7.5.5     | Message transmission             | 75  |
|     | 7.5.6     | Message transmission abort       | 76  |
|     | 7.5.7     | A full STB                       | .77 |
|     | 7.5.8     | Extended status and error report | 77  |
|     | 7.5.9     | Extended features                | .78 |
|     | 7.5.10    | Software reset                   | .80 |
|     | 7.5.1     | CAN bit time                     | .83 |
| LIN |           |                                  | 86  |
| 8.1 | Introduc  | tion                             | 86  |
| 8.2 | Feature   | list                             | .86 |
| 8.3 | Block dia | agram                            | .86 |
| 8.4 | Applicati | ion note                         | .87 |
|     | 8.4.1     | Operating modes                  | .87 |
|     | 8.4.2     | Test modes                       | .88 |
|     | 8.4.3     | Baud rate generation             | .89 |
|     | 8.4.4     | Error detection                  | .89 |
|     | 8.4.5     | Interrupt table                  | .90 |
|     | 8.4.6     | Master mode                      | .90 |
|     | 8.4.7     | Slave mode                       | .91 |
|     | 8.4.8     | Register definition              | .92 |

8

# **VutoChips**

| 9  | UAR   | т          |                             |     |
|----|-------|------------|-----------------------------|-----|
|    | 9.1   | Introduct  | ion                         |     |
|    | 9.2   | Features   |                             |     |
|    | 9.3   | Block dia  | ıgram                       |     |
|    | 9.4   | Input & C  | Dutput timing               |     |
|    | 9.5   | Basic UA   | ART functions               |     |
|    |       | 9.5.1      | Noise detection             |     |
|    |       | 9.5.2      | Baud rate description       |     |
|    | 9.6   | Hardwar    | e flow control function     |     |
|    | 9.7   | RS485 fu   | Inction                     |     |
|    | 9.8   | LIN funct  | ion                         |     |
|    | 9.9   | Two chip   | power mode                  |     |
|    | 9.10  | Baud rate  | e configuration description | 110 |
|    | 9.11  | Configure  | e note                      | 111 |
|    | 9.12  | Register   | Definition                  | 112 |
| 10 | ADC   |            |                             | 122 |
|    | 10.1  | ADC intro  | oduction                    |     |
|    | 10.2  | ADC feat   | tures                       |     |
|    | 10.3  | ADC fund   | ctional description         |     |
|    |       | 10.3.1     | ADC power on sequence       |     |
|    |       | 10.3.2     | ADC power modes             |     |
|    |       | 10.3.3     | ADC operation modes         |     |
|    | 10.4  | Analog m   | nonitor                     |     |
|    | 10.5  | Status fla | ag description              |     |
|    | 10.6  | Calibratio | on                          |     |
|    | 10.7  | Sampling   | g conversion time           |     |
|    | 10.8  | Tempera    | ture sensor                 | 134 |
|    | 10.9  | DMA acc    | cess                        | 134 |
|    | 10.10 | ) Program  | guide                       |     |

© 2013 - 2021 AutoChips Inc.

Page 8 of 360



|    |       | 10.10.1    | Normal power mode             | 135 |
|----|-------|------------|-------------------------------|-----|
|    |       | 10.10.2    | Low power mode                | 135 |
|    | 10.11 | ADC regi   | ister definition              | 135 |
| 11 | ACM   | IP         |                               | 142 |
|    | 11.1  | Introduct  | ion                           | 142 |
|    | 11.2  | Features   |                               | 142 |
|    |       | 11.2.1     | Block diagram                 | 142 |
|    | 11.3  | Functiona  | al description                | 143 |
|    |       | 11.3.1     | ACMP0                         | 143 |
|    |       | 11.3.2     | ACMP1                         | 144 |
|    |       | 11.3.3     | Low power wakeup              | 144 |
|    | 11.4  | Memory     | map and register definition   | 144 |
|    | 11.5  | Interrupts | 5                             | 153 |
| 12 | PWN   | 1          |                               | 154 |
|    | 12.1  | Introduct  | ion                           | 154 |
|    |       | 12.1.1     | PWM features                  |     |
|    |       | 12.1.2     | Block diagram                 |     |
|    | 12.2  | Memory     | map and register definition   |     |
|    | 12.3  | Functiona  | al description                |     |
|    |       | 12.3.1     | Clock source                  |     |
|    |       | 12.3.2     | Prescaler                     |     |
|    |       | 12.3.3     | Counter                       |     |
|    |       | 12.3.4     | Operation mode                |     |
|    |       | 12.3.5     | Input capture mode            |     |
|    |       | 12.3.6     | Output Compare mode           |     |
|    |       | 12.3.7     | Edge-Aligned PWM(EPWM) mode   |     |
|    |       | 12.3.8     | Center-Aligned PWM(CPWM) mode |     |
|    |       | 12.3.9     | Combine mode                  |     |
|    |       | 12.3.10    | Complementary mode            |     |
|    |       |            |                               |     |

Page 9 of 360



|    |      | 12.3.11    | Registers updated from write buffers           |     |
|----|------|------------|------------------------------------------------|-----|
|    |      | 12.3.12    | PWM synchronization                            | 190 |
|    |      | 12.3.13    | Inverting                                      | 190 |
|    |      | 12.3.14    | Channel trigger output                         | 191 |
|    |      | 12.3.15    | Initialization trigger                         | 191 |
|    |      | 12.3.16    | Capture Test mode                              | 191 |
|    |      | 12.3.17    | Dual Edge Capture mode                         | 191 |
|    |      | 12.3.18    | Software output control                        | 192 |
|    |      | 12.3.19    | Deadtime insertion                             | 193 |
|    |      | 12.3.20    | Fault control                                  |     |
|    |      | 12.3.21    | Polarity control                               | 194 |
|    |      | 12.3.22    | Features priority                              | 194 |
|    | 12.4 | PWM inte   | errupts                                        | 195 |
|    |      | 12.4.1     | Count Overflow interrupt                       | 195 |
|    |      | 12.4.2     | Channel interrupt                              | 195 |
|    |      | 12.4.3     | Fault interrupt                                | 195 |
| 13 | Puls | e Width    | Detect Timer(PWDT)                             | 196 |
|    | 13.1 | Introducti | ion                                            | 196 |
|    | 13.2 | Features   |                                                | 196 |
|    | 13.3 | Functiona  | al description                                 | 196 |
|    |      | 13.3.1     | Pulse Width Measurement function               | 197 |
|    |      | 13.3.2     | Timer function                                 | 200 |
|    |      | 13.3.3     | Reset operation                                | 201 |
|    | 13.4 | Program    | guide                                          | 201 |
|    |      | 13.4.1     | Pulse Width Measurement function program guide | 201 |
|    |      | 13.4.2     | Timer function program guide                   | 201 |
|    | 13.5 | Register   | definition                                     | 202 |
|    |      |            |                                                |     |
| 14 | ТІМ  | ER         |                                                | 205 |
| 14 |      |            | ion                                            |     |



|    | 14.2 | Features   |                                       | )5 |
|----|------|------------|---------------------------------------|----|
|    | 14.3 | Functiona  | al description                        | )5 |
|    |      | 14.3.1     | General operation20                   | )6 |
|    |      | 14.3.2     | Chained timers                        | )6 |
|    | 14.4 | Memory     | map and register definition20         | )6 |
|    | 14.5 | Interrupts |                                       | )9 |
| 15 | сти  |            | 21                                    | 0  |
|    | 15.1 | Introduct  | on21                                  | 0  |
|    | 15.2 | Features   |                                       | 0  |
|    | 15.3 | Function   | description21                         | 0  |
|    |      | 15.3.1     | ACMP output capture                   | 1  |
|    |      | 15.3.2     | ADC hardware trigger21                | 1  |
|    | 15.4 | Register   | definition21                          | 1  |
| 16 | CRC  |            | 21                                    | 5  |
|    | 16.1 | Introduct  | on21                                  | 5  |
|    | 16.2 | Features   |                                       | 5  |
|    | 16.3 | Block dia  | gram21                                | 5  |
|    | 16.4 | Memory     | map and register descriptions21       | 5  |
|    | 16.5 | Functiona  | al description21                      | 8  |
|    |      | 16.5.1     | CRC initialization/reinitialization21 | 8  |
|    |      | 16.5.2     | CRC calculations                      | 8  |
|    |      | 16.5.3     | Transpose feature21                   | 8  |
|    |      | 16.5.4     | Types of transpose                    | 8  |
|    |      | 16.5.5     | CRC result complement                 | 20 |
|    |      | 16.5.6     | CRC data register (CRC_DATA)22        | 20 |
|    |      | 16.5.7     | CRC Polynomial register (CRC_GPOLY)22 | 20 |
|    |      | 16.5.8     | CRC Control register (CRC_CTRL)22     | 20 |
|    | 16.6 | Program    | guide22                               | 20 |
|    |      | 16.6.1     | 16-bit CRC22                          | 20 |

Page 11 of 360



|    |      | 16.6.2      | 32-bit CRC                    | 221 |
|----|------|-------------|-------------------------------|-----|
| 17 | GPI  | 0           |                               | 222 |
|    | 17.1 | Introduct   | ion                           | 222 |
|    | 17.2 | Features    | S                             |     |
|    | 17.3 | Block dia   | agram                         | 223 |
|    | 17.4 | Mode of     | operation                     | 223 |
|    |      | 17.4.1      | External interrupt            | 223 |
|    |      | 17.4.2      | Multi-Function                | 225 |
|    | 17.5 | Application | on note                       | 228 |
|    |      | 17.5.1      | External interrupt            |     |
|    |      | 17.5.2      | Multi-Function                | 228 |
|    |      | 17.5.3      | GPIO function                 | 228 |
|    |      | 17.5.4      | Programming guide             | 228 |
|    | 17.6 | Memory      | map and register descriptions | 229 |
| 18 | 12C. |             |                               | 238 |
|    | 18.1 | Introduct   | ion                           | 238 |
|    | 18.2 | Features    | 5                             | 238 |
|    | 18.3 | Block dia   | agram                         | 238 |
|    | 18.4 | Mode of     | operation                     |     |
|    | 18.5 | Memory      | map and register descriptions | 239 |
|    | 18.6 | Function    | al description                | 248 |
|    |      | 18.6.1      | Data flow & Algorithm         | 248 |
|    |      | 18.6.2      | Input & Output timing         | 248 |
|    |      | 18.6.3      | Master SCL output timing set  | 249 |
|    |      | 18.6.4      | Data transmission             | 249 |
|    |      | 18.6.5      | DMA operation                 |     |
|    |      | 18.6.6      | Slave low power wakeup        |     |
|    |      | 18.6.7      | Interrupt                     |     |
|    | 18.7 | Program     | guide                         |     |

Page 12 of 360



|    |       | 18.7.1     | Description              | 253 |
|----|-------|------------|--------------------------|-----|
|    |       | 18.7.2     | Master transmitter       | 253 |
|    |       | 18.7.3     | Master receiver          | 254 |
|    |       | 18.7.4     | Master combined format   | 254 |
|    |       | 18.7.5     | Slave                    | 255 |
| 19 | SPI   |            |                          | 256 |
|    | 19.1  | Introduct  | tion                     | 256 |
|    | 19.2  | Feature I  | list                     | 256 |
|    | 19.3  | Block dia  | agram                    | 257 |
|    | 19.4  | Data flow  | w & Algorithm            | 257 |
|    | 19.5  | Input & C  | Output timing            | 258 |
|    |       | 19.5.1     | CPHA = 0 transfer format | 258 |
|    |       | 19.5.2     | CPHA = 1 transfer format | 259 |
|    | 19.6  | Master S   | SCK output timing set    | 260 |
|    | 19.7  | Master m   | node fault detect        | 260 |
|    | 19.8  | Slave lov  | w power wakeup           | 261 |
|    | 19.9  | Interrupt  | t                        | 262 |
|    | 19.10 | ) Master C | CS continuous mode       | 262 |
|    | 19.11 | Master C   | CS discontinuous output  |     |
|    | 19.12 | 2 Slave mo | ode                      |     |
|    | 19.13 | 3 DMA mo   | ode                      |     |
|    | 19.14 | Register   | definition               |     |
| 20 | DMA   | ۱          |                          | 269 |
|    | 20.1  | Introduct  | tion                     | 269 |
|    | 20.2  | Features   | 3                        | 269 |
|    | 20.3  | Block dia  | agram                    | 270 |
|    | 20.4  | Mode of    | operations               | 270 |
|    | 20.5  | Function   | n description            | 270 |
|    |       | 20.5.1     | DMA request mapping      | 270 |

Page 13 of 360



|    |                              | 20.5.2                                                                                                   | DMA arbiter                                                                                                                                                                                       | 270               |
|----|------------------------------|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
|    |                              | 20.5.3                                                                                                   | Configuration guide                                                                                                                                                                               | 271               |
|    | 20.6                         | Memory                                                                                                   | map and register descriptions                                                                                                                                                                     | 273               |
| 21 | WD                           | г                                                                                                        |                                                                                                                                                                                                   |                   |
|    | 21.1                         | Introduct                                                                                                | ion                                                                                                                                                                                               |                   |
|    | 21.2                         | Features                                                                                                 |                                                                                                                                                                                                   |                   |
|    | 21.3                         | Block dia                                                                                                | agram                                                                                                                                                                                             |                   |
|    | 21.4                         | Mode of                                                                                                  | operation                                                                                                                                                                                         |                   |
|    | 21.5                         | Memory                                                                                                   | map and register descriptions                                                                                                                                                                     |                   |
|    | 21.6                         | Function                                                                                                 | al description                                                                                                                                                                                    |                   |
|    |                              | 21.6.1                                                                                                   | Watchdog refresh mechanism                                                                                                                                                                        |                   |
|    |                              | 21.6.2                                                                                                   | Configuring the Watchdog                                                                                                                                                                          |                   |
|    |                              | 21.6.3                                                                                                   | Using interrupts to delay watchdog reset                                                                                                                                                          |                   |
|    |                              | 21.6.4                                                                                                   | Backup reset                                                                                                                                                                                      |                   |
| 22 | RTC                          |                                                                                                          |                                                                                                                                                                                                   |                   |
|    | 22.1                         | Introduct                                                                                                | ion                                                                                                                                                                                               |                   |
|    | ~~~~                         | _                                                                                                        |                                                                                                                                                                                                   | 200               |
|    | 22.2                         | Features                                                                                                 |                                                                                                                                                                                                   |                   |
|    | 22.2<br>22.3                 |                                                                                                          | agram                                                                                                                                                                                             |                   |
|    | 22.3                         | Block dia                                                                                                | agramoperation                                                                                                                                                                                    | 290               |
|    | 22.3<br>22.4                 | Block dia<br>Mode of                                                                                     | -                                                                                                                                                                                                 | 290               |
|    | 22.3<br>22.4<br>22.5         | Block dia<br>Mode of<br>Memory                                                                           | operation                                                                                                                                                                                         | 290<br>290<br>290 |
|    | 22.3<br>22.4<br>22.5         | Block dia<br>Mode of<br>Memory                                                                           | operation<br>map and register descriptions                                                                                                                                                        |                   |
|    | 22.3<br>22.4<br>22.5         | Block dia<br>Mode of<br>Memory<br>Function                                                               | operation<br>map and register descriptionsal description                                                                                                                                          |                   |
|    | 22.3<br>22.4<br>22.5         | Block dia<br>Mode of<br>Memory<br>Function<br>22.6.1                                                     | operation<br>map and register descriptions<br>al description<br>Low power mode operation                                                                                                          |                   |
| 23 | 22.3<br>22.4<br>22.5<br>22.6 | Block dia<br>Mode of<br>Memory<br>Function<br>22.6.1<br>22.6.2<br>22.6.3                                 | operation<br>map and register descriptions<br>al description<br>Low power mode operation<br>RTC backup registers                                                                                  |                   |
| 23 | 22.3<br>22.4<br>22.5<br>22.6 | Block dia<br>Mode of<br>Memory<br>Function<br>22.6.1<br>22.6.2<br>22.6.3<br>edded F                      | operation<br>map and register descriptions<br>al description<br>Low power mode operation<br>RTC backup registers<br>Configuration sequence                                                        |                   |
| 23 | 22.3<br>22.4<br>22.5<br>22.6 | Block dia<br>Mode of<br>Memory<br>Function<br>22.6.1<br>22.6.2<br>22.6.3<br>edded F                      | operation<br>map and register descriptions<br>al description<br>Low power mode operation<br>RTC backup registers<br>Configuration sequence                                                        |                   |
| 23 | 22.3<br>22.4<br>22.5<br>22.6 | Block dia<br>Mode of<br>Memory<br>Function<br>22.6.1<br>22.6.2<br>22.6.3<br>edded F<br>Embedde           | operation<br>map and register descriptions<br>al description<br>Low power mode operation<br>RTC backup registers<br>Configuration sequence<br>Flash<br>ed flash function overview                 |                   |
| 23 | 22.3<br>22.4<br>22.5<br>22.6 | Block dia<br>Mode of<br>Memory<br>Function<br>22.6.1<br>22.6.2<br>22.6.3<br>edded F<br>Embedde<br>23.1.1 | operation<br>map and register descriptions<br>al description<br>Low power mode operation<br>RTC backup registers<br>Configuration sequence<br>Flash<br>ed flash function overview<br>Introduction |                   |

Page 14 of 360



|    |      | 23.1.4      | Data flow & Algorithm                | 298 |
|----|------|-------------|--------------------------------------|-----|
|    | 23.2 | Embedde     | ed flash memory organization         | 298 |
|    | 23.3 | Embedde     | ed flash protect                     | 299 |
|    |      | 23.3.1      | Read and write protection            | 299 |
|    |      | 23.3.2      | Others                               |     |
|    | 23.4 | Program     | guide                                |     |
|    |      | 23.4.1      | Brief introduction                   |     |
|    |      | 23.4.2      | Command operation description        |     |
|    | 23.5 | Register    | definition                           |     |
| 24 | Seri | al Flash    |                                      | 316 |
|    | 24.1 | Serial FL   | ASH function overview                | 316 |
|    |      | 24.1.1      | Introduction                         | 316 |
|    |      | 24.1.2      | Feature list:                        | 316 |
|    |      | 24.1.3      | Block diagram                        | 316 |
|    | 24.2 | Application | on note                              | 316 |
|    |      | 24.2.1      | Clock setting                        | 316 |
|    |      | 24.2.2      | RISC access NOR flash                | 317 |
|    |      | 24.2.3      | Read NOR flash id                    | 317 |
|    |      | 24.2.4      | Write status register (WRSR)         | 319 |
|    |      | 24.2.5      | Erase NOR flash (sector/block erase) |     |
|    |      | 24.2.6      | Erase NOR flash (chip erase)         |     |
|    |      | 24.2.7      | Page Program NOR flash               |     |
|    |      | 24.2.8      | 4 x I/O Page Program(4PP)            |     |
|    |      | 24.2.9      | AAI program NOR flash                |     |
|    |      | 24.2.10     | Read NOR flash                       |     |
|    | 24.3 | System b    | boot from serial flash               |     |
|    | 24.4 | Register    | definitions                          |     |

# **//utoChips**

# **List of Figures**

| Figure 2-1 System architecture                                                 |                |
|--------------------------------------------------------------------------------|----------------|
| Figure 3-1 Reset block diagram                                                 |                |
| Figure 4-1 Clock control diagram                                               |                |
| Figure 4-2 System clock diagram                                                |                |
| Figure 6-1 SPM block diagram                                                   |                |
| Figure 7-1 Connection to CAN bus and main features of the CAN-CTRL core        |                |
| Figure 7-2 Message buffers concept                                             |                |
| Figure 7-3 Access to the acceptance filters                                    |                |
| Figure 7-4 Schematic of the FIFO-like RB (example with 6 slots)                | 74             |
| Figure 7-5 Schematic of PTB and STB in FIFO mode (empty PTB and 6 STB slots)   | 75             |
| Figure 7-6 CAN Bit Timing Specifications                                       |                |
| Figure 8-1 LINCORE block diagram                                               |                |
| Figure 8-2 LINCORE operating modes                                             |                |
| Figure 8-3 Loop back mode                                                      |                |
| Figure 8-4 Self-test mode                                                      |                |
| Figure 8-5 The structure of a frame                                            |                |
| Figure 8-6 LIN bus structure                                                   |                |
| Figure 8-7 LIN header reception                                                |                |
| Figure 9-1 UART block diagram                                                  |                |
| Figure 9-2 UART transmitter flow                                               |                |
| Figure 9-2 UART receiver flow                                                  |                |
|                                                                                |                |
| Figure 9-4 UART noise detection<br>Figure 9-5 Hardware flow control connection |                |
|                                                                                |                |
| Figure 9-6 Hardware flow control principle                                     |                |
| Figure 9-7 Single byte data transmission                                       |                |
| Figure 9-8 Multiple bytes data transmission                                    |                |
| Figure 9-9 Practical circuit connection                                        |                |
| Figure 9-10 LIN frame flow                                                     |                |
| Figure 9-11 Chip normal mode and stop mode condition                           |                |
| Figure 9-12 Typical flow for waking up the chip by UART                        |                |
| Figure 9-13 Diagram for baud rate generator                                    |                |
| Figure 10-1 UART block diagram                                                 |                |
| Figure 10-2 ADC Power on sequence                                              |                |
| Figure 10-3 CPU normal mode and sleep mode condition                           |                |
| Figure 10-4 Regular group sequence                                             |                |
| Figure 10-5 Valid regular group sequence                                       |                |
| Figure 10-6 Injection group sequence                                           |                |
| Figure 10-7 Valid injection group sequence                                     |                |
| Figure 10-8 Mode 1 operation flow                                              |                |
| Figure 10-9 Mode 2 operation flow                                              |                |
| Figure 10-10 Mode 3 typical operation flow                                     |                |
| Figure 10-11 Mode 3 operation flow with injection trigger at ADC idle state    |                |
| Figure 10-12 Mode 4 operation flow with auto injection trigger                 |                |
| Figure 10-13 Mode 5 typical operation flow                                     | 128            |
| Figure 10-14 Mode 5 operation flow with injection trigger at ADC idle state    | 129            |
| Figure 10-15 Mode 6 operation flow                                             | 129            |
| Figure 10-16 Mode 7 operation flow                                             | 130            |
| Figure 10-17 Mode 8 operation flow                                             | 130            |
| Figure 10-18 Analog monitor detecting region                                   |                |
| Figure 10-19 Three flags under condition 1                                     |                |
| Figure 10-20 Three flags under condition 2                                     |                |
| Figure 10-21 Three flags under condition 3                                     |                |
| Figure 11-1 ACMP block diagram                                                 |                |
| AutoChips Confidential © 2013 - 2021 AutoChips Inc.                            | Page 16 of 360 |
| This document contains information that is proprietary to AutoChips Inc.       |                |

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.



| Figure 11-2 Polling mode                                         | .144 |
|------------------------------------------------------------------|------|
| Figure 12-1 PWM block diagram                                    | .156 |
| Figure 12-2 PWM clock source                                     | .181 |
| Figure 12-3 Prescaler                                            | .182 |
| Figure 12-4 Up counting                                          | .183 |
| Figure 12-5 Up-Down counting                                     |      |
| Figure 12-6 Input Capture mode                                   |      |
| Figure 12-7 Output Compare mode                                  |      |
| Figure 12-8 Edge-aligned PWM mode                                | 186  |
| Figure 12-9 Center-aligned PWM mode                              | 187  |
| Figure 12-10 Combine mode                                        |      |
| Figure 12-10 Combine mode                                        |      |
|                                                                  |      |
| Figure 12-12 Dual edge capture mode                              |      |
| Figure 12-13 Features priority                                   |      |
| Figure 13-1 PWDT block diagram                                   | .197 |
| Figure 13-2 Four basic measurement modes                         |      |
| Figure 13-3 Hall measurement modes                               |      |
| Figure 13-4 Two common installation ways                         | .199 |
| Figure 13-5 Example for low level noise and filter               |      |
| Figure 13-6 Example for high level noise and filter              |      |
| Figure 13-7 PWDTC counter and counting error                     |      |
| Figure 13-8 Modify the TIMCNTVAL between the TIMEN=0 and TIMEN=1 | .201 |
| Figure 13-9 Modify the TIMCNTVAL during TIMEN=1                  | .201 |
| Figure 14-1 TIMER block diagram                                  | .205 |
| Figure 15-1 CTU block diagram                                    | .210 |
| Figure 16-1 CRC block diagram                                    |      |
| Figure 16-2 CTRL[TOTW] / CTRL[TOTR] is 01                        |      |
| Figure 16-3 CTRL[TOTW] / CTRL[TOTR] is 10                        |      |
| Figure 16-4 CTRL[TOTW] / CTRL[TOTR] is 11                        |      |
| Figure 17-1 GPIO block diagram                                   |      |
| Figure 17-2 GPIO external interrupt                              |      |
| Figure 17-3 GPIO multi-function                                  |      |
| Figure 18-1 I2C block diagram                                    |      |
| Figure 18-2 Data flow of transmitter                             |      |
| Figure 18-3 Data flow of Receiver                                |      |
| Figure 18-4 START and STOP conditions                            | 240  |
| Figure 18-5 Data transmission format                             |      |
| Figure 18-6 Baud rate generation                                 |      |
|                                                                  |      |
| Figure 18-7 BND sequence of master write slave mode              |      |
| Figure 18-8 BND sequence of master read slave mode               |      |
| Figure 18-9 Master transmitter case 1                            |      |
| Figure 18-10 Master transmitter case 2                           |      |
| Figure 18-11 Master receiver                                     |      |
| Figure 18-12 Slave transmitter                                   |      |
| Figure 18-13 Slave receiver                                      |      |
| Figure 18-14 Wakeup sequence                                     |      |
| Figure 18-15 Master write operation sequence                     |      |
| Figure 18-16 Master receiver operation sequence                  |      |
| Figure 18-17 Combined format option sequence                     |      |
| Figure 18-18 Typical I2C slave interrupt routine                 |      |
| Figure 19-1 SPI system connection                                |      |
| Figure 19-2 SPI block diagram                                    |      |
| Figure 19-3 Data flow of master                                  | .257 |
| Figure 19-4 Data flow of slave                                   |      |
| Figure 19-5 CPHA=0 Transmission Format                           |      |
| Figure 19-6 CPHA=1 Transmission Format                           |      |
| Figure 19-7 Baud rate generation                                 |      |
|                                                                  |      |

#### AutoChips Confidential

 $\ensuremath{\textcircled{}}$  2013 - 2021 AutoChips Inc.

Page 17 of 360

#### AC781x Reference Manual eral

| <b>//utoChips</b>                             | AC781x Reference Manua<br>Genera |
|-----------------------------------------------|----------------------------------|
|                                               |                                  |
| Figure 19-8 SCK output timing with mode fault | t detect enable261               |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               | controller                       |
|                                               | d flash controller               |
|                                               | low                              |
| Figure 23-4 Mass erase command operation f    | low                              |
|                                               | n flow                           |
|                                               | ation flow                       |
| Figure 23-7 Mass erase verify command oper    | ation flow                       |
| Figure 23-8 Option page erase command ope     | ration flow                      |
|                                               | peration flow                    |
|                                               | er                               |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               | se) flow                         |
|                                               | solution 1                       |
|                                               | solution 2                       |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               |                                  |
|                                               | 0.40                             |

# **VutoChips**

# **List of Tables**

| Table 1-1 AC781x module description                                      |           |
|--------------------------------------------------------------------------|-----------|
| Table 2-1 High-level device memory map                                   |           |
| Table 2-2 Interrupt table                                                |           |
| Table 2-3 Boot configuration                                             |           |
| Table 2-4 Address assignment of each peripheral                          |           |
| Table 3-1 Reset register map                                             |           |
| Table 4-1 Clock register map                                             |           |
| Table 5-1 Module functionality in low-power modes                        | 46        |
| Table 6-1 SPM Register Map                                               | 50        |
| Table 7-1 CAN-CRTL Register Mapping                                      | 61        |
| Table 7-2 Bits in Register ACF_3, if SELMASK=1                           |           |
| Table 7-3 Receive Buffer Registers RBUF – Standard Format (r-0)          |           |
| Table 7-4 Receive Buffer Registers RBUF – Extended Format (r-0)          | 71        |
| Table 7-5 Transmit Buffer Registers TBUF – Standard Format (rw-u)        | 71        |
| Table 7-6 Transmit Buffer Registers TBUF – Extended Format (rw-u)        | 71        |
| Table 7-7 Control bits in RBUF and TBUF                                  | 72        |
| Table 7-8 Definition of the DLC (according to the CAN 2.0 specification) | 72        |
| Table 7-9 Software reset                                                 | 81        |
| Table 7-10 CAN Timing Segments                                           |           |
| Table 7-11 CAN-CTRL Timing Settings                                      |           |
| Table 7-12 Sample settings for 48MHz can_clk                             |           |
| Table 7-13 Sample settings for 8MHz can_clk                              |           |
| Table 8-1 LIN interrupt table                                            |           |
| Table 8-2 LIN register map                                               |           |
| Table 9-1 Function classification and configuration                      |           |
| Table 9-2 UART input&output timing                                       |           |
| Table 9-3 Typical baud rate and error@bclock=50MHz                       |           |
| Table 9-4 Typical baud rate and error @bclock=36MHz                      |           |
| Table 9-5 UART register map                                              |           |
| Table 10-1 Power modes                                                   |           |
| Table 10-2 ADC operation modes and its corresponding configuration       |           |
| Table 10-3 Analog monitor configuration                                  |           |
| Table 10-4 ADC register map                                              |           |
| Table 11-1 ACMP register map                                             |           |
| Table 11-2 ACMP interrupt table                                          |           |
| Table 12-1 PWM modules configuration                                     |           |
| Table 12-2 PWM register map and reset values                             |           |
| Table 12-3 Operation mode configuration                                  |           |
| Table 12-4 PWM_CNTIN register update buffer                              |           |
| Table 12-5 PWM_CH(n)V register update buffer                             |           |
| Table 12-6 PWM_MCVR register update buffer                               | 189       |
| Table 12-7 Software output control when COMP bit is zero                 |           |
| Table 12-8 Software output control when COMP bit is one                  |           |
| Table 12-9 Fault source and number table                                 |           |
| Table 13-1 Measurable pulse width range                                  |           |
| Table 13-2 Filterable pulse width range                                  |           |
| Table 13-3 PWDT register map and reset values                            |           |
| Table 14-1 TIMER register map                                            |           |
| Table 15-1 ADC hardware trigger1 source                                  |           |
| Table 15-2 CTU register map                                              |           |
| Table 16-1 CRC register map                                              |           |
| Table 17-1 GPIO multi-function                                           |           |
| Table 17-2 GPIO register map                                             |           |
|                                                                          | 19 of 360 |
|                                                                          | 10 01 000 |

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.



| Table 18-1 I2C register map                                      | 239 |
|------------------------------------------------------------------|-----|
| Table 18-1 I2C register map         Table 18-2 Interrupt summary | 252 |
| Table 19-1 Interrupt summary                                     |     |
| Table 19-2 SPI register map                                      |     |
| Table 20-1 DMA request mapping                                   | 270 |
| Table 20-2 Programmable data width & data alignment              | 273 |
| Table 20-3 DMA register map                                      | 273 |
| Table 21-1 WDG register map                                      |     |
| Table 22-1 RTC register map                                      |     |
| Table 23-1 Flash memory organization                             |     |
| Table 23-2 The content of the key addresses in option page       |     |
| Table 23-3 Read protection description                           |     |
| Table 23-4 Write protection description                          |     |
| Table 23-5 Watch dog enable description                          |     |
| Table 23-6 Embedded flash register map                           |     |
| Table 24-1 Clock configuration register                          |     |
| Table 24-2 Flashif related register map                          |     |

### 1 Introduction

**NutoChips** 

#### 1.1 Overview

This chapter provides an overview of AC781x. It also presents high level descriptions of the modules. AC781x is a high-performance, low-power MCU with ARM Cortex<sup>™</sup>-M3 core.

- Up to 100 MHz CPU frequency
- Temperature range (ambient): -40°C to +125°C
- Voltage range: 2.7 V to 5.5 V

### **1.2 Module description**

#### Table 1-1 AC781x module description

| Module              | Descriptions                                                        |
|---------------------|---------------------------------------------------------------------|
| ARM Cortex CM3 core | 32-bit MCU core from ARM's Cortex-M class                           |
|                     | 96 MHz CPU frequency                                                |
| Memories            | Up to 256 KB flash memory                                           |
|                     | Up to 64 KB SRAM                                                    |
|                     | External crystal oscillator or resonator                            |
|                     | Range: 4 MHz to 30 MHz                                              |
| Clocks              | External square wave input clock                                    |
| Clocke              | Internal clock references                                           |
|                     | 8 MHz oscillator                                                    |
|                     | <ul> <li>32 kHz oscillator</li> </ul>                               |
|                     | One 12-bit ADC with up to 16 channels                               |
| Analog              | Two analog comparators (ACMP) with internal 6-bit digital-to-analog |
|                     | converter (DAC)                                                     |
|                     | One 6-channel PWM with full function                                |
|                     | Three 2-channel PWMs with basic function                            |
| Timers              | 8 * periodic interrupt timer (Timer)                                |
|                     | Real time clock (RTC)                                               |
|                     | One pulse width detection timer (PWDT)                              |
|                     | System tick timer (SysTick)                                         |
|                     | Two SPI modules                                                     |
|                     | Two I2C modules                                                     |
| Communications      | <ul> <li>Six UART modules, only UART6 support LIN break</li> </ul>  |
|                     | Two CAN controller                                                  |
|                     | One LIN controller                                                  |
| Interfaces          | General Purpose Input/Output (GPIO)                                 |
|                     | Interrupt (IRQ)                                                     |
| Debug interfaces    | • JTAG                                                              |
| 3                   | • SWD                                                               |

# **//utoChips**

# 2 Memory and Bus Architecture

### 2.1 System architecture

The main system consists of :

- Four masters
  - Cortex<sup>™</sup>-M3 core ICode bus (I-bus).
  - o Cortex<sup>™</sup>-M3 core DCode bus (D-bus).
  - o Cortex<sup>™</sup>-M3 core System bus (S-bus).
  - o DMA (general-purpose DMA).
- Five slaves
  - Internal SRAM.
  - o Internal Flash memory.
  - $\circ$   $\;$  External serial Flash memory.
  - Fast IO, CRC and GPIO.
  - o AHB to APB bridges (AHB2APB), which connect all the APB peripherals.

These are interconnected using a multilayer AHB bus architecture as shown in Figure 2-1.



#### Figure 2-1 System architecture

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 22 of 360



#### ICode bus

This bus connects the Instruction bus of the Cortex<sup>™</sup>-M3 core to the Flash memory instruction interface. Prefetching is performed on this bus.

#### DCode bus

This bus connects the DCode bus (literal load and debug access) of the Cortex<sup>™</sup>-M3 core to the Flash Memory Data interface.

#### System bus

This bus connects the system bus of the Cortex<sup>™</sup>-M3 core (peripherals bus) to a BusMatrix which manages the arbitration between the core and the DMA.

#### MPU

AC781x supports MPU function, which is disabled by default. Please enable relevant configuration when using, please refer to the Cortex<sup>™</sup>-M3 Technical Reference Manual.

#### **DMA** bus

This bus connects the AHB master interface of the DMA to the BusMatrix , which manages the access of CPU DCode and DMA to SRAM and peripherals.

#### **BusMatrix**

The BusMatrix manages the access arbitration between the core system bus and the DMA master bus. The arbitration uses a Round Robin algorithm. In connectivity line devices, the BusMatrix is composed of four masters (CPU ICode, CPU DCode, System bus and DMA) and five slaves (internal flash, serial flash, SRAM, fast IO and AHB2APB bridges).

Internal flash can only be accessed by ICode and DCode masters.

ICode and DCode can access SRAM and internal flash slaves, DCode master has higher priority than ICode.

AHB peripherals are connected on system bus through a BusMatrix to allow DMA access.

#### AHB2APB bridges (APB)

The AHB2APB bridge provides full synchronous connections between the AHB and the APB buses. APB1 is limited to ½ frequency of AHB frequency.

#### I-Cache

The I-Cache manages the access between Cortex<sup>™</sup>-M3 core ICode and internal flash memory. It includes direct access 8x32x2 SRAM to provide zero wait access time when cache matched. The cache structure is 8-ways, 2-set with LRU (Least Recently Used) replacement algorithm.

#### **D-Cache**

The D-Cache manages the access between Cortex<sup>™</sup>-M3 core DCode and internal flash memory. It includes direct access 4x32x2 SRAM to provide zero wait access time when cache matched. D-Cache has higher priority than I-Cache.

The cache structure is 2-ways, 2-set with LRU (Least Recently Used) replacement algorithm.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 23 of 360

### 2.2 Memory organization

Program memory, data memory, registers and I/O ports are organized within the same linear 4-Gbyte address space.

The bytes are coded in memory in Little Endian format. The lowest numbered byte in a word is considered the word's least significant byte and the highest numbered byte the most significant.

For the detailed mapping of peripheral registers, please refer to the related chapters. The addressable memory space is divided into 8 main blocks, each of 512 MB.

#### 2.2.1 Memory map

The following table is high-level device memory map, which includes four different memory map tables based on different boot up configuration, such as embedded flash memory boot up, ISP boot up, sram boot up and serial flash boot up.

All the memory areas that are not allocated to on-chip memories and peripherals are considered "Reserved".

|             |                    |             | -                  |             |                 |             |                 |
|-------------|--------------------|-------------|--------------------|-------------|-----------------|-------------|-----------------|
| 0xE010 0000 | Reserved           | 0xE010 0000 | Reserved           | 0xE010 0000 | Reserved        | 0xE010 0000 | Reserved        |
| 0xE00F FFFF | Cortex-M3's        | 0xE00F FFFF | Cortex-M3's        | 0xE00F FFFF | Cortex-M3's     | 0xE00F FFFF | Cortex-M3's     |
|             | internal           |             | internal           |             | internal        |             | internal        |
| 0xE000 0000 | peripherals        | 0xE000 0000 | peripherals        | 0xE000 0000 | peripherals     | 0xE000 0000 | peripherals     |
| 0xDFFFFFFF  |                    | 0xDFFFFFFF  |                    | 0xDFFFFFF   |                 | 0xDFFFFFF   |                 |
|             | Reserved           |             | Reserved           |             | Reserved        |             | Reserved        |
| 0x6100 0000 |                    | 0x6100 0000 |                    | 0x6100 0000 |                 | 0x6100 0000 |                 |
| 0x60FF FFFF |                    | 0x60FF FFFF |                    | 0x60FF FFFF |                 | 0x60FF FFFF |                 |
|             | external<br>memory |             | external<br>memory |             | external memory |             | external memory |
| 0x6000 0000 |                    | 0x6000 0000 |                    | 0x6000 0000 |                 | 0x6000 0000 |                 |
| 0x5FFF FFFF |                    | 0x5FFF FFFF |                    | 0x5FFF FFFF |                 | 0x5FFF FFFF |                 |
| 0x4400 0000 | Reserved           | 0x4400 0000 | Reserved           | 0x4400 0000 | Reserved        | 0x4400 0000 | Reserved        |
|             |                    |             |                    |             |                 |             |                 |
| 0x43FF FFFF | Peripheral         | 0x43FF FFFF | Peripheral         | 0x43FF FFFF | Peripheral      | 0x43FF FFFF | Peripheral      |
| 0x4200 0000 | alias region       | 0x4200 0000 | alias region       | 0x4200 0000 | alias region    | 0x4200 0000 | alias region    |
| 0x41FF FFFF |                    | 0x41FF FFFF |                    | 0x41FF FFFF |                 | 0x41FF FFFF |                 |
|             | Reserved           |             | Reserved           |             | Reserved        |             | Reserved        |
| 0x4010 0000 |                    | 0x4010 0000 |                    | 0x4010 0000 |                 | 0x4010 0000 |                 |
| 0x400F FFFF | Peripheral         | 0x400F FFFF | Peripheral         | 0x400F FFFF | Peripheral      | 0x400F FFFF | Peripheral      |
|             | APB                |             | APB                |             | APB             |             | APB             |
| 0x4000 0000 | Address            | 0x4000 0000 | Address            | 0x4000 0000 | Address         | 0x4000 0000 | Address         |
| 0x3FFF FFFF |                    | 0x3FFF FFFF |                    | 0x3FFF FFFF |                 | 0x3FFF FFFF |                 |
| 0x2400 0000 | Reserved           | 0x2400 0000 | Reserved           | 0x2400 0000 | Reserved        | 0x2400 0000 | Reserved        |
|             |                    |             |                    |             |                 |             |                 |
| 0x23FF FFFF | AHB SRAM           | 0x23FF FFFF | AHB SRAM           | 0x23FF FFFF | AHB SRAM        | 0x23FF FFFF | AHB SRAM        |
| 0x2200 0000 | alias region       | 0x2200 0000 | alias region       | 0x2200 0000 | alias region    | 0x2200 0000 | alias region    |
|             |                    |             |                    |             |                 |             |                 |
| 0x21FF FFFF | Reserved           | 0x21FF FFFF | Reserved           | 0x21FF FFFF | Reserved        | 0x21FF FFFF | Reserved        |
|             |                    |             |                    |             |                 |             |                 |

#### Table 2-1 High-level device memory map

AutoChips Confidential

#### $\textcircled{\mbox{\sc c}}$ 2013 - 2021 AutoChips Inc.

# **//utoChips**

| 0x2008 2000                |              | 0x2008 2000                |             | 0x2008 2000                |             | 0x2008 2000                |             |
|----------------------------|--------------|----------------------------|-------------|----------------------------|-------------|----------------------------|-------------|
| 0x2008 1FFF                |              | 0x2008 1FFF                |             | 0x2008 1FFF                |             | 0x2008 1FFF                |             |
|                            | AHB Fast IO  |                            | AHB Fast    |                            | AHB Fast IO |                            | AHB Fast IO |
| 0x2008 0000                |              | 0x2008 0000                | _           | 0x2008 0000                |             | 0x2008 0000                |             |
| 0x2007 FFFF                |              | 0x2007 FFFF                |             | 0x2007 FFFF                |             | 0x2007 FFFF                |             |
| 0x2001 0000                | Reserved     | 0x2001 0000                | Reserved    | 0x2001 0000                | Reserved    | 0x2001 0000                | Reserved    |
| 0x2000 FFFF                |              | 0x2000 FFFF                |             | 0x2000 FFFF                |             | 0x2000 FFFF                |             |
|                            | AHB SRAM     |                            | AHB SRAM    |                            | AHB SRAM    |                            | AHB SRAM    |
| 0x2000 0000                |              | 0x2000 0000                | _           | 0x2000 0000                |             | 0x2000 0000                |             |
| 0x1FFF FFFF                |              | 0x1FFF FFFF                |             | 0x1FFF FFFF                |             | 0x1FFF FFFF                |             |
| 0x0804 3000                | Reserved     | 0x0804 3000                | Reserved    | 0x0804 3000                | Reserved    | 0x0804 3000                | Reserved    |
| 0x0804 3000<br>0x0804 27FF |              | 0x0804 3000<br>0x0804 27FF |             | 0x0804 3000<br>0x0804 27FF |             | 0x0804 3000<br>0x0804 27FF |             |
| 0X0604 27FF                | Deserved     | 0x0604 27FF                | Reserved    | 0x0804 27FF                | Reserved    | 0X0604 27FF                | Reserved    |
| 0x0804 2000                | Reserved     | 0x0804 2000                | Reserved    | 0x0804 2000                | Reserved    | 0x0804 2000                | Reserved    |
| 0x0804 1FFF                |              | 0x0804 1FFF                |             | 0x0804 1FFF                |             | 0x0804 1FFF                |             |
|                            | ISP Code     |                            | ISP Code    |                            | ISP Code    |                            | ISP Code    |
| 0x0804 0800                |              | 0x0804 0800                |             | 0x0804 0800                |             | 0x0804 0800                |             |
| 0x0804 002F                |              | 0x0804 002F                |             | 0x0804 002F                |             | 0x0804 002F                |             |
| 0x0804 0000                | option byte  | 0x0804 0000                | option byte | 0x0804 0000                | option byte | 0x0804 0000                | option byte |
| 0x0803 FFFF                |              | 0x0803_FFFF                |             | 0x0803 FFFF                |             | 0x0803 FFFF                |             |
|                            | Flash        |                            | Flash       |                            | Flash       |                            | Flash       |
| 0x0800 0000                | memory       | 0x0800 0000                | memory      | 0x0800 0000                | memory      | 0x0800 0000                | memory      |
| 0x07FF FFFF                |              | 0x07FF FFFF                |             | 0x07FF FFFF                |             | 0x07FF FFFF                |             |
| 0.0004_0000                | Reserved     | 0.0000 4000                | Reserved    | 0.0004.0000                | Reserved    | 0.0100.0000                | Reserved    |
| 0x0004_0000<br>0x0003 FFFF |              | 0x0000 1800<br>0x0000 17FF |             | 0x0001 0000<br>0x0000 FFFF |             | 0x0100 0000<br>0x00FF FFFF |             |
|                            | Flash        |                            | system      |                            | AHB SRAM    |                            | external    |
| 0x0000 0000                | memory       | 0x0000 0000                | memory      | 0x0000 0000                |             | 0x0000 0000                | memory      |
| Flash n                    | Flash memory |                            | P           | SR                         | AM          | Serial                     | flash       |
| boot up                    |              | boot                       | t up        | boo                        | ot up       | boo                        | t up        |

### 2.3 Detail function description

#### 2.3.1 Internal SRAM

There is a 64 Kbytes of static SRAM. It can be accessed as bytes, half- words (16 bits) or full words (32 bits). The SRAM start address is 0x2000 0000.

#### 2.3.2 Bit banding

The Cortex<sup>™</sup>-M3 memory map includes two bit-band regions. These regions map each word in an alias region of memory to a bit in a bit-band region of memory. Writing to a word in the alias region has the same effect as a read-modify-write operation on the targeted bit in the bit-band region.

#### AC781x Reference Manual General

In AC781x, both peripheral registers and SRAM are mapped in a bit-band region. This allows single bit-band write and read operations to be performed.

A mapping formula shows how to refer each word in the alias region to a corresponding bit in the bitband region. The mapping formula is:

bit\_word\_addr = bit\_band\_base + (byte\_offset x 32) + (bit\_number x 4)

where:

**NutoChips** 

*bit\_word\_addr* is the address of the word in the alias memory region that maps to the targeted bit.

*bit\_band\_base* is the starting address of the alias region.

*byte\_offset* is the number of the byte in the bit-band region that contains the targeted bit. *bit\_number* is the bit position (0-7) of the targeted bit.

#### Example:

The following example shows how to map bit 2 of the byte located at SRAM address 0x20000300 in the alias region:

 $0x22006008 = 0x22000000 + (0x300^{*}32) + (2^{*}4)$ 

Writing to address 0x22006008 has the same effect as a read-modify-write operation on bit 2 of the byte at SRAM address 0x20000300.

Reading address 0x22006008 returns the value (0x01 or 0x00) of bit 2 of the byte at SRAM address 0x20000300 (0x01: bit set; 0x00: bit reset).

For more information on Bit-Banding, please refer to the Cortex<sup>™</sup>-M3 Technical Reference Manual.

#### 2.3.3 Fast IO memory map

The Fast IO bridge provides the channel to access CRC and GPIO through AHB bus with more efficiency, each has 4KB address range.

GPIO address range: 0x2008 0000 ~ 0x2008 0fff.

CRC address range: 0x2008 1000 ~ 0x2008 1fff.

#### 2.3.4 Internal flash memory

The high-performance Flash memory module has the following key features:

- Density up to 256 Kbytes.
- Memory organization: The Flash memory is organized as a main block and an information block.

• Main memory block of size: up to 64 Kb × 32 bits divided into 256 pages of 2 Kbytes each.

• Information block of size:  $512 \times 32$  bits.

The Flash memory controller features:

- Flash Program / Erase operation.
- Read / Write protection.
- Erase and blank check.
- Cache controller to improve read efficiency, the maximum efficiency is zero wait.

#### 2.3.5 Read internal flash memory

Flash memory instructions and data access are performed through the AHB bus. The I-cache block is used for instruction fetches through the ICode bus. The D-cache block is used for data fetches through the DCode bus. Arbitration is performed to give the higher priority to DCode bus.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 26 of 360

#### 2.3.6 Chip Model

**NutoChips** 

The model Type information can be accessed by users through the eflash read operation interface. The chip model information is stored in the continuous space (1\*32 Bit) of 0x40002028 to 0x4000202B. Among them, the upper 8 bits are fixed 0XFF, and the lower 24 bits are chip model information.

#### 2.3.7 Chip UUID

The UUID has a total of 128 Bit, which is generated by a random number and can be used as the unique identification mark of the chip. It can be accessed through the eflash read operation interface. The UUID information is stored in a continuous space (4\*32Bit) from 0x4000202C to 0x40002038.

#### 2.3.8 I-Cache and D-Cache

- Cache size is 8x32x2 and D-cache size is 4x32x2.
- The maximum of efficiency of I-cache controller is zero cycle wait of Cortex<sup>™</sup> M3 running frequency.
- The maximum of efficiency of D-cache controller is zero cycle wait of Cortex<sup>™</sup> M3 running frequency.
- DCode has the higher priority than ICode, D-cache will fetch data if D-cache missed and I-cache will stop and wait D-cache finished.

#### 2.3.9 AHB to APB bridge

AHB to APB bridge translates AHB protocol to APB protocol and get low frequency interface. Most peripherals are APB interface. Below is the detail address assignment of each peripheral.

#### 2.3.10 Nested Vectored Interrupt Controller (NVIC)

#### Features:

- 55 maskable interrupt channels (not including the 16 interrupt lines of Cortex<sup>™</sup>-M3).
- 128 programmable priority levels (7 bits of interrupt priority are used).
- Low-latency exception and interrupt handling.
- Power management control.
- Implementation of System Control Registers.

The NVIC and the processor core interface are closely coupled, which enables low latency interrupt processing and efficient processing of late arriving interrupts.

All interrupts including the core exceptions are managed by the NVIC. For more information on exceptions and NVIC programming see Chapter 5 Exceptions & Chapter 8 Nested Vectored Interrupt Controller of the ARM Cortex<sup>™</sup>-M3 Technical Reference Manual.

Below is interrupt table:

#### Table 2-2 Interrupt table

| Number | Type of priority | Acronym  | Description |
|--------|------------------|----------|-------------|
|        |                  | Reserved | Reserved    |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

# **//utoChips**

|    | Number | Type of priority | Acronym       | Description                             |
|----|--------|------------------|---------------|-----------------------------------------|
|    | -3     | fixed            | Reset         | System reset                            |
|    | -2     | fixed            | NMI           | Non-markable interrupt                  |
|    | -1     | fixed            | Hard Fault    | All class of fault                      |
|    | 0      | settable         | Mem Manage    | Memory management                       |
|    | 1      | settable         | Bus Fault     | AHB bus access fault                    |
|    | 2      | settable         | Usage Fault   | Undefined instruction or illegal state  |
|    |        |                  | Reserved      | Reserved                                |
|    | 3      | settable         | SVCall        | System service call via SWI instruction |
|    | 4      | settable         | Debug Monitor | Debug monitor                           |
|    |        |                  | Reserved      | Reserved                                |
|    | 5      | settable         | Pend SV       | Pendable request for system service     |
|    | 6      | settable         | Sys Tick      | System tick timer                       |
| 0  | 7      | settable         | PWDT          | PWDT interrupt                          |
| 1  | 8      | settable         | UART_1        | UART1 interrupt                         |
| 2  | 9      | settable         | UART_2        | UART2 interrupt                         |
| 3  | 10     | settable         | UART_3        | UART3 interrupt                         |
| 4  | 11     | settable         | UART_4        | UART4 interrupt                         |
| 5  | 12     | settable         | UART_5        | UART5 interrupt                         |
| 6  | 13     | settable         | UART_6        | UART6 interrupt                         |
| 7  | 14     | settable         | EXTI0         | EXTI Line0 interrupt                    |
| 8  | 15     | settable         | EXTI1         | EXTI Line1 interrupt                    |
| 9  | 16     | settable         | EXTI2         | EXTI Line2 interrupt                    |
| 10 | 17     | settable         | EXTI3         | EXTI Line3 interrupt                    |
| 11 | 18     | settable         | EXTI4         | EXTI Line4 interrupt                    |
| 12 | 19     | settable         | EXTI5         | EXTI Line5 interrupt                    |
| 13 | 20     | settable         | SPI_1         | SPI0 interrupt                          |
| 14 | 21     | settable         | SPI_2         | SPI1 interrupt                          |
| 15 | 22     | settable         | IIC_1         | IIC0 interrupt                          |
| 16 | 23     | settable         | IIC_2         | IIC1 interrupt                          |
| 17 | 24     | settable         | DMA_1         | DMA channel 0 interrupt                 |
| 18 | 25     | settable         | DMA_2         | DMA channel 1 interrupt                 |
| 19 | 26     | settable         | DMA_3         | DMA channel 2 interrupt                 |
| 20 | 27     | settable         | DMA_4         | DMA channel 3 interrupt                 |
| 21 | 28     | settable         | DMA_5         | DMA channel 4 interrupt                 |
| 22 | 29     | settable         | DMA_6         | DMA channel 5 interrupt                 |
| 23 | 30     | settable         | DMA_7         | DMA channel 6 interrupt                 |
| 24 | 31     | settable         | DMA_8         | DMA channel 7 interrupt                 |
| 25 | 32     | settable         | DMA_9         | DMA channel 8 interrupt                 |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

#### AC781x Reference Manual General

# **VutoChips**

|    | Number | Type of priority | Acronym        | Description                    |
|----|--------|------------------|----------------|--------------------------------|
| 26 | 33     | settable         | DMA_10         | DMA channel 9 interrupt        |
| 27 | 34     | settable         | DMA_11         | DMA channel 10 interrupt       |
| 28 | 35     | settable         | DMA_12         | DMA channel 11 interrupt       |
| 29 | 36     | settable         | TIMER_0        | Timer 0 interrupt              |
| 30 | 37     | settable         | TIMER_1        | Timer 1 interrupt              |
| 31 | 38     | settable         | BKP            | BKP tamper interrupt           |
| 32 | 39     | settable         | RTC            | RTC interrupt                  |
| 33 | 40     | settable         | WDT            | Watch dog timer interrupt      |
| 34 | 41     | settable         | PWM_0          | PWM 0 interrupt                |
| 35 | 42     | settable         | PWM_1          | PWM 1 interrupt                |
| 36 | 43     | settable         | PWM _2         | PWM 2 interrupt                |
| 37 | 44     | settable         | PVD            | Power detect interrupt         |
| 38 | 45     | settable         | LIN            | LIN interrupt                  |
| 39 | 46     | settable         | EXTI6          | EXTI Line6 interrupt           |
| 40 | 47     | settable         | SPM            | System power manager interrupt |
| 41 | 48     |                  | Reserved       |                                |
| 42 | 49     | settable         | CAN_1          | CAN 1 interrupt                |
| 43 | 50     | settable         | CAN_2          | CAN 2 interrupt                |
| 44 | 51     | settable         | ADC            | ADC interrupt                  |
| 45 | 52     | settable         | ACMP_0         | ACMP 0 interrupt               |
| 46 | 53     | settable         | ACMP_1         | ACMP 1 interrupt               |
| 47 | 54     | settable         | TIMER_2        | TIMER 2 interrupt              |
| 48 | 55     | settable         | TIMER_3        | TIMER 3 interrupt              |
| 49 | 56     | settable         | TIMER_4        | TIMER 4 interrupt              |
| 50 | 57     | settable         | TIMER_5        | TIMER 5 interrupt              |
| 51 | 58     | settable         | TIMER_6        | TIMER 6 interrupt              |
| 52 | 59     | settable         | TIMER_7        | TIMER 7 interrupt              |
| 53 | 60     | settable         | PWM_3          | PWM 3 interrupt                |
| 54 | 61     | settable         | Embedded Flash | Embedded flash interrupt       |

#### 2.3.11 Boot configuration

There are four boot up modes can be selected through below configuration table.

#### Table 2-3 Boot configuration

| PIN Name          | BOOT | UART1_CTS | UART1_RTS |
|-------------------|------|-----------|-----------|
| eflash boot up    | 0    | х         | х         |
| ISP boot          | 1    | 0         | 0         |
| sram boot         | 1    | 1         | 0         |
| serial flash boot | 1    | 0         | 1         |

#### Note:

1. x means do not care. AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 29 of 360

- 2. The control of the boot configuration is bound to the pins and must be PC7(UART1\_RTS) and PD0(UART1\_CTS).
- 3. If the application only needs EFLASH BOOT, UART1\_RTS and UART1\_CTS can be used for other function after controlling BOOT=0, which can ignore the level state.
- 4. ISP download pins are UART2's PD1 (TX) and PD2 (Rx).

The values on the boot up configuration pins are latched on the 8th rising edge of 8MHz clock after a Reset. It is up to the user to set these pins to select the required boot mode, user should keep these pins stable before latched.

Due to its fixed memory map, the code area starts from address 0x0000 0000 (accessed through the ICode/DCode buses). The Cortex-M3 CPU always fetches the reset vector on the ICode bus, which implies to have the boot space available only in the code area (typically, Flash memory). This microcontrollers implement a special mechanism to be able to boot also from SRAM and not only from main Flash memory and ISP Code memory.

Depending on the selected boot mode, main Flash memory, ISP, SRAM and serial flash is accessible as follows:

- Boot from main Flash memory: the main Flash memory is aliased in the boot memory space (0x0000 0000), but still accessible from its original memory space (0x800 0000). In other words, the Flash memory contents can be accessed starting from address 0x0000 0000 or 0x800 0000.
- Boot from ISP: the ISP is aliased in the boot memory space (0x0000 0000), but still accessible from its original memory space (0x08040800).
- Boot from the embedded SRAM: SRAM is aliased in the boot memory space (0x0000 0000), but still accessible from its original memory space 0x2000 0000.
- Boot from the serial flash: serial flash address is aliased in the boot memory space (0x0000 0000), but still accessible from its original memory space 0x6000 0000.

### 2.4 Address Table

**NutoChips** 

| APB Memory Map | Base_Address               | Size |
|----------------|----------------------------|------|
| CKGEN          | 0x40000000                 | 4K   |
| GPIO           | 0x40001000 / 0x20080000    | 4K   |
| Embedded flash | 0x40002000                 | 4K   |
| ADC            | 0x40003000                 | 4K   |
| ACMP           | 0x40005000                 | 4K   |
| LIN_0          | 0x40007000                 | 2K   |
| CAN_1          | 0x40007800                 | 1K   |
| CAN_2          | 0x40007C00                 | 1K   |
| SPM            | 0x40008000                 | 1K   |
| RTC            | 0x40008400                 | 1K   |
| WDT            | <b>0x4000</b> B <b>000</b> | 4K   |
| SPI_0          | 0x4000C000                 | 4K   |
| SPI_1          | 0x4000D000                 | 4K   |
| IIC_0          | 0x4000E000                 | 4K   |

Table 2-4 Address assignment of each peripheral

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 30 of 360

This document contains information that is proprietary to AutoChips Inc. Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.



| APB Memory Map          | Base_Address | Size |
|-------------------------|--------------|------|
| IIC_1                   | 0x4000F000   | 4K   |
| Cortex-M3 controller    | 0x40010000   | 2K   |
| Serial flash controller | 0x40010800   | 2K   |
| TIMER                   | 0x40011000   | 4K   |
| DMA                     | 0x40012000   | 4K   |
| PWM_0                   | 0x40013000   | 4K   |
| PWM _1                  | 0x40014000   | 4K   |
| PWM _2                  | 0x40015000   | 4K   |
| СТИ                     | 0x40016000   | 4K   |
| PWDT                    | 0x40017000   | 4K   |
| UART_1                  | 0x40018000   | 4K   |
| UART_2                  | 0x40019000   | 4K   |
| UART_3                  | 0x4001A000   | 4K   |
| UART_4                  | 0x4001B000   | 4K   |
| UART_5                  | 0x40010000   | 4K   |
| UART_LIN_6              | 0x4001D000   | 4K   |
| PWM_3                   | 0x4001E000   | 4K   |
| CRC                     | 0x20081000   | 4K   |

# **VutoChips**

### 3 Reset

### 3.1 Introduction

There are 8 reset sources to generate IC reset. POR reset:

• POR\_rst: IC power up reset.

System reset:

- ext\_rstin : external reset from IC pad, active low.
- lvd\_rst: low power detection reset, active low.
- sysreset\_req: Cortex-M3 software reset.
- lock\_up: Cortex-M3 lock up reset.
- wdt\_rst: watch dog timer reset, active in normal mode.
- wdt\_rst\_32k: watch dog timer reset, active in stop mode.
- stop\_ack\_error: stop mode acknowledge error reset. In stop mode, if wake up source is busy during 16'h0080 32K clock cycles, then generate acknowledge error to reset whole chip.

Each of the system reset sources has an associated bit in the status register 0x40000010.

### 3.2 Block diagram

The simple block diagram is listed in Figure 3-1. Note: Low-level reset signal trigger the system reset.



#### Figure 3-1 Reset block diagram

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 32 of 360

### 3.3 Reset detail function description

#### 3.3.1 Power On Reset (POR)

When power is initially applied to the MCU or when the supply voltage drops below the power-on reset voltage level (VPOR), the POR circuit causes a POR reset condition. As the supply voltage rises, the LVD circuit holds the MCU in reset until the supply has risen above the LVD low threshold (VLVDL), please refer to the detail POR/LVD control document.

#### 3.3.2 System reset source

Resetting the MCU provides a way to start processing from a known set of initial conditions. System reset begins with the on-chip regulator in full regulation and system clocking generation from an internal reference. When the processor exits reset, it performs the following:

- Read the start SP (SP\_main) from vector-table offset 0.
- Read the start program counter (PC) from vector-table offset 4.
- The Link Register (LR) is set to 0xFFFF\_FFF.

#### 3.3.2.1 External pin reset (ext\_rstin)

There is a dedicated pin in the MCU, it is used to reset the whole MCU function and restart. As it is low active, suggest to add pull up function in external PCB to reject noise.

#### 3.3.2.2 Low voltage detection (lvd\_rst)

This device includes a system to protect against low-voltage conditions in order to protect memory contents and control MCU system states during supply voltage variations. This system consists of a power-on reset (POR) circuit, and a LVD circuit with a user selectable trip voltage, either high (VLVDH) or low (VLVDL).

Please refer to the detail POR/LVD control document.

#### 3.3.2.3 Watch dog timer (wdt\_rst/wdt\_rst\_32k)

The watchdog timer (WDOG) monitors the operation of the system by expecting periodic communication from the software. This communication is generally known as servicing (or refreshing) the watchdog. If this periodic refreshing does not occur, the watchdog issues a system reset. Please refer to watch dog timer section for detail.

#### 3.3.2.4 XOSC monitor

XOSC monitor system can be activated by CKGEN\_SRC\_SEL[16]. In this case, the clock detector is enabled after the HSE oscillator startup delay, and disabled when this oscillator is stopped. If a failure is detected on the HSE oscillator clock, this oscillator is automatically disabled, XOSC loss status flag is active and NMI interrupt is generated to inform the software about the failure allowing the MCU to perform rescue operations.

00000800

#### 3.3.2.5 LOCKUP reset (lock\_up)

**NutoChips** 

The lock\_up gives immediate indication of seriously errant kernel software. This is the result of the core being locked because of an unrecoverable exception following the activation of the processor's built in system state protection hardware.

### 3.4 Register mapping

#### Table 3-1 Reset register map

| Address  | Name         | Width | Register Function  |
|----------|--------------|-------|--------------------|
| 400000C  | RESET_CTL1   | 32    | chip reset control |
| 40000010 | RESET_STATUS | 32    | chip reset status  |

#### 4000000C <u>RESET\_CTL1</u> chip reset control

| Bit   | 31             | 30 | 29 | 28 | 27 | 26 | 25                            | 24    | 23 | 22 | 21 | 20 | 19 | 18      | 17      | 16 |
|-------|----------------|----|----|----|----|----|-------------------------------|-------|----|----|----|----|----|---------|---------|----|
| Name  |                |    |    |    |    |    | cpu_l<br>ockup<br>_rst_e<br>n | vsrst |    |    |    |    | re | eset_pu | Ilse_32 | к  |
| Туре  |                |    |    |    |    |    | RW                            | RW    |    |    |    |    | RW |         |         |    |
| Reset |                |    |    |    |    |    | 0                             | 1     |    |    |    |    | 0  | 0       | 0       | 0  |
| Bit   | 15             | 14 | 13 | 12 | 11 | 10 | 9                             | 8     | 7  | 6  | 5  | 4  | 3  | 2       | 1       | 0  |
| Name  | reset_pulse_8M |    |    |    |    |    |                               |       |    |    |    |    |    |         |         |    |
| Туре  | RW             |    |    |    |    |    |                               |       |    |    |    |    |    |         |         |    |
| Reset | 0              | 0  | 0  | 0  | 1  | 0  | 0                             | 0     |    |    |    |    |    |         |         |    |

| Bit(s) | Name              | Description                                                                                                      |
|--------|-------------------|------------------------------------------------------------------------------------------------------------------|
| 25     | cpu_lockup_rst_en | CPU lock up reset enable                                                                                         |
|        |                   | 1'b1 : can generate reset for IC<br>1'b0 : can not generate reset for IC                                         |
| 24     | cpu_sysrst_en     | CPU system reset enable                                                                                          |
|        |                   | 1'b1 : can generate reset for IC<br>1'b0 : can not generate reset for IC                                         |
| 19:16  | reset_pulse_32K   | Programmable reset pulse with 32KHz clock, include watch dog timer 32KHz reset and stop mode ack error reset.    |
| 15:8   | reset_pulse_8M    | Programmable reset pulse with 8MHz clock, include cpu system reset, cpu lock up reset and watch dog timer reset. |

#### 40000010 RESET\_STATUS chip reset status

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23                                | 22                              | 21                               | 20              | 19                             | 18     | 17 | 16                         |
|-------|----|----|----|----|----|----|----|--------|-----------------------------------|---------------------------------|----------------------------------|-----------------|--------------------------------|--------|----|----------------------------|
| Name  |    |    |    |    |    |    |    |        |                                   |                                 |                                  |                 |                                |        |    | clear_<br>reset_<br>status |
| Туре  |    |    |    |    |    |    |    |        |                                   |                                 |                                  |                 |                                |        |    | RW                         |
| Reset |    |    |    |    |    |    |    |        |                                   |                                 |                                  |                 |                                |        |    | 0                          |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7                                 | 6                               | 5                                | 4               | 3                              | 2      | 1  | 0                          |
| Name  |    |    |    |    |    |    |    | ror rs | CPU_I<br>ockup<br>_rst_s<br>tatus | CPU_<br>sysres<br>et_sta<br>tus | wdt_3<br>2k_res<br>et_sta<br>tus | wul_i<br>eset s | nowdt<br>_reset<br>_statu<br>s | ext_re |    | POR_r<br>eset_s<br>tatus   |
| Туре  |    |    |    |    |    |    | RO | RO     | RO                                | RO                              | RO                               | RO              | RO                             | RO     | RO | RO                         |
| Reset |    |    |    |    |    |    | 0  | 0      | 0                                 | 0                               | 0                                | 0               | 0                              | 0      | 0  | 0                          |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 34 of 360

0000000

| Bit(s) | Name                      | Description                                                           |
|--------|---------------------------|-----------------------------------------------------------------------|
| 16     | clear_reset_status        | clear reset status                                                    |
|        |                           | 1'b1 : clear all reset status<br>1'b0 : allow resest status to update |
| 9      | xosc loss status          | xosc loss status, high active                                         |
| 8      | stop_ack_error_rst_status | stop mode acknowledge error reset status, high active                 |
| 7      | CPU_lockup_rst_status     | CPU lock up reset status, high active                                 |
| 6      | CPU_sysreset_status       | CPU system reset status, high active                                  |
| 5      | wdt_32k_reset_status      | watch dog 32k type reset status, high active                          |
| 4      | wdt_reset_status          | watch dog normal reset status, high active                            |
| 3      | nowdt_reset_status        | Chip power on reset status, high active                               |
| 2      | ext_reset_status          | external pin reset status, high active                                |
| 1      | LVD_reset_status          | LVD reset status, high active                                         |
| 0      | POR_reset_status          | POR reset status, high active                                         |

# **//utoChips**

# 4 Clock

### 4.1 Introduction

The clock control function provides clock source choices for the MCU. The module contains a phaselocked loop (PLL) as a clock source that is controllable by either an internal or an external reference clock. The module can provide this PLL clock or either of the internal or external reference clocks as a source for the MCU system clock.

There are configuration control signals to generate all modules' clock source and frequency.

### 4.2 Clock control diagram

This device contains the following on-chip clock sources:

- High speed internal RC(HSI): the internal RC OSC to provide 8MHz clock source.
- High speed external RC(HSE): the external OSC to provide 4MHZ ~30MHz crystal and oscillator.
- Low speed internal RC(LSI): the internal low speed RC OSC to provide 32kHz clock source.
- Phase-lock loop (SYSPLL): the PLL provides high speed clock up to 96MHz.

Each peripheral has dedicated clock enable signal to control clock on/off, please refer to register control chapter to know the detail address.

Note:

- System clock up to 100MHz (typical usage value is 96MHz)
- HCLK (AHB) up to 100MHz
- PCLK (APB) up to 50MHz. when HCLK is 100MHz, APBCLK\_DIV minimum value is 2



Figure 4-1 Clock control diagram

## 4.3 System Clock



### Figure 4-2 System clock diagram

FIN: Frequency Input, support 4MHz to 30MHz VCO = FIN \* FBKDIV / PREDIV System Clock = VCO / POSDIV / 2 / pll\_clk\_div / sysclk\_div

Note: AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 37 of 360

- 1. The frequency of VCO divided by POSDIV cannot be greater than 400MHz, and the frequency range of VCO is 0.5GHz to 1.5GHz.
- 2. The FBKDIV recommendation is 72, 80, 96, 128, 144, 160, 192
- 3. The external crystal can be 4MHz to 30MHz, and the recommendation input frequency of PLL is less than 8MHz.

#### **Register mapping** 4.4

**//utoChips** 

#### Table 4-1 Clock register map

| Address  | Name                 | Width | Register Function                   |
|----------|----------------------|-------|-------------------------------------|
| 4000000  | CKGEN_SRC_SEL        | 32    | clock source selection              |
| 4000004  | PERI_CLK_EN_0        | 32    | peripheral clock enable control 0   |
| 4000008  | PERI_CLK_EN_1        | 32    | peripheral clock enable control 1   |
| 40000018 | PERI_SFT_RST1        | 32    | peripheral software reset control 1 |
| 4000001C | PERI_SFT_RST2        | 32    | peripheral software reset control 2 |
| 40000020 | PLL_CLK_DIV          | 32    | PLL clock divider                   |
| 40008890 | REG_MCU_SYSPLL1_CFG0 | 32    | SYSPLL1 configuration register 0    |

| 40000000 CKGEN_SRC_SEL |    |             |        |    | clock source selection |     |       |                            |    |       |       |                     | 00000400 |              |    |                             |
|------------------------|----|-------------|--------|----|------------------------|-----|-------|----------------------------|----|-------|-------|---------------------|----------|--------------|----|-----------------------------|
| Bit                    | 31 | 30          | 29     | 28 | 27                     | 26  | 25    | 24                         | 23 | 22    | 21    | 20                  | 19       | 18           | 17 | 16                          |
| Name                   | Cá | an2_clk_div | can1_o |    | can2<br>_clk<br>_sel   |     |       | sflas<br>h_cl<br>k_se<br>I |    |       |       | PII_r<br>ef_s<br>el |          |              |    | xosc_<br>mon<br>_ena<br>ble |
| Type                   |    | RW          | R      | W  | RW                     | RW  |       | RW                         |    |       |       | RW                  |          |              |    | RW                          |
| Reset                  | 0  | 0           | 0      | 0  | 0                      | 0   |       | 0                          |    |       |       | 0                   |          |              |    | 0                           |
| Bit                    | 15 | 14          | 13     | 12 | 11                     | 10  | 9     | 8                          | 7  | 6     | 5     | 4                   | 3        | 2            | 1  | 0                           |
| Name                   |    |             |        |    |                        | apl | oclk_ | div                        |    | syscl | k_div | '                   |          | sh_cl<br>div | •  | clk_s<br>el                 |
| Туре                   |    |             |        |    |                        |     | RW    |                            |    | R     | W     |                     | R        | W            | R  | W                           |
| Reset                  |    |             |        |    |                        | 1   | 0     | 0                          | 0  | 0     | 0     | 0                   | 0        | 0            | 0  | 0                           |

| Bit(s)   | Name            | Description                                                                                                                                     |                |
|----------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 31:30    | can2_clk_div    | CAN2 clock divider by AHB clock (can2_clk <= 50MHz)<br>2'h0 : divider by 1<br>2'h1 : divider by 2<br>2'h2 : divider by 4<br>2'h3 : divider by 8 |                |
| 29:28    | can1_clk_div    | CAN1 clock divider by AHB clock (can1_clk <= 50MHz)<br>2'h0 : divider by 1<br>2'h1 : divider by 2<br>2'h2 : divider by 4<br>2'h3 : divider by 8 |                |
| 27       | can2_clk_sel    | CAN2 clock source select<br>1'h0 : external oscillator clock<br>1'h1 : apb divided clock                                                        |                |
| 26       | can1_clk_sel    | CAN1 clock source select<br>1'h0 : external oscillator clock<br>1'h1 : apb divided clock                                                        |                |
| 24       | sflash_clk_sel  | <b>serial flash clock source select</b><br>1'h0 : pll reference clock<br>1'h1 : apb divided clock                                               |                |
| 20       | Pll_ref_sel     | pll reference clock select                                                                                                                      |                |
| AutoChip | os Confidential | © 2013 - 2021 AutoChips Inc.                                                                                                                    | Page 38 of 360 |

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit(s) | Name            | Description                                                                                                                                                                                                                                                            |
|--------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |                 | 1 : reference clock is external oscillator<br>0 : reference clock is internal oscillator                                                                                                                                                                               |
| 16     | xosc_mon_enable | XOSC monitor enable                                                                                                                                                                                                                                                    |
| 10:8   | apbclk_div      | APB clock divider by system clock<br>3'b0xx : divider by 1<br>3'b100 : divider by 2                                                                                                                                                                                    |
|        |                 | 3'b101 : divider by 4<br>3'b110 : divider by 8<br>3'b111 : divider by 16                                                                                                                                                                                               |
| 7:4    | sysclk_div      | system clock divider<br>4'b0xxx : divider by 1<br>4'b1000 : divider by 2<br>4'b1001 : divider by 4<br>4'b1010 : divider by 8<br>4'b1011 : divider by 16<br>4'b1100 : divider by 64<br>4'b1101 : divider by 128<br>4'b1110 : divider by 256<br>4'b1111 : divider by 512 |
| 3:2    | sflash_clk_div  | serial flash clock divider by APB clock<br>2'h0 : divider by 1<br>2'h1 : divider by 2<br>2'h2 : divider by 4<br>2'h3 : divider by 8                                                                                                                                    |
| 1:0    | sysclk_sel      | system clock source select<br>2'h0 : internal oscillator<br>2'h1 : PLL output<br>2'h2 : external oscillator<br>2'h3 : 1'b0                                                                                                                                             |

| 40000 | 004                    | PERI_CL           | K_EN_0           |                  | peripheral clock enable control 0 |                  |     |    |                          |     |     |     | 0                 | 03400001  |     |                                |  |
|-------|------------------------|-------------------|------------------|------------------|-----------------------------------|------------------|-----|----|--------------------------|-----|-----|-----|-------------------|-----------|-----|--------------------------------|--|
| Bit   | 31                     | 30                | 29               | 28               | 27                                | 26               | 25  | 24 | 23                       | 22  | 21  | 20  | 19                | 18        | 17  | 16                             |  |
| Name  | CLK_C<br>AN2_C<br>ORE  | CLK_CAN1<br>_CORE | CLK_CAN2         | CLK_CAN1         | CLK<br>_LIN                       |                  | _WD |    | CLK<br>_gpi<br>0_a<br>Pb | _DM | _DM |     | CLK<br>_TIM       | _PW<br>M3 | _PW | CLK<br>_PW<br>M1_<br>TIM<br>ER |  |
| Туре  | RW                     | RW                | RW               | RW               | RW                                | RW               | RW  | RW | RW                       | RW  | RW  | RW  | RW                | RW        | RW  | RW                             |  |
| Reset | 0                      | 0                 | 0                | 0                | 0                                 | 0                | 1   | 1  | 1                        | 0   | 0   | 0   | 0                 | 0         | 0   | 0                              |  |
| Bit   | 15                     | 14                | 13               | 12               | 11                                | 10               | 9   | 8  | 7                        | 6   | 5   | 4   | 3                 | 2         | 1   | 0                              |  |
| Name  | CLK_P<br>WM0_TI<br>MER | CLK_PWM3<br>_APB  | CLK_PWM2_A<br>PB | CLK_PWM1_A<br>PB | CLK<br>_PW<br>M0_<br>APB          | CLK<br>_PW<br>DT | -   | -  | -                        | -   | _UA | _UA | CLK<br>_UA<br>RT4 | _UA       | _UA |                                |  |
| Туре  | RW                     | RW                | RW               | RW               | RW                                | RW               | RW  | RW | RW                       | RW  | RW  | RW  | RW                | RW        | RW  | RW                             |  |
| Reset | 0                      | 0                 | 0                | 0                | 0                                 | 0                | 0   | 0  | 0                        | 0   | 0   | 0   | 0                 | 0         | 0   | 1                              |  |

| Bit(s) | Name          | Description                                 |
|--------|---------------|---------------------------------------------|
| 31     |               | CAN2 core clock enable                      |
|        | CLK_CAN2_CORE | 1'b1 : clock enable<br>1'b0 : clock disable |
|        |               | CAN1 core clock enable                      |
| 30     | CLK_CAN1_CORE | 1'b1 : clock enable<br>1'b0 : clock disable |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 39 of 360

| Bit(s) | Name           | Description                                                            |
|--------|----------------|------------------------------------------------------------------------|
| 29     | CLK_CAN2       | CAN2 clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable       |
| 28     | CLK_CAN1       | CAN1 clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable       |
| 27     | CLK_LIN        | LIN clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable        |
| 26     | CLK_CRC        | CRC clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable        |
| 25     | CLK_WDT_APB    | WDG APB clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable    |
| 24     | CLK_GPIO_AHB   | GPIO AHB clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable   |
| 23     | CLK_GPIO_APB   | GPIO APB clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable   |
| 22     | CLK_DMA_AHB    | DMA AHB clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable    |
| 21     | CLK_DMA_APB    | DMA APB clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable    |
| 20     | CLK_RTC        | RTC clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable        |
| 19     | CLK_TIM        | TIMER clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable      |
| 18     | CLK_PWM3_TIMER | PWM3 timer clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable |
| 17     | CLK_PWM2_TIMER | PWM2 timer clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable |
| 16     | CLK_PWM1_TIMER | PWM1 timer clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable |
| 15     | CLK_PWM0_TIMER | PWM0 timer clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable |
| 14     | CLK_PWM3_APB   | PWM3 APB clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable   |
| 13     | CLK_PWM2_APB   | PWM2 APB clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable   |
| 12     | CLK_PWM1_APB   | PWM1 APB clock enable<br>1'b1 : clock enable                           |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit(s) | Name         | Description                                 |
|--------|--------------|---------------------------------------------|
|        |              | 1'b0 : clock disable                        |
|        |              | PWM0 APB clock enable                       |
| 11     | CLK_PWM0_APB | 1'b1 : clock enable                         |
|        |              | 1'b0 : clock disable                        |
|        |              | PWDT clock enable                           |
| 10     | CLK_PWDT     | 1'b1 : clock enable                         |
|        |              | 1'b0 : clock disable                        |
| 0      |              | IIC2 clock enable                           |
| 9      | CLK_I2C2     | 1'b1 : clock enable<br>1'b0 : clock disable |
|        |              |                                             |
| 8      | CLK_I2C1     | IIC1 clock enable                           |
| 0      | ULK_1201     | 1'b1 : clock enable<br>1'b0 : clock disable |
|        |              | SPI2 clock enable                           |
| 7      | CLK_SPI2     | 1'b1 : clock enable                         |
|        |              | 1'b0 : clock disable                        |
|        |              | SPI1 clock enable                           |
| 6      | CLK_SPI1     | 1'b1 : clock enable                         |
|        |              | 1'b0 : clock disable                        |
|        | CLK_UART6    | UART6 clock enable                          |
| 5      |              | 1'b1 : clock enable                         |
|        |              | 1'b0 : clock disable                        |
|        |              | UART5 clock enable                          |
| 4      | CLK_UART5    | 1'b1 : clock enable                         |
|        |              | 1'b0 : clock disable                        |
| 0      |              | UART4 clock enable                          |
| 3      | CLK_UART4    | 1'b1 : clock enable<br>1'b0 : clock disable |
|        |              |                                             |
| 2      | CLK_UART3    | UART3 clock enable<br>1'b1 : clock enable   |
| 2      | OLK_OAKTS    | 1'b0 : clock disable                        |
|        |              | UART2 clock enable                          |
| 1      | CLK_UART2    | 1'b1 : clock enable                         |
|        |              | 1'b0 : clock disable                        |
|        |              | UART1 clock enable                          |
| 0      | CLK_UART1    | 1'b1 : clock enable                         |
|        |              | 1'b0 : clock disable                        |

| 400000 | 80 | PERI_0 | CLK_EN_1 |    | peri | pher | al cl | ock | enabl | e co | ontr | ol 1 |                  | 0   | 000 | 0001                   |
|--------|----|--------|----------|----|------|------|-------|-----|-------|------|------|------|------------------|-----|-----|------------------------|
| Bit    | 31 | 30     | 29       | 28 | 27   | 26   | 25    | 24  | 23    | 22   | 21   | 20   | 19               | 18  | 17  | 16                     |
| Name   |    |        |          |    |      |      |       |     |       |      |      |      |                  |     |     |                        |
| Туре   |    |        |          |    |      |      |       |     |       |      |      |      |                  |     |     |                        |
| Reset  |    |        |          |    |      |      |       |     |       |      |      |      |                  |     |     |                        |
| Bit    | 15 | 14     | 13       | 12 | 11   | 10   | 9     | 8   | 7     | 6    | 5    | 4    | 3                | 2   | 1   | 0                      |
| Name   |    |        |          |    |      |      |       |     |       |      |      |      | CLK<br>_AC<br>MP | CLK | _СТ | CLK<br>_SF<br>LAS<br>H |
| Туре   |    |        |          |    |      |      |       |     |       |      |      |      | RW               | RW  | RW  | RW                     |
| Reset  |    |        |          |    |      |      |       |     |       |      |      |      | 0                | 0   | 0   | 1                      |

| Bit(s) | Name     | Description       |
|--------|----------|-------------------|
| 3      | CLK_ACMP | ACMP clock enable |

AutoChips Confidential

 $\ensuremath{\textcircled{\sc 0}}$  2013 - 2021 AutoChips Inc.

| Bit(s) | Name        | Description                                                                                |
|--------|-------------|--------------------------------------------------------------------------------------------|
|        |             | 1'b1 : clock enable<br>1'b0 : clock disable                                                |
| 2      | CLK_ADC     | ADC core clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable                       |
| 1      | CLK_CTU_APB | CTU APB clock enable<br>1'b1 : clock enable<br>1'b0 : clock disable                        |
| 0      | CLK_SFLASH  | <b>serial flash controller clock enable</b><br>1'b1 : clock enable<br>1'b0 : clock disable |

| 40000018 <u>PERI_SFT_RST1</u> | peripheral software reset control 1 |
|-------------------------------|-------------------------------------|
|-------------------------------|-------------------------------------|

03900001

| Bit   | 31                                | 30                            | 29                            | 28                            | 27                                | 26                    | 25                    | 24                                | 23                                | 22                               | 21                         | 20                         | 19                         | 18                                      | 17                                 | 16                                      |
|-------|-----------------------------------|-------------------------------|-------------------------------|-------------------------------|-----------------------------------|-----------------------|-----------------------|-----------------------------------|-----------------------------------|----------------------------------|----------------------------|----------------------------|----------------------------|-----------------------------------------|------------------------------------|-----------------------------------------|
| Name  | res<br>erv<br>ed                  | reser<br>ved                  | SRS<br>T_C<br>AN2             | SRS<br>T_C<br>AN1             | SR<br>ST_<br>LIN                  | SR<br>ST_<br>CR<br>C  | SR<br>ST_<br>WD<br>G  | SR<br>ST_<br>GPI<br>O_<br>AH<br>B | SR<br>ST_<br>GPI<br>O_<br>AP<br>B | SR<br>ST_<br>DM<br>A_<br>AH<br>B | SR<br>ST_<br>DM<br>A_<br>B | SR<br>ST_<br>RT<br>C       | SR<br>ST_<br>TIM           | SR<br>ST_<br>PW<br>M3<br>_TI<br>ME<br>R | SR<br>ST_<br>PW<br>_TI<br>_ME<br>R | SR<br>ST_<br>PW<br>M1<br>_TI<br>ME<br>R |
| Туре  | RW                                | RW                            | RW                            | RW                            | RW                                | RW                    | RW                    | RW                                | RW                                | RW                               | RW                         | RW                         | RW                         | RW                                      | RW                                 | RW                                      |
| Reset | 0                                 | 0                             | 0                             | 0                             | 0                                 | 0                     | 1                     | 1                                 | 1                                 | 0                                | 0                          | 1                          | 0                          | 0                                       | 0                                  | 0                                       |
| Bit   | 15                                | 14                            | 13                            | 12                            | 11                                | 10                    | 9                     | 8                                 | 7                                 | 6                                | 5                          | 4                          | 3                          | 2                                       | 1                                  | 0                                       |
| Name  | SR<br>ST<br>_P<br>0_T<br>IME<br>R | SRS<br>T_P<br>WM3<br>_AP<br>B | SRS<br>T_P<br>WM2<br>_AP<br>B | SRS<br>T_P<br>WM1<br>_AP<br>B | SR<br>ST_<br>PW<br>M0<br>_A<br>PB | SR<br>ST_<br>PW<br>DT | SR<br>ST_<br>I2C<br>2 | SR<br>ST_<br>I2C<br>1             | SR<br>ST_<br>SPI<br>2             | SR<br>ST_<br>SPI<br>1            | SR<br>ST_<br>UA<br>RT<br>6 | SR<br>ST_<br>UA<br>RT<br>5 | SR<br>ST_<br>UA<br>RT<br>4 | SR<br>ST_<br>UA<br>RT<br>3              | SR<br>ST_<br>UA<br>RT<br>2         | SR<br>ST_<br>UA<br>RT<br>1              |
| Туре  | RW                                | RW                            | RW                            | RW                            | RW                                | RW                    | RW                    | RW                                | RW                                | RW                               | RW                         | RW                         | RW                         | RW                                      | RW                                 | RW                                      |
| Reset | 0                                 | 0                             | 0                             | 0                             | 0                                 | 0                     | 0                     | 0                                 | 0                                 | 0                                | 0                          | 0                          | 0                          | 0                                       | 0                                  | 1                                       |

| Bit(s)  | Name            | Description                                                              |                |
|---------|-----------------|--------------------------------------------------------------------------|----------------|
| 29      | SRST_CAN2       | CAN2 software reset<br>0 : reset active<br>1 : reset inactive            |                |
| 28      | SRST_CAN1       | CAN1 software reset<br>0 : reset active<br>1 : reset inactive            |                |
| 27      | SRST_LIN        | LIN software reset<br>0 : reset active<br>1 : reset inactive             |                |
| 26      | SRST_CRC        | CRC software reset<br>0 : reset active<br>1 : reset inactive             |                |
| 25      | SRST_WDG        | Watch dog timer software reset<br>0 : reset active<br>1 : reset inactive |                |
| 24      | SRST_GPIO_AHB   | GPIO AHB software reset<br>0 : reset active<br>1 : reset inactive        |                |
| 23      | SRST_GPIO_APB   | GPIO APB software reset<br>0 : reset active                              |                |
| AutoChi | ps Confidential | © 2013 - 2021 AutoChips Inc.                                             | Page 42 of 360 |

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

## **NutoChips**

| Bit(s) | Name            | Description                                |                |
|--------|-----------------|--------------------------------------------|----------------|
|        |                 | 1 : reset inactive                         |                |
|        |                 | DMA AHB software reset                     |                |
| 22     | SRST_DMA_AHB    | 0 : reset active<br>1 : reset inactive     |                |
|        |                 | DMA APB software reset                     |                |
| 21     | SRST_DMA_APB    | 0 : reset active                           |                |
|        |                 | 1 : reset inactive                         |                |
|        |                 | RTC software reset                         |                |
| 20     | SRST_RTC        | 0 : reset active                           |                |
|        |                 | 1 : reset inactive TIMER software reset    |                |
| 19     | SRST_TIM        | 0 : reset active                           |                |
|        |                 | 1 : reset inactive                         |                |
|        |                 | PWM3 timer software reset                  |                |
| 18     | SRST_PWM3_TIMER | 0 : reset active                           |                |
|        |                 | 1 : reset inactive                         |                |
| 17     | SRST_PWM2_TIMER | PWM2 timer software reset 0 : reset active |                |
|        |                 | 1 : reset inactive                         |                |
|        |                 | PWM1 timer software reset                  |                |
| 16     | SRST_PWM1_TIMER | 0 : reset active                           |                |
|        |                 | 1 : reset inactive                         |                |
| 15     | SRST_PWM0_TIMER | PWM0 timer software reset 0 : reset active |                |
| 10     |                 | 1 : reset inactive                         |                |
|        |                 | PWM3 APB software reset                    |                |
| 14     | SRST_PWM3_APB   | 0 : reset active                           |                |
|        |                 | 1 : reset inactive                         |                |
| 13     | SRST_PWM2_APB   | PWM2 APB software reset 0 : reset active   |                |
| 10     |                 | 1 : reset inactive                         |                |
|        |                 | PWM1 APB software reset                    |                |
| 12     | SRST_PWM1_APB   | 0 : reset active<br>1 : reset inactive     |                |
|        |                 | PWM0 APB software reset                    |                |
| 11     | SRST PWM0 APB   | 0 : reset active                           |                |
|        |                 | 1 : reset inactive                         |                |
|        |                 | PWDT software reset                        |                |
| 10     | SRST_PWDT       | 0 : reset active<br>1 : reset inactive     |                |
|        |                 | IIC2 software reset                        |                |
| 9      | SRST_I2C2       | 0 : reset active                           |                |
|        |                 | 1 : reset inactive                         |                |
|        |                 | IIC1 software reset                        |                |
| 8      | SRST_I2C1       | 0 : reset active                           |                |
|        |                 | 1 : reset inactive                         |                |
| 7      | SRST_SPI2       | SPI2 software reset<br>0 : reset active    |                |
|        |                 | 1 : reset inactive                         |                |
|        |                 | SPI1 software reset                        |                |
| 6      | SRST_SPI1       | 0 : reset active                           |                |
|        |                 | 1 : reset inactive                         |                |
| 5      | SRST_UART6      | © 2013 - 2021 AutoChing Inc                | Page 13 of 360 |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit(s) | Name       | Description                            |
|--------|------------|----------------------------------------|
|        |            | 0 : reset active<br>1 : reset inactive |
|        |            | UART5 software reset                   |
| 4      | SRST_UART5 | 0 : reset active<br>1 : reset inactive |
|        |            | UART4 software reset                   |
| 3      | SRST_UART4 | 0 : reset active<br>1 : reset inactive |
|        |            | UART3 software reset                   |
| 2      | SRST_UART3 | 0 : reset active                       |
|        |            | 1 : reset inactive                     |
|        |            | UART2 software reset                   |
| 1      | SRST_UART2 | 0 : reset active                       |
|        |            | 1 : reset inactive                     |
|        |            | UART1 software reset                   |
| 0      | SRST_UART1 | 0 : reset active                       |
|        |            | 1 : reset inactive                     |

| 400000 | 01C | PERI | SFT R | <u>ST2</u> | peri | phera | al soft | ware | reset | cont | rol 2 |                             |                           | 0000                 | 00011                |                                |
|--------|-----|------|-------|------------|------|-------|---------|------|-------|------|-------|-----------------------------|---------------------------|----------------------|----------------------|--------------------------------|
| Bit    | 31  | 30   | 29    | 28         | 27   | 26    | 25      | 24   | 23    | 22   | 21    | 20                          | 19                        | 18                   | 17                   | 16                             |
| Name   |     |      |       |            |      |       |         |      |       |      |       |                             |                           |                      |                      |                                |
| Туре   |     |      |       |            |      |       |         |      |       |      |       |                             |                           |                      |                      |                                |
| Reset  |     |      |       |            |      |       |         |      |       |      |       |                             |                           |                      |                      |                                |
| Bit    | 15  | 14   | 13    | 12         | 11   | 10    | 9       | 8    | 7     | 6    | 5     | 4                           | 3                         | 2                    | 1                    | 0                              |
| Name   |     |      |       |            |      |       |         |      |       |      |       | SR<br>ST _A<br>_NA _R<br>EG | SR<br>ST<br>_A<br>CM<br>P | SR<br>ST<br>_A<br>DC | SR<br>ST<br>_C<br>TU | SR<br>ST<br>S<br>FL<br>AS<br>H |
| Туре   |     |      |       |            |      |       |         |      |       |      |       | RW                          | RW                        | RW                   | RW                   | RW                             |
| Reset  |     |      |       |            |      |       |         |      |       |      |       | 1                           | 0                         | 0                    | 0                    | 1                              |

| Bit(s) | Name         | Description                                                     |
|--------|--------------|-----------------------------------------------------------------|
| 4      | SRST_ANA_REG | ANA reg soft reset                                              |
| 3      | SRST_ACMP    | ACMP software reset<br>0 : reset active<br>1 : reset inactive   |
| 2      | SRST_ADC     | ADC software reset<br>0 : reset active<br>1 : reset inactive    |
| 1      | SRST_CTU     | CTU software reset<br>0 : reset active<br>1 : reset inactive    |
| 0      | SRST_SFLASH  | Sflash software reset<br>0 : reset active<br>1 : reset inactive |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

| 400000 | 20 | <u>PLL_</u> | CLK_D | V  | pll cl | k divid | er |    |    |    |    |    |         | 0000 | 0000 |    |
|--------|----|-------------|-------|----|--------|---------|----|----|----|----|----|----|---------|------|------|----|
| Bit    | 31 | 30          | 29    | 28 | 27     | 26      | 25 | 24 | 23 | 22 | 21 | 20 | 19      | 18   | 17   | 16 |
| Name   |    |             |       |    |        |         |    |    |    |    |    |    |         |      |      |    |
| Туре   |    |             |       |    |        |         |    |    |    |    |    |    |         |      |      |    |
| Reset  |    |             |       |    |        |         |    |    |    |    |    |    |         |      |      |    |
| Bit    | 15 | 14          | 13    | 12 | 11     | 10      | 9  | 8  | 7  | 6  | 5  | 4  | 3       | 2    | 1    | 0  |
| Name   |    |             |       |    |        |         |    |    |    |    |    |    | pll_clk | _div |      |    |
| Туре   |    |             |       |    |        |         |    |    |    |    |    |    | RW      |      |      |    |
| Reset  |    |             |       |    |        |         |    |    |    |    |    |    | 0       | 0    | 0    | 0  |

| Bit(s) | Name        | Description               |
|--------|-------------|---------------------------|
| 3:0    | pll_clk_div | divider = pll_clk_div + 1 |

#### 40008890 REG MCU SYSPLL1 CFG0

### SYSPLL1 configuration register 0 003240C0

| Bit   | 31                                                 | 30     | 29  | 28 | 27 | 26   | 25    | 24 | 23  | 22  | 21   | 20   | 19 | 18  | 17 | 16 |
|-------|----------------------------------------------------|--------|-----|----|----|------|-------|----|-----|-----|------|------|----|-----|----|----|
| Name  | RG_MCU_SYSPLL<br>1_PREDIV<br>RG_MCU_SYSPLL1_POSDIV |        |     |    |    |      |       |    | RG_ | MCU | _SYS | PLL1 | FB | DIV |    |    |
| Туре  |                                                    | RW     | R   | W  |    |      |       |    |     |     | R    | W    |    |     |    |    |
| Reset | 0                                                  | 0      | 0   | 0  | 0  | 0    | 0     | 0  | 0   | 0   | 1    | 1    | 0  | 0   | 1  | 0  |
| Bit   | 15                                                 | 14     | 13  | 12 | 11 | 10   | 9     | 8  | 7   | 6   | 5    | 4    | 3  | 2   | 1  | 0  |
| Name  |                                                    | Reserv | ved |    |    | Rese | erved |    |     |     |      |      |    |     |    |    |
| Туре  |                                                    |        |     |    |    |      |       |    |     |     |      |      |    |     |    |    |
| Reset | 0                                                  | 1      | 0   | 0  | 0  | 0    | 0     | 0  | 1   | 1   | 0    |      |    |     |    |    |

| Bit(s) | Name                  | Description                                                                                    |
|--------|-----------------------|------------------------------------------------------------------------------------------------|
| 31:30  | RG_MCU_SYSPLL1_PREDIV | Pre-divider ratio                                                                              |
|        |                       | 2'b00: Fref = Fin/1<br>2'b01: Fref = Fin/2<br>2'b1X: Fref = Fin/4                              |
| 27     | RG_MCU_SYSPLL1_FBKSEL | Feedback clock select (set1'b1, when VCO>750MHz)<br>1'b0: Fvco/1<br>1'b1: Fvco/2               |
| 29:28  | RG_MCU_SYSPLL1_POSDIV | Post-divider ratio for single-end clock output<br>2'b00: VCO/1<br>2'b01: VCO/2<br>2'b1X: VCO/4 |
| 24:17  | RG_MCU_SYSPLL1_FBKDIV | Feedback divide ratio<br>8'd6: /6<br>8'd255: /255                                              |

## 5 Power Modes

**NutoChips** 

### 5.1 Introduction

This chapter describes the chip power modes and functionality of each module in these modes.

### 5.2 Power modes

The device supports Run, Sleep, Stop, and Standby modes which are easy to use for customers both from different power consumption level and functional requirement. I/O states are held in Run, Sleep, Stop modes.

- Run mode CPU clocks can be run at full speed.
- Sleep mode CPU into sleep mode, system clocks and bus clock are running.
- Stop mode CPU into deep sleep mode, some modules can wake up CPU.
- Standby mode CPU and modules are shut down, RTC, WKUP pin can wake up CPU.

## 5.3 Entering and exiting power modes

- 1. Enable the wakeup source required with the **REG\_EN\_PERIPH\_WKUP**.
- 2. Set the power mode with the REG\_SLEEP\_MODE[1:0] before WFI, the configuration as follows:
  - 1) 2'b00: stop mode lite
  - 2) 2'b01: stop mode
  - 3) 2'b1x: standby mode
- 3. Call WFI to enter the power mode.

The processor exits the low-power mode via an interrupt.

### 5.4 Module operation in low-power modes

The following table illustrates the functionality of each module while the chip is in each of the low-power modes. The standard behavior is shown with some exceptions.

| Module | Sleep   | Stop  | Stop lite       | Standby |
|--------|---------|-------|-----------------|---------|
| CM3    | Standby | On    | On              | Off     |
| SRAM   | ON      | Sleep | Sleep           | Off     |
| eflash | ON      | Off   | Off             | Off     |
| I2C    | ON      | On    | On <sup>3</sup> | Off     |
| SPI    | ON      | On    | On <sup>2</sup> | Off     |
| GPIO   | ON      | On    | On <sup>4</sup> | Off     |
| WDT    | ON      | On    | On              | Off     |
| PWDT   | ON      | Off   | On              | Off     |
| UART   | ON      | Off   | On              | Off     |
| DMA    | ON      | Off   | On              | Off     |

### Table 5-1 Module functionality in low-power modes

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 46 of 360

| <b>NutoChips</b> | Л | uto | Ch | ps |
|------------------|---|-----|----|----|
|------------------|---|-----|----|----|

| Module | Sleep                            | Stop                          | Stop lite                        | Standby                          |
|--------|----------------------------------|-------------------------------|----------------------------------|----------------------------------|
| TIM    | ON                               | Off                           | On                               | Off                              |
| PWM    | ON                               | Off                           | On                               | Off                              |
| CRC    | ON                               | Off                           | On                               | Off                              |
| CTU    | ON                               | Off                           | On                               | Off                              |
| CAN    | ON                               | On                            | On <sup>1</sup>                  | Off                              |
| LIN    | ON                               | On                            | On <sup>1</sup>                  | Off                              |
| RTC    | ON                               | On                            | On                               | On                               |
| SPM    | ON                               | On                            | On                               | On                               |
| PLL    | ON                               | Off                           | Off                              | Off                              |
| XOSC   | ON                               | Off                           | Off                              | Off                              |
| LFOSC  | ON                               | Off                           | Off                              | Off                              |
| LPOSC  | ON                               | On                            | On                               | On                               |
| LVD    | Selectable inactive<br>or active | Selectable inactive or active | Selectable inactive<br>or active | Selectable inactive<br>or active |

#### Note:

- 1. Supports wake-up on edge in Stop mode.
- 2. Supports slave mode receive and wake-up in Stop mode.
- 3. Supports address match wake-up in Stop mode.
- 4. Supports pin interrupt wake-up in Stop mode.

## 6 System Power Management

### 6.1 Introduction

**//utoChips** 

SPM (System Power Management) provides the max flexibility for software developers to develop the system housekeeping task. It aims for low level sleep/wake-up task such as MTCMOS power domain, SRAM and analog module power control.

## 6.2 Feature list

• Stop/standby mode whole chip power management.

## 6.3 Block diagram



Figure 6-1 SPM block diagram

# **//utoChips**

## 6.4 Application notes

### 6.4.1 SPM power control program guide

Stop mode and standby mode are supported in AC781x. For stop mode, PD\_MTCMOS power off, but in standby mode, all digital modules are external power off except module SPM.

The WFI instruction invokes stop and standby modes for the chip, and processor exits the low-power mode via an interrupt.

Program sequence:

- 1. Program power timer counter initial value if need.
- 2. Program SPM config registers to determined power mode, wakeup source supported.
- 3. WFI.

Power related config bits:

- **force sleep mode:** when cm3 triggers a WFI instruction, SPM will send a sleep request to all peripherals to check the working state. If all peripherals idle and a sleep ack is replayed in a certain clk cycle (programmable), SPM will continue the sleep sequence. If not, SPM will stop the sleep sequence and send over counter flag to cm3. But when enable force sleep mode, chip will enter sleep state at the end of sleep ack waiting count, even not all peripherals reply sleep ack.
- **fast boot mode:** when enable, chip will wake up immediately when receive a wakeup interrupt during sleeping sequence.
- **en\_adc\_wakeup:** when enable, ADC wakeup supported, Ifosc (8M)/BGR will be always on. But SPM will work in clk 32k frequency.
- **en\_periph\_ack[17:0]**: when disable, SPM will not check corresponding peripheral sleep ack reply before enter sleep sequence.
- **en\_periph\_wakeup\_int[19:0]**: when disable, corresponding peripheral wakeup is not supported, and this int will be ignored.
- **en\_periph\_irq\_trigger**: when enables, SPM triggers spm\_irq to wakeup cm3. For peripheral (e.g. rtc/adc/gpio/..) trigger wakeup irq themselves, just set corresponding bit 0.
- en\_rtc\_32k\_aon: 1'b1 enable rtc 32k clk always on. When disable, rtc 32K gated when chip enter sleep state.

### 6.4.2 XOSC/SYSPLL power control

XOSC/SYSPLL is off at default. When XOSC/SYSPLL is needed, XOSC/SYSPLL can be power on by configuring REG\_PWR\_MGR\_CFG1.

SPM register REG\_PWR\_MGR\_CFG1:

- **REG\_XOSC\_ON**: External high-speed clock enables.
- **REG\_XOSC\_HSEBYP**: External high-speed clock bypass.
- **REG\_SYSPLL\_ON**: SYSPLL enable.

When corresponding bit is set to 1'b1, SPM will power XOSC/PLL on following the power on sequence and it may take a few times. So you should be waiting for XOSC/SYSPLL power on finish and clock ready before use it. XOSC/PLL power on states can be determined by reading SPM register REG\_PWR\_MGR\_CFG1.

- **XOSC\_RDY:** External high-speed clock ready flag.
- SYSPLL\_RDY: PLL clock ready flag.

© 2013 - 2021 AutoChips Inc.

For example, before clk source switches to PLL clk, you should power SYSPLL on first, and wait for SYSPLL clock stable.

When chip wakes up from stop mode, SPM will keep XOSC/SYSPLL on or off same as state before sleep. But when wakeup from standby mode, XOSC/SYSPLL will be off.

## 6.5 Register mapping

**NutoChips** 

#### Table 6-1 SPM Register Map

#### SPM: 0x40008000

| ADDRESS     | TITLE                        | DESCRIPTION                              |
|-------------|------------------------------|------------------------------------------|
| SPM + 0x000 | REG_PWR_MGR_CFG0             | Power Manager Configuration 0 Register   |
| SPM + 0x004 | REG_PWR_MGR_CFG1             | Power Manager Configuration 1 Register   |
| SPM + 0x00C | REG_PERIPH_SLEEP_ACK_STATUS  | Periph Sleep Ack Status                  |
| SPM + 0x010 | REG_EN_PERIPH_SLEEP_ACK_WAIT | Periph Sleep Ack Waiting Enable Register |
| SPM + 0x014 | REG_EN_PERIPH_WKUP           | Periph Wakeup Enable Register            |
| SPM + 0x018 | REG_EN_TRIGGER_SPM_IRQ       | Periph Trigger SPM IRQ Enable Register   |
| SPM + 0x01C | REG_SPM_WAKEUP_IRQ_STATUS    | SPM Wakeup IRQ Flags Status Register     |

### SPM + 0x000 REG\_PWR\_MGR\_CFG0

#### **Power Manager Configuration 0 Register**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21    | 20     | 19     | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|------|-------|--------|--------|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |      |       |        |        |    |    |    |
| Туре  |    |    |    |    |    |    |    |    |    |      |       |        |        |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |      |       |        |        |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6    | 5     | 4      | 3      | 2  | 1  | 0  |
| Name  |    | -  |    |    | -  |    | -  | •  |    | REG_ | PWR_M | GR_CFG | 0[9:0] | •  | •  | -  |
| Туре  |    |    |    |    |    |    | RW |    |    |      |       |        |        |    |    |    |
| Reset |    |    |    |    |    |    | 0  | 1  | 0  | 0    | 0     | 1      | 1      | 0  | 0  | 0  |

| Bit Fie | eld Name                | Description                                                               |
|---------|-------------------------|---------------------------------------------------------------------------|
| 31:10   | reserved                |                                                                           |
|         |                         | sleep mode                                                                |
| 9:8     | REG_SLEEP_MODE          | 2'b00:stop mode lite                                                      |
| 9.0     | REG_SLEEF_MODE          | 2'b01:stop mode                                                           |
|         |                         | 2'b1x:standby mode                                                        |
|         |                         | enable IO suspend in stop mode/stop lite mode                             |
| 7       | REG_EN_IO_SUS_STOP_MODE | 1'b1:I/O suspend when enter stop mode/stop lite mode                      |
|         |                         | This ctrl bits does not affect in standby mode, hardware auto suspend io. |
| · · · · |                         | enable can1 wakeup int filter                                             |
| 6       | REG_EN_CAN1_FILTER      | 1'b1:enable                                                               |
|         |                         | when enable SPM will use int after analog filter as can2 wakeup int.      |
| ·       |                         | enable can0 wakeup int filter                                             |
| 5       | REG_EN_CAN0_FILTER      | 1'b1:enable                                                               |
|         |                         | when enable SPM will use int after analog filter as can1 wakeup int.      |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.



| 4 | REG_EN_PWRLVD    | chip lower voltage detect control bit<br>1'b1:enable<br>AD_MCU_PORLPVD_PWRLVD_RST=0 @ DA_MCU_PORLPVD_PWRLVD_PD=0,<br>AVDD50 <vlvd< th=""></vlvd<>                      |
|---|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 | Reserved         |                                                                                                                                                                        |
| 2 | REG_EN_PWRWARN   | chip lower voltage warning control bit<br>1'b1:enable<br>AD_MCU_PORLPVD_PWR_WARNING=1 @DA_MCU_PORLPVD_PWRWARN_PD=0,<br>AVDD50 <vpvd< td=""></vpvd<>                    |
| 1 | REG_EN_FAST_BOOT | enable fast boot mode<br>1'b1:enable<br>fast boot mode: to save wakeup time, chip will stop sleep sequence and wake up<br>immediately when receive a wakeup interrupt. |
| 0 | REG_PWR_EN       | SPM power control enable<br>1'b1: enable. enable SPM power control.                                                                                                    |

| SPM + 0x004 | REG_PWR_MGR_CFG1 |
|-------------|------------------|
|             |                  |

Power Manager Configuration 1 Register

| Bit   | 31 | 30 | 29  | 28  | 27  | 26 | 25 | 24 | 23  | 22 | 21   | 20    | 19     | 18      | 17 | 16 |
|-------|----|----|-----|-----|-----|----|----|----|-----|----|------|-------|--------|---------|----|----|
| Name  |    |    |     |     |     |    |    |    |     |    |      |       |        |         |    |    |
| Туре  | R  | R  | R/W | R/W | R/W |    |    |    |     |    |      |       |        |         |    |    |
| Reset | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0   | 0  | 0    | 0     | 0      | 0       | 0  | 0  |
| Bit   | 15 | 14 | 13  | 12  | 11  | 10 | 9  | 8  | 7   | 6  | 5    | 4     | 3      | 2       | 1  | 0  |
| Name  |    |    |     |     |     |    |    |    |     |    | REG_ | PWR_M | GR_CFG | 61[7:0] | -  |    |
| Туре  |    |    |     |     |     |    |    |    | R/W |    |      |       |        |         |    |    |
| Reset | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0   | 0  | 0    | 0     | 0      | 0       | 0  | 0  |

| Bit<br>Field | Name                                                                                                        | Description                                           |  |
|--------------|-------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--|
| 31           | Name       XOSC_RDY       SYSPLL_RDY       REG_XOSC_HSEON       REG_XOSC_HSEBYP       REG_SYSPLL_ON       7 | XOSC clock ready flag                                 |  |
| 51           | X030_KD1                                                                                                    | 1:ready                                               |  |
| 30           |                                                                                                             | PLL clock ready flag                                  |  |
| 30           | STSPEL_RDT                                                                                                  | 1:ready                                               |  |
| 29           |                                                                                                             | External high-speed clock enable                      |  |
| 29           | REG_XOSC_HSEON                                                                                              | 1'b1: enable XOSC                                     |  |
| 28           |                                                                                                             | External high-speed clock bypass                      |  |
| 20           | REG_AOSC_HSEBTF                                                                                             | 1'b1: bypassing the oscillator with an external clock |  |
| 27           | REC SYSPLE ON                                                                                               | SYSPLL enable                                         |  |
| 21           | REG_STSFEL_ON                                                                                               | 1'b1:SPM power SYSPLL on                              |  |
| 26:7         | reserved                                                                                                    |                                                       |  |
| 6:4          | reserved                                                                                                    |                                                       |  |



|     |         | PVDLVD setting                        |
|-----|---------|---------------------------------------|
|     |         | 4'b0000: VLVDL = 2.65V VPVDL_0 = 2.7V |
|     |         | 4'b0x01: VLVDL = 2.65V VPVDL_0 = 2.8V |
|     |         | 4'b0x10: VLVDL = 2.65V VPVDL_0 = 2.9V |
| 3:0 | PORLPVD | 4'b0x11: VLVDL = 2.65V VPVDL_0 = 3.0V |
|     |         | 4'b1x00: VLVDL = 4.3V VPVDL_0 = 4.4V  |
|     |         | 4'b1x01: VLVDL = 4.3V VPVDL_0 = 4.5V  |
|     |         | 4'b1x10: VLVDL = 4.3V VPVDL_0 = 4.6V  |
|     |         | 4'b1x11: VLVDL = 4.3V VPVDL_0 = 4.7V  |
|     |         |                                       |

| SPM + | 0x0c |       | REG_F | PERIPH | RIPH_SLEEP_ACK_STATUS Periph Sleep Ack Status Registe |       |       |      |      |     |      |      | egister |        |       |       |
|-------|------|-------|-------|--------|-------------------------------------------------------|-------|-------|------|------|-----|------|------|---------|--------|-------|-------|
| Bit   | 31   | 30    | 29    | 28     | 27                                                    | 26    | 25    | 24   | 23   | 22  | 21   | 20   | 19      | 18     | 17    | 16    |
| Name  |      |       |       |        |                                                       |       |       |      |      |     |      |      |         | eflash | gpio  | adc   |
| Туре  |      |       |       |        |                                                       |       |       |      |      |     |      |      |         | R      | R     | R     |
| Reset |      |       |       |        |                                                       |       |       |      |      |     |      |      |         | 0      | 0     | 0     |
| Bit   | 15   | 14    | 13    | 12     | 11                                                    | 10    | 9     | 8    | 7    | 6   | 5    | 4    | 3       | 2      | 1     | 0     |
| Name  | dma  | uart6 | uart5 | uart4  | uart3                                                 | uart2 | uart1 | can1 | can0 | lin | spi2 | spi1 | iic2    | iic1   | acmp1 | acmp0 |
| Туре  | R    | R     | R     | R      | R                                                     | R     | R     | R    | R    | R   | R    | R    | R       | R      | R     | R     |
| Reset | 0    | 0     | 0     | 0      | 0                                                     | 0     | 0     | 0    | 0    | 0   | 0    | 0    | 0       | 0      | 0     | 0     |

| Bit   | News     | Beendation .            |  |
|-------|----------|-------------------------|--|
| Field | Name     | Description             |  |
| 31:19 | reserved |                         |  |
| 18    | eflash   | eflash idle status      |  |
| 10    | enasn    | 1:eflash idle           |  |
| 17    | gpio     | gpio sleep ack status.  |  |
| 17    | gpio     | 1'b1:ack                |  |
| 16    | adc      | adc sleep ack status.   |  |
| 10    | auc      | 1'b1:ack                |  |
| 15    | dma      | dma sleep ack status.   |  |
| 15    | unia     | 1'b1:ack                |  |
| 14    | uart6    | uart6 sleep ack status. |  |
| 14    | uarto    | 1'b1:ack                |  |
| 13    | uart5    | uart5 sleep ack status. |  |
| 15    | uano     | 1'b1:ack                |  |
| 12    | uart4    | uart4 sleep ack status. |  |
| 12    | uant     | 1'b1:ack                |  |
| 11    | uart3    | uart3 sleep ack status. |  |
|       | uano     | 1'b1:ack                |  |
| 10    | uart2    | uart2 sleep ack status. |  |
| 10    | ualtz    | 1'b1:ack                |  |
| 9     | uart1    | uart1 sleep ack status. |  |
| 5     | uarri    | 1'b1:ack                |  |
| 8     | can1     | can1 sleep ack status.  |  |
| 0     | Calli    | 1'b1:ack                |  |
| 7     | can0     | can0 sleep ack status.  |  |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

|   |       | 1'b1:ack                |  |
|---|-------|-------------------------|--|
| 6 | lin   | lin sleep ack status.   |  |
| 0 | 1111  | 1'b1:ack                |  |
| 5 | spi2  | spi2 sleep ack status.  |  |
| 5 | spiz  | 1'b1:ack                |  |
| 4 | spi1  | spi1 sleep ack status.  |  |
| 4 | 3011  | 1'b1:ack                |  |
| 3 | iic2  | iic2 sleep ack status.  |  |
| 5 | 1162  | 1'b1:ack                |  |
| 2 | iic1  | iic1 sleep ack status.  |  |
| Z | IIC I | 1'b1:ack                |  |
| 1 | acmp1 | acmp1 sleep ack status. |  |
| I | acmp1 | 1'b1:ack                |  |
| 0 | 20000 | acmp0 sleep ack status. |  |
| 0 | acmp0 | 1'b1:ack                |  |

| SPM + | 0x010 | 0 REG_EN_PERIPH_SLEEP_ACK Periph Sleep Ack Waiting Enable Register |       |       |       |       |       |      |      |     |      |      |      |      |       |       |
|-------|-------|--------------------------------------------------------------------|-------|-------|-------|-------|-------|------|------|-----|------|------|------|------|-------|-------|
| Bit   | 31    | 30                                                                 | 29    | 28    | 27    | 26    | 25    | 24   | 23   | 22  | 21   | 20   | 19   | 18   | 17    | 16    |
| Name  |       |                                                                    |       |       |       |       |       |      |      |     |      |      |      |      | gpio  | adc   |
| Туре  |       |                                                                    |       |       |       |       |       |      |      |     |      |      |      |      | R/W   | R/W   |
| Reset |       |                                                                    |       |       |       |       |       |      |      |     |      |      |      |      | 1     | 1     |
| Bit   | 15    | 14                                                                 | 13    | 12    | 11    | 10    | 9     | 8    | 7    | 6   | 5    | 4    | 3    | 2    | 1     | 0     |
| Name  | dma   | uart6                                                              | uart5 | uart4 | uart3 | uart2 | uart1 | can1 | can0 | lin | spi2 | spi1 | iic2 | iic1 | acmp1 | acmp0 |
| Туре  | R/W   | R/W                                                                | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | R/W | R/W  | R/W  | R/W  | R/W  | R/W   | R/W   |
| Reset | 1     | 1                                                                  | 1     | 1     | 1     | 1     | 1     | 1    | 1    | 1   | 1    | 1    | 1    | 1    | 1     | 1     |

| Bit<br>Field | Name     | Description                                                                       |
|--------------|----------|-----------------------------------------------------------------------------------|
| 31:18        | reserved |                                                                                   |
|              |          | enable gpio sleep ack waiting.                                                    |
| 17           | gpio     | 1'b1: enable. SPM wait for gpio sleep ack before enter sleep sequence.            |
|              |          | when disable SPM will not check gpio sleep ack reply before enter sleep sequence. |
| 16           | adc      | enable adc sleep ack waiting.                                                     |
| 10           | auc      | 1'b1:enable.                                                                      |
| 15           | dma      | enable dma sleep ack waiting.                                                     |
| 15           | una      | 1'b1:enable.                                                                      |
| 14           | uart6    | enable uart6 sleep ack waiting.                                                   |
| 14           | uano     | 1'b1:enable.                                                                      |
| 13           | uart5    | enable uart5 sleep ack waiting.                                                   |
| 13           | Cana     | 1'b1:enable.                                                                      |
| 12           | uort 1   | enable uart4 sleep ack waiting.                                                   |
| 12           | uart4    | 1'b1:enable.                                                                      |
| 11           | uart3    | enable uart3 sleep ack waiting.                                                   |
| 11           | uano     | 1'b1:enable.                                                                      |
| 10           | uort?    | enable uart2 sleep ack waiting.                                                   |
| 10           | uart2    | 1'b1:enable.                                                                      |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

## **NutoChips**

| 9 | uart1     | enable uart1 sleep ack waiting. |  |
|---|-----------|---------------------------------|--|
| 9 | uarri     | 1'b1:enable.                    |  |
| 8 | can1      | enable can1 sleep ack waiting.  |  |
| 0 | Call      | 1'b1:enable.                    |  |
| 7 | 2220      | enable can0 sleep ack waiting.  |  |
| 7 | can0      | 1'b1:enable.                    |  |
|   | 1:        | enable lin sleep ack waiting.   |  |
| 6 | lin       | 1'b1:enable.                    |  |
|   |           | enable spi2 sleep ack waiting.  |  |
| 5 | spi2      | 1'b1:enable.                    |  |
| 4 | an'i      | enable spi1 sleep ack waiting.  |  |
| 4 | spi1      | 1'b1:enable.                    |  |
|   | <b></b> 0 | enable iic2 sleep ack waiting.  |  |
| 3 | iic2      | 1'b1:enable.                    |  |
|   |           | enable iic1 sleep ack waiting.  |  |
| 2 | iic1      | 1'b1:enable.                    |  |
|   | oomo1     | enable acmp1 sleep ack waiting. |  |
| Т | acmp1     | 1'b1:enable.                    |  |
| 0 |           | enable acmp0 sleep ack waiting. |  |
| 0 | acmp0     | 1'b1:enable.                    |  |
|   |           |                                 |  |

SPM + 0x014

### **REG\_EN\_PERIPH\_WAKEUP**

#### Periph Wakeup Enable Register

| Bit   | 31  | 30    | 29    | 28    | 27    | 26    | 25    | 24   | 23   | 22  | 21   | 20   | 19              | 18   | 17    | 16    |
|-------|-----|-------|-------|-------|-------|-------|-------|------|------|-----|------|------|-----------------|------|-------|-------|
| Name  |     |       |       |       |       |       |       |      |      |     |      |      | lvd_war<br>ning | nmi  | gpio  | adc   |
| Туре  |     |       |       |       |       |       |       |      |      |     |      |      | R/W             | R/W  | R/W   | R/W   |
| Reset |     |       |       |       |       |       |       |      |      |     |      |      | 0               | 0    | 1     | 0     |
| Bit   | 15  | 14    | 13    | 12    | 11    | 10    | 9     | 8    | 7    | 6   | 5    | 4    | 3               | 2    | 1     | 0     |
| Name  | rtc | uart6 | uart5 | uart4 | uart3 | uart2 | uart1 | can1 | can0 | lin | spi2 | spi1 | iic2            | iic1 | acmp1 | acmp0 |
| Туре  | R/W | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | R/W | R/W  | R/W  | R/W             | R/W  | R/W   | R/W   |
| Reset | 1   | 0     | 0     | 0     | 0     | 0     | 0     | 0    | 0    | 0   | 0    | 0    | 0               | 0    | 0     | 0     |

| Bit<br>Field | Name        | Description                                                                             |
|--------------|-------------|-----------------------------------------------------------------------------------------|
| 31:20        | reserved    |                                                                                         |
|              |             | enable lvd warning wakeup                                                               |
| 19           | lvd warning | 1'b1: enable.                                                                           |
|              |             | When disable, Ivd warning wakeup is not supported, and this wakeup int will be ignored. |
| 18           | nmi         | enable nmi wakeup                                                                       |
| 10           | 11111       | 1'b1:enable                                                                             |
| 17           | anio        | enable gpio wakeup.                                                                     |
| 17           | gpio        | 1'b1:enable.                                                                            |
| 16           | adc         | enable adc wakeup.                                                                      |
| 10           | auc         | 1'b1:enable.                                                                            |
| 15           | rtc         | enable rtc wakeup.                                                                      |
| 15           | 110         | 1'b1:enable.                                                                            |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 54 of 360

| 14 | uart6   | enable uart6 wakeup. |
|----|---------|----------------------|
| 14 | uarto   | 1'b1:enable.         |
| 13 | uart5   | enable uart5 wakeup. |
| 15 | uarto   | 1'b1:enable.         |
| 12 | uart4   | enable uart4 wakeup. |
| 12 | udil4   | 1'b1:enable.         |
| 11 | uart3   | enable uart3 wakeup. |
| 11 | uarto   | 1'b1:enable.         |
| 10 | uart2   | enable uart2 wakeup. |
| 10 | uartz   | 1'b1:enable.         |
| 9  | uart1   | enable uart1 wakeup. |
| 9  | ualli   | 1'b1:enable.         |
| 8  | can1    | enable can1 wakeup.  |
| 0  | Call    | 1'b1:enable.         |
| 7  | can0    | enable can0 wakeup.  |
| ,  | Carlo   | 1'b1:enable.         |
| 6  | lin     | enable lin wakeup.   |
| 0  | 1111    | 1'b1:enable.         |
| 5  | spi2    | enable spi2 wakeup.  |
| 5  | Spiz    | 1'b1:enable.         |
| 4  | spi1    | enable spi1 wakeup.  |
| 4  | Spir    | 1'b1:enable.         |
| 3  | iic2    | enable iic2 wakeup.  |
| 5  | 1162    | 1'b1:enable.         |
| 2  | iic1    | enable iic1 wakeup.  |
| 2  |         | 1'b1:enable.         |
| 1  | acmp1   | enable acmp1 wakeup. |
| ·  | acitip  | 1'b1:enable.         |
| 0  | acmp0   | enable acmp0 wakeup. |
| 0  | acilipo | 1'b1:enable.         |
|    |         |                      |

| SPM + | 0x018 |       | REG_EN_TRIGGER_IRQ         Periph Trigger SPM IRQ Enable Register |       |       |       |       |      |      |     |      |               |                 |      |       |       |
|-------|-------|-------|-------------------------------------------------------------------|-------|-------|-------|-------|------|------|-----|------|---------------|-----------------|------|-------|-------|
| Bit   | 31    | 30    | 29                                                                | 28    | 27    | 26    | 25    | 24   | 23   | 22  | 21   | 20            | 19              | 18   | 17    | 16    |
| Name  |       |       |                                                                   |       |       |       |       |      |      |     |      | over<br>count | porlpvd<br>warn | nmi  | gpio  | adc   |
| Туре  |       |       |                                                                   |       |       |       |       |      |      |     |      | R/W           | R/W             | R/W  | R/W   | R/W   |
| Reset |       |       |                                                                   |       |       |       |       |      |      |     |      | 1             | 0               | 1    | 0     | 0     |
| Bit   | 15    | 14    | 13                                                                | 12    | 11    | 10    | 9     | 8    | 7    | 6   | 5    | 4             | 3               | 2    | 1     | 0     |
| Name  | rtc   | uart6 | uart5                                                             | uart4 | uart3 | uart2 | uart1 | can1 | can0 | lin | spi2 | spi1          | iic2            | iic1 | acmp1 | acmp0 |
| Туре  | R/W   | R/W   | R/W                                                               | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | R/W | R/W  | R/W           | R/W             | R/W  | R/W   | R/W   |
| Reset | 0     | 1     | 1                                                                 | 1     | 1     | 1     | 1     | 1    | 1    | 1   | 1    | 1             | 1               | 1    | 0     | 0     |

| Bit<br>Field | Name     | Description |
|--------------|----------|-------------|
| 31:22        | reserved |             |
|              |          |             |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

| Bit<br>Field | Name            | Description                                                                               |
|--------------|-----------------|-------------------------------------------------------------------------------------------|
|              |                 | enable SPM over count irq                                                                 |
|              |                 | 1'b1: enable.                                                                             |
|              |                 | (1).counter overflow: before enter sleep state, SPM waiting for all periph reply sleep    |
| 20           | SPM over count  | ack in certain cycle. If not, timer counter overflow.                                     |
|              |                 | (2).when enables SPM over count & counter overflow, trigger spm_irq to wakeup cm3.        |
|              |                 | (3).for periph (e.g. rtc/adc/gpio/) trigger wakeup irq themselves, just set corresponding |
|              |                 | bit 0.                                                                                    |
| 19           | porlpvd warning | enable porlpvd warning irq                                                                |
|              |                 | 1'b1: enable.                                                                             |
| 18           | nmi             | enable nmi irq                                                                            |
| ,            |                 | 1'b1:enable                                                                               |
| 17           | gpio            | enable gpio irq.                                                                          |
|              |                 | 1'b1:enable.                                                                              |
| 16           | adc             | enable adc irq.                                                                           |
|              |                 | 1'b1:enable.                                                                              |
| 15           | rtc             | enable rtc irq.                                                                           |
|              |                 | 1'b1:enable.                                                                              |
| 14           | uart6           | enable uart6 irq.                                                                         |
|              |                 | 1'b1:enable.                                                                              |
| 13           | uart5           | enable uart5 irq.                                                                         |
| ,            |                 | 1'b1:enable.                                                                              |
| 12           | uart4           | enable uart4 irq.                                                                         |
|              |                 | 1'b1:enable.                                                                              |
| 11           | uart3           | enable uart3 irq.                                                                         |
|              |                 | 1'b1:enable.                                                                              |
| 10           | uart2           | enable uart2 irq.                                                                         |
| ,            |                 | 1'b1:enable.                                                                              |
| 9            | uart1           | enable uart1 irq.                                                                         |
|              |                 | 1'b1:enable.                                                                              |
| 8            | can1            | enable can1 irq.                                                                          |
|              |                 | 1'b1:enable.                                                                              |
| 7            | can0            | enable can0 irq.                                                                          |
|              |                 | 1'b1:enable.                                                                              |
| 6            | lin             | enable lin irq.                                                                           |
|              |                 | 1'b1:enable.                                                                              |
| 5            | spi2            | enable spi2 irq.                                                                          |
|              |                 | 1'b1:enable.                                                                              |
| 4            | spi1            | enable spi1 irq.                                                                          |
| •            | opii            | 1'b1:enable.                                                                              |
| 3            | iic2            | enable iic2 irq.                                                                          |
|              |                 | 1'b1:enable.                                                                              |
| 2            | iic1            | enable iic1 irq.                                                                          |
| <u> </u>     |                 | 1'b1:enable.                                                                              |
| 1            | acmp1           | enable acmp1 irq.                                                                         |
| I            | aompi           | 1'b1:enable.                                                                              |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

| Bit<br>Field | Name  | Description                       |
|--------------|-------|-----------------------------------|
| 0            | acmp0 | enable acmp0 irq.<br>1'b1:enable. |

| SPM + | 0x01c |       | REG_S | EG_SPM_WAKEUP_IRQ_STATUS SPM Wakeup IRQ Flags Register |       |       |       |      |      |     |      |               |                 |      |       |       |
|-------|-------|-------|-------|--------------------------------------------------------|-------|-------|-------|------|------|-----|------|---------------|-----------------|------|-------|-------|
| Bit   | 31    | 30    | 29    | 28                                                     | 27    | 26    | 25    | 24   | 23   | 22  | 21   | 20            | 19              | 18   | 17    | 16    |
| Name  |       |       |       |                                                        |       |       |       |      |      |     |      | over<br>count | porlpvd<br>warn | nmi  | gpio  | adc   |
| Туре  |       |       |       |                                                        |       |       |       |      |      |     |      | R             | R               | R    | R     | R     |
| Reset |       |       |       |                                                        |       |       |       |      |      |     |      | 0             | 0               | 0    | 0     | 0     |
| Bit   | 15    | 14    | 13    | 12                                                     | 11    | 10    | 9     | 8    | 7    | 6   | 5    | 4             | 3               | 2    | 1     | 0     |
| Name  | rtc   | uart6 | uart5 | uart4                                                  | uart3 | uart2 | uart1 | can1 | can0 | lin | spi2 | spi1          | iic2            | iic1 | acmp1 | acmp0 |
| Туре  | R     | R     | R     | R                                                      | R     | R     | R     | R    | R    | R   | R    | R             | R               | R    | R     | R     |
| Reset | 0     | 0     | 0     | 0                                                      | 0     | 0     | 0     | 0    | 0    | 0   | 0    | 0             | 0               | 0    | 0     | 0     |

| Bit   |                 |                                                                                       |
|-------|-----------------|---------------------------------------------------------------------------------------|
| Field | Name            | Description                                                                           |
| 31:21 | reserved        |                                                                                       |
|       |                 | SPM over count irq flag                                                               |
|       |                 | 1'b1: SPM counter trigger this spm_irq                                                |
| 20    | spm over count  | (1). when spm_irq trigger and cm3 be wakeup, cm3 will read this register to determine |
|       |                 | which periph trigger this wakeup.                                                     |
|       |                 | (2). cm3 should write corresponding bit 1 back to clear spm_irq.                      |
| 19    | porlpvd warning | porlpvd warning irq flag                                                              |
| 18    | nmi             | nmi irq flag                                                                          |
| 17    | gpio            | gpio irq flag.                                                                        |
| 16    | adc             | adc irq flag.                                                                         |
| 15    | rtc             | rtc irq flag.                                                                         |
| 14    | uart6           | uart6 irq flag.                                                                       |
| 13    | uart5           | uart5 irq flag.                                                                       |
| 12    | uart4           | uart4 irq flag.                                                                       |
| 11    | uart3           | uart3 irq flag.                                                                       |
| 10    | uart2           | uart2 irq flag.                                                                       |
| 9     | uart1           | uart1 irq flag.                                                                       |
| 8     | can1            | can1 irq flag.                                                                        |
| 7     | can0            | can0 irq flag.                                                                        |
| 6     | lin             | lin irq flag.                                                                         |
| 5     | spi2            | spi2 irq flag.                                                                        |
| 4     | spi1            | spi1 irq flag.                                                                        |
| 3     | iic2            | iic2 irq flag.                                                                        |
| 2     | iic1            | iic1 irq flag.                                                                        |
| 1     | acmp1           | acmp1 irq flag.                                                                       |
| 0     | acmp0           | acmp0 irq flag.                                                                       |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

### AC781x Reference Manual General

## 7 CAN

## 7.1 Introduction

**NutoChips** 

### 7.1.1 The CAN-CTRL core

The CAN-CTRL core is a serial communications controller that performs serial communication according to the CAN protocol. This CAN bus interface uses the basic CAN principle and meets all constraints of the CAN-specification 2.0B active.

The CAN protocol uses a multi-master bus configuration for the transfer of frames (communication objects) between nodes of the network and manages the error handling without any burden on the CPU. The CAN-CTRL bus controller enables the user to set up economic and reliable links between various components. The CAN-CTRL core appears to a microcontroller as a memory-mapped I/O device. A CPU accesses the CAN-CTRL core to control transmission or reception of frames through a two wire CAN bus system. The connection to a CAN bus is illustrated in Figure 7-1.





### 7.1.2 The CAN protocol

CAN communication is organized in frames. Two types of frames exist: standard and extended frames. For CAN 2.0, the maximum data payload is up to 8 bytes can be transmitted using one frame. All CAN nodes are equal in terms of bus access. There is no super-node because the CAN is a multi-

All CAN nodes are equal in terms of bus access. There is no super-node because the CAN is a multimaster bus.

Data addressing is done using message identifiers. In a CAN network, only one node shall transmit messages with a certain identifier. All nodes receive all messages and the node host controller has to decide if it was addressed by the appropriate message identifier. To reduce the load of a host controller, a CAN core may use acceptance filters. These filters compare all received message identifiers to user-selectable bit patterns. Only if a message passes an acceptance filter, it will be stored in the receive buffer and signaled to the host controller.

The identifiers of CAN frames are also used for bus arbitration. The CAN protocol machine stops transmission of a message with a low-priority identifier when a message with a higher priority identifier

is transmitted by another CAN node. The CAN protocol machine automatically attempts to re-transmit the stopped message at the next possible transmit position. CAN 2.0B defines data bit rates up to 1 Mbit/s.

## 7.2 Feature list

- Support CAN specification: CAN 2.0A/B (up to 8 bytes payload, verified by Bosch reference model).
- Free programmable data rate: CAN 2.0B defines data rates up to 1Mbit/s.
- Programmable baud rate prescaler (1 to 1/256).
- Nine receive buffers with FIFO-like behavior.
- Two transmit buffers:
  - One Primary Transmit Buffer (PTB);
  - Five Secondary Transmit Buffer (STB), operation in FIFO or priority decision mode.
  - 16 Independent and programmable internal 29 bits acceptance filters.
- Extended features:
  - $\circ$  Single Shot Transmission Mode (for PTB and / or for STB).
  - Listen Only Mode.
  - Loop Back Mode (internal and external).
  - Transceiver Standby Mode.
- Extended status and error report:
  - Capturing of last occurred kind of error and of arbitration lost position.
  - Programmable Error Warning Limit.
- Configurable interrupt sources.
- Time-stamping
  - ISO 11898-4 Time-Triggered CAN with partial hardware support.
- Programmable wake-up functionality with integrated low-pass filter.

## 7.3 Message buffers

### 7.3.1 Message buffers concept

The concept of the message buffers is illustrated. This schematic focuses on the buffers and hides other details of the CAN-CTRL core. All buffer slots are big enough to store frames with the maximum length.

# **//utoChips**



Figure 7-2 Message buffers concept

### 7.3.2 Receive buffer

To reduce the load of received frames for the host controller, the core uses acceptance filters. The CAN-CTRL core checks the message identifier during acceptance filtering. If the received frame matches the filter criteria of one of the acceptance filters, then it will be stored in the Receive Buffer (RB), which has FIFO-like behavior.

Depending on the number of available message slots, the host controller does not need to read incoming messages immediately. The CAN-CTRL core is able to generate interrupts upon every received message, when the RB is full or filled to a user-selectable "almost full" limit. Because of the FIFO-like behavior, the host controller always reads the oldest message from the RB.

### 7.3.3 Transmit buffer

For frame transmission purposes, two Transmit Buffers (TB) are offered. The Primary TB (PTB) has a higher priority, but is able to buffer only one frame. The Secondary TB (STB) has a lower priority. It can act in FIFO or in priority mode. The priority decision between PTB and STB is fixed and fully independent from the CAN bus arbitration. Bus arbitration is a priority decision based on the frame identifiers.

The STB can be commanded to transmit one or all stored frames. In FIFO mode with every transmission, the oldest frame inside this buffer is transmitted first. In priority mode, the frame with the highest priority inside this buffer (based on the frame identifier) is transmitted first.

A frame located in the PTB has always a higher priority for the CAN protocol machine than the frames in the STB regardless of the frame identifiers. A PTB transmission stops and delays an STB transmission. The STB transmission is automatically restarted after the PTB frame has been successfully transmitted.

A PTB transmission starts at the next transmit position that is possible by the CAN protocol (after the next interframe space). Because of this, a STB transmission that has won the arbitration and is actually transmitted, will be completed before.

Interrupting STB transmissions using a PTB transmission may happen in the following cases:

1. The STB is commanded to output all stored frames and the host controller decides to command a PTB transmission before all STB transmissions are completed.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

2. The STB is commanded to output a single frame and the host controller decides to command a PTB transmission before the STB transmission is completed.

If the host controller waits until each commanded transmission is completed, then it can easily decide which buffer shall transmit the next frame. As a drawback a message with a low-priority identifier may block more important messages, then the host could abort the message.

## 7.4 Register definition

0x40007800

CAN\_1:

**NutoChips** 

CAN-CTRL is a 32 bit component and offers downward-compatible interfaces for 8 and 16 bit hosts. The mapping of the registers for 8 host interfaces.

|      |                           |                      |         | Bit po       | sition                     |         |                  |                   | Register name |
|------|---------------------------|----------------------|---------|--------------|----------------------------|---------|------------------|-------------------|---------------|
|      | 7                         | 6                    | 5       | 4            | 3                          | 2       | 1                | 0                 |               |
| 0x00 | 1                         | ļ                    |         | Receive Buf  | fer Registers              | ;<br>;  |                  | I                 |               |
| to   | and                       |                      |         |              |                            |         |                  | RBUF<br>(and RTS) |               |
| 0x4F |                           | Reception Time Stamp |         |              |                            |         |                  |                   | (anu KTS)     |
| 0x50 |                           |                      |         |              |                            |         |                  |                   |               |
| to   |                           |                      |         | Transmit Buf | fer Registers              | 3       |                  |                   | TBUF          |
| )x97 |                           |                      |         |              |                            |         |                  |                   |               |
| )xA0 | RESET                     | LBME                 | LBMI    | TPSS         | TSSS                       | RACTIVE | TACTIVE          | BUSOFF            | CFG_STAT      |
| )xA1 | TBSEL                     | LOM                  | STBY    | TPE          | TPA                        | TSONE   | TSALL            | TSA               | TCMD          |
| )xA2 | -                         | TSNEXT               | TSMODE  |              | -                          |         | TSS <sup>-</sup> | TAT(1:0)          | TCTRL         |
| )xA3 | -                         | ROM                  | ROV     | RREL         |                            |         | RST              | AT(1:0)           | RCTRL         |
| )xA4 | RIE                       | ROIE                 | RFIE    | RAFIE        | TPIE                       | TSIE    | EIE              | TSFF              | RTIE          |
| )xA5 | RIF                       | ROIF                 | RFIF    | RAFIF        | TPIF                       | TSIF    | EIF              | AIF               | RTIF          |
| )xA6 | EWARN                     | EPASS                | EPIE    | EPIF         | ALIE                       | ALIF    | BEIE             | BEIF              | ERRINT        |
| )xA7 | ¥                         | AFV                  | VL(3:0) |              |                            | EWL     | (3:0)            |                   | LIMIT         |
| )xA8 |                           | S_Seg_1(7:0)         |         |              |                            |         | S_Seg_1          |                   |               |
| )xA9 | -                         | S_Seg_2(6:0)         |         |              |                            |         |                  | S_Seg_2           |               |
| )xAA | -                         | - S_SJW(6:0)         |         |              |                            |         |                  |                   | S_SJW         |
| )xAB |                           |                      |         |              |                            |         |                  | S_PRESC           |               |
| 0xB0 |                           | KOER(2:0)            |         |              | ALC(4:0)                   |         |                  |                   | EALCAP        |
| 0xB2 |                           |                      |         | REC          | CNT                        |         |                  |                   | RECNT         |
| 0xB3 |                           |                      |         | TEC          | CNT                        |         |                  |                   | TECNT         |
| )xB4 | -                         | - SELMASK            |         | -            | - ACF/                     |         | ADR              |                   | ACFCTRL       |
| 0xB6 | AE_7                      | AE_6                 | AE_5    | AE_4         | AE_3                       | AE_2    | AE_1             | AE_0              | ACF_EN_0      |
| )xB7 | AE_15                     | AE_14                | AE_13   | AE_12        | AE_11                      | AE_10   | AE_9             | AE_8              | ACF_EN_1      |
| )xB8 |                           | I                    |         | ACODE_x or A | MASK_x (7:0                | ))      |                  | <u> </u>          | ACF_0         |
| )xB9 | ACODE_x or AMASK_x (15:8) |                      |         |              |                            |         | ACF_1            |                   |               |
| хВА  |                           |                      |         | CODE_x or AN | •                          | ,       |                  |                   | ACF_2         |
| xBB  | -                         | AIDEE                | AIDE    |              | ACODE_x or AMASK_x (28:24) |         |                  |                   | ACF_3         |
| xBC  |                           | I                    |         | VERSI        |                            | _       | _ `              | ,                 | VER_0         |

### Table 7-1 CAN-CRTL Register Mapping

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

0xBD

VERSION(15:8)

VER\_1

| 0x0A0 | 0x0A0 <u>CFG_STAT</u> |        | Configuration and Status Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-----------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits  | Name                  | Access | s Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7     | RESET                 | rw-1   | Reset request bit         1: The host controller performs a local reset of CAN-CTRL.         0: no local reset of CAN-CTRL.         Some register (e.g. for node configuration) can only be modified if RESET=1.         Bit RESET forces several components to a reset state.         RESET is automatically set if the node enters "bus off" state.         Note: A CAN node will participate in CAN communication after RESET is switched         to 0 after 11 CAN bit times. This delay is required by the CAN standard (bus idle time).         If RESET is set to 1 and immediately set to 0, then it takes some time until RESET can be read as 0 and becomes inactive. The reason is clock domain crossing from host to CAN clock domain. RESET is held active as long as needed depending on the relation between host and |
| 6     | LBME                  | rw-0   | Loop Back Mode, External<br>0: Disabled<br>1: Enabled<br>LBME should not be enabled while a transmission is active.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5     | LBMI                  | rw-0   | Loop Back Mode, Internal<br>0: Disabled<br>1: Enabled<br>LBMI should not be enabled while a transmission is active.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4     | TPSS                  | rw-0   | <b>Transmission Primary Single Shot mode for PTB</b><br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3     | TSSS                  | rw-0   | Transmission Secondary Single Shot mode for STB<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2     | RACTIVE               | r-0    | Reception Active (Receive Status bit)         1: The controller is currently receiving a frame.         0: No receive activity.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1     | TACTIVE               | r-0    | Transmission Active (Transmit Status bit)<br>1: The controller is currently transmitting a frame.<br>0: No transmit activity.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0     | BUSOFF                | rw-0   | Bus Off (Bus Status bit)<br>1: The controller status is "bus off".<br>0: The controller status is "bus on".<br>Writing a 1 will clear TECNT and RECNT and exit BUSOFF when in BUSOFF status. This<br>should be done only for debugging.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

|  | 0x0A1 | TCMD |
|--|-------|------|
|--|-------|------|

#### **Command Register**

| Bits | Name  | Access Function                                                                                                                                                                                                                                                                                                |
|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | TBSEL | Transmit Buffer Select         Selects the transmit buffer to be loaded with a message. Use the TBUF registers for access. TBSEL needs to be stable all the time the TBUF registers are written and when TSNEXT is set.         rw-0       TSNEXT is set.         0: PTB (high-priority buffer)         1: STB |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 62 of 360

| Bits | Name  | Acces | s Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|------|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 6    | LOM   | rw-0  | Listen Only Mode<br>0: Disabled<br>1: Enabled<br>LOM should not be enabled while a transmission is active. No transmission can be started<br>if LOM is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| 5    | STBY  | rw-0  | Transceiver Standby Mode 0: Disabled 1: Enabled This register bit is connected to the output signal standby which can be used to control a standby mode of a transceiver. STBY cannot be set to 1 if TPE=1, TSONE=1 or TSALL=1. If the host sets STBY to 0 then the host needs to wait for the time required by the transceiver to start up before the host requests a new transmission.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| 4    | TPE   | rw-0  | Transmit Primary Enable1: Transmission enable for the message in the high-priority PTB0: No transmission for the PTBIf TPE is set, the message from the PTB will be transmitted at the next possible transmitposition. A started transmission from the STB will be completed before, but pending newmessages are delayed until the PTB message has been transmitted.TPE stays set until the message has been transmitted successfully or it is aborted usingTPA.The host controller can set TPE to 1 but cannot reset it to 0. This would only be possibleusing TPA and aborting the message.During the short time while the CAN-CTRL core resets the bit, it cannot be set by thehost.The bit will be reset to the hardware reset value if RESET=1, BUSOFF=1, STBY=1,LOM=1.                                                                                                                                                                                                                                                     |  |
| 3    | TPA   | rw-0  | Transmit Primary Abort<br>1: Aborts a transmission from PTB which has been requested by TPE=1 but not<br>started yet. (The data bytes of the message remains in the PTB.)<br>0: no abort.<br>The bit has to be set by the host controller and will be reset by CAN-CTRL. Setting TPA<br>automatically de-asserts TPE.<br>The host controller can set TPA to 1 but cannot reset it to 0.<br>During the short time while the CAN-CTRL core resets the bit, it cannot be set by the<br>host.<br>The bit will be reset to the hardware reset value if RESET=1, BUSOFF=1.<br>TPA should not be set simultaneously with TPE.                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| 2    | TSONE | rw-0  | <ul> <li>Transmit Secondary One frame <ol> <li>Transmission enable of one in the STB. In FIFO mode this is the oldest message and in priority mode this is the one with the highest priority.</li> <li>TSONE in priority mode is difficult to handle, because it is not always clear which message will be transmitted if new messages are written to the STB meanwhile.</li> <li>The controller starts the transmission as soon as the bus becomes vacant and no request of the PTB (bit TPE) is pending.</li> <li>0: No transmission for the STB.</li> <li>TSONE stays set until the message has been transmitted successfully or it is aborted using TSA.</li> <li>The host controller can set TSONE to 1 but cannot reset it to 0. This would only be possible using TSA and aborting the message.</li> <li>During the short time while the CAN-CTRL core resets the bit, it cannot be set by the host.</li> <li>The bit will be reset to the hardware reset value if RESET=1, BUSOFF=1, STBY=1, LOM=1.</li> </ol></li></ul> |  |

| Bits | Name  | Access Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | TSALL | Transmit Secondary All frames         1: Transmission enable of all messages in the STB.         The controller starts the transmission as soon as the bus becomes vacant and no request of the PTB (bit TPE) is pending.         rw-0       0: No transmission for the STB.         TSALL stays set until all messages have been transmitted successfully or they are aborted using TSA.         The host controller can set TSALL to 1 but cannot reset it to 0. This would only be possible using TSA and aborting the messages.         During the short time while the CAN-CTRL core resets the bit, it cannot be set by the host.         The bit will be reset to the hardware reset value if RESET=1, BUSOFF=1, STBY=1, LOM=1.         If during a transmission the STB is loaded with a new frame, then the new frame will be transmitted too. In other words: a transmission initiated by TSALL is finished                                                                                         |
| 0    | TSA   | when the STB becomes empty.         Transmit Secondary Abort         1: Aborts a transmission from STB which has been requested but not started yet.         For a TSONE transmission, only one frame is aborted while for a TSALL         Transmission, all frames are aborted.         One or all message slots will be released which updates TSSTAT.         All aborted messages are lost because they are not accessible any more.         If in priority mode a TSONE transmission is aborted, then it is not clear which frame will be aborted if new frames are written to the STB meanwhile.         0: no abort.         The bit has to be set by the host controller and will be reset by CAN-CTRL. Setting TSA, automatically de-asserts TSONE or TSALL respectively.         The host controller can set TSA to 1 but cannot reset it to 0.         The bit will be reset to the hardware reset value if RESET=1 or BUSOFF=1.         TSA should not be set simultaneously with TSONE or TSALL. |

Setting both TSONE and TSALL is meaningless. While TSALL is already set, it is impossible to set TSONE and vice versa. If both TSONE and TSALL are set simultaneously then TSALL wins and TSONE is cleared by the CAN-CTRL core.

| 0x0A2 <u>TCTRL</u> |        | Transmit Control Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits               | Name   | Access Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6                  | TSNEXT | Transmit buffer Secondary Next         0: no action         1: STB slot filled, select next slot.         After all frame bytes are written to the TBUF registers, the host controller has to set<br>TSNEXT to signal that this slot has been filled. Then the CAN-CTRL core connects the TBUF<br>registers to the next slot. Once a slot is marked as filled a transmission can be started<br>using TSONE or TSALL.         rw-0       It is possible to set TSNEXT and TSONE or TSALL together in one write access.<br>TSNEXT has to be set by the host controller and is automatically reset by the CAN-CTRL<br>core immediately after it was set.<br>Setting TSNEXT is meaningless if TBSEL=0. In this case TSNEXT is ignored<br>and automatically cleared. It does not do any harm.<br>If all slots of the STB are filled, TSNEXT stays set until a slot becomes free. |

## **NutoChips**

| Bits | Name   | Access | s Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5    | TSMODE | rw-0   | Transmit buffer Secondary Operation Mode<br>0: FIFO mode<br>1: priority decision mode<br>In FIFO mode frames are transmitted in the order in that they are written into the STB. In<br>priority decision mode the frame with the highest priority in the STB is automatically<br>transmitted first. The ID of a frame is used for the priority decision. A lower ID means a<br>higher priority of a frame. A frame in the PTB has always the highest priority regardless of<br>the ID.<br>TSMODE shall be switched only if the STB if empty. |
| 4:2  | -      | r-0    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1:0  | TSSTAT | r-0    | Transmission Secondary Status bits<br>00: STB is empty<br>01: STB is less than or equal to half full<br>10: STB is more than half full<br>11: STB is full                                                                                                                                                                                                                                                                                                                                                                                    |

#### 0x0A3 <u>RCTRL</u>

#### **Receive Control Register**

| Bits | Name  | Access | Function                                                                                                                                                                                                                              |
|------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | -     | r-0    | reserved                                                                                                                                                                                                                              |
| 6    | ROM   | rw-0   | Receive buffer Overflow Mode<br>In case of a full RBUF when a new message is received, then ROM selects the following:<br>1: The new message will not be stored.<br>0 : The oldest message will be overwritten.                       |
| 5    | ROV   | r-0    | Receive buffer Overflow<br>1: Overflow. At least one message is lost.<br>0: No Overflow.<br>ROV is cleared by setting RREL=1.                                                                                                         |
| 4    | RREL  | rw-0   | Receive buffer Release<br>The host controller has read the actual RB slot and releases it. Afterwards the CAN-CTRL<br>core points to the next RB slot. RSTAT gets updated.<br>1: Release: The host has read the RB.<br>0 : No release |
| 3:2  | -     | r-0    | Reserved                                                                                                                                                                                                                              |
| 1:0  | RSTAT | r-0    | Receive buffer Status00: empty01: > empty and < almost full (AFWL)                                                                                                                                                                    |

| 0x0A4 RTIE | Receive and Transmit Interrupt Enable Register |
|------------|------------------------------------------------|
|            |                                                |

| Bits   | Name       | Access | Function                                |                |     |      |     |      |                           |  |
|--------|------------|--------|-----------------------------------------|----------------|-----|------|-----|------|---------------------------|--|
| 7      | RIE        | rw-1   | Receive Interrupt Enable                |                |     |      |     |      |                           |  |
|        |            | 1 44-1 | 0 : Disabled, 1 : Enabled               |                |     |      |     |      |                           |  |
| 6      | ROIE       | rw-1   | RB Overrun Interrupt Enable             |                |     |      |     |      |                           |  |
| 0      | RUIE       | 1 VV-1 | 0 : Disabled, 1 : Enabled               |                |     |      |     |      |                           |  |
| 5      | RFIE       | rw-1   | RB Full Interrupt Enable                |                |     |      |     |      |                           |  |
| 5      |            | 1 44-1 | 0:Disabled, 1 : Enabled                 |                |     |      |     |      |                           |  |
| 4      | RAFIE      | m      | RB Almost Full Interrupt Enable         |                |     |      |     |      |                           |  |
| 4      | KAFIE      | rw-1   | 0 : Disabled, 1 : Enabled               |                |     |      |     |      |                           |  |
| 3      | TPIE       | rw-1   | Transmission Primary Interrupt Enable   |                |     |      |     |      |                           |  |
| 3      | IFIC       | 1 44-1 | 0 :Disabled, 1 :Enabled                 |                |     |      |     |      |                           |  |
| 2      | TSIE       |        | Transmission Secondary Interrupt Enable |                |     |      |     |      |                           |  |
| 2      | ISE        | ISIE   | ISE                                     | ISE            | ISE | ISIE | ISE | rw-1 | 0 : Disabled, 1 : Enabled |  |
| 1      | EIE        | may 4  | Error Interrupt Enable                  |                |     |      |     |      |                           |  |
|        | EIE        | rw-1   | 0 : Disabled, 1 :Enabled                |                |     |      |     |      |                           |  |
| AutoCh | ips Confid | ential | © 2013 - 2021 AutoChips Inc.            | Page 65 of 360 |     |      |     |      |                           |  |

2021 AutoChips Inc. ⊜ z013

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

## **NutoChips**

| Bits | Name | Access | Access Function                                                                                                                                                          |  |  |  |  |  |
|------|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0    | TSFF | r-0    | <b>Transmit Secondary Buffer Full Flag</b><br>1: The STB is filled with the maximal number of messages.<br>0 : The STB is not filled with the maximal number of messages |  |  |  |  |  |

#### 0x0A5 <u>RTIF</u> **Receive and Transmit Interrupt Flag Register**

| Bits | Name  | Access   | s Function                                                                                   |
|------|-------|----------|----------------------------------------------------------------------------------------------|
|      |       |          | Receive Interrupt Flag                                                                       |
| 7    | RIF   | rw-0     | 1: Data or a remote frame has been received and is available in the receive buffer.          |
|      |       |          | 0: No frame has been received.                                                               |
|      |       |          | RB Overrun Interrupt Flag                                                                    |
| 6    | ROIF  | rw-0     | 1: At least one received message has been overwritten in the RB.                             |
| 0    | RUIF  | TW-0     | 0: No RB overwritten.                                                                        |
|      |       |          | In case of an overrun both ROIF and RFIF will be set.                                        |
|      |       |          | RB Full Interrupt Flag                                                                       |
| 5    | RFIF  | rw-0     | 1: All RBs are full. If no RB will be released until the next valid message is received, the |
| Э    | KLIL  | TW-0     | oldest message will be lost.                                                                 |
|      |       |          | 0: The RB FIFO is not full.                                                                  |
|      |       |          | RB Almost Full Interrupt Flag                                                                |
| 4    | RAFIF | rw-0     | 1: number of filled RB slots ≥ AFWL_i                                                        |
|      |       |          | 0: number of filled RB slots < AFWL_i                                                        |
|      |       |          | Transmission Primary Interrupt Flag                                                          |
| 3    | TPIF  | rw-0     | 1: The requested transmission of the PTB has been successfully completed.                    |
| 3    | IFIF  |          | 0: No transmission of the PTB has been completed.                                            |
|      |       | SIF rw-0 | Transmission Secondary Interrupt Flag                                                        |
| 2    | TSIF  |          | 1: The requested transmission of the STB has been successfully completed.                    |
|      |       |          | 0: No transmission of the STB has been completed successfully.                               |
|      |       |          | Error Interrupt Flag                                                                         |
| 4    | FIF   |          | 1: The border of the error warning limit has been crossed in either direction, or the        |
| 1    | EIF   | rw-0     | BUSOFF bit has been changed in either direction.                                             |
|      |       |          | 0: There has been no change.                                                                 |
|      |       |          | Abort Interrupt Flag                                                                         |
|      |       |          | 1: After setting TPA or TSA the appropriated message(s) have been aborted.                   |
|      |       |          | It is recommended to not set both TPA and TSA simultaneously because both source             |
| 0    | AIF   | rw-0     | AIF.                                                                                         |
|      |       |          | 0: No abort has been executed.                                                               |
|      |       |          | The AIF does not have an associated enable register.                                         |

| 0x0A6 <u>ERRINT</u>    |       |        | Error Interrupt Enable and Flag Register                        |                               |
|------------------------|-------|--------|-----------------------------------------------------------------|-------------------------------|
| Bits                   | Name  | Access | Function                                                        |                               |
|                        |       |        | Error Warning limit reached                                     |                               |
| 7                      | EWARN | r-0    | 1: One of the error counters RECNT or TECNT is equal or         | bigger than EWL               |
|                        |       |        | 0 : The values in both counters are less than EWL.              |                               |
|                        |       |        | Error Passive mode active                                       |                               |
| 6                      | EPASS | r-0    | 0: not active (node is error active)                            |                               |
|                        |       |        | 1 : active (node is error passive)                              |                               |
| 5                      | EPIE  | rw-0   | Error Passive Interrupt Enable                                  |                               |
| 4                      | EPIF  | rw-0   | Error Passive Interrupt Flag. EPIF will be activated if         | the error status changes from |
| 4                      |       | 100-0  | error active to error passive or vice versa and if this interru | upt is enabled.               |
| 3                      | ALIE  | rw-0   | Arbitration Lost Interrupt Enable                               |                               |
| 2                      | ALIF  | rw-0   | Arbitration Lost Interrupt Flag                                 |                               |
| AutoChips Confidential |       | ential | © 2013 - 2021 AutoChips Inc.                                    | Page 66 of 360                |

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bits | Name | Access | Access Function            |  |  |  |
|------|------|--------|----------------------------|--|--|--|
| 1    | BEIE | rw-0   | Bus Error Interrupt Enable |  |  |  |
| 0    | BEIF | rw-0   | Bus Error Interrupt Flag   |  |  |  |

To reset an interrupt flag, the host controller needs to write a 1 to the flag. Writing a 0 has no effect. If a new interrupt event occurs while the write access is active, then this event will set the flag and override the reset. This ensures that no interrupt event is lost.

Interrupt flags will only be set if the associated interrupt enable bit is set.

#### 0x0A7 <u>LIMIT</u>

#### Warning Limits Register

| Bits | Name      | Access | AccessFunction                                                                                                           |  |  |  |
|------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------|--|--|--|
|      |           |        | Receive buffer Almost Full Warning Limit                                                                                 |  |  |  |
|      |           |        | AFWL defines the internal warning limit AFWL_i with $n_{ m RB}$ being the number of available RB slots.                  |  |  |  |
|      |           |        | AFWL_i is compared to the number of filled RB slots and triggers RAFIF if equal. The valid range of AFWL_i : $1n_{RB}$ . |  |  |  |
|      |           |        | AFWL_i = 0 is meaningless and automatically treated as 0x1.                                                              |  |  |  |
|      |           |        | (Note that AFWL is meant in this rule and not AFWL_i.)                                                                   |  |  |  |
|      |           |        | AFWL_i > $n_{\rm RB}$ is meaningless and automatically treated as $n_{\rm RB}$ .                                         |  |  |  |
| 7:4  | AFWL(3:0) | rw-0x1 | AFWL_i = $n_{RB}$ is a valid value, but note that RFIF also exists.                                                      |  |  |  |
| 3:0  | EWL(3:0)  | rw-0xB | <b>Programmable Error Warning Limit</b> = (EWL+1) *8. Possible Limit values: 8, 16, 128. The value of EWL controls EIF.  |  |  |  |

| 0x0A8 |              |        | Bit Timing Register                                                                                       |
|-------|--------------|--------|-----------------------------------------------------------------------------------------------------------|
| Bits  | Name         | Access | Function                                                                                                  |
|       |              |        | Bit Timing Segment 1                                                                                      |
| 7:0   | S_Seg_1(7:0) | rw-0x3 | The sample point will be set to $t_{\text{Seg 1}} = (\text{Seg}_1 + 2) \cdot TQ$ after start of bit time. |

| 0x0A9 |              |        | Bit Timing Register                                                           |
|-------|--------------|--------|-------------------------------------------------------------------------------|
| Bits  | Name         | Access | Function                                                                      |
| 7     | -            | r-0    | Reserved                                                                      |
|       |              |        | Bit Timing Segment 2                                                          |
| 6:0   | S_Seg_2(6:0) | rw-0x2 | Time $t_{\text{Seg}_2} = (\text{Seg}_2 + 1) \cdot TQ$ after the sample point. |
|       |              |        | Please note the synthesis parameter SHORT_SEG2.                               |

#### 0x0AA <u>S\_SJW</u>

#### **Bit Timing Register**

| Bits | Name       | Access | Access Function                                                                          |  |  |
|------|------------|--------|------------------------------------------------------------------------------------------|--|--|
| 7    | -          | r-0    | Reserved                                                                                 |  |  |
|      | S_SJW(6:0) | rw-0x2 | Synchronization Jump Width                                                               |  |  |
| 6:0  |            |        | The Synchronization Jump Width $t_{SJW} = (SJW + 1) \cdot TQ$ is the maximum time for    |  |  |
| 6.0  |            |        | shortening or lengthening the Bit Time for resynchronization, where TQ is a time quanta. |  |  |

#### 0x0AB S\_PRESC

#### **Prescaler Registers**

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 67 of 360

## **//utoChips**

| Bits | Name        | Access Function                                                                                                                                                                        |  |  |
|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7:0  | S_PRES<br>C | Prescaler         rw-0x01       The prescaler divides the system clock to get the time quanta clock tq_clk.         Valid range PRESC=[0x00, 0xff] results in divider values 1 to 256. |  |  |

#### 0x0B0 EALCAP Error and Arbitration Lost Capture Register

| Bits | Name      | Reset<br>Value | Function                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|-----------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5  | KOER(2:0) | r-0x0          | Kind Of Error (Error code)000 : no error001 : BIT ERROR010 : FORM ERROR011 : STUFF ERROR100 : ACKNOWLEDGEMENT ERROR101 : CRC ERROR110: OTHER ERROR(dominant bits after own error flag, received active Error Flag too long, dominantbit during Passive-Error-Flag after ACK error).111: not usedKOER is updated with each new error. Therefore, it stays untouched when frames are<br>successfully transmitted or received. |
| 4:0  | ALC(4:0)  | r-0x0          | Arbitration Lost Capture (bit position in the frame where the arbitration has been lost)                                                                                                                                                                                                                                                                                                                                    |

### 0x0B2-B3 <u>RECNT</u> Error Counter Registers (TECNT (0xB3))

| Bits | Name  | Access | Function                                                                                                                                                                                                                                                                        |
|------|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0  | RECNT | r-0x00 | <b>Receive Error Count (number of errors during reception)</b><br>RECNT is incremented and decremented as defined in the CAN specification.<br>RECNT does not overflow. RECNT signals 0xff = 255 as maximum value.<br>For more details about RECNT and the "bus off" state.     |
| 7:0  | TECNT | r-0x00 | <b>Transmit Error Count (number of errors during transmission)</b><br>TECNT is incremented and decremented as defined in the CAN specification.<br>TECNT does not overflow. TECNT signals 0xff = 255 as maximum value.<br>For more details about TECNT and the "bus off" state. |

| 0x0B4 <u>ACFCTRL</u> |         |        | Acceptance Filter Control Register                                                                                                                                                                                                                                                                                                         |
|----------------------|---------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits                 | Name    | Access | Function                                                                                                                                                                                                                                                                                                                                   |
| 7:6                  | -       | r-0    | reserved                                                                                                                                                                                                                                                                                                                                   |
|                      |         |        | Select acceptance Mask                                                                                                                                                                                                                                                                                                                     |
| 5                    | SELMASK | rw-0   | 0 : Registers ACF_x point to acceptance code                                                                                                                                                                                                                                                                                               |
| 5                    | SELWASK | TW-0   | 1 : Registers ACF_x point to acceptance mask.                                                                                                                                                                                                                                                                                              |
|                      |         |        | ACFADR selects one specific acceptance filter.                                                                                                                                                                                                                                                                                             |
| 4                    | -       | r-0    | Reserved                                                                                                                                                                                                                                                                                                                                   |
| 3:0                  | ACFADR  | rw-0   | Acceptance filter address<br>ACFADR points to a specific acceptance filter. The selected filter is accessible using the<br>registers ACF_x. Bit SELMASK selects between acceptance code and mask for the<br>selected acceptance filter.<br>A value of ACFADR>NR_OF_ACF-1 is meaningless and automatically treated as value<br>NR_OF_ACF-1. |

AutoChips Confidential

The acceptance filter registers ACF\_x provide access to the acceptance filter codes ACODE\_x and acceptance filter masks AMASK\_x depending on the setting of SELMASK. Read/ Write access to ACF\_x is only possible if RESET=1. If RESET=0 then reading from ACF\_x results in the value 0. The acceptance filters are build using a true 32 bits wide memory and therefore a write access needs to be performed as 32 bits write.



Figure 7-3 Access to the acceptance filters

| 0x0B8-BB <u>ACF_x</u> |                    | 4               | Acceptance CODE ACODE_x Register                                                                                                                                                                                                                                                                                                                      |
|-----------------------|--------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits                  | Name               | Access          | Function                                                                                                                                                                                                                                                                                                                                              |
| 7:0                   | ACODE_0<br>ACODE_x | rw-0x00<br>rw-u | Acceptance CODE<br>1: ACC bit value to compare with ID bit of the received message<br>0: ACC bit value to compare with ID bit of the received message<br>ACODE_x(10:0) will be used for extended frames.<br>ACODE_x(28:0) will be used for extended frames.<br>Only filter 0 is affected by the power-on reset. All other filters stay uninitialized. |

| 0x0B8-BB <u>ACF_x</u> |                    | A               | Acceptance CODE AMASK_x Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------|--------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits                  | Name               | Access          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7:0                   | AMASK_0<br>AMASK_x | rw-0xFF<br>rw-u | Acceptance Mask<br>1: acceptance check for these bits of receive identifier disabled<br>0: acceptance check for these bits of receive identifier enable<br>AMASK_x(10:0) will be used for extended frames.<br>AMASK_x(28:0) will be used for extended frames.<br>Disabled bits result in accepting the message. Therefore, the default configuration after<br>reset for filter 0 accepts all messages.<br>Only filter 0 is affected by the power-on reset. All other filters stay uninitialized. |

AutoChips Confidential

**NutoChips** 

© 2013 - 2021 AutoChips Inc.

The AMASK\_x includes additional bits in register ACF\_3 which can be only accessed if SELMASK=1. These bits can be used to accept only either standard or extended frames with the selected ACODE/ AMASK setting or to accept both frame types. Only acceptance filter 0 is affected by the power-on reset and it is configured to accept both frame types after power-up.

### Table 7-2 Bits in Register ACF\_3, if SELMASK=1

| Bits | Name  | Access       | Function                                                                                                                                                                                                                                                                       |
|------|-------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6    | AIDEE | rw-0<br>rw-u | Acceptance mask IDE bit check enable<br>1: acceptance filter accepts either standard or extended as defined by AIDE<br>0: acceptance filter accepts both standard or extended frames<br>Only filter 0 is affected by the power-on reset. All other filters stay uninitialized. |
| 5    | AIDE  | rw-0<br>rw-u | Acceptance mask IDE bit value<br>If AIDEE=1 then:<br>1: acceptance filter accepts only extended frames<br>0: acceptance filter accepts only standard frames<br>Only filter 0 is affected by the power-on reset. All other filters stay uninitialized.                          |

#### 0x0B6 <u>ACF\_EN\_0</u> Acceptance Filter Enable Register

| Bits | Name | Access  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0  | AE_x | rw-0x01 | Acceptance filter Enable<br>1: acceptance filter enable<br>0: acceptance filter disable<br>Each acceptance filter (AMASK / ACODE) can be individually enabled or disabled.<br>Only filter number 0 is enabled by default after hardware reset.<br>Disabled filters reject a message. Only enabled filters can accept a message if the<br>appropriate AMASK / ACODE configuration matches.<br>To accept all messages one filter x has to be enabled by setting AE_x=1,<br>AMASK_x=0xff and ACODE_x=0x00. This is the default configuration after hardware<br>reset for filter x=0 while all other filters are disabled. |

#### 0x0B7 <u>ACF\_EN\_1</u> Acceptance Filter Enable Register

| Bits | Name | Access  | Function                                                                                                                                                                                                                                                                                                              |
|------|------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0  | AE_x | rw-0x00 | Acceptance filter Enable<br>1: acceptance filter enable<br>0: acceptance filter disable<br>Each acceptance filter (AMASK / ACODE) can be individually enabled or disabled.<br>Disabled filters reject a message. Only enabled filters can accept a message if the<br>appropriate AMASK / ACODE configuration matches. |

0x0BC-BD <u>VER\_0 – 1</u>

**NutoChips** 

#### **Version Information Register**

| Bits | Name           | Access Function                                                                                                                                                                     |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0 | VER_0<br>VER_1 | Version of CAN-CTRL, given as decimal value. VER_1 holds the major version and<br>r VER_0 the minor version.<br>Example: version 5x16N00S00 is represented by VER_1=5 and VER_0=16. |

AutoChips Confidential



| Table 7-3 Receive | <b>Buffer Reaisters</b> | RBUF – Standard | Format (r-0) |
|-------------------|-------------------------|-----------------|--------------|
|                   |                         |                 |              |

| Address |         | Bit position         |   |     |      |            |             |   |             |
|---------|---------|----------------------|---|-----|------|------------|-------------|---|-------------|
|         | 7       | 6                    | 5 | 4   | 3    | 2          | 1           | 0 |             |
| RBUF    |         |                      |   | ID( | 7:0) |            |             |   | Identifier  |
| RBUF+1  |         |                      | - |     |      | ID(10:8)   |             |   | Identifier  |
| RBUF+2  |         |                      |   |     |      | Identifier |             |   |             |
| RBUF+3  |         |                      |   |     |      | Identifier |             |   |             |
| RBUF+4  | IDE=0   | IDE=0 RTR - DLC(3:0) |   |     |      |            | Control     |   |             |
| RBUF+5  |         |                      | - |     |      |            |             |   | -           |
| RBUF+6  |         |                      | - |     |      |            |             |   | -           |
| RBUF+7  |         |                      |   |     | -    |            |             |   | -           |
| RBUF+8  | d1(7:0) |                      |   |     |      |            | Data byte 1 |   |             |
| RBUF+9  |         |                      |   | d2( | 7:0) |            |             |   | Data byte 2 |
|         |         |                      |   | -   |      |            |             |   |             |
| RBUF+15 |         |                      |   | d8( | 7:0) |            |             |   | Data byte 8 |

#### Table 7-4 Receive Buffer Registers RBUF - Extended Format (r-0)

| Address |             | Bit position |   |      |       |          |             |            |             |
|---------|-------------|--------------|---|------|-------|----------|-------------|------------|-------------|
|         | 7           | 6            | 5 | 4    | 3     | 2        | 1           | 0          |             |
| RBUF    |             |              |   | ID(  | 7:0)  |          |             |            | Identifier  |
| RBUF+1  |             |              |   | ID(1 | 15:8) |          |             |            | Identifier  |
| RBUF+2  |             | ID(23:16)    |   |      |       |          |             | Identifier |             |
| RBUF+3  | - ID(28:24) |              |   |      |       |          | Identifier  |            |             |
| RBUF+4  | IDE=1       | RTR          |   | -    | C C   | DLC(3:0) |             |            | Control     |
| RBUF+5  |             |              | - |      |       |          |             |            | -           |
| RBUF+6  |             |              | - |      |       |          |             |            | -           |
| RBUF+7  |             |              |   |      |       |          | -           |            |             |
| RBUF+8  | d1(7:0)     |              |   |      |       |          | Data byte 1 |            |             |
| RBUF+9  | d2(7:0)     |              |   |      |       |          | Data byte 2 |            |             |
|         |             |              |   |      |       |          |             |            |             |
| RBUF+15 |             |              |   | d8(  | 7:0)  |          |             |            | Data byte 8 |

The RBUF registers (0x00 to 0x47) point the message slot with the oldest received message in the RB. All RBUF registers can be read in any order.

Please mind the gap inside the addressing range of RBUF at RBUF+7. This is for better address segment alignment for a wider host controller interface.

| Address |            | Bit position |     |    |        |     |             |            |             |  |
|---------|------------|--------------|-----|----|--------|-----|-------------|------------|-------------|--|
|         | 7          | 6            | 5   | 4  | 3      | 2   | 1           | 0          |             |  |
| TBUF    |            |              |     | ID | 0(7:0) |     |             |            | Identifier  |  |
| TBUF+1  | - ID(10:8) |              |     |    |        |     | Identifier  |            |             |  |
| TBUF+2  |            |              | • • |    |        |     |             | Identifier |             |  |
| TBUF+3  |            |              |     |    | -      |     |             |            | Identifier  |  |
| TBUF+4  | IDE=0      | RTR          |     | -  |        | DLO | C(3:0)      |            | Control     |  |
| TBUF+8  | d1(7:0)    |              |     |    |        |     | Data byte 1 |            |             |  |
| TBUF+9  | d2(7:0)    |              |     |    |        |     | Data byte 2 |            |             |  |
|         |            |              |     |    |        |     |             |            |             |  |
| TBUF+15 |            |              |     | d8 | 8(7:0) |     |             |            | Data byte 8 |  |

#### Table 7-6 Transmit Buffer Registers TBUF – Extended Format (rw-u)

© 2013 - 2021 AutoChips Inc.

| Address |             | Bit position |   |   |   |     |             |            |            |
|---------|-------------|--------------|---|---|---|-----|-------------|------------|------------|
|         | 7           | 6            | 5 | 4 | 3 | 2   | 1           | 0          |            |
| TBUF    |             | ID(7:0)      |   |   |   |     |             |            | Identifier |
| TBUF+1  | ID(15:8)    |              |   |   |   |     |             | Identifier |            |
| TBUF+2  | ID(23:16)   |              |   |   |   |     |             | Identifier |            |
| TBUF+3  | - ID(28:24) |              |   |   |   |     | Identifier  |            |            |
| TBUF+4  | IDE=1       | RTR          |   | - |   | DLC | 2(3:0)      |            | Control    |
| TBUF+8  | d1(7:0)     |              |   |   |   |     | Data byte 1 |            |            |
| TBUF+9  | d2(7:0)     |              |   |   |   |     | Data byte 2 |            |            |
|         |             |              |   |   |   |     |             |            |            |
| TBUF+15 | d8(7:0)     |              |   |   |   |     | Data byte 8 |            |            |

The TBUF registers (0x48 to 0x8f) point the next empty message slot in the STB if TBSEL=1 or to the PTB otherwise. All TBUF registers can be written in any order. For the STB it is necessary to set TSNEXT to mark a slot filled and to jump to the next message slot.

Please mind the gap inside the addressing range of TBUF from TBUF+5 to TBUF+7. This is for better address segment alignment. The memory cells in the gap can be read and written, but have no meaning for the CAN protocol.

TBUF is build using a true 32 bit wide memory and therefore a write access needs to be performed as 32 bit write.

Both RBUF and TBUF include some frame-individual control bits (Table 7-7). For RBUF these bits signal the status of the appropriate CAN control field bits of the received CAN frame while for TBUF these bits select the appropriate CAN control field bit for the frame that has to be transmitted.

In contrast to RTS, which is stored for every received frame, TTS is stored only for the last transmitted frame. TTS is not related to the actual selected TBUF slot.

Table 7-7 Control bits in RBUF and TBUF

| Bit | Description                               |
|-----|-------------------------------------------|
|     | Identifier Extension                      |
| IDE | 0 – Standard Format: ID(10:0)             |
|     | 1 – Extended Format: ID(28:0)             |
|     | Remote Transmission Request               |
| 575 | 0 – data frame                            |
| RTR | 1 – remote frame                          |
|     | Only CAN 2.0 frames can be remote frames. |

The Data Length Code (DLC) in RBUF and TBUF defines the length of the payload – the number of payload bytes in a frame.

Remote frames (only for CAN 2.0 frames where EDL=0) are always transmitted with 0 payload bytes, but the content of the DLC is transmitted in the frame header. Therefore, it is possible to code some information into the DLC bits for remote frames. But then care needs to be taken if different CAN nodes are allowed to transmit a remote frame with the same ID. In this case, all transmitters need to use the same DLC because otherwise this would result in an unresolvable collision.

### Table 7-8 Definition of the DLC (according to the CAN 2.0 specification)

| DLC (binary) | Frame Type | Payload in Bytes |
|--------------|------------|------------------|
| 0000 to 1000 | CAN 2.0    | 0 to 8           |
| 1001 to 1111 | CAN 2.0    | 8                |

© 2013 - 2021 AutoChips Inc.

The TBUF registers are readable and writable. Therefore, a host controller may use TBUF to successively prepare a message bit-by-bit if necessary.

# 7.5 General operation

## 7.5.1 The bus off state

**NutoChips** 

The "bus off" state is signaled using the status bit BUSOFF in register CFG\_STAT. A CAN node enters the "bus off" state automatically if its transmit error counter becomes >255. Then it will not take part in further communications until it returns into the error active state again. A CAN node returns to error active state if it is reset by a power-on reset or if it receives 128 sequences of 11 recessive bits (recovery sequences).

In the "bus off" state, RECNT is used to count the recovery sequences while TECNT stays unchanged. Please note that while entering bus off state TECNT rolls over and therefore may hold a small value. Therefore, it is recommended to use TECNT before the node enters bus off state and status bit BUSOFF afterwards.

If the node recovers from "bus off" state, then RECNT and TECNT are automatically reset to 0. When BUSOFF gets set, then RESET is automatically set. Therefore, both RECNT and TECNT are not affected by the software reset.

## 7.5.2 Acceptance filters

To reduce the load of received frames for the host controller, the core uses acceptance filters. The CAN- CTRL core checks the message identifier during acceptance filtering. Therefore, the length of each acceptance filter is 29 bits.

If a message passes one of the filters, then it will be accepted. If accepted, the message will be stored into the RB and finally RIF is set if RIE is enabled. If the message is not accepted, RIF is not set and the RB FIFO pointer is not increased. Messages that are not accepted will be discarded and overwritten by the next message. No stored valid message will be overwritten by any not accepted message.

Independently of the result of acceptance filtering, the CAN-CTRL core checks every message on the bus and sends an acknowledge or an error frame to the bus.

The acceptance mask defines which bits shall be compared while the acceptance code defines the appropriate values. Setting mask bits to 0 enables the comparison of the selected acceptance code bits with the corresponding message identifier bits. Mask bits that are set to 1 are disabled for the acceptance check and this results in accepting the message.

The identifier bits will be compared with the corresponding acceptance code bits ACODE as follows:

- Standard: ID (10:0) with ACODE (10:0).
- Extended: ID (28:0) with ACODE (28:0).

Example: If AMASK\_x (0) = 0 and all other AMASK\_x bits are 1, then the value of the last ID bit has to be equal to ACODE (0) for an accepted message. All other ID bits are ignored by the filter.

Note: Disabling a filter by setting AE\_x=0 blocks messages. In contrast to this disabling a mask bit in AMASK\_x disables the check for this bit which results in accepting messages.

The definitions of AMASK and ACODE alone do not distinguish between standard or extended frames. If bit AIDEE=1 then the value of AIDE defines with frame type is accepted. Otherwise if AIDE=0 both types are accepted.

After power-on reset, the CAN-CTRL core is configured to accept all messages. (Filter 0 is enabled by AE\_0=1, all bits in AMASK\_0 are set to 1 and AIDEE=0. All other filters are disabled. Filter 0 is the only filter that has defined reset values for AMASK/ ACODE while all other filters have undefined reset values.)

# 7.5.3 Message reception

**NutoChips** 

The received data will be stored in the RB as shown in Figure 7-4. The RB is configurable by a presynthesis parameter and has FIFO-like behavior. Every received message that is valid and accepted sets RIF=1 if RIE is enabled. RSTAT is set depending of the fill state. When the number of filled buffers is equal to the programmable value AFWL, then RAFIF is set if RAFIE is enabled. In case, when all buffers are full, the RFIF is set if RFIE is enabled.



Figure 7-4 Schematic of the FIFO-like RB (example with 6 slots)

The RB always maps the message slot containing the oldest message to the RBUF registers.

The maximum payload length for CAN 2.0 messages is 8. The individual length of each message is defined by the DLC. Because of this, the RB provides slots for each message and the host controller is required to set RREL to jump to the next RB slot. All RBUF bytes of the actual slot can be read in any order.

If the RB is full, the next incoming message will be stored temporarily until it passes for valid (6<sup>th</sup> EOF bit). Then if ROM=0 the oldest message will be overwritten by the newest or if ROM=1 the newest message will be discarded. In both cases, ROIF is set if ROIE is enabled. If the host controller reads the oldest message and sets RREL before a new incoming message becomes valid, then no message will be lost.

# 7.5.4 Handling message receptions

Without acceptance filtering, the CAN-CTRL core would signal the reception of every frame and the host would be required to decide if it was addressed. This would result in quite a big load on the host controller.

It is possible to disable interrupts and use the acceptance filters to reduce the load for the host controller. For a basic operation RIF is set to 1 if RIE is enabled and the CAN-CTRL core has received a valid message. To reduce the number of reception interrupts, it is possible to use RAIE / RAIF (RB

© 2013 - 2021 AutoChips Inc.

Almost full Interrupt) or RFIE/RFIF (RB Full Interrupt) instead of RIE/RIF (Reception Interrupt). The "almost full limit" is programmable using AFWL.

The RB contains a number of RB slots, which is selectable before synthesis using a generic parameter. Reading the RB shall be done as follows:

- 1. Read the oldest message from the RB FIFO using the RBUF registers.
- 2. Release the RB slot with RREL=1. This selects the next message (the next FIFO slot). RBUF will be updated automatically.
- 3. Repeat these actions until RSTAT signals an empty RB.

If the RB FIFO is full and a new received message is recognized as valid (6<sup>th</sup> EOF bit) then one message will be lost (see bit ROM). Before this event, no message is lost. This should give enough time for the host controller to read at least one frame from the RB after the RB FIFO has been filled and the selected interrupt has occurred. To enable this behavior, the RB includes one more (hidden) slot than specified by the synthesis parameter RBUF\_SLOTS. This hidden slot is used to receive a message, validate it and check it if it matches the acceptance filters before an overflow occurs.

# 7.5.5 Message transmission

**NutoChips** 

Before starting any transmission, at least one of the transmit buffers (PTB or STB) has to be loaded with a message. TPE signals if the PTB is locked and TSSTAT signals the fill state of the STB. The TBUF registers provide access to both the PTB as well as to the STB. Below is the recommended programming flow:

- 1. Set TBSEL to the desired value to select either the PTB or the STB.
- 2. Write the frame to the TBUF registers.
- 3. For the STB set TSNEXT=1 to finish loading of this STB slot.



#### Figure 7-5 Schematic of PTB and STB in FIFO mode (empty PTB and 6 STB slots)

The maximum payload length for CAN 2.0 messages is 8 bytes. The individual length of each message is defined by the DLC. For remote frames (bit RTR), the DLC becomes meaningless, because remote frames always have a data length of 0 bytes. The host controller is required to set TSNEXT to jump to the next STB slot. All TBUF bytes can be written in any order.

Setting TSNEXT=1 is meaningless if TBSEL=0 selects the PTB. In this case TSNEXT is automatically cleared and does no harm.

Bit TPE should be set to start a transmission when using the PTB. To use the STB, TSONE has to be set to start a transmission of a single message or TSALL to transmit all messages.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 75 of 360

# **//utoChips**

The PTB has always a higher priority than the STB. If both transmit buffers have the order to transmit, the PTB message will be always sent first regardless of the frame identifiers. If a transmission from the STB is already active, it will be completed before the message from the PTB is sent at the next possible transmit position (the next frame slot). After the PTB transmission is completed or aborted, the CAN-CTRL core returns to process other pending messages from the STB.

When the transmission is completed, the following transmission interrupts are set:

- For the PTB, TPIF is set if TPIE is enabled.
- For the STB using TSONE, TSIF is set if one message has been completed and TSIE is enabled.
- For the STB using TSALL, TSIF is set if all messages have been completed and if TSIE is enabled. In other words, TSIE is set if the STB is empty. Therefore, if the host controller writes an additional message to the STB after a TSALL transmission has been started then the additional message will be also transmitted before TSIF will be set.

It is meaningless to set TSONE or TSALL while the STB is empty. In such a case TSONE respectively TSALL will be reset automatically. No interrupt flag will be set and no frame will be transmitted.

# 7.5.6 Message transmission abort

If the situation arises, where a message in a transmit buffer cannot be sent due to its low priority, this would block the buffer for a long time. In order to avoid this, the host controller can withdraw the transmission request by setting TPA or TSA respectively, if the transmission has not yet been started. Both TPA and TSA source a single interrupt flag: AIF. The CAN protocol machine executes an abort only if it does not transmit anything to the CAN bus. Therefore, the following is valid:

- There is no abort during bus arbitration.
  - If the node loses arbitration, the abort will be executed afterwards.
  - If the node wins arbitration, the frame will be transmitted.
- There is no abort while a frame is transmitted.
  - If a frame is transmitted successfully, then a successful transmission is signaled to the host controller. In this case no abort is signaled. This is done by the appropriate interrupt and status bits.
  - After an unsuccessful transmission where the CAN node does not receive an acknowledge, the error counter is incremented and the abort will be executed.
  - If there is at least one frame left in the STB, while the host has commanded all frames to be transmitted (TSALL=1), then both the completed frame as well as the abort is signaled to the host.

Because of these facts aborting a transmission may take some time depending on the CAN communication speed and frame length. If an abort is executed, this results in the following actions:

- TPA releases the PTB which results in TPE=0.
   The frame data is still stored in the PTB after releasing the PTB.
- TSA releases one single message slot or all message slots of the STB. This depends on whether TSONE or TSALL was used to start the transmission. TSSTAT will be updated accordingly. Releasing a frame in the STB results in discarding the frame data because the host cannot access it.

Setting both TPA and TSA simultaneously is not recommended. If a host controller decides to do it anyway, then AIF will be set and both transmissions from PTB and STB will be aborted if possible. As

Page 76 of 360

already stated if one transmission will be completed before the abort can be executed, this will result in signaling a successful transmission. Therefore, the following interrupt flags may be set if enabled:

- AIF (once for both PTB and STB transmission abort)
- TPIF + AIF

**NutoChips** 

- TSIF + AIF
- TPIF + TSIF (very seldom, will only happen if the host does not handle TPIF immediately)
- TPIF + TSIF + AIF (very seldom, will only happen if the host does not handle TPIF and TSIF immediately)

To clear the entire STB, both TSALL and TSA need to be set. In order to detect if a message cannot be sent for a long time because it loses arbitration, the host may use the ALIF/ALIE.

# 7.5.7 A full STB

After writing a message to the STB, TSNEXT=1 marks a buffer slot filled and jumps to the next free message slot. TSNEXT is automatically reset to 0 by the CAN-CTRL core after this operation.

If the last message slot has been filled and therefore all message slots are occupied, then TSNEXT stays set until a new message slot becomes free. While TSNEXT=1, then writing to TBUF is blocked by the CAN-CTRL core.

When a slot becomes free, then the CAN-CTRL core automatically resets TSNEXT to 0. A slot becomes free if a frame from the STB is transmitted successfully or if the host requests an abort (TSA=1). If a TSALL transmission is aborted, then TSNEXT is also reset, but additionally the complete STB is marked as empty.

## 7.5.8 Extended status and error report

During CAN bus communication transmission errors may occur. The following features support detection and analysis of them.

## 7.5.8.1 Programmable error warning limit

Errors during reception/ transmission are counted by RECNT and TECNT. A programmable error warning limit EWL, located in register LIMIT, can be used by the host controller for flexible reaction on those events. The limit values can be chosen in steps of 8 errors from 8 to 128:

Limit of count of errors = (EWL+1) \*8.

The interrupt EIF will be set if enabled by EIE under the following conditions:

- The border of the error warning limit has been crossed in either direction by RECNT or TECNT
- The BUSOFF bit has been changed in either direction.

## 7.5.8.2 Arbitration Lost Capture (ALC)

The core is able to detect the exact bit position in the Arbitration Field where the arbitration has been lost. This event can be signaled by the ALIF interrupt if it is enabled. The value of ALC stays unchanged if the node is able to win the arbitration. Then ALC holds the old value of the last loss of arbitration.

The value of ALC is defined as follows: A frame starts with the SOF bit and then the first bit of the ID is transmitted. This first ID bit has ALC value 0, the second ID bit ALC value 1 and so on.

Arbitration is only allowed in the arbitration field. Therefore, the maximum value of ALC is 31 which is the RTR bit in extended frames.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 77 of 360

Additional hint: If a standard remote frame arbitrates with an extended frame, then the extended frame loses arbitration at the IDE bit and ALC will be 12. The node transmitting the standard remote frame will not notice that an arbitration has been taken place, because this node has won.

It is impossible to get an arbitration loss outside of the arbitration field. Such an event is a bit error.

## 7.5.8.3 Kind of Error (KOER)

**NutoChips** 

The core recognizes errors on the CAN bus and stores the last error event in the KOER bits. A CAN bus error can be signaled by the BEIF interrupt if it is enabled. Every new error event overwrites the previous stored value of KOER. Therefore, the host controller has to react quickly on the error event.

## 7.5.9 Extended features

#### 7.5.9.1 Single shot transmission

Sometimes an automatic re-transmission is not desired. Therefore, the order to transmit a message only once can be set separately for the transmit buffers PTB by the bit TPSS and for the transmit buffer STB by the bit TSSS. In this case no re-transmission will be performed in the event of an error or arbitration lost if the selected transmission is active.

In the case of an immediate successful transmission, there is no difference to normal transmission. But in the case of an unsuccessful transmission, the following will happen:

- TPIF gets set if enabled, the appropriate transmit buffer slot gets cleared.
- In case of an error, KOER and the error counters get updated. BEIF gets set if BEIE is enabled and the other error interrupt flags will act accordingly.
- In case of a lost arbitration, ALIF gets set if ALIE is enable.

Therefore, for single shot transmission TPIF alone does not indicate if the frame has been successfully transmitted. Therefore, single shot transmission should only be used together with BEIF and ALIF.

If single shot transmission is used with TSALL and there is more than one frame in the STB then for each frame a single shot transmission is done. Regardless if any of the frames is not successfully transmitted (e.g. because of an ACK error), the CAN-CTRL advances to the next frame and stops if the STB is empty. Therefore, in this scenario only the error counters indicate what has happened. This can be quite complex to evaluate because if one of two frames got errors, the host cannot detect which one was the successful one.

If the bus is occupied by another frame, if a single shot transmission is started, then CAN-CTRL waits till the bus is idle and then tries to transmit the single shot frame.

## 7.5.9.2 Listen Only Mode (LOM)

LOM provides the ability of monitoring the CAN bus without any influence to the bus.

Another application is the automatic bit rate detection where the host controller tries different timing settings until no errors occur.

Errors will be monitored (KOER, BEIF) in LOM.

- In LOM, the core is not able to write dominant bits onto the bus (no active error flags or overload flags, no acknowledge). This is done using the following rules.
- In LOM, the protocol machine acts as if in error passive mode where only recessive error flags are generated. Only the protocol machine acts as if in error passive mode. All other components including the status registers are not touched.
- In LOM, the protocol machine does not generate a dominant ACK.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

• The error counters stay unchanged regardless of any error condition.

Important facts regarding ACKs for LOM:

**NutoChips** 

- If a frame is transmitted by a node, then an ACK visible at the bus will be only generated if at least one additional node is attached to the bus that is not in LOM. Then there will be no error and all nodes (also those in LOM) will receive the frame.
- If there is an active or passive error flag after an ACK error, then the node in LOM is able to detect this as ACK error.

Activation of LOM should not be done while a transmission is active. The host controller has to take care of this. There is not additional protection from CAN-CTRL.

If LOM is enabled, then no transmission can be started.

### 7.5.9.3 Bus connection test

To check if a node is connected to the bus, the following steps shall be done:

- Transmit a frame. If the node is connected to the bus, then its TX bits are visible on its RX input.
- If there are other nodes connected to the CAN bus, then a successful transmission (including an acknowledge from the other nodes) is expected. No error will be signaled.
- If the node is the only node that is connected to the CAN bus (but the connection between the bus, the transceiver and the CAN-CTRL core is fine), then the first regular error situation occurs in the ACK slot because of no acknowledge from other nodes. Then a BEIF error interrupt will be generated if enabled and KOER= "100" (ACK error).
- If the connection to the transceiver or the bus is broken, then immediately after the SOF bit the BEIF error interrupt will be set and KOER= "001" (BIT error).

## 7.5.9.4 Loop Back Mode (LBMI and LBME)

CAN-CTRL supports two Loop Back Modes: internal (LBMI) and external (LBME). Both modes result in reception of the own transmitted frame which can be useful for self-tests.

In LBMI, CAN-CTRL is disconnected from the CAN bus and the txd output is set to recessive. The output data stream is internally fed back to the input. In LBMI, the node generates a self-ACK to avoid an ACK error.

In LBME,CAN-CTRL stays connected to the transceiver and a transmitted frame will be visible on the bus. With the help of the transceiver, CAN-CTRL receives its own frame. In LBME, the node does not generate a self-ACK. Therefore, in LBME, there are two possible results upon a frame transmission:

- 1. Another node receives the frame too and generates an ACK. This will result in a successful transmission and reception.
- No other node is connected to the bus and this results in an ACK error. To avoid retransmissions and incrementing the error counters, it is recommended to use TPSS or TSSS if it is unknown if other nodes are connected.

In Loop Back Mode, the core receives its own message, stores it in the RBUF and sets the appropriate receive and transmit interrupt flags if enabled.

LBMI can be useful for chip-internal and software tests while LBME can test the transceiver and the connections to it.

Activation of both Loop Back Modes should not be done while a transmission is active. The host controller has to take care of this. There is not additional protection from CAN-CTRL.

If the node is connected to a CAN bus, then switching back from LBMI to normal operation must not be done by simply setting LBMI to 0, because then it may be that this occurs just at the moment while another CAN node is transmitting. In this case, switching back to normal operation shall be done by setting bit RESET to 1. This automatically clears LBMI to 0. Finally RESET can be disabled and the core returns back to normal operation. In contrast to this, LBME can be disabled every time.

## 7.5.9.5 Transceiver standby mode

**NutoChips** 

Using the register bit STBY, the output signal standby is driven. It can be used to activate a standby mode for a transceiver.

Once standby is activated, no transmission is possible and therefore TPE, TSONE and TSALL cannot be set. On the other hand, CAN-CTRL does not allow STBY to be set if a transmission is already active (TPE, TSONE or TSALL is set).

If STBY is set, the transceiver enters a low-power mode. In this mode, it is unable to receive a frame at full speed but monitors the CAN bus for a dominant state. If the dominant state is active for a time which is defined in the transceivers data sheet, the transceiver will pull the rxd signal low. If rxd is low, CAN-CTRL automatically clears STBY to 0 which disables standby mode for the transceiver. This is done silently without an interrupt to the host controller.

Switching from standby mode to active mode takes some time for the transceiver and therefore the initial wakeup frame cannot be received successfully. Therefore, the node recently being in standby will not respond with an ACK. If no CAN node at the bus responds to the wakeup frame with an ACK, then this results in an ACK error for the transmitter of the wakeup frame. Then the transmitter will automatically repeat the frame. During the repetition, the transceiver will be back in active mode and CAN-CTRL will receive the frame and will respond with an ACK.

In summary, one node transmits a frame for wakeup. If all others nodes are in standby mode, then the transmitter gets an ACK error and will automatically repeat the frame. During the repetition, the nodes are back in active mode and will respond with an ACK.

STBY is not affected by bit RESET.

#### 7.5.9.6 Error counter reset

According to the CAN standard RECNT counts receive errors and TECNT counts transmit errors. After too many transmit errors, a CAN node has to go to bus off state. This will activate the bit RESET. Deactivating the bit, RESET does not modify the errors counters or bus off state. The CAN specification defines rules how to disable bus off state and to decrease the error counters. A good node will recover from all of this automatically if only a temporary error has caused the problems. The classic CAN 2.0B specification requires this automatic behavior without host controller interaction to avoid the babbling idiot problem.

Writing a 1 to the bit BUSOFF resets the error counters and therefore forces the node to leave the bus off state. This is done without setting EIF.

## 7.5.10 Software reset

If bit RESET in CFG\_STAT is set to 1, then the software reset is active. Several components are forced to a reset state if RESET=1 but no all components are touched by RESET. Some components are only sensitive to a hardware reset. The reset values of all bits are always the same for software and hardware reset.

#### Table 7-9 Software reset

| Register | RESET | Comment                                                                                                                                                              |
|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RBUF     | (Yes) | All RB slots are marked as empty. RBUF contains unknown data.                                                                                                        |
| TBUF     | (Yes) | All STB slots are marked as empty. Because of TBSEL TBUF points to the PTB.                                                                                          |
| TTS      | No    | -                                                                                                                                                                    |
| LBME     | Yes   | -                                                                                                                                                                    |
| LBMI     | Yes   | -                                                                                                                                                                    |
| TPSS     | Yes   | -                                                                                                                                                                    |
| TSSS     | Yes   | -                                                                                                                                                                    |
| RACTIVE  | Yes   | Reception is immediately cancelled even if a reception is active. No ACK will be generated.                                                                          |
| TACTIVE  | Yes   | All transmissions are immediately terminated with RESET. If a transmission is active this will result in an erogenous frame. Other nodes will generate error frames. |
| BUSOFF   | No    |                                                                                                                                                                      |
| TBSEL    | Yes   | TBUF fixed to point to PTB.                                                                                                                                          |
| LOM      | Yes   |                                                                                                                                                                      |
| STBY     | No    | -                                                                                                                                                                    |
| TPE      | Yes   |                                                                                                                                                                      |
| TPA      | Yes   |                                                                                                                                                                      |
| TSONE    | Yes   |                                                                                                                                                                      |
| TSALL    | Yes   | -                                                                                                                                                                    |
| TSA      | Yes   | -                                                                                                                                                                    |
| TSNEXT   | Yes   | -                                                                                                                                                                    |
| TSMODE   | No    | -                                                                                                                                                                    |
| TSSTAT   | Yes   | All STB slots are marked as empty.                                                                                                                                   |
| ROM      | No    | -                                                                                                                                                                    |
| ROV      | Yes   | All RB slots are marked as empty.                                                                                                                                    |
| RREL     | Yes   | -                                                                                                                                                                    |
| RSTAT    | Yes   | All RB slots are marked as empty.                                                                                                                                    |
| RIE      | No    |                                                                                                                                                                      |
| ROIE     | No    |                                                                                                                                                                      |
| RFIE     | No    |                                                                                                                                                                      |
| RAFIE    | No    |                                                                                                                                                                      |
| TPIE     | No    |                                                                                                                                                                      |
| TSIE     | No    | -                                                                                                                                                                    |
| EIE      | No    |                                                                                                                                                                      |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 81 of 360

| Register | RESET | Comment                                                 |
|----------|-------|---------------------------------------------------------|
| TSFF     | Yes   | All STB slots are marked as empty.                      |
| RIF      | Yes   | -                                                       |
| ROIF     | Yes   | -                                                       |
| RFIF     | Yes   | -                                                       |
| RAFIF    | Yes   | -                                                       |
| TPIF     | Yes   | -                                                       |
| TSIF     | Yes   | -                                                       |
| EIF      | No    | -                                                       |
| AIF      | Yes   | -                                                       |
| EWARN    | No    | -                                                       |
| EPASS    | No    | -                                                       |
| EPIE     | No    | -                                                       |
| EPIF     | Yes   | -                                                       |
| ALIE     | No    | -                                                       |
| ALIF     | Yes   | -                                                       |
| BEIE     | No    |                                                         |
| BEIF     | Yes   | -                                                       |
| S_Seg_1  | No    | Register is writeable if RESET=1 and write-locked if 0. |
| S_Seg_2  | No    | Register is writeable if RESET=1 and write-locked if 0. |
| S_SJW    | No    | Register is writeable if RESET=1 and write-locked if 0. |
| S_PRESC  | No    | Register is writeable if RESET=1 and write-locked if 0. |
| AFWL     | No    | -                                                       |
| EWL      | Yes   |                                                         |
| KOER     | Yes   |                                                         |
| ALC      | Yes   |                                                         |
| RECNT    | No    |                                                         |
| TECNT    | No    |                                                         |
| SELMASK  | No    |                                                         |
| ACFADR   | No    |                                                         |
| AE_x     | No    |                                                         |
| ACODE_x  | No    | Register is writeable if RESET=1 and write-locked if 0. |
| AMASK_x  | No    | Register is writeable if RESET=1 and write-locked if 0. |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

## 7.5.1 CAN bit time

**NutoChips** 

CAN 2.0B defines data bit rates up to 1Mbit/s. For real life systems the data rates are limited by the used transceiver and the achievable clock frequency for the CAN-CTRL core which depends on the used target cell library.

The CAN-CTRL core can be programmed to arbitrarily chosen data rates only limited by the range of the bit settings in the appropriate bit timing and prescaler registers.



Figure 7-6 CAN Bit Timing Specifications

The CAN bit time *BT* consists of several segments as shown in Figure 7-6. Each segment consists of a number of time quanta units  $n_{TO}$ . The duration of a time quanta TQ is:

 $TQ = n_{prescaler} / f_{CLOCK}$ 

 $BT = n_{prescaler} * n_{TQ} / f_{CLOCK} = t_{Seg_1} + t_{Seg_2}$ 

The CAN specification requires several relationships between the segment lengths (Table 7-10) which results in relationships between  $t_{Seg_{-}1}$ ,  $t_{Seg_{t_{-}2}}$  and the maximum synchronization jump width  $t_{SJW}$ . Please note that Table 7-10 lists the minimum configuration ranges defined by the CAN specification.

| Table 7-10 CAN T | iming Segments |
|------------------|----------------|
|------------------|----------------|

| Segment    | Description                                                                                                                                         |  |  |  |  |  |  |  |  |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| SYNC_SEG   | Synchronization Segment = 1 TQ                                                                                                                      |  |  |  |  |  |  |  |  |
| PROP_SEG   | Propagation Segment<br>[18] TQ CAN 2.0 bit rate CAN FD not enabled<br>[148] TQ CAN 2.0 bit rate CAN FD enabled                                      |  |  |  |  |  |  |  |  |
| PHASE_SEG1 | Phase Buffer Segment 1         [18] TQ       CAN 2.0 bit rate       CAN FD not enabled         [116] TQ       CAN 2.0 bit rate       CAN FD enabled |  |  |  |  |  |  |  |  |
| PHASE_SEG2 | Phase Buffer Segment 2[28] TQCAN 2.0 bit rateCAN FD not enabled[216] TQCAN 2.0 bit rateCAN FD enabled                                               |  |  |  |  |  |  |  |  |
| SJW        | Synchronization Jump Width<br>[14] TQ CAN 2.0 bit rate CAN FD not enabled [116] TQ<br>CAN 2.0 bit rate CAN FD enabled                               |  |  |  |  |  |  |  |  |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

As can be seen in Figure 7-10 the CAN-CTRL core collects SYNC\_SEG, PROP\_SEG and PHASE\_SEG1 into one group and the length of the group is configurable with  $t_{Seg_1}$ . Table 7-11 lists the available configuration ranges. Please note that the CAN-CTRL core does not check if all rules are met and offers a wider configuration range than defined by the CAN specification.

| Setting            | Requirements                                 |                  |        |
|--------------------|----------------------------------------------|------------------|--------|
| t <sub>Seg_1</sub> | [265] TQ                                     | CAN 2.0 bit rate | (slow) |
| t <sub>Seg_2</sub> | [116] TQ $t_{Seg_l} \ge t_{Seg_2} + 2$       | CAN 2.0 bit rate | (slow) |
| t <sub>SJW</sub>   | [116] TQ $t_{Seg_2} \ge t_{SJW}$ CAN 2.0 bit | rate (slow)      |        |

#### Table 7-11 CAN-CTRL Timing Settings

For CAN 2.0 bit rate nominal bit rate the register settings S\_Seg\_1, S\_Seg\_2, S\_SJW and S\_PRESC define the appropriate segment lengths.

 $t_{Seg_{-}l} = (S_Seg_{-}l + 2) * TQ$  $t_{Seg_{-}2} = (S_Seg_{-}2 + 1) * TQ$ 

**NutoChips** 

 $I_{Seg_2} = (S_Seg_2 + 1) + IQ$ 

 $t_{SJW} = (S\_SJW + 1) * TQ$ 

 $n_{prescaler} = S\_PRESC + 1$ 

The following steps need to be carried for the configuration of the CAN-CTRL core:

- 1. Set bit RESET=1.
- 2. Set registers S\_Seg\_1 and S\_Seg\_2: In the example the data rate on the bus 1M baud and the system clock is 48 MHz. The values of  $n_{TQ}$  and  $n_{prescaler}$  have to be selected to fit *BT*.

In this example  $n_{prescaler} = 2$  and  $n_{TQ} = 24$  are chosen which results in a perfect match: BT = 24TQ.

the time segment definitions  $t_{Seg_1} = 18TQ$ ;  $t_{Seg_2} = 6TQ$  can be chosen as suitable values which finally results in the register settings S\_Seg\_1=16 and S\_Seg\_2=5.

3. Load the acceptance code and mask registers (optional).

4. Set register S\_SJW:

With  $t_{Seg 2} \ge t_{SJW}$  one is free to chose  $t_{SJW} = 4$  which finally results in 3.

- 5. Load the clock prescaler register S\_PRESC:  $n_{prescaler} = PRESC + 1$  results in S\_PRESC=1.
- 6. Set bit RESET=0.

The given order is not mandatory. It is merely necessary to set bit RESET=1 at the beginning, as it is otherwise not possible to load the bit timing, ACODE and AMASK registers. RESET=0 is required upon completion of the configuration. The controller then waits for 8 recessive bits (frame end) and resumes its normal operation.

7. Continue with configuration of interrupts other configuration bits and execute commands.

There are some sample tables for the bit timing settings that should apply to all nodes in a CAN network:

| Bit Rate[Mbit/s] | SP[%] | Prescaler | Bit Time[TQ] | Seg1 [TQ] | Seg2 [TQ] | SJW [TQ] |
|------------------|-------|-----------|--------------|-----------|-----------|----------|
| 1                | 75    | 2         | 24           | 18        | 6         | 4        |
| 0.8              | 75    | 3         | 20           | 15        | 5         | 4        |
| 0.5              | 75    | 4         | 24           | 18        | 6         | 4        |
| 0.25             | 75    | 8         | 24           | 18        | 6         | 4        |
| 0.125            | 75    | 16        | 24           | 18        | 6         | 4        |

Table 7-12 Sample settings for 48MHz can\_clk

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 84 of 360



| Bit Rate[Mbit/s] | SP[%] | Prescaler | Bit Time[TQ] | Seg1 [TQ] | Seg2 [TQ] | SJW [TQ] |  |
|------------------|-------|-----------|--------------|-----------|-----------|----------|--|
| 0.1              | 75    | 20        | 24           | 18        | 6         | 4        |  |

#### Table 7-13 Sample settings for 8MHz can\_clk

| Bit Rate[Mbit/s] | SP[%] | Prescaler | Bit Time[TQ] | Seg1 [TQ] | Seg2 [TQ] | SJW [TQ] |
|------------------|-------|-----------|--------------|-----------|-----------|----------|
| 1                | 75    | 1         | 8            | 6         | 2         | 2        |
| 0.8              | 80    | 1         | 10           | 8         | 2         | 2        |
| 0.5              | 75    | 1         | 16           | 12        | 4         | 4        |
| 0.25             | 75    | 2         | 16           | 12        | 4         | 4        |
| 0.125            | 75    | 4         | 16           | 12        | 4         | 4        |
| 0.1              | 75    | 4         | 20           | 15        | 5         | 4        |

# **//utoChips**

# 8 LIN

# 8.1 Introduction

The controller interfaces the local interconnect network (LINCORE), compliant with LIN Protocol Specification Revisions 1.3, 2.0, 2.1, and 2.2, which works in master and slave modes, and judges errors automatically.

# 8.2 Feature list

- LIN Protocol Specification Revisions 1.3, 2.0, 2.1, and 2.2.
- Classic checksum or enhanced checksum selectable.
- Autonomous header and response handling.
- Up to 8 data bytes in response field.
- Detects dominant level to produce wake-up signal.
- Resynchronizes clock in slave mode.
- 16 identifier filters in slave mode.
- Fractional baud rate generator.
- 3 operating modes for power saving and configuration registers lock:
  - o Initialization
  - o Normal
  - o Sleep
- 2 test mode
  - Loop back
  - o Self-test
- Error detection
  - o Bit error
  - o Checksum error
  - Frame timeout error
  - Physical bus error
  - Framing error
  - o Overrun error

# 8.3 Block diagram

The structure of the LINCORE is as follows.



Figure 8-1 LINCORE block diagram

# 8.4 Application note

# 8.4.1 Operating modes

LINCORE has three main operating modes: Initialization, Normal and Sleep.





AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 87 of 360

### 8.4.1.1 Initialization mode

The software sets the LM bits to 0x01 in the LINSYS to enter initialization mode, sets the LM bits to other value, either 0 or 2, to exit this mode.

In initialization mode, the software can set up work mode (master or slave mode), baud rate and filter function.

#### 8.4.1.2 Normal mode

After initialization, the software enters to normal mode by setting the LM bits to 0 in LINSYS.

### 8.4.1.3 Sleep mode

The LINCORE enters the sleep mode to reduce power consumption by setting the LM bits to 2. If auto-wake mode is enabled, software programs the LM bit or LINCORE detects the dominant level, and then LINCORE can exit sleep mode.

## 8.4.2 Test modes

The LINCORE has two test mode: loop back mode and self-test mode. They can be set by the LBM and STM bits in the LINCR1 in Initialization mode.

### 8.4.2.1 Loop back mode

In this mode, the LINCORE performs an internal feedback from its Tx output to its Rx input. The RX input pin is disconnected from the LINRX pin. The LINCORE can receive messages that itself sent in master mode, and the bus can receive messages.



Figure 8-3 Loop back mode

#### 8.4.2.2 Self-test mode

In this mode, the LINCORE performs an internal feedback from its Tx output to its Rx input. The RX input pin is disconnected from the LINRX pin, and the TX output pin is disconnected from the LINRTX pin. The LINCORE can receive messages that itself sent in master mode, and the bus cannot receive messages.

# **//utoChips**



Figure 8-4 Self-test mode

# 8.4.3 Baud rate generation

The LINCORE can work with different baud rate, using the Mantissa and Fraction registers.

Baud Rate = 
$$\frac{F_{bus}}{(16 \times DIV)}$$

DIV is calculated by the previous formula, for example:

 $F_{bus}$  = 48MHz, if set baud rate = 19200 DIV = 156.25 Mantissa = 156 Fraction = 0.25 \* 16 = 4 Actual baud rate = 19200, error = 0%

# 8.4.4 Error detection

LINCORE is able to detect and handle LIN communication errors. A code stored in the LIN error status register (LINESTS) signals the errors to the software.

- **Bit error:** during transmission, the value read back from the bus differs from the transmitted value.
- **Header error:** an error occurred during header reception in slave mode only (Break Delimiter error, Inconsistent Synch Field, Parity ID Error).
- **Framing error:** a dominant state has been sampled on the stop bit of the currently received character (sync field, identifier field or data field).
- Checksum error: the computed checksum does not match the received one.
- **Time out error:** header timeout is checked start from the end of sync byte stop bit to the end of the parity id stop bit, the minimum value is 11, the maximum value is 32. Check the response space timeout in the response time space with a maximum timeout value of 36. Response timeout is checked in the time space including response space, data field and the checksum field, the timeout value is set according to the data filed length.



#### Figure 8-5 The structure of a frame

## 8.4.5 Interrupt table

**NutoChips** 

#### Table 8-1 LIN interrupt table

| Interrupt event                       | Flag bit         | Enable control bit |
|---------------------------------------|------------------|--------------------|
| Header Transmitted/Received interrupt | HTRF             | HTRIE              |
| Data Transmitted interrupt            | DTF              | DTIE               |
| Data Received interrupt               | DRF              | DRIE               |
| Wake-up interrupt                     | WUF              | WUIE               |
| Buffer Overrun interrupt              | BOF              | BOIE               |
| Framing Error interrupt               | FEF              | FEIE               |
| Header Error interrupt                | IPEF, BDEF, SFEF | HEIE               |
| Checksum Error interrupt              | CEF              | CEIE               |
| Bit Error interrupt                   | BEF              | BEIE               |
| Time out interrupt                    | TOEF             | TOIE               |
| Long Zero interrupt                   | LZEF             | LZIE               |

## 8.4.6 Master mode

When the LINCR1[SM] bit is cleared, the master mode is selected. In the master mode, the application handles the messages from schedule table.



#### Figure 8-6 LIN bus structure

 $\ensuremath{\textcircled{\sc 0}}$  2013 - 2021 AutoChips Inc.

Page 90 of 360

## 8.4.6.1 Header transmission

Before requesting the header transmission, the application must set up the identifier, the data field length and configure the message (response direction and checksum type). Once the header has been transmitted, the header transmitted flag LINSTS[HRF] is set and an interrupt is generated if the LINIER[HTRIE] is enabled.

#### 8.4.6.2 Response transmission

If the response direction of a special identifier is publisher, the application must fill the data buffer before requesting the header transmission. The LINCORE transmits the data and the checksum according to the data field length and the checksum type. The LINSTS[DTF] bit is set if the response has been sent successfully, otherwise the DTF flag is not set if there are errors.

#### 8.4.6.3 Response reception

If the response direction is receiver, the LINCORE receives response that sending from slave node, after the header is received with a corresponding identifier. The LINSTS[DRF] is set if the response has been received successfully.

## 8.4.7 Slave mode

When the LINCR1[SM] bit is set, the slave mode is selected. In the slave mode, the LINCORE receives the headers from the master mode, then transmits or receives response.

#### 8.4.7.1 Header reception

The LINCORE detects break, break delimiter, sync field and identifier in slave mode. A valid break field is longer than 10 bits or 11 bits dominant time. After each LIN Break delimiter, the LINCORE detects five falling edges, then measures the baud rate when the re-synchronization function is enabled. This function makes the slave frequency tolerance to be better than  $\pm 14\%$ .



Figure 8-7 LIN header reception

After sync field, the LINCORE receives the identifier, check the parity data when the Manual Checksum is disable.

AutoChips Confidential © 2013 - 2021 AutoChips Inc.

Page 91 of 360

### 8.4.7.2 Response transmission

The application checks the identifier after receives the header, if the response direction is publisher, then fills the data buffer, sets the data field and triggers the data transmission by setting the LINCR2[RTR] bit. If the received identifier comes from an identifier filter, the software only needs to fill the data buffer before transmission. The LINSTS[DTF] bit is set If the response has been sent successfully.

#### 8.4.7.3 Response reception

If the response direction is receiver, the LINCORE receives response that sending from other node, after the header is received with a corresponding identifier. The LINSTS[DRF] is set, if the response has been received successfully.

### 8.4.7.4 Filters

16 identifier filters can be configured in filter mode, with each filter identify one identifier. These filters can be configured in mask mod to handle more identifiers. In this mode, the odd number filter registers are used as identifier registers, and the even number filter registers are used as mask registers. The mask register sets this bit to 1 to indicate that it is irrelevant and can be ignored. If you configured filter in mask mode with don't care bits, that means more than received identifiers will match this filter. Please make sure that these identifiers must have the same response direction, data length and checksum type.

# 8.4.8 Register definition

#### Table 8-2 LIN register map

| ADDRESS     | TITLE      | DESCRIPTION                                                            |
|-------------|------------|------------------------------------------------------------------------|
| LIN + 0x000 | LINSYS     | LIN system control register                                            |
| LIN + 0x004 | LINCTRL1   | LIN control register 1                                                 |
| LIN + 0x008 | LIN_CTRL2  | LIN control register 2                                                 |
| LIN + 0x00C | LINIEN     | LIN interrupt enable register                                          |
| LIN + 0x010 | LINSTS     | LIN status register                                                    |
| LIN + 0x014 | LINESTS    | LIN error status register                                              |
| LIN + 0x018 | LINTO1     | LIN time out ctrl register                                             |
| LIN + 0x01C | LINTO2     | LIN timeout ctrl register                                              |
| LIN + 0x020 | LINIBR     | LIN integer baud rate register                                         |
| LIN + 0x024 | LINFBR     | LIN fractional baud rate register                                      |
| LIN + 0x028 | LINCS      | LIN Checksum field register                                            |
| LIN + 0x02C | LINFRM     | LIN Frame Control register                                             |
| LIN + 0x030 | BDLR       | LIN Buffer data low register                                           |
| LIN + 0x034 | BDHR       | LIN Buffer data high register                                          |
| LIN + 0x038 | LIN_IFEN   | LIN ID filter enable register                                          |
| LIN + 0x03C | LIN_IFMR   | LIN ID filter mode register                                            |
| LIN + 0x040 | LIN_IFMI   | LIN ID filter match index register                                     |
| LIN + 0x044 | LIN_IFCR2n | LIN ID filter control register<br>Offsets: 0x0044–0x007C (8 registers) |

#### LIN: 0x40007000

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

| ADDRESS     | TITLE        | DESCRIPTION                                                            |
|-------------|--------------|------------------------------------------------------------------------|
| LIN + 0x080 | LIN_IFCR2n+1 | LIN ID filter control register<br>Offsets: 0x0048–0x0080 (8 registers) |

| 0x000 |    | LINSYS |    |    |    |    | LIN system control register |   |   |   |   |   |   |   |    |            |
|-------|----|--------|----|----|----|----|-----------------------------|---|---|---|---|---|---|---|----|------------|
| Bit   | 15 | 14     | 13 | 12 | 11 | 10 | 9                           | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0          |
| Name  |    |        |    |    |    |    |                             |   |   |   |   |   |   |   | L  | М          |
| Туре  |    |        |    |    |    |    |                             |   |   |   |   |   |   |   | WR |            |
| Reset |    |        |    |    |    |    |                             |   |   |   |   |   |   |   | 02 | <b>k</b> 2 |

| Bit(s) Mnemo    | nic Name | Description          |
|-----------------|----------|----------------------|
| [1:0] <b>LM</b> | LIN_MODE | 0x0 = Normal mode    |
|                 |          | 0x1 = Initial mode   |
|                 |          | 0x2 = Sleep mode     |
|                 |          | 0x3 = undefined mode |

| 0x004 | LINCT    | <u>RL1</u> |          | LIN control register 1 |      |     |    |    |          |    |          |          |          |          |          |    |
|-------|----------|------------|----------|------------------------|------|-----|----|----|----------|----|----------|----------|----------|----------|----------|----|
| Bit   | 31       | 30         | 29       | 28                     | 27   | 26  | 25 | 24 | 23       | 22 | 21       | 20       | 19       | 18       | 17       | 16 |
| Name  |          |            |          |                        |      |     |    |    | DIO<br>B |    | R        | IL       | R        | SL       | н        | IL |
| Туре  |          |            |          |                        |      |     |    |    | WI_<br>R |    | WI_R     |          | WI_R     |          | WI_R     |    |
| Reset |          |            |          |                        |      |     |    |    | 0        |    | 0        |          | 0        |          | 0        |    |
| Bit   | 15       | 14         | 13       | 12                     | 11   | 10  | 9  | 8  | 7        | 6  | 5        | 4        | 3        | 2        | 1        | 0  |
| Name  | BDL      | CS<br>M    | RSE      | AW<br>U                |      | BTL |    |    |          |    |          | BDT      | SC<br>M  | STM      | LB<br>M  | SM |
| Туре  | WI_<br>R | WI_<br>R   | WI_<br>R | WI_<br>R               | WI_R |     |    |    |          |    | WI_<br>R | WI<br>_R | WI_<br>R | WI_<br>R | WI_<br>R |    |
| Reset | 0        | 0          | 0        | 0                      | 3    |     |    |    |          |    | 0        | 0        | 0        | 0        | 0        |    |

| Bit(s)  | Mnemonic             | Name                      | Description                                                                                                                   |  |  |  |  |  |  |  |
|---------|----------------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0       | SM                   | Slave mode                | 0: Master mode                                                                                                                |  |  |  |  |  |  |  |
|         |                      |                           | 1 : Slave mode                                                                                                                |  |  |  |  |  |  |  |
| 1       | LBM                  | Loopback mode             | 0: Disable                                                                                                                    |  |  |  |  |  |  |  |
|         |                      |                           | 1 : Enable                                                                                                                    |  |  |  |  |  |  |  |
| 2       | 2 STM Self-test mode |                           | 0: Disable                                                                                                                    |  |  |  |  |  |  |  |
|         |                      |                           | 1 : Enable                                                                                                                    |  |  |  |  |  |  |  |
| 3       | SCM                  | Software control mode     | 0: Disable                                                                                                                    |  |  |  |  |  |  |  |
|         |                      |                           | 1 : Enable (not use filter)                                                                                                   |  |  |  |  |  |  |  |
| 4       | BLT                  | Break length threshold    | Break length threshold in slave mode                                                                                          |  |  |  |  |  |  |  |
|         |                      |                           | 0: 11-bit                                                                                                                     |  |  |  |  |  |  |  |
|         |                      |                           | 1 : 10-bit                                                                                                                    |  |  |  |  |  |  |  |
| [11:8]  | BTL                  | Break TX length           | Break field transmit length in mater mode                                                                                     |  |  |  |  |  |  |  |
|         |                      |                           | 0: 10-bit time                                                                                                                |  |  |  |  |  |  |  |
|         |                      |                           | 1: 11-bit time                                                                                                                |  |  |  |  |  |  |  |
|         |                      |                           | -                                                                                                                             |  |  |  |  |  |  |  |
|         |                      |                           | 15 : 25-bit time                                                                                                              |  |  |  |  |  |  |  |
| 12      | ATWU                 | AUTO_WAKEUP               | This bit controls the behavior of the LIN hardware during Sleep mode.                                                         |  |  |  |  |  |  |  |
|         |                      |                           | <ul><li>0 : The Sleep mode is exited on software.</li><li>1 : The Sleep mode is exited automatically by hardware on</li></ul> |  |  |  |  |  |  |  |
| AutoChi | ps Confidential      | © 2013                    | 3 - 2021 AutoChips Inc. Page 93 of 36                                                                                         |  |  |  |  |  |  |  |
|         |                      | This document contains in | formation that is proprietary to AutoChips Inc.                                                                               |  |  |  |  |  |  |  |

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit(s)  | Mnemonic | Name                   | Description                                                              |
|---------|----------|------------------------|--------------------------------------------------------------------------|
|         |          |                        | LINRX dominant state detection.                                          |
| 13      | RSE      | Re-synchronization     | LIN slave automatic resynchronization enable                             |
|         |          | enable                 | 0: Automatic re-synchronization disable.                                 |
|         |          |                        | 1 : Automatic re-synchronization enable.                                 |
| 14      | MCS      | Manual Checksum        | Disable the hardware checksum calculation                                |
|         |          | mode                   | 0: Hardware automatic checksum calculation                               |
|         |          |                        | 1 : SW manually load the checksum                                        |
| 15      | BDL      | Break delimiter length | Break delimiter length in master mode                                    |
|         |          |                        | 0: 1-bit                                                                 |
|         |          |                        | 1 : 4-bit                                                                |
| [17:16] | HIL      | Header inter length    | Header inter-byte length between sync field and PID field in master mode |
|         |          |                        | 0: 0-bit time                                                            |
|         |          |                        | 1: 2-bit time                                                            |
|         |          |                        | 2: 4-bit time                                                            |
|         |          |                        | 3: 8-bit time                                                            |
| [19:18] | RSL      | Response space length  | Response inter space length, only for master mode                        |
|         |          |                        | 0: 0-bit time                                                            |
|         |          |                        | 1: 1-bit time                                                            |
|         |          |                        | 2: 4-bit time                                                            |
|         |          |                        | 3 : 8-bit time                                                           |
| [21:20] | RIL      | Response inter length  | Response inter-byte length between response data                         |
|         |          |                        | 0: 0-bit time                                                            |
|         |          |                        | 1: 1-bit time                                                            |
|         |          |                        | 2: 2-bit time                                                            |
|         |          |                        | 3 : 4-bit time                                                           |
| [23]    | DIOB     | Disable IDLE on bit    | LIN state machine goes to IDLE on bit error detection                    |
|         |          | error                  | 0: Enable IDLE on bit error                                              |
|         |          |                        | 1 : Disable IDLE on bit error                                            |

0x008 LIN\_CTRL2

LIN control register 2

| Bit   | 7 | 6 | 5 | 4    | 3    | 2    | 1 | 0    |
|-------|---|---|---|------|------|------|---|------|
| Name  |   |   |   | WTR  | RDR  | RTR  |   | HTR  |
| Туре  |   |   |   | W_R0 | W_R0 | W_R0 |   | W_R0 |
| Reset |   |   |   | 0    | 0    | 0    |   | 0    |

| Bit(s) | Mnemonic | Name                | Description                                                                                                                                                                          |
|--------|----------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | HTR      | Header TX request   | Header Transmission Request (write 1)<br>Set by software to request the transmission of the LIN<br>header.<br>Cleared by hardware when the request has been completed<br>or aborted. |
|        |          |                     | <b>Note:</b> This bit can be written when LIN core is in normal mode (LINSYS.LM=0)                                                                                                   |
| 2      | RTR      | Response TX request | Data Transmission Request (write 1)                                                                                                                                                  |
|        |          |                     | Set by software in Slave mode to request the transmission o<br>the LIN Data field stored in the Buffer data register. This bit<br>can be set only when HRF bit in LINSTS is set.     |
|        |          |                     | Cleared by hardware when the request has been completed or aborted or on an error condition.                                                                                         |
|        |          |                     | In Master mode, this bit is set by hardware when                                                                                                                                     |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

| Bit(s) | Mnemonic | Name              | Description                                                                                                                                                                                                                                                                                                                                                            |
|--------|----------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |          |                   | LINFRM[DIR] = 1 and header transmission is completed.                                                                                                                                                                                                                                                                                                                  |
|        |          |                   | <b>Note:</b> This bit can be written when LIN core is in normal mode (LINSYS.LM=0)                                                                                                                                                                                                                                                                                     |
| 3      | RDR      | Response Discard  | Response Discard Request (write 1)                                                                                                                                                                                                                                                                                                                                     |
|        |          | Request           | Set by software to stop data reception if the frame does not concern the node. This bit is reset by hardware once LIN has moved to idle state.                                                                                                                                                                                                                         |
|        |          |                   | In Slave mode, this bit can be set only when HRF bit in LINSTS is set and identifier did not match any filter.                                                                                                                                                                                                                                                         |
|        |          |                   | <b>Note:</b> This bit can be written when LIN core is in normal mode (LINSYS.LM=0)                                                                                                                                                                                                                                                                                     |
| 4      | WUTR     | Wakeup TX request | Wake-up TX Request (write 1)                                                                                                                                                                                                                                                                                                                                           |
|        |          |                   | Setting this bit generates a wake-up pulse. It is reset by<br>hardware when the wake-up character has been transmitted.<br>The character sent is copied from DATA0 in TX buffer. Note<br>that this bit cannot be set in Sleep mode. Software has to<br>exit Sleep mode before requesting a wake-up. Bit error is not<br>checked when transmitting the wake-up request. |
|        |          |                   | <b>Note:</b> This bit can be written when LIN core is in normal mode (LINSYS.LM=0)                                                                                                                                                                                                                                                                                     |

0x00C LINIEN

#### LIN interrupt enable register

| Bit   | 15   | 14   | 13   | 12   | 11   | 10 | 9    | 8    | 7 | 6 | 5    | 4 | 3 | 2    | 1    | 0     |
|-------|------|------|------|------|------|----|------|------|---|---|------|---|---|------|------|-------|
| Name  | LZIE | TOIE | BEIE | CEIE | HEIE |    | BOIE | FEIE |   |   | WUIE |   |   | DRIE | DTIE | HTRIE |
| Туре  | RW   | RW   | RW   | RW   | RW   |    | RW   | RW   |   |   | RW   |   |   | RW   | RW   | RW    |
| Reset | 0    | 0    | 0    | 0    | 0    |    | 0    | 0    |   |   | 0    |   |   | 0    | 0    | 0     |

| Bit(s)  | Mnemonic        | Name                         | Description                                                                                                                      |  |  |  |  |
|---------|-----------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0       | HRIE            | Header Received              | Header Received Interrupt Enable                                                                                                 |  |  |  |  |
|         |                 | Interrupt Enable             | 0 : No interrupt when a valid LIN header has been received.                                                                      |  |  |  |  |
|         |                 |                              | 1 : Interrupt generated when a valid LIN header has been received, that is, HRF bit in LINSTS is set.                            |  |  |  |  |
| 1       | RTIE            | Response Transmitted         | Response Transmitted Interrupt Enable                                                                                            |  |  |  |  |
|         |                 | Interrupt Enable             | 0 : No interrupt when data transmission is completed.                                                                            |  |  |  |  |
|         |                 |                              | 1 : Interrupt generated when data transmitted flag (DTF) is set in LINSTS.                                                       |  |  |  |  |
| 2       | RRIE            | Response Reception           | Response Reception Complete Interrupt Enable                                                                                     |  |  |  |  |
|         |                 | Complete Interrupt<br>Enable | 0 : No interrupt when data reception is completed.<br>1 : Interrupt generated when data received flag (DRF) in<br>LINSTS is set. |  |  |  |  |
| 5       | WUIE            | Wake-up Interrupt Enable     | Wake-up Interrupt Enable                                                                                                         |  |  |  |  |
|         |                 |                              | 0 : No interrupt when WUF bit in LINSTS is set.                                                                                  |  |  |  |  |
|         |                 |                              | 1 : Interrupt generated when WUF bit in LINSTS is set.                                                                           |  |  |  |  |
| 8       | FEIE            | Framing Error Interrupt      | Framing Error Interrupt Enable                                                                                                   |  |  |  |  |
|         |                 | Enable                       | 0 : No interrupt on Framing error.                                                                                               |  |  |  |  |
|         |                 |                              | 1 : Interrupt generated on Framing error.                                                                                        |  |  |  |  |
| 9       | BOIE            | Buffer Overrun Interrupt     | Buffer Overrun Interrupt Enable                                                                                                  |  |  |  |  |
|         |                 | Enable                       | 0 : No interrupt on Buffer overrun.                                                                                              |  |  |  |  |
|         |                 |                              | 1 : Interrupt generated on Buffer overrun.                                                                                       |  |  |  |  |
| 11      | HEIE            | Header Error Interrupt       | Header Error Interrupt Enable                                                                                                    |  |  |  |  |
|         |                 | Enable                       | 0 : No interrupt on Break Delimiter error, Synch Field error<br>Identifier field error.                                          |  |  |  |  |
|         |                 |                              | 1 : Interrupt generated on Break Delimiter error, Synch Field                                                                    |  |  |  |  |
| AutoChi | ps Confidential | © 2013 -                     | 2021 AutoChips Inc. Page 95 of 360                                                                                               |  |  |  |  |
|         |                 |                              |                                                                                                                                  |  |  |  |  |

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit(s) | Mnemonic | Name                       | Description                                                               |
|--------|----------|----------------------------|---------------------------------------------------------------------------|
|        |          |                            | error, Identifier field error.                                            |
| 12     | CEIE     | Checksum Error Interrup    | Checksum Error Interrupt Enable                                           |
|        |          | Enable                     | 0 : No interrupt on Checksum error.                                       |
|        |          |                            | 1 : Interrupt generated when checksum error flag (CEF) in LINESTS is set. |
| 13     | BEIE     | Bit Error Interrupt Enable | Bit Error Interrupt Enable                                                |
|        |          |                            | 0 : No interrupt when BEF bit in LINESTS is set.                          |
|        |          |                            | 1 : Interrupt generated when BEF bit in LINESTS is set.                   |
| 14     | TOIE     | Timeout Interrupt Enable   | Timeout Interrupt Enable                                                  |
|        |          |                            | 0 : No interrupt when TOEF is set.                                        |
|        |          |                            | 1 : Interrupt generated when TOEF is set.                                 |
| 15     | LZIE     | Long Zero Error Interrupt  | Long Zero Error Interrupt Enable                                          |
|        |          | Enable                     | 0 : No interrupt when LZEF is set.                                        |
|        |          |                            | 1 : Interrupt generated when LZEF is set.                                 |

| 0x010 <u>I</u> |    | <u>s</u> |    | I  | LIN status register |      |   |   |   |      |      |     |     |     |     |      |
|----------------|----|----------|----|----|---------------------|------|---|---|---|------|------|-----|-----|-----|-----|------|
| Bit            | 15 | 14       | 13 | 12 | 11                  | 10   | 9 | 8 | 7 | 6    | 5    | 4   | 3   | 2   | 1   | 0    |
| Name           |    |          |    |    |                     | LINS |   |   |   | RRIP | RTIP | RPS | WUF | DRF | DTF | HTRF |
| Туре           |    |          |    |    |                     | R    |   |   |   | R    | R    | R   | W1C | W1C | W1C | W1C  |
| Reset          |    |          |    |    |                     | 0    |   |   |   | 0    | 0    | 0   | 0   | 0   | 0   | 0    |

| Bit(s) | Mnemonic              | Name                  | Description                                                                                                                                       |  |  |  |  |  |  |  |
|--------|-----------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0      | HRF                   | Header Transmission   | Header Transmission/ Reception Flag                                                                                                               |  |  |  |  |  |  |  |
|        |                       | Reception Flag        | This bit is set by hardware and indicates a valid header reception is completed.                                                                  |  |  |  |  |  |  |  |
|        |                       |                       | This bit must be cleared by software.                                                                                                             |  |  |  |  |  |  |  |
|        |                       |                       | This bit is reset by hardware in Initialization mode and at encount of completed.                                                                 |  |  |  |  |  |  |  |
| 1      | DTF Data Transmission |                       | Data Transmission Completed Flag                                                                                                                  |  |  |  |  |  |  |  |
|        |                       | Completed Flag        | This bit is set by hardware and indicates the data transmission is completed.                                                                     |  |  |  |  |  |  |  |
|        |                       |                       | This bit must be cleared by software and the next frame's<br>header received event.                                                               |  |  |  |  |  |  |  |
|        |                       |                       | It is reset by hardware in Initialization mode.                                                                                                   |  |  |  |  |  |  |  |
| 2      | DRF Data Reception    |                       | Data Reception Completed Flag                                                                                                                     |  |  |  |  |  |  |  |
|        | 2                     | Completed Flag        | This bit is set by hardware and indicates the data reception is completed.                                                                        |  |  |  |  |  |  |  |
|        |                       |                       | This bit must be cleared by software.                                                                                                             |  |  |  |  |  |  |  |
|        |                       |                       | It is reset by hardware in Initialization mode.                                                                                                   |  |  |  |  |  |  |  |
|        |                       |                       | Note: This flag is not set in case of bit error or framing error.                                                                                 |  |  |  |  |  |  |  |
| 3      | WUF                   | Wake-up Flag          | Wake-up Flag                                                                                                                                      |  |  |  |  |  |  |  |
|        |                       |                       | This bit is set by hardware and indicates to the software that LIN has detected a falling edge on the LINRX pin when:                             |  |  |  |  |  |  |  |
|        |                       |                       | <ul> <li>Slave is in Sleep mode.</li> </ul>                                                                                                       |  |  |  |  |  |  |  |
|        |                       |                       | <ul> <li>Master is in Sleep mode or idle state.</li> </ul>                                                                                        |  |  |  |  |  |  |  |
|        |                       |                       | This bit must be cleared by software. It is reset by hardware<br>in Initialization mode. An interrupts generated if WUIE bit in<br>LINIER is set. |  |  |  |  |  |  |  |
| 4      | PS                    | LIN receive pin state | LIN receive pin state                                                                                                                             |  |  |  |  |  |  |  |
|        |                       |                       | This bit reflects the current status of LINRX pin for diagnost<br>purposes                                                                        |  |  |  |  |  |  |  |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

| Bit(s) | Mnemonic | Name                    | Description                                                                                                                                                                               |
|--------|----------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5      | RTIP     | Response TX In Progress | Response TX in Progress<br>LIN is in Transmitting data                                                                                                                                    |
| 6      | RRIP     | Response RX In Progress | Response RX in Progress<br>LIN is Transmitting data                                                                                                                                       |
| 7      | RSV      | Reserved                | Reserved                                                                                                                                                                                  |
| [11:8] |          | LIN mode status         | LIN mode status                                                                                                                                                                           |
| [11.0] | 010      |                         | 0000: Idle                                                                                                                                                                                |
|        |          |                         | This state is entered on several events:                                                                                                                                                  |
|        |          |                         | <ul> <li>SLEEP bit and INIT bit in LIN_SYS_CTRL have been<br/>cleared by software.</li> </ul>                                                                                             |
|        |          |                         | - A falling edge has been received on RX pin and AWUM bit is set.                                                                                                                         |
|        |          |                         | <ul> <li>The previous frame reception or transmission has been<br/>completed or aborted.</li> </ul>                                                                                       |
|        |          |                         | 001: Break                                                                                                                                                                                |
|        |          |                         | In Slave mode, a falling edge followed by a dominant state has been detected. Receiving Break.                                                                                            |
|        |          |                         | <b>Note:</b> In Slave mode, in case of error new LIN state can be<br>either Idle or Break depending on last bit state. If last bit is<br>dominant new LIN state is Break, otherwise Idle. |
|        |          |                         | In Master mode, Break transmission ongoing.                                                                                                                                               |
|        |          |                         | 0010: Break Delimiter                                                                                                                                                                     |
|        |          |                         | In Slave mode, a valid Break has been detected for break length configuration (10-bit or 11-bit). Waiting for a rising edge.                                                              |
|        |          |                         | In Master mode, Break transmission has been completed.<br>Break Delimiter transmission is ongoing.                                                                                        |
|        |          |                         | 0011: Synch Field                                                                                                                                                                         |
|        |          |                         | In Slave mode, a valid Break Delimiter has been detected (recessive state for at least one bit time). Receiving Synch Field.                                                              |
|        |          |                         | In Master mode, Synch Field transmission is ongoing.                                                                                                                                      |
|        |          |                         | 0100: Parity Identifier Field                                                                                                                                                             |
|        |          |                         | In Slave mode, a valid Synch Field has been received.<br>Receiving Identifier Field.                                                                                                      |
|        |          |                         | In Master mode, identifier transmission is ongoing.                                                                                                                                       |
|        |          |                         | 0101: Header reception/transmission completed                                                                                                                                             |
|        |          |                         | In Slave mode, a valid header has been received and identifier field is available.                                                                                                        |
|        |          |                         | In Master mode, header transmission is completed.                                                                                                                                         |
|        |          |                         | 0110: Data reception/transmission Field                                                                                                                                                   |
|        |          |                         | Response reception/transmission is ongoing.<br>0111: Checksum                                                                                                                             |
|        |          |                         | Data reception/transmission completed. Checksum reception/transmission ongoing.                                                                                                           |
|        |          |                         | 1111: Wake up transmission field.                                                                                                                                                         |
|        |          |                         | Wake up transmission ongoing.                                                                                                                                                             |

0x014 LINESTS

LIN error status register

|       |    |    |    |    | _  |    |      | - J  | -   |     |      |      |      |     |     |     |
|-------|----|----|----|----|----|----|------|------|-----|-----|------|------|------|-----|-----|-----|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8    | 7   | 6   | 5    | 4    | 3    | 2   | 1   | 0   |
| Name  |    |    |    |    |    |    | LZEF | TOEF | BEF | CEF | SFEF | BDEF | IPEF | FEF | BOF | NF  |
| Туре  |    |    |    |    |    |    | W1C  | W1C  | W1C | W1C | W1C  | W1C  | W1C  | W1C | W1C | W1C |
| Reset |    |    |    |    |    |    | 0    | 0    | 0   | 0   | 0    | 0    | 0    | 0   | 0   | 0   |

AutoChips Confidential

#### © 2013 - 2021 AutoChips Inc.

Page 97 of 360

| Bit(s) | Mnemonic | Name                         | Description                                                                                                                                                                                                                                                                                       |
|--------|----------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | NF       | Noise Flag                   | This bit is set by hardware when noise is detected on a received character.                                                                                                                                                                                                                       |
|        |          |                              | Note: This bit needs to be cleared by software.                                                                                                                                                                                                                                                   |
| 1      | BOF      | Buffer Overrun Flag          | This bit is set by hardware when a new data byte is received<br>and the buffer full flag is not cleared.                                                                                                                                                                                          |
|        |          |                              | Note: This bit needs to be cleared by software.                                                                                                                                                                                                                                                   |
| 2      | FEF      | Framing Error Flag           | This bit is set by hardware and indicates to the software that LINCORE has detected a framing error (invalid stop bit). This error can occur during reception of any data in the response field (Master or Slave mode) or during reception of Synch Field or Identifier Field in Slave mode.      |
| 3      | IPEF     | Identifier Parity Error Flag | This bit is set by hardware and indicates that an identifier Parity error occurred.                                                                                                                                                                                                               |
|        |          |                              | <b>Note:</b> Header interrupt is triggered when SFEF or BDEF or IPEF bit is set and HEIE bit in LINIEN is set.                                                                                                                                                                                    |
| 4      | BDEF     | Break Delimiter Error Flag   | Break Delimiter Error Flag<br>This bit is set by hardware and indicates that the received<br>Break Delimiter is too short (less than one bit time).                                                                                                                                               |
| 5      | SFEF     | Synch Field Error Flag       | <b>Synch Field Error Flag</b><br>This bit is set by hardware and indicates that a Synch Field<br>error occurred (inconsistent Synch Field).                                                                                                                                                       |
| 6      | CEF      | Checksum Error Flag          | This bit is set by hardware and indicates that the received checksum does not match the hardware calculated checksum.<br><b>Note:</b> This bit needs to be cleared by software.                                                                                                                   |
| 7      | BEF      | Bit Error Flag               | This bit is set by hardware and indicates to the software that<br>LINC has detected a bit error. This error can occur during<br>response field transmission (Slave and Master modes) or<br>during header transmission (in Master mode).<br><b>Note:</b> This bit needs to be cleared by software. |
| 8      | TOEF     | Time Out Error Flag          | Time out Error event occurs either for header time out or response time out.                                                                                                                                                                                                                      |
| 9      | LZEF     | Long Zero Error Flag         | This bit is set by hardware when the bus is dominant for<br>more than a 256-bit time. If the dominant state continues. It<br>is cleared by software.                                                                                                                                              |

0x018 <u>LINTO1</u>

LIN time out ctrl register

|       |    |    |    |    |    |    |   |   | 1 |   |   |   |    |    |   |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|----|----|---|---|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2  | 1 | 0 |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | H  | го |   |   |
| Туре  |    |    |    |    |    |    |   |   |   |   |   |   | WI | _R |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0x | 18 |   |   |

| Bit(s) Mnemonic   | Name                 | Description                                                                                                                                            |
|-------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5:0] <b>HTOV</b> | header timeout value | This field contains the header timeout duration (in bit time).<br>This value does not include the Break and the Break<br>Delimiter and the sync field. |
|                   |                      | <b>Note:</b> if the written value is less than or equal to 11, the value will be overrode as 11                                                        |

AutoChips Confidential



| 0x01C LINTO2 | LIN timeout ctrl register |
|--------------|---------------------------|
|              |                           |

| Bit   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|-------|---|---|---|---|---|---|---|------|
| Name  |   |   |   |   |   |   |   | TOEN |
| Туре  |   |   |   |   |   |   |   | WI   |
| Reset |   |   |   |   |   |   |   | 0    |
|       |   |   |   |   |   |   |   |      |

| Bit(s) Mnemonic | Name            | Description                                             |
|-----------------|-----------------|---------------------------------------------------------|
| 0 <b>TOEN</b>   | Time out enable | <b>Time out enable bit</b><br>0 : Disable<br>1 : Enable |

| 0x020 <u> </u> | LINIB | <u>२</u> |    | LIN | integer baud rate register |    |   |  |   |   |  |    |    |   |   |   |   |   |   |
|----------------|-------|----------|----|-----|----------------------------|----|---|--|---|---|--|----|----|---|---|---|---|---|---|
| Bit            | 15    | 14       | 13 | 12  | 11                         | 10 | 9 |  | 8 | 7 |  | 6  | 5  | 4 | 3 | 2 | 1 | ( | 0 |
| Name           |       |          |    |     |                            |    |   |  |   |   |  | 11 | BR |   |   |   |   |   |   |
| Туре           |       |          |    |     |                            | WR |   |  |   |   |  |    |    |   |   |   |   |   |   |
| Reset          |       |          |    |     |                            |    |   |  |   |   |  |    | 0  |   |   |   |   |   |   |

| Bit(s) Mnemonic   | Name                           | Description                                                                              |
|-------------------|--------------------------------|------------------------------------------------------------------------------------------|
| [11:0] <b>IBR</b> | Integer Baud Rate divide value | Integer Baud Rate divide value<br>This field can be written in Initialization mode only. |

| 0x024 | LINFB | R  |    | LIN fractional baud rate register |    |    |   |   |   |   |   |   |     |    |    |   |
|-------|-------|----|----|-----------------------------------|----|----|---|---|---|---|---|---|-----|----|----|---|
| Bit   | 15    | 14 | 13 | 12                                | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2  | 1  | 0 |
| Name  |       |    |    |                                   |    |    |   |   |   |   |   |   | FBR |    |    |   |
| Туре  |       |    |    |                                   |    |    |   |   |   |   |   |   |     | WI | _R |   |
| Reset |       |    |    |                                   |    |    |   |   |   |   |   |   |     | (  | )  |   |

| Bit(s) Mnemonic  | Name                      | Description                                            |
|------------------|---------------------------|--------------------------------------------------------|
| [3:0] <b>FBR</b> | Fraction Baud Rate divide | Fraction Baud Rate divide value                        |
|                  | value                     | This field can be written in Initialization mode only. |

| 0x028 <u> </u> | 28 LINCS LIN Checksum field register |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|--------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit            | 15                                   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           |                                      |    |    |    |    |    |   |   |   |   |   | С | S |   |   |   |
| Туре           |                                      |    |    |    |    |    |   |   |   |   |   | R | W |   |   |   |
| Reset          |                                      |    |    |    |    |    |   |   |   |   |   | ( | ) |   |   |   |
|                |                                      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) Mnemonic | Name           | Description                                                             |
|-----------------|----------------|-------------------------------------------------------------------------|
| [7:0] <b>CS</b> | Checksum Field | Checksum field                                                          |
|                 |                | Read only in auto checksum mode.                                        |
|                 |                | Read and write in manual checksum mode if the LINCTRL1. CSM bit is set. |

0x02C LINFRM LIN Frame Control register

| Bit   | 15 | 14 | 13 | 12 | 11  | 10 | 9   | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|-----|----|-----|-----|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    | DFL |    | DIR | CST |   |   |   |   | I | D |   |   |
| Туре  |    |    |    |    | RW  |    | RW  | RW  |   |   |   |   | R | W |   |   |
| Reset |    |    |    |    | 0   |    | 0   | 0   |   |   |   |   | ( | ) |   |   |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 99 of 360

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit(s)  | Mnemonic | Name              | Description                                                                                                                                                                                                                                                                                                                                           |
|---------|----------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5:0]   | ID       | Identifier        | Identifier part of the identifier field without the identifier parity.                                                                                                                                                                                                                                                                                |
| 8       | CST      | Checksum type     | <ul> <li>This bit controls the type of checksum applied on the current message.</li> <li>0 : Enhanced Checksum covering Identifier and Data fields.</li> <li>This is compatible with LIN specification 2.0 and higher.</li> <li>1 : Classic Checksum covering Data fields only. This is compatible with LIN specification 1.3 and earlier.</li> </ul> |
| 9       | DIR      | Direction         | This bit controls the direction of the data field.<br>0 : LIN receives the data and copies them in the BDRL and<br>BDRH registers.<br>1 :LIN transmits the data from the BDRL and BDRH registers.                                                                                                                                                     |
| [12:10] | DFL      | Data field length | This field defines the number of data bytes in the response<br>part of the frame. The value range 0-7 represents 1-8 bytes of<br>data respectively. The master and slave need to configure<br>this register.                                                                                                                                          |

0x030 <u>BDLR</u>

Buffer data low register

| Bit   | 31 | 30 | 29 | 28   | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18 | 17 | 16 |
|-------|----|----|----|------|----|----|----|----|----|----|----|----|-----|----|----|----|
| Name  |    |    |    | DATA | 13 |    |    |    |    |    |    | DA | TA2 |    |    |    |
| Туре  |    |    |    | RW   |    |    |    |    |    |    |    | R  | W   |    |    |    |
| Reset |    |    |    | 0    |    |    |    |    |    |    |    |    | 0   |    |    |    |
| Bit   | 15 | 14 | 13 | 12   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3   | 2  | 1  | 0  |
| Name  |    |    |    | DATA | \1 |    |    |    |    |    |    | DA | TA0 |    |    |    |
| Туре  |    | RW |    |      |    |    |    | RW |    |    |    |    |     |    |    |    |
| Reset |    | 0  |    |      |    |    |    | 0  |    |    |    |    |     |    |    |    |

0x034 <u>BDHR</u>

LIN Buffer data high register

| Bit   | 31 | 30 | 29 | 28   | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18 | 17 | 16 |
|-------|----|----|----|------|----|----|----|----|----|----|----|----|-----|----|----|----|
| Name  |    |    |    | DATA | \7 |    |    |    |    |    |    | DA | TA6 |    |    |    |
| Туре  |    |    |    | RW   |    |    |    |    |    |    |    | R  | W   |    |    |    |
| Reset |    |    |    | 0    |    |    |    |    |    |    |    |    | 0   |    |    |    |
| Bit   | 15 | 14 | 13 | 12   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3   | 2  | 1  | 0  |
| Name  |    |    |    | DATA | \5 |    |    |    |    |    |    | DA | TA4 |    |    |    |
| Туре  |    |    |    | RW   |    |    |    |    |    |    |    | R  | W   |    |    |    |
| Reset |    | 0  |    |      |    |    |    | 0  |    |    |    |    |     |    |    |    |

| 0x038 <u> </u> | _IN_IF | <u>IN_IFEN</u> LIN ID filter enable register |    |    |    |    |   |   |    |   |   |   |   |   |   |   |
|----------------|--------|----------------------------------------------|----|----|----|----|---|---|----|---|---|---|---|---|---|---|
| Bit            | 15     | 14                                           | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           |        |                                              |    |    |    |    |   |   | EN |   |   |   |   |   |   |   |
| Туре           |        |                                              |    |    |    |    |   | F | RM |   |   |   |   |   |   |   |
| Reset          |        |                                              |    |    |    |    |   |   | 0  |   |   |   |   |   |   |   |

| Bit(s) Mnemonic  | Name                 | Description                                                                                                                                                                                                                                                             |
|------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:0] <b>EN</b> | Filter Number Enable | Filter Number start from 0 to 15.<br>In list mode, each EN corresponds to each filter.<br>In mask mode, EN [2n+1] have no effect on the<br>corresponding filters as they act as the masks for the filter<br>2n.<br>0 : filter is deactivated<br>1 : filter is activated |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 100 of 360



#### 0x03C LIN IFMR LIN ID filter mode register

| Name         IFM           Type         RW | Bit   | 7 | 7 6 5 4 3 2 1 0 |  |     |  |   |   |   |  |  |  |  |
|--------------------------------------------|-------|---|-----------------|--|-----|--|---|---|---|--|--|--|--|
| Type RW                                    | Name  |   | -               |  | IFM |  | - | - | - |  |  |  |  |
|                                            | Туре  |   | RW              |  |     |  |   |   |   |  |  |  |  |
| Reset 0                                    | Reset |   | 0               |  |     |  |   |   |   |  |  |  |  |

| Bit(s) Mnemonic  | Name           | Description                                                                                                                                                                                                                              |
|------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] <b>IFM</b> | ID filter Mode | 0 : Filters 2n and 2n + 1 are in identifier filter mode.<br>1 : Filters 2n and 2n + 1 are in mask mode (filter 2n + 1 is<br>the mask for the filter 2n).<br><b>Note</b> : "n" ranges from 0 to 7, corresponds to the bit index of<br>IFM |

0x040 LIN\_IFMI

LIN ID filter match index register

| Bit   | 7 | 6 | 5 | 4 | 3 | 2         | 1 | 0 |
|-------|---|---|---|---|---|-----------|---|---|
| Name  |   |   |   |   |   | IFMI[4:0] |   |   |
| Туре  |   |   |   |   |   | RW        |   |   |
| Reset |   |   |   |   |   | 0         |   |   |

| Bit(s) Mnemonic   | Name                  | Description                                                                                                                                                                                                                      |
|-------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] <b>IFMI</b> | ID filter Match Index | This register contains the index corresponding to the received identifier. It can be used to directly write or read the data in SRAM. When no filter matches, $IFMI[4:0] = 0$ . When Filter n is matching, $IFMI[4:0] = n + 1$ . |

#### 0x044 LIN\_IFCR2n LIN ID filter control register Offsets: 0x0044-0x007C (8 registers)

| Bit   | 15 | 14 | 13 | 12 | 11     | 10 | 9  | 8  | 7 | 6 | 5  | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|--------|----|----|----|---|---|----|---|---|---|---|---|
| Name  |    |    |    |    | DFL DI |    |    |    |   |   | ID |   |   |   |   |   |
| Туре  |    |    |    |    | RW     |    | RW | RW |   |   | RW |   |   |   |   |   |
| Reset |    |    |    |    | 0      |    | 0  | 0  |   |   | 0  |   |   |   |   |   |

| Bit(s)  | Mnemonic | Name              | Description                                                                                                                                                                                                                                                                                                                                           |
|---------|----------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5:0]   | ID       | Identifier        | Identifier part of the identifier field without the identifier parity.                                                                                                                                                                                                                                                                                |
| 8       | CST      | Checksum Type     | <ul> <li>This bit controls the type of checksum applied on the current message.</li> <li>0 : Enhanced Checksum covering Identifier and Data fields.</li> <li>This is compatible with LIN specification 2.0 and higher.</li> <li>1 : Classic Checksum covering Data fields only. This is compatible with LIN specification 1.3 and earlier.</li> </ul> |
| 9       | DIR      | Direction         | This bit controls the direction of the data field.<br>0 : LIN receives the data and copies them in the BDRL and<br>BDRH registers.<br>1 : LIN transmits the data from the BDRL and BDRH<br>registers.                                                                                                                                                 |
| [12:10] | DFL      | Data Field Length | This field defines the number of data bytes in the response<br>part of the frame. The value range 0-7 represents 1-8 bytes of<br>data respectively. The master and slave need to configure<br>this register.                                                                                                                                          |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 101 of 360

## 0x080 <u>LIN\_IFCR2n+1</u> LIN ID filter control register Offsets: 0x0048–0x0080 (8 registers)

| Bit   | 15 | 14 | 13 | 12 | 11          | 10 | 9  | 8  | 7 | 6 | 5 4 3 2 1 0 |    |  |  | 0 |
|-------|----|----|----|----|-------------|----|----|----|---|---|-------------|----|--|--|---|
| Name  |    |    |    |    | DFL DIR CST |    |    |    |   |   |             | ID |  |  |   |
| Туре  |    |    |    |    | RW          |    | RW | RW |   |   | RW          |    |  |  |   |
| Reset |    |    |    |    | 0           |    | 0  | 0  |   |   | 0           |    |  |  |   |

| Bit(s)  | Mnemonic | Name              | Description                                                                                                                                                                                                                                                                                                                                           |
|---------|----------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5:0]   | ID       | Identifier        | Identifier part of the identifier field without the identifier parity.                                                                                                                                                                                                                                                                                |
| 8       | CST      | Checksum Type     | <ul> <li>This bit controls the type of checksum applied on the current message.</li> <li>0 : Enhanced Checksum covering Identifier and Data fields.</li> <li>This is compatible with LIN specification 2.0 and higher.</li> <li>1 : Classic Checksum covering Data fields only. This is compatible with LIN specification 1.3 and earlier.</li> </ul> |
| 9       | DIR      | Direction         | This bit controls the direction of the data field.<br>0 : LIN receives the data and copies them in the BDRL and<br>BDRH registers.<br>1 : LIN transmits the data from the BDRL and BDRH<br>registers.                                                                                                                                                 |
| [12:10] | DFL      | Data Field Length | This field defines the number of data bytes in the response<br>part of the frame. The value range 0-7 represents 1-8 bytes of<br>data respectively. The master and slave need to configure<br>this register.                                                                                                                                          |

# 9 UART

# 9.1 Introduction

**NutoChips** 

The UART (Universal Asynchronous Receiver/Transmitter) is a basic peripheral for serial communication. It operates to achieve many functions mainly by transmitter and receiver. In Table 9-1, main functions are classified and listed.

| Functions  | LINEN | RS485EN | MULCOMEN |
|------------|-------|---------|----------|
| BASIC UART | 0     | 0       | 0        |
| RS485      | 0     | 1       | 0        |
| LIN        | 1     | 0       | 0        |

Table 9-1 Function classification and configuration

**Note1:** Only UART1 support hardware flow control function; Only UART6 support soft LIN. **Note2:** Hardware flow control function must be disabled when it is under RS485 mode. **Note3:** LIN mode just supports 8-bit data format and 16 times oversample. Meanwhile, if auto baud rate function is enabled (LABAUDEN=1), the synchronous field data (0x55) will be discarded. **Note4:** DMA function must operate with FIFO enable.

# 9.2 Features

- Full duplex, standard NRZ format.
- Programmable baud rate (16 bit divisor).
  - The baud rate range is 600 bps to 3 Mbps, baud rate error is less than 1%.
- Polling or interrupt driven
  - Transmitter data register empty, transmission complete.
  - Receiver data register full.
  - Receive overrun error, frame error, parity error.
  - o Idle line detect.
  - Break detect supporting LIN.
  - Active edge detects for wake up from stop mode.
- Support DMA.
- Programmable 8-/9-bit data length, 1/2 stop bit, parity hardware generation and checking.
- Selectable transmitter output and receiver input polarity.
- Support hardware flow control.
- 13-bit break character generation and optional 10-/11-bit break character detection for LIN function.
- Support RS485 with direction auto-control.

# 9.3 Block diagram





# 9.4 Input & Output timing

| Pin name  | Corresponding signal | Width I/O |   | Pull up or not | Timing<br>limitation |
|-----------|----------------------|-----------|---|----------------|----------------------|
| UARTx_TX  | uart_tx              | 1         | 0 | no             | None                 |
| UARTx_RX  | uart_rx              | 1         | I | no             | None                 |
| UARTx_RTS | uart_rts_n           | 1         | 0 | no             | None                 |
| UARTx_CTS | uart_cts_n           | 1         | 1 | no             | None                 |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 104 of 360

**Note:** *x*= 1 to 6. Just UART1 has the full hardware flow control and its four signals (UART1\_TX, UART1\_RX, UARTx\_RTS, UARTx\_CTS) can all be found in PIN.

# 9.5 Basic UART functions

Basic UART function is to transmit and receive the serial data bit by bit. In Figure 9-2 and Figure 9-3, it illustrates the full data bits including start bit, data bits, parity bit, stop bits and guard time. But the bit6, bit7, bit8, bit9, parity, stop2 bit and guard time can be configured by user described in UARTn\_LCR0 and UARTn\_LCR1 in detail. One bit is corresponding to one bit time controlled by baud rate.

There exist many statuses for transmitting and receiving. User had better know when the statuses are generated in the transmitting or receiving process. In this way, user can use the UART function better. The status bits THRE and TC just occur in transmitting process illustrated in Figure 9-2. During the initialization condition after global reset or power on, THRE and TC turn to 1 just after TXEN is set to 1. But in the process of transmitting, THRE turns to 1 just after start bit and TC turns to 1 just after the last bit, such as the guard time if GUARDEN=1.



#### Figure 9-2 UART transmitter flow

The status bit DR, OE, PE, FE, BI and NE are set to 1 just after the stop1 bit if related events occur during receiving process as illustrated in Figure 9-3.



#### Figure 9-3 UART receiver flow

To point out, the status PE, FE and NE just aims at the current receiving data byte and will be cleared automatically just at the point the next data is received completely. For other statuses, they hold the value for all the time if they are not being cleared by reading or writing 1 to them.

## 9.5.1 Noise detection

For NE status, it is generated during receiving process when the noise exists in UART\_RX signal. In order to detect the noise, UART\_RX is sampled three times at the middle position as illustrated in Figure 9-4.



AutoChips Confidential

Figure 9-4 UART noise detection © 2013 - 2021 AutoChips Inc.

Page 105 of 360

To explain clearly and conveniently, the value of three times sample is called SM1, SM2 and SM3 respectively. If there are more than two '1' among SM1, SM2 and SM3 for start bit, the start bit is invalid and receiver is reset to receive again. Other than this case for start bit, if the value of SM1, SM2 and SM3 are different for each other, the noise is detected with the NE status turns to 1.

## 9.5.2 Baud rate description

**NutoChips** 

UART Baud rate accuracy is determined by many aspects including UART clock, oversample time and so on. So, some specific and too high baud rate is not realized or realized with large error. The Table 9-3 and Table 9-4 describe the typical baud rate configuration and corresponding error at different system clocks.

| Number | Theoretical<br>value<br>(Kbps) | Practical<br>value(bps) | DIV_MAN<br>[15:0] | DIV_FRAC<br>[4:0] | Oversample<br>times | Error   |
|--------|--------------------------------|-------------------------|-------------------|-------------------|---------------------|---------|
| 1      | 2.4                            | 2399.98                 | 1302              | 3                 | 16                  | -0.001% |
| 2      | 9.6                            | 9599.69                 | 325               | 17                | 16                  | -0.003% |
| 3      | 19.2                           | 19202.22                | 162               | 24                | 16                  | 0.006%  |
| 4      | 57.6                           | 57603.69                | 54                | 8                 | 16                  | 0.006%  |
| 5      | 115.2                          | 115207.38               | 27                | 4                 | 16                  | 0.006%  |
| 6      | 230.4                          | 230414.75               | 13                | 18                | 16                  | 0.006%  |
| 7      | 460.8                          | 460829.50               | 6                 | 25                | 16                  | 0.006%  |
| 8      | 921.6                          | 917431.19               | 3                 | 13                | 16                  | -0.452% |
| 9      | 1843.2                         | 1834862.38              | 3                 | 13                | 8                   | -0.452% |
| 10     | 4200                           | 4166666.75              | 1                 | 16                | 8                   | -0.794% |

#### Table 9-3 Typical baud rate and error@bclock=50MHz

#### Table 9-4 Typical baud rate and error @bclock=36MHz

| Number | Theoretical<br>value<br>(Kbps) | Practical<br>value(bps) | DIV_MAN<br>TI[15:0] | DIV_FRAC<br>[4:0] | Oversample<br>times | Error |
|--------|--------------------------------|-------------------------|---------------------|-------------------|---------------------|-------|
| 1      | 2.4                            | 2400                    | 937                 | 16                | 16                  | 0     |
| 2      | 9.6                            | 9600                    | 234                 | 12                | 16                  | 0     |
| 3      | 19.2                           | 19200                   | 117                 | 6                 | 16                  | 0     |
| 4      | 57.6                           | 57600                   | 39                  | 2                 | 16                  | 0     |
| 5      | 115.2                          | 115200                  | 19                  | 17                | 16                  | 0     |
| 6      | 230.4                          | 230769.23               | 9                   | 24                | 16                  | 0.16% |
| 7      | 460.8                          | 461538.47               | 4                   | 28                | 16                  | 0.16% |
| 8      | 921.6                          | 923076.94               | 2                   | 14                | 16                  | 0.16% |
| 9      | 1843.2                         | 1846153.88              | 1                   | 7                 | 16                  | 0.16% |
| 10     | 4200.0                         | no possible             | -                   | -                 | -                   | -     |

# **//utoChips**

# 9.6 Hardware flow control function

UART hardware flow controls the communication between two UART devices by RTS\_n and CTS\_n in order to reduce the CPU workload. In this way, the two communication sides can handle the data one by one leisurely. The practical application connection is described as Figure 9-5.



Figure 9-5 Hardware flow control connection

In Figure 9-5, signal RTS\_n of UART1 can inform UART2 not to transmit data because UART1 RX data register or FIFO has been full. When UART1 RX data register or FIFO turns to not full by reading, the UART1 RTS\_n turns to low automatically. Then UART2 can transmit data by detecting the UART2 CTS\_n low. In the similar way, the UART2 RTS\_n and UART1 CTS\_n operate to control the UART1 transmission.

Especially, if the UART2 CTS\_n turns to high during the UART2 is transmitting data, the current data will be transmitted completely. So, user should usually check the CTS or CTS\_n status to use the hardware flow control function in addition to other status bits.



Figure 9-6 Hardware flow control principle

# 9.7 RS485 function

Compared with basic UART function, RS485 function generates an auto direction control signal UART\_RTS, which is default low for receiving the data and high for transmitting data illustrated as Figure 9-7 and Figure 9-8. Because of the half-duplex, RS485 can implement one of the transmitting or receiving operation for just one moment. In the Figure 9-7, there are two delays: delay1 is used for pulling up the UART\_RTS signal before practical data transmission and guard time is used for pulling down the UART\_RTS after the data bit transmission has absolutely been finished. Practical PCB

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 107 of 360

routing delay may lead to UART\_RTS signal turning to high later than UART\_TX so that the first data bits may be damaged. So, the delays help to guarantee the UART\_RTS is high during the whole transmission. After transmission is finished, UART\_RTS will go to low automatically to let the UART in receiving state.

| UART_TX   | star  | t bit | 1 bit | 2 bi   | it3 bit4 | bit5   | bit6    | bit7 | bit8   | parity | stop1 | stop2 |       |  |
|-----------|-------|-------|-------|--------|----------|--------|---------|------|--------|--------|-------|-------|-------|--|
| UART_RTSd | elay1 |       |       |        |          |        |         |      |        |        |       |       | guard |  |
|           |       | Fi    | gure  | 9-7 \$ | Single b | yte da | ata tra | ansm | nissic | on     |       |       |       |  |
| UART_TX   | data1 | data2 | data3 | data4  |          | data5  | data6   |      |        |        | data7 | data8 | data9 |  |
| UART_RTS  | _     |       |       |        |          |        |         | 1    |        |        |       |       |       |  |

Figure 9-8 Multiple bytes data transmission

Figure 9-9 describes a typical case of the user application connection. UART\_RTS acts as a direction control signal to MAX485. With this connection method, the default value of UART\_RTS is low so that MAX485 is under default receiving condition. When UART wants to transmit data, the signal UART\_RTS is set to high by hardware.





# 9.8 LIN function

The UART LIN is just a soft LIN which transmits the break field, synchronous field and data respectively controlled by user as Figure 9-10. User can learn more details in the newest LIN protocol and the figure just illustrates a basic frame condition. User should pay more attention to the UARTn\_LINCR register in addition to the basic UART registers. In UART module, there exits a hardware logics for LIN detection and it is enabled when LINEN is configured to 1.

Firstly, description for receiving process are introduced based on the serial data stream appears on the UART\_RX as Figure 9-10. Firstly, when UART receives 10 (LBRKDL=0) or 11 (LBRKDL=1) bit zero, UART LIN detection logics treat it as a valid break field for LIN frame and the LIN break flag AutoChips Confidential © 2013 - 2021 AutoChips Inc. Page 108 of 360

# **//utoChips**

FBRK is set to 1 by hardware to indicate a valid LIN break field has occurred. To point out, the LIN break is not a data and not stored into the RX data register or FIFO. Then, delimiter bits with UART\_RX high occurs following the break field. After delimiter bits period, synchronous field namely 0x55 acts as a normal data for receiving. If LABAUDEN is configured to 1, auto baud rate detection is in operation during synchronous field and the auto baud rate detection operation is finished just after the fifth rising edge illustrated in Figure 9-10. But the data 0x55 will not be stored into RX data register or FIFO. If LABAUDEN is configured to 0, auto baud rate detection is not performed and the data 0x55 is stored into the RX data register or FIFO. After synchronous field, the data streams are the useful data for user and received by UART without difference.

To avoid the module halting when exception condition occurs, time out mechanism is brought in. As illustrated in Figure 9-10, more than 25 bit time for break field, more than 14 bit time for delimiter and more than 13 bit time for synchronous field can lead the module to reset the receiver and LIN detection logics.





Then, introduction for transmitting LIN protocol frame is described in this paragraph. As software LIN, how to transmit the break field is the key procedure. When user wants to transmit the break field, user should check the UARTn\_LSR0[THRE] status. If the UARTn\_LSR0[THRE] value is 1, user can write 1 to the UARTn\_LINCR[SBRK] to send a 13-bit time break field with other control bits not changed in LINCR. To point out, when UARTn\_LINCR[SBRK] has been written to 1, the break field will be transmitted just after the current data has been transmitted completely or be transmitted immediately when the UART is in idle state. The UARTn\_LINCR[SBRK] will be cleared automatically by hardware. And then the synchronous field(0x55) and other following data can be written to the THR data register and sent as normal data transmitting.

# 9.9 Two chip power mode



Figure 9-11 Chip normal mode and stop mode condition

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 109 of 360

# **//utoChips**

There are two power modes designed for the chip. As the Figure 9-11 illustrates, user can execute the WFI instruction to make the chip go into stop mode, in which the chip power consumption will be much less obviously and the UART module will power down and be reset by default. Certainly, all the UART configuration and other registers are reset for the stop mode condition.

In stop mode, the chip can wake up to normal mode by UART receiving a falling edge if the chip is enabled to wake up by UART. Because of the time required for the wake-up flow, UART can normally receive data just after the sum time of 5ms and re-configure UART time at least from receiving the wake-up falling edge. In details, TX1 can send 0xFF to act as a falling edge and actually other data is also ok. Specially, data will be lost in RX2 if TX1 send some data to RX2 during the wake up flow.



Figure 9-12 Typical flow for waking up the chip by UART

## 9.10 Baud rate configuration description



Figure 9-13 Diagram for baud rate generator

As illustrated in the Figure 9-13, the baud rate related configuration registers are as follows: UARTn\_SMP\_CNT/UARTn\_DIV\_H/UARTn\_DIV\_L / UARTn\_DIV\_FRAC. And the detailed information is described in register map. For configuration, the formula below is used for baud rate configuration.

© 2013 - 2021 AutoChips Inc.

Page 110 of 360

$$Baudrate = \frac{f_{clk}}{DIV * SMP \quad CNT}$$

Note: DIV = {UARTn\_DIV\_H, UARTn\_DIV\_L}; SMP\_CNT = UARTn\_SMP\_CNT;

For example:

**NutoChips** 

If user wants to get baud rate 230400 bps at 8 times sample mode with 50MHz bus frequency, so we can get the DIV configuration as follows. So, UARTn\_DIV\_L=13, UARTn\_DIV\_H=0, UARTn\_DIV\_FRAC=32 \* 0.5634=18.

$$DIV = \frac{50000000}{Baudrate*SMP\_CNT} = \frac{50000000}{230400*8} = 13.5634$$

Combined with the example above, UARTn\_DIV\_FRAC[4:0] can be explained clearly. In the expression above, DIV is not an integer. If user removes the fractional part, the accuracy of baud rate will decrease. Especially in large baud rate condition, the discard of DIV fractional part may reduce the accuracy to a low level so that the normal data transmission will make a mistake.

In order to keep high accuracy, UARTn\_DIV\_FRAC[4:0] is configured to represent the DIV fractional part. Because of 5 bits width, UARTn\_DIV\_FRAC ranges from 0 to 31. So, 32 multiplied by the DIV fractional part generates the configuration value for UARTn\_DIV\_FRAC[4:0].

## 9.11 Configure note

Configuration steps:

- (1) TX/RX data storage mode: UARTn\_FCR.
- (2) Baud rate: UARTn\_DIV\_L/UARTn\_DIV\_H/ UARTn\_DIV\_FRAC/UARTn\_SMP\_CNT
- (3) DMA: UARTn\_DMA\_EN

Note: DMA function must operate with FIFO.

- (4) Data format: UARTn\_LCR0/UARTn\_LCR1
- Note: SB bit must be taken care of.
  - (5) Function configuration: UARTn\_RS485CR/UARTn\_LINCR/UARTn\_MULCOMCR/ UARTn\_CNRT / UARTn\_SLADDR and so on.
- Note: This step is an option for different function.
  - (6) Interrupt enable: UARTn\_IER
  - (7) Transmitter and receiver enable: UARTn\_LCR1[TXEN] / UARTn\_LCR1[RXEN] .
  - (8) Transmit or receive data: UARTn\_THR/UARTn\_RBR

Note: this step is in normal transmitting or receiving data process actually.

#### Notes:

- 1. For LIN function, data format must be configured as 8 bit with no parity check with 16 times oversample.
- 2. For LIN function, sync field data(0x55) will be received and stored into FIFO or RX register when LABAUDEN=0 and will be received and not stored into FIFO or RX register when LABAUDEN=1.
- 3. For RS485 function, RTS\_n PIN is used as the transmitting or receiving direction controlling signal.

## 9.12 Register Definition

#### Table 9-5 UART register map

#### Address = Base address + Offset address

| Module name | Base address | Offset address | Comment                      |
|-------------|--------------|----------------|------------------------------|
| UART1       | 0x40018000   | 0x00 ~ 0x58    |                              |
| UART2       | 0x40019000   | 0x00 ~ 0x58    | 1. No UARTn_LCR              |
| UART3       | 0x4001a000   | 0x00 ~ 0x58    | 2. Part of the registers are |
| UART4       | 0x4001b000   | 0x00 ~ 0x58    | reversed.                    |
| UART5       | 0x4001c000   | 0x00 ~ 0x58    |                              |
| UART6       |              |                | 1. UARTn_LCR.                |
| (UART_LIN)  | 0x4001d000   | 0x00 ~ 0x5c    | 2. Part of the registers are |
|             |              |                | reversed.                    |

| Offset<br>Address | Name           | Width | Register function                                  |
|-------------------|----------------|-------|----------------------------------------------------|
| 0x00              | UARTn_RBR/THR  | 32    | TX holding register /RX buffer register            |
| 0x04              | UARTn_DIV_L    | 32    | Divisor Low 8 bits                                 |
| 80x0              | UARTn_DIV_H    | 32    | Divisor High 8 bits                                |
| 0x0C              | UARTn_LCR0     | 32    | UART supplementary control register 0              |
| 0x10              | UARTn_LCR1     | 32    | UART supplementary control register 1              |
| 0x14              | UARTn_FCR      | 32    | FIFO control register                              |
| 0x18              | UARTn_EFR      | 32    | Hardware flow enable register                      |
| 0x1c              | UARTn_IER      | 32    | Interrupt enable register                          |
| 0x20              | UARTn_LSR0     | 32    | Status register0                                   |
| 0x24              | UARTn_LSR1     | 32    | Status register1                                   |
| 0x28              | UARTn_SMP_CNT  | 32    | UART sample counter register                       |
| 0x34              | UARTn_GUARD    | 32    | Guard time added register                          |
| 0x38              | Reserved       | 32    |                                                    |
| 0x3c              | UARTn_SLEEP_EN | 32    | Sleep enable register                              |
| 0x40              | UARTn_DMA_EN   | 32    | DMA enable register                                |
| 0x44              | UARTn_DIV_FRAC | 32    | Fractional divider register                        |
| 0x48              | Reserved       | 32    |                                                    |
| 0x4c              | UARTn_RS485CR  | 32    | RS485 control register                             |
| 0x50              | UARTn_SLADDR   | 32    | Address for RS485 or Multi-processor communication |
| 0x54              | UARTn_CNTR     | 32    | Delay time for RS485                               |
| 0x58              | UARTn_MULCOMCR | 32    | Idle interrupt enable register                     |
| 0x5c              | UARTn_LINCR    | 32    | Software LIN control register                      |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.



| 0x00                                          |                | <u>UARTn</u> | RBR/               | <u>THR</u>     | RX/T            | X Dat                              | a Re                                             | giste                         | r    |         |        |                |              |        |         | 000        |
|-----------------------------------------------|----------------|--------------|--------------------|----------------|-----------------|------------------------------------|--------------------------------------------------|-------------------------------|------|---------|--------|----------------|--------------|--------|---------|------------|
| Bit                                           | 32~15          | 14           | 13                 | 12             | 11              | 10                                 | 9                                                | 8                             | 7    | 6       | 5      | 4              | 3            | 2      | 1       | 0          |
| Name                                          |                |              |                    |                |                 |                                    |                                                  |                               |      | -       |        | RBR/T          |              |        |         |            |
| Туре                                          |                |              |                    |                |                 |                                    |                                                  |                               | ~    |         |        | RO/W           |              |        |         |            |
| Reset                                         |                |              |                    |                |                 |                                    |                                                  | 0                             | 0    | 0       | 0      | 0              | 0            | 0      | 0       | 0          |
|                                               |                |              |                    |                |                 |                                    |                                                  |                               |      |         |        |                |              |        |         |            |
| Bit(s)                                        | Mnemo          | nic N        | lame               |                | De              | script                             | tion                                             |                               |      |         |        |                |              |        |         |            |
|                                               |                |              |                    |                | RX              | /TX Da                             | ata re                                           | giste                         | r    |         |        |                |              |        |         |            |
| 8:0                                           | RBR/TH         | R R          | BR/TH              | R              | The             | e recei                            | ved o                                            | lata d                        | an b | e read  | dbya   | access         | sing th      | is reg | ister a | and th     |
| 0.0                                           |                | IX I         |                    | I X            |                 | nsmittir                           |                                                  |                               |      | writter | n into | this re        | egister      | . The  | data v  | vidth i    |
|                                               |                |              |                    |                | not             | more                               | than §                                           | hite                          |      |         |        |                |              |        |         |            |
| ) <b>v</b> 04                                 |                | HARTn        | ו עוס              | Divid          | sor lo          | w 8 hi                             |                                                  |                               |      |         |        |                |              |        |         | 000        |
| Bit                                           | 32~15          | <b>UARTn</b> | <b>DIV_I</b>       | <u>-</u> Divis | <b>sor lo</b>   | <b>w 8 b</b> i                     |                                                  |                               | er   | 6       | 5      | 4              | 3            | 2      | 1       | <b>000</b> |
| Bit<br>Name                                   | 32~15          |              |                    | _              |                 |                                    | its re                                           | giste                         | er   | 6       | 5      | DIV            | L            | 2      | 1       |            |
| Bit                                           | 32~15          |              |                    | _              |                 |                                    | its re                                           | giste                         | er   | 6       | 5      | -              | L            | 2      | 1       |            |
| Bit<br>Name<br>Type                           | 32~15          |              |                    | _              |                 |                                    | its re                                           | giste                         | er   |         |        | DIV<br>RV      | _L<br>V      |        |         | 0          |
| Bit<br>Name<br>Type<br>Reset                  | 32~15<br>Mnemo | 14 13        |                    | _              | 10              |                                    | its re                                           | giste                         | er   |         |        | DIV<br>RV      | _L<br>V      |        |         | 0          |
| Name<br>Type<br>Reset                         | Mnemo          | 14 13        | 12                 | _              | 10<br>De        | 9<br>script                        | its re<br>8                                      | giste                         | er   |         |        | DIV<br>RV      | _L<br>V      |        |         | 0          |
| Bit<br>Name<br>Type<br>Reset                  |                | 14 13        | 12                 | _              | 10<br>De<br>Ba  | 9<br>script<br>ud rate             | its re<br>8<br>ion                               | giste<br>7<br>0<br>0          | er   |         |        | DIV<br>RV      | _L<br>V      |        |         | 0          |
| Bit<br>Name<br>Type<br>Reset<br>Bit(s)        | Mnemo          | 14 13        | 12                 | _              | 10<br>De<br>Ba  | 9<br>script                        | its re<br>8<br>ion                               | giste<br>7<br>0<br>0          | er   |         |        | DIV<br>RV      | _L<br>V      |        |         | 0          |
| Bit<br>Name<br>Type<br>Reset<br>Bit(s)        | Mnemo          | 14 13        | 12                 | _              | 10<br>De<br>Ba  | 9<br>script<br>ud rate             | its re<br>8<br>ion                               | giste<br>7<br>0<br>0          | er   |         |        | DIV<br>RV      | _L<br>V      |        |         | 0          |
| Bit<br>Name<br>Type<br>Reset<br>Bit(s)<br>7:0 | Mnemo<br>DIV_L | 14 13        | Iame               |                | 10<br>De<br>Ba  | 9<br>script<br>ud rate             | tion<br>e divi                                   | giste<br>7<br>0<br>0          |      |         |        | DIV<br>RV      | _L<br>V      |        |         |            |
| Bit<br>Name<br>Type<br>Reset<br>Bit(s)<br>7:0 | Mnemo<br>DIV_L | 14 13        | Iame               |                | 10<br>De<br>Ba  | 9<br>script<br>ud rate             | tion<br>e divi                                   | giste<br>7<br>0<br>0          | er   |         |        | DIV<br>RV      | _L<br>V      |        |         |            |
| Bit<br>Name<br>Type<br>Reset<br>Bit(s)<br>7:0 | Mnemo<br>DIV_L | 14 13        | 12<br>lame<br>NV_L | Divis          | De<br>Ba<br>Div | 9<br>script<br>ud rate<br>isor lov | its re<br>8<br>ion<br>e divi<br>w 8 bi<br>its re | giste<br>7<br>0<br>sor<br>ts. | er   | 0       | 0      | DIV<br>RV<br>0 | _L<br>V<br>0 | 0      | 0       | 0000       |

| Bit(s) Mnemonic  | Name  | Description                               |
|------------------|-------|-------------------------------------------|
| 7:0 <b>DIV_H</b> | DIV_H | Baud rate divisor<br>Divisor high 8 bits. |

0

0

0

0

0

0

0

0

| 0x0C  |       | UAR | [n_LC | <u> R0</u> | Cont | rol Re | egiste | r 0 |   |     |    |     |     |     |      | 0000  |
|-------|-------|-----|-------|------------|------|--------|--------|-----|---|-----|----|-----|-----|-----|------|-------|
| Bit   | 32~15 | 14  | 13    | 12         | 11   | 10     | 9      | 8   | 7 | 6   | 5  | 4   | 3   | 2   | 1    | 0     |
| Name  |       |     |       |            |      |        |        |     |   | SUB | SP | EPS | PEN | STB | WLS1 | _WLS0 |
| Туре  |       |     |       |            |      |        |        |     |   | RW  | RW | RW  | RW  | RW  | F    | RM    |
| Reset |       |     |       |            |      |        |        |     |   | 0   | 0  | 0   | 0   | 0   | 0    | 0     |

Note: SB bit configuration must be 0, otherwise tx transmit '0' at any time.

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                                      |
|--------|----------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6      | SUB      | SUB  | Sets up break                                                                                                                                                                    |
|        |          |      | 0: No effect                                                                                                                                                                     |
|        |          |      | 1: SOUT signal is forced into the "0" state.                                                                                                                                     |
| 5      | SP       | SP   | Stick parity                                                                                                                                                                     |
|        |          |      | 0: No effect.                                                                                                                                                                    |
|        |          |      | <ol> <li>The parity bit is forced into a defined state,<br/>depending on the states of EPS and PEN: If EPS<br/>= 1 &amp; PEN = 1, the parity bit is set and checked =</li> </ol> |
|        |          |      | , , , , , , , , , , , , , , , , , , , ,                                                                                                                                          |

Reset

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit(s) | Mnemonic  | Name      | Description                                                                                                         |
|--------|-----------|-----------|---------------------------------------------------------------------------------------------------------------------|
|        |           |           | 0. If EPS = 0 & PEN = 1, the parity bit is set and checked = 1.                                                     |
| 4      | EPS       | EPS       | Selects even parity                                                                                                 |
|        |           |           | 0: When EPS = 0, an odd number of ones is sent and checked.                                                         |
|        |           |           | 1: When EPS = 1, an even number of ones is sent and checked.                                                        |
| 3      | PEN       | PEN       | Enables parity                                                                                                      |
|        |           |           | 0: The parity is neither transmitted nor checked.                                                                   |
|        |           |           | 1: The parity is transmitted and checked.                                                                           |
| 2      | STB       | STB       | Number of STOP bits                                                                                                 |
|        |           |           | 0: One STOP bit is always added.                                                                                    |
|        |           |           | 1: Two STOP bits are added after each character is sent; unless the character length is 5 when 1 STOP bit is added. |
| 1:0    | WLS1_WLS0 | WLS1_WLS0 | Selects word length                                                                                                 |
|        |           |           | 0: 5 bits                                                                                                           |
|        |           |           | 1: 6 bits                                                                                                           |
|        |           |           | 2: 7 bits                                                                                                           |
|        |           |           | 3: 8 bits                                                                                                           |
|        |           |           | 4: 9 bits (wls2)                                                                                                    |

| 0x10  |       | UAR | <u>n LC</u> | <u>R1</u> | Control Register 1 |    |   |   |       |       |      |      |   |   |      | 0000 |
|-------|-------|-----|-------------|-----------|--------------------|----|---|---|-------|-------|------|------|---|---|------|------|
| Bit   | 32~15 | 14  | 13          | 12        | 11                 | 10 | 9 | 8 | 7     | 6     | 5    | 4    | 3 | 2 | 1    | 0    |
| Name  |       |     |             |           |                    |    |   |   | INVTX | INVRX | WLS2 | LOOP |   |   | TXEN | RXEN |
| Туре  |       |     |             |           |                    |    |   |   | RW    | RW    | RW   | RW   |   |   | RW   | RW   |
| Reset |       |     |             |           |                    |    |   |   | 0     | 0     | 0    | 0    |   |   | 0    | 0    |

| Bit(s) | Mnemonic | Name  | Description                                                                                    |
|--------|----------|-------|------------------------------------------------------------------------------------------------|
| 7      |          |       | Determine whether inverse the tx output, including idle, break, data bits,start bit, stop bit. |
| 7      | ΙΝΥΤΧ    | INVTX | 0: don't inverse tx output                                                                     |
|        |          |       | 1: inverse tx output                                                                           |
|        |          |       | Determine whether inverse the tx output, including idle, break, data bits,start bit, stop bit. |
| 6      | INVRX    | INVRX | 0: don't inverse rx input                                                                      |
|        |          |       | 1: inverse rx input                                                                            |
|        |          |       | Determine whether 9-bit data mode is available                                                 |
| 5      | WLS2     | WLS2  | 0: not available                                                                               |
|        |          |       | 1: available                                                                                   |
|        |          |       | LOOP                                                                                           |
| 4      | LOOP     | LOOP  | 0: for user normal use                                                                         |
|        |          |       | 1: control the uart into loop mode(can used for testing uart by itself)                        |
|        |          |       | UART Transmitter enable                                                                        |
| 1      | TXEN     | TXEN  | 0: disable                                                                                     |
|        |          |       | 1: enable                                                                                      |
|        |          |       | UART Receiver enable                                                                           |
| 0      | RXEN     | RXEN  | 0: disable                                                                                     |
|        |          |       | 1: enable                                                                                      |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.



| 0x14  | UARTn FCR |    |    |    | FIFO | FIFO Control Register |   |   |   |   |   |   |   |   |   | 0000  |
|-------|-----------|----|----|----|------|-----------------------|---|---|---|---|---|---|---|---|---|-------|
| Bit   | 32~15     | 14 | 13 | 12 | 11   | 10                    | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
| Name  |           |    |    |    |      |                       |   |   |   | - |   | _ |   |   |   | FIFOE |
| Туре  |           |    |    |    |      |                       |   |   |   |   |   |   |   |   |   | RW    |
| Reset |           |    |    |    |      |                       |   |   |   |   |   |   |   |   |   | 0     |
|       |           |    |    |    |      |                       |   |   |   |   |   |   |   |   |   |       |
|       |           | -  |    |    |      | _                     | - | - |   |   |   |   |   |   |   |       |

| Bi | t(s) | Mnemonic | Name  | Description                     |
|----|------|----------|-------|---------------------------------|
|    | 0    | FIFOE    | FIFOE | Enables FIFO                    |
|    |      |          |       | 0: Disable both RX and TX FIFOs |
|    |      |          |       | 1: Enable both RX and TX FIFOs. |

| 0x18  |       | UART | n EF | R  |    |    |   |   |              |              |   |   |   |   |   | 0000 |
|-------|-------|------|------|----|----|----|---|---|--------------|--------------|---|---|---|---|---|------|
| Bit   | 32~15 | 14   | 13   | 12 | 11 | 10 | 9 | 8 | 7            | 6            | 5 | 4 | 3 | 2 | 1 | 0    |
| Name  |       |      |      |    |    |    |   |   | AUTO<br>_CTS | AUTO_<br>RTS |   |   |   | _ | _ |      |
| Туре  |       |      |      |    |    |    |   |   | RW           | RW           |   |   |   |   |   |      |
| Reset |       |      |      |    |    |    |   |   | 0            | 0            |   |   |   |   |   |      |

Overview: AUTOCTS=1 represents enabling the Hardware flow function of pin CTS\_n, so if AUTOCTS=1, user must make the n\_CTS pin be tied to a fixed level, such as the other MCU's or device's pin. If AUTOCTS=0, user needn't to care about the CTS\_n pin.

| Bit(s) | Mnemonic | Name     | Description                                |
|--------|----------|----------|--------------------------------------------|
| 7      | AUTO_CTS | AUTO_CTS | Enables hardware transmission flow control |
|        |          |          | 0: Disable                                 |
|        |          |          | 1: Enable                                  |
| 6      | AUTO_RTS | AUTO_RTS | Enables hardware reception flow control    |
|        |          |          | 0: Disable                                 |
|        |          |          | 1: Enable.                                 |

| 0 | 0x1c <u>UARTn_IER</u> |       |    |    | Interr | Interrupt Enable Register |    |   |   |           |       |     |     |     |     | 0000 |       |
|---|-----------------------|-------|----|----|--------|---------------------------|----|---|---|-----------|-------|-----|-----|-----|-----|------|-------|
|   | Bit                   | 32~15 | 14 | 13 | 12     | 11                        | 10 | 9 | 8 | 7         | 6     | 5   | 4   | 3   | 2   | 1    | 0     |
|   | Name                  |       |    |    |        |                           |    |   |   | EDCT<br>S | EOEBI | ENE | EFE | EPE | ETC | ETXE | ERXNE |
|   | Туре                  |       |    |    |        |                           |    |   |   | RW        | RW    | RW  | RW  | RW  | RW  | RW   | RW    |
|   | Reset                 |       |    |    |        |                           |    |   |   | 0         | 0     | 0   | 0   | 0   | 0   | 0    | 0     |

| Bit(s  | ) Mnemonic        | Name  | Description                                       |                 |
|--------|-------------------|-------|---------------------------------------------------|-----------------|
| 7      | EDCTS             | EDCTS | CTS_n changing interrupt enable                   |                 |
|        |                   |       | 0: disable                                        |                 |
| _      |                   |       | 1: enable                                         |                 |
| 6      | EOEBI             | EOEBI | Interrupt enable of overflow error or break error |                 |
|        |                   |       | 0: disable                                        |                 |
|        |                   |       | 1: enable                                         |                 |
| 5      | ENE               | ENE   | Interrupt enable of noise error                   |                 |
|        |                   |       | 0: disable                                        |                 |
|        |                   |       | 1: enable                                         |                 |
| 4      | EFE               | EFE   | Interrupt enable of overflow error or frame error | r               |
|        |                   |       | 0: disable                                        |                 |
| AutoCh | nips Confidential |       | © 2013 - 2021 AutoChips Inc.                      | Page 115 of 360 |

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit(s) | Mnemonic | Name   | Description                                  |
|--------|----------|--------|----------------------------------------------|
|        |          |        | 1: enable                                    |
| 3      | EPE      | ELSI   | Interrupt enable of parity error             |
|        |          |        | 0: disable                                   |
|        |          |        | 1: enable                                    |
| 2      | ETC      | ETXTCI | Interrupt enable of transmitting completed   |
|        |          |        | 0: disable                                   |
|        |          |        | 1: enable                                    |
| 1      | ETXE     | ETBEI  | Interrupt enable of transmitting data empty  |
|        |          |        | Note: fifoe=1 represents fifo empty;         |
|        |          |        | fifoe=0 represent data register empty.       |
|        |          |        | 0: disable                                   |
|        |          |        | 1: enable                                    |
| 0      | ERXNE    | ERBFI  | Interrupt enable of receiving data not empty |
|        |          |        | Note: fifoe=1 represents fifo not empty;     |
|        |          |        | fifoe=0 represent data register not empty.   |
|        |          |        | 0: disable                                   |
|        |          |        | 1: enable                                    |

| 0x20  |       | UAR | Tn_L | <u>SR</u> 0 | Line \$ | Status | s Regi | ster |     |    |      |     |     |     |     | 0020 |
|-------|-------|-----|------|-------------|---------|--------|--------|------|-----|----|------|-----|-----|-----|-----|------|
| Bit   | 32~15 | 14  | 13   | 12          | 11      | 10     | 9      | 8    | 7   | 6  | 5    | 4   | 3   | 2   | 1   | 0    |
| Name  |       |     |      |             |         |        |        |      | NE  | тс | THRE | BI  | FE  | PE  | OE  | DR   |
| Туре  |       |     |      |             |         |        |        |      | W1C | R  | R    | W1C | W1C | W1C | W1C | R    |
| Reset |       |     |      |             |         |        |        |      | 0   | 0  | 1    | 0   | 0   | 0   | 0   | 0    |

| <b>Note:</b> NE/PE/FE error | iust aims at the current byte | e data. Meanwhile. | OE/BI will exist until it is cleared. |
|-----------------------------|-------------------------------|--------------------|---------------------------------------|
|                             |                               |                    |                                       |

| Bit(s)  | Mnemonic        | Name | Description                                                                                                                                                                                                                                                        |
|---------|-----------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7       | NE              | NE   | Noise error flag                                                                                                                                                                                                                                                   |
|         |                 |      | <i>Note</i> : write 1 to clear this flag to 0.                                                                                                                                                                                                                     |
|         |                 |      | 0: No noise error.                                                                                                                                                                                                                                                 |
|         |                 |      | 1: Noise error has been occurred.                                                                                                                                                                                                                                  |
| 6       | тс              | тс   | The flag of Transmitting finished                                                                                                                                                                                                                                  |
|         |                 |      | <b>Note</b> : write data to TX FIFO(fifoe=1)/TX register(fifoe=0) to clear this flag to 0. For LIN function, set SBRK bit also can clear this flag to 0.                                                                                                           |
|         |                 |      | 0: TX FIFO(fifoe=1) or TX register(fifoe=0) is not empty, or transmitter has not finished the data shifting.                                                                                                                                                       |
|         |                 |      | 1: TX FIFO(fifoe=1) or TX register(fifoe=0) is empty and transmitter has finished the data shifting.                                                                                                                                                               |
| 5       | THRE            | THRE | The empty flag of TX holding register or TX FIFO                                                                                                                                                                                                                   |
|         |                 |      | <b>Note</b> : write data to TX FIFO(fifoe=1)/TX register(fifoe=0) to clear this flag to 0.                                                                                                                                                                         |
|         |                 |      | 0: Reset whenever the contents of the TX FIFO are not empty, or whenever TX holding register is not empty (FIFOs are disabled).                                                                                                                                    |
|         |                 |      | 1: Set whenever the contents of the TX FIFO are empty, or whenever TX holding register is empty (FIFOs are disabled).                                                                                                                                              |
| 4       | BI              | BI   | Break error flag                                                                                                                                                                                                                                                   |
|         |                 |      | Note: write 1 to clear this flag to 0.                                                                                                                                                                                                                             |
|         |                 |      | 0: No break error                                                                                                                                                                                                                                                  |
|         |                 |      | 1: Break error has been occurred. If FIFOs are disabled, this bit is set whenever the SIN is held in the 0 state for more than one transmission time (START bit + DATA bits + PARITY + STOP bit). When a break occurs, only one zero character is loaded into FIFO |
| AutoChi | ps Confidential | (    | © 2013 - 2021 AutoChips Inc. Page 116 of 360                                                                                                                                                                                                                       |
|         |                 |      |                                                                                                                                                                                                                                                                    |

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

# **NutoChips**

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |          |      | or TX holding register.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3      | FE       | FE   | Framing error flag                                                                                                                                                                                                                                                                                                                                                                                                                               |
|        |          |      | Note: write 1 to clear this flag to 0.                                                                                                                                                                                                                                                                                                                                                                                                           |
|        |          |      | 0: No framing error.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|        |          |      | 1: Framing error has been occurred. This bit will be set if the received data do not have a valid STOP bit.                                                                                                                                                                                                                                                                                                                                      |
| 2      | PE       | PE   | Parity error flag                                                                                                                                                                                                                                                                                                                                                                                                                                |
|        |          |      | Note: write 1 to clear this flag to 0.                                                                                                                                                                                                                                                                                                                                                                                                           |
|        |          |      | 0: No parity error.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|        |          |      | 1: Parity error has been occurred. This bit will be set if the received data do not have a valid parity bit.                                                                                                                                                                                                                                                                                                                                     |
| 1      | OE       | OE   | Overrun error flag                                                                                                                                                                                                                                                                                                                                                                                                                               |
|        |          |      | Note: write 1 to clear this flag to 0.                                                                                                                                                                                                                                                                                                                                                                                                           |
|        |          |      | 0: No RX overflow error.                                                                                                                                                                                                                                                                                                                                                                                                                         |
|        |          |      | 1: RX overflow error has been occurred. If FIFOs are disabled, this bit will be set if the RX buffer is not read by the CPU before the new data from the RX shift register overwrites the previous contents. If FIFOs are enabled, an overrun error occurs when RX FIFO is full and the RX shift register becomes full. OE is set as soon as this happens. The character in the shift register is then overwritten, but not transferred to FIFO. |
| 0      | DR       | DR   | Data ready flag                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|        |          |      | <b>Note</b> : Read register UART_RBR/THR, or read all RX FIFO to clear this flag to 0.                                                                                                                                                                                                                                                                                                                                                           |
|        |          |      | 0: Data not ready.                                                                                                                                                                                                                                                                                                                                                                                                                               |
|        |          |      | 1: Data ready. Set by the RX buffer becoming full or RX FIFO not empty(at least one byte being transferred into the FIFO).                                                                                                                                                                                                                                                                                                                       |

| 0x24  |       |    |    |    | Line \$ | Status | s Regi | ster |     |     |               |   |      |      |   | 0000 |
|-------|-------|----|----|----|---------|--------|--------|------|-----|-----|---------------|---|------|------|---|------|
| Bit   | 32~15 | 14 | 13 | 12 | 11      | 10     | 9      | 8    | 7   | 6   | 5             | 4 | 3    | 2    | 1 | 0    |
| Name  |       |    |    |    |         |        |        |      | RTS | CTS | UART<br>_IDLE |   | DCTS | FBRK |   | IDLE |
| Туре  |       |    |    |    |         |        |        |      | R   | R   | R             |   | W1C  | W1C  |   | W1C  |
| Reset |       |    |    |    |         |        |        |      | 0   | 0   | 0             |   | 0    | 0    |   | 0    |

| Bit(s)  | Mnemonic        | Name      | Description                                                                                                                               |                      |
|---------|-----------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| 7       | RTS             | RTS       | Hardware flow status – RTS                                                                                                                |                      |
|         |                 |           | <b>Note:</b> RTS is opposite to the signal of PIN interrupt source.                                                                       | RTS_n. It is not an  |
|         |                 |           | 0: Under hardware flow control function, it repre-<br>register is already full. This signal can info<br>transmitting data to the MCU.     |                      |
|         |                 |           | 1: Under hardware flow control function, it repre<br>register is not full.                                                                | esents RX FIFO or RX |
| 6       | CTS             | CTS       | Hardware flow status – CTS                                                                                                                |                      |
|         |                 |           | <b>Note:</b> CTS is opposite to the signal of PIN interrupt source.                                                                       | CTS_n. It is not an  |
|         |                 |           | 0: Under hardware flow control function, it represents register of other device is already full. This MCU not transmitting the next data. |                      |
|         |                 |           | 1: Under hardware flow control function, it repre<br>register of other device is not full.                                                | esents RX FIFO or RX |
| 5       | UART_IDLE       | UART_IDLE | UART_IDLE                                                                                                                                 |                      |
| AutoChi | ns Confidential |           | © 2013 - 2021 AutoChips Inc                                                                                                               | Page 117 of 360      |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                                            |
|--------|----------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |          |      | 0: uart is at operation.                                                                                                                                                               |
|        |          |      | 1: uart is not at operation, namely, transmitter and receiver are not working or has finished the data transmission or reception.                                                      |
| 3      | DCTS     | DCTS | The flag of pin CTS_n signal changing                                                                                                                                                  |
|        |          |      | Note: write 1 to clear this flag to 0.                                                                                                                                                 |
|        |          |      | 0: no change.                                                                                                                                                                          |
|        |          |      | 1: represents CTS_n pin signal changing from 1 to 0 or 0 to 1.                                                                                                                         |
| 2      | FBRK     | FBRK | The flag of LIN BREAK occurred.                                                                                                                                                        |
|        |          |      | Note: write 1 to clear this flag to 0.                                                                                                                                                 |
|        |          |      | 0: has not detected the break field in LIN frame just in LIN function.                                                                                                                 |
|        |          |      | 1: has detected the break field in LIN frame just in LIN function                                                                                                                      |
| 0      | IDLE     | IDLE | IDLE flag                                                                                                                                                                              |
|        |          |      | Receiver has received the data followed by a high level maintaining<br>at least one byte data time. IDLE status flag will be work after the<br>MUI-Communication(MULCOMEN) is enabled. |
|        |          |      | Note: write 1 to clear this flag to 0.                                                                                                                                                 |
|        |          |      | 0: idle line has not been detected                                                                                                                                                     |
|        |          |      | 1: idle line detected                                                                                                                                                                  |

| 0x28  |       | UAR | [n_SN | /IP_CI | NT | Sa | mple | count | ter reg | gister |   |   |   |   |         | 0000 |
|-------|-------|-----|-------|--------|----|----|------|-------|---------|--------|---|---|---|---|---------|------|
| Bit   | 32~15 | 14  | 13    | 12     | 11 | 10 | 9    | 8     | 7       | 6      | 5 | 4 | 3 | 2 | 1       | 0    |
| Name  |       |     |       |        |    |    |      |       |         |        |   |   |   |   | SMP_CNT |      |
| Туре  |       |     |       |        |    |    |      |       |         |        |   |   |   |   | RŴ      |      |
| Reset |       |     |       |        |    |    |      |       |         |        |   |   |   |   | 0       | 0    |

| Bit(s) Mnemonic    | Name    | Description                                                                                |
|--------------------|---------|--------------------------------------------------------------------------------------------|
|                    |         | UART sample counter                                                                        |
|                    |         | 0: Based on 16*baud_pulse, baud_rate = system clock<br>frequency/16/{DLH, DLL}             |
| 1:0 <b>SMP_CNT</b> | SMP_CNT | 1: Based on 8*baud_pulse, baud_rate = system clock<br>frequency/8/{DLH, DLL}               |
|                    |         | 2: Based on 4*baud_pulse, baud_rate = system clock<br>frequency/4/{DLH, DLL}               |
|                    |         | 3: Based on sampe_count * baud_pulse, baud_rate = system clock<br>frequency/16 /{DLM, DLL} |

| 0x34  |       | UAR1 | <u>n Gl</u> | <u>JARD</u> | D Guard time register |    |   |   |   |   |   |              | 00 |      |       |   |  |
|-------|-------|------|-------------|-------------|-----------------------|----|---|---|---|---|---|--------------|----|------|-------|---|--|
| Bit   | 32~15 | 14   | 13          | 12          | 11                    | 10 | 9 | 8 | 7 | 6 | 5 | 4            | 3  | 2    | 1     | 0 |  |
| Name  |       |      |             |             |                       |    |   |   |   |   |   | GUARD<br>_EN |    | GUAR | RD_CN | г |  |
| Туре  |       |      |             |             |                       |    |   |   |   |   |   | RW           |    | F    | RM    |   |  |
| Reset |       |      |             |             |                       |    |   |   |   |   |   | 0            | 1  | 1    | 1     | 1 |  |

**Notes**: Adding the guard time can contribute to eliminate the accumulated error every byte, so it is significant to improve the accuracy of the baud rate by using the fraction divisor with the guard time.

| Bit(s) | ) Mnemonic        | Name     | Description                               |                 |
|--------|-------------------|----------|-------------------------------------------|-----------------|
| 4      | GUARD_EN          | GUARD_EN | Guard interval time added enabling signal |                 |
| AutoCh | nips Confidential |          | © 2013 - 2021 AutoChips Inc.              | Page 118 of 360 |

| Bit(s) | Mnemonic  | Name      | Description                |
|--------|-----------|-----------|----------------------------|
|        |           |           | 0: disable                 |
|        |           |           | 1: enable                  |
| 3:0    | GUARD_CNT | GUARD_CNT | Guard interval count value |
|        |           |           | 0~15: 0 ~ 15 bit time      |

| 0x3C  |       | UARTn_SLEEP_EN Sleep enable register |    |    |    |    |   |   |   |   |   |   |   | 0000 |   |              |
|-------|-------|--------------------------------------|----|----|----|----|---|---|---|---|---|---|---|------|---|--------------|
| Bit   | 32~15 | 14                                   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1 | 0            |
| Name  |       |                                      |    |    |    |    |   |   |   |   |   |   |   |      |   | SLEEP<br>_EN |
| Туре  |       |                                      |    |    |    |    |   |   |   |   |   |   |   |      |   | RW           |
| Reset |       |                                      |    |    |    |    |   |   |   |   |   |   |   |      |   | 0            |

| Bit(s) Mnemonic | Name     | Description                                                                                                                                                                                                                                                                    |
|-----------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 SLEEP_EN      | SLEEP_EN | <ul> <li>Sleep function enable</li> <li>0: Does not deal with sleep mode indication signal</li> <li>1: Activate hardware flow control according to software initial settings when the chip enters the sleep mode. Release the hardware flow when the chip wakes up.</li> </ul> |

| 0x40  | <u> </u> | UART | n_DN | IA_EI | <u> </u> | 000 | 0 |   |   |   |   |   |   |   |    |                   |
|-------|----------|------|------|-------|----------|-----|---|---|---|---|---|---|---|---|----|-------------------|
| Bit   | 32~15    | 14   | 13   | 12    | 11       | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0                 |
| Name  |          |      |      |       |          |     |   |   |   |   |   |   |   |   |    | RX_D<br>MA_E<br>N |
| Туре  |          |      |      |       |          |     |   |   |   |   |   |   |   |   | RW | RW                |
| Reset |          |      |      |       |          |     |   |   |   |   |   |   |   |   | 0  | 0                 |

| Bit(s) | Mnemonic  | Name      | Description                                      |
|--------|-----------|-----------|--------------------------------------------------|
| 1      | TX_DMA_EN | TX_DMA_EN | TX_DMA mechanism enabling signal                 |
|        |           |           | 0: Does not use DMA in TX                        |
|        |           |           | 1: Use DMA in TX. When this register is enabled. |
| 0      | RX_DMA_EN | RX_DMA_EN | RX_DMA mechanism enabling signal                 |
|        |           |           | 0: Does not use DMA in RX                        |
|        |           |           | 1: Use DMA in RX. When this register is enabled. |

| 0x44  | UARTn_DIV_FRAC |    |    |    | <u>AC</u> | Fractional Divider Address |   |   |   |   |   |   |   |        |    |   |  |
|-------|----------------|----|----|----|-----------|----------------------------|---|---|---|---|---|---|---|--------|----|---|--|
| Bit   | 32~15          | 14 | 13 | 12 | 11        | 10                         | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2      | 1  | 0 |  |
| Name  |                |    |    |    |           |                            |   |   |   |   |   |   | D | IV_FRA | NC |   |  |
| Туре  |                |    |    |    |           |                            |   |   |   |   |   |   |   | RW     |    |   |  |
| Reset |                |    |    |    |           |                            |   |   |   |   |   |   |   | 0      |    |   |  |

| Bit(s) Mnemonic     | Name     | Description                                                                                                    |
|---------------------|----------|----------------------------------------------------------------------------------------------------------------|
| 4:0 <b>DIV_FRAC</b> | DIV_FRAC | Fraction divisor : if actual divisor is 135.65, then DIV_FRAC is $0.65^{*}32 = [20.8]=21$ , and the DIV_L=135. |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 119 of 360

| 0x4c  |       | UARTn_RS485CR |    |    |    | 5 con | trol r | egist | er          |   |            |           |   |   |   | 0000 |
|-------|-------|---------------|----|----|----|-------|--------|-------|-------------|---|------------|-----------|---|---|---|------|
| Bit   | 32~15 | 14            | 13 | 12 | 11 | 10    | 9      | 8     | 7           | 6 | 5          | 4         | 3 | 2 | 1 | 0    |
| Name  |       |               |    |    |    |       |        |       | RS48<br>5EN |   | INVP<br>OL | DLYE<br>N |   |   |   |      |
| Туре  |       |               |    |    |    |       |        |       | RW          |   | RW         | RW        |   |   |   |      |
| Reset |       |               |    |    |    |       |        |       | 0           |   | 0          | 0         |   |   |   |      |

#### Notes:

1. Delay ahead of transmitting is corresponding to the UARTn\_CNTR ; Delay after the transmitting can use the UARTn\_GUARD.

2. RS485 function use PIN RTS\_n as a transmitting or receiving direction control PIN.

| Bit(s) | Mnemonic | Name    | Description                                                                                                                                                                                                        |
|--------|----------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | RS485EN  | RS485EN | 0: disable rs485 mode                                                                                                                                                                                              |
|        | K340JEN  | K3403EN | 1: enable rs485 mode                                                                                                                                                                                               |
|        |          |         | INVPOL                                                                                                                                                                                                             |
| 5      | INVPOL   | INVPOL  | 0: don't inverse the polarity of rosin                                                                                                                                                                             |
|        |          |         | 1: inverse the polarity of rts_n                                                                                                                                                                                   |
| 4      | DLYEN    | DLYEN   | A DELAY is inserted between the RS485 switch to output state and<br>the actual START bit. The specific DELAY time is determined by the<br>register UART_CNTR. That is, the delay1 corresponding to Figure 9-<br>7. |
|        |          |         | 0: disable delay<br>1: enable delay                                                                                                                                                                                |

| 0x50  | <u> </u> | UART | 'n SL | ADDR | ADDRESS FOR WAKE UP |    |   |   |      |      |      |      |      |      | 0000 |      |
|-------|----------|------|-------|------|---------------------|----|---|---|------|------|------|------|------|------|------|------|
| Bit   | 32~15    | 14   | 13    | 12   | 11                  | 10 | 9 | 8 | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| Name  |          |      |       |      |                     |    |   |   | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
| Туре  |          |      |       |      |                     |    |   |   | RW   |
| Reset |          |      |       |      |                     |    |   |   | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

Note: RS485en=1 and mulcomen=1 can't be available simultaneously.

| Bit(s) | Mnemonic | Name | Description                                             |
|--------|----------|------|---------------------------------------------------------|
| 7:0    | SLADDR   | ADDR | SLADDR                                                  |
| 7.0    | SLADDR   | ADDK | 7:0: 0~255 as a slave address for RS485 when rs485en=1. |

| 0x54  |       | UART | n_CN | <u>ITR</u> |    |    |   |   |           |    |    |    |    |    |    | 0000 |
|-------|-------|------|------|------------|----|----|---|---|-----------|----|----|----|----|----|----|------|
| Bit   | 32~15 | 14   | 13   | 12         | 11 | 10 | 9 | 8 | 7         | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
| Name  |       |      |      |            |    |    |   |   | CNTR[7:0] |    |    |    |    |    |    |      |
| Туре  |       |      |      |            |    |    |   |   | RW        | RW | RW | RW | RW | RW | RW | RW   |
| Reset |       |      |      |            |    |    |   |   |           |    |    |    | 0  | 0  | 0  | 0    |

| Bit(s) | Mnemonic | Name  | Description                                       |
|--------|----------|-------|---------------------------------------------------|
| 7:0    | CNTR     | CNITP | COUNTER                                           |
| 7.0    | CNTR     | CNTR  | 7:0: 0~255 bits time for time delay in RS485 mode |

| 0x58 <u>UARTn_MULCOMCR</u> |       |    |    |    |    | Idle interrupt enable register |   |   |                  |   |   |            |   |   | 0000 |   |  |  |
|----------------------------|-------|----|----|----|----|--------------------------------|---|---|------------------|---|---|------------|---|---|------|---|--|--|
| Bit                        | 32~15 | 14 | 13 | 12 | 11 | 10                             | 9 | 8 | 7                | 6 | 5 | 4          | 3 | 2 | 1    | 0 |  |  |
| Name                       |       |    |    |    |    |                                |   |   | MUL<br>COM<br>EN |   |   | IDLEI<br>E |   |   |      |   |  |  |
| Туре                       |       |    |    |    |    |                                |   |   | RW               |   |   | RW         |   |   |      |   |  |  |
| Reset                      |       |    |    |    |    |                                |   |   | 0                |   |   | 0          |   |   |      |   |  |  |

| Bit(s) | Mnemonic | Name     | Description              |
|--------|----------|----------|--------------------------|
|        |          |          | MUI-Communication enable |
| 7      | MULCOMEN | MULCOMEN | 0: disabled              |
|        |          |          | 1: enabled               |
|        |          |          | IDLE interrupt enable    |
| 4      | IDLEIE   | IDLEIE   | 0: disabled              |
|        |          |          | 1: enabled               |

| 0x5c  |       | UART | n_LIN | NCR | LIN c | ontro | l regi | ster |       |            |            |    |              |   |   | 0000 |
|-------|-------|------|-------|-----|-------|-------|--------|------|-------|------------|------------|----|--------------|---|---|------|
| Bit   | 32~15 | 14   | 13    | 12  | 11    | 10    | 9      | 8    | 7     | 6          | 5          | 4  | 3            | 2 | 1 | 0    |
| Name  |       |      |       |     |       |       |        |      | LINEN | LBRKI<br>E | LBRK<br>DL | -  | LABA<br>UDEN |   |   |      |
| Туре  |       |      |       |     |       |       |        |      | RW    | RW         | RW         | RW | RW           |   |   |      |
| Reset |       |      |       |     |       |       |        |      | 0     | 0          | 0          | 0  | 0            |   |   |      |

| Bit(s) | Mnemonic | Name     | Description                                                                                                                                                                              |
|--------|----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | LINEN    | LINEN    | <b>LIN Mode enable</b><br>0: disable<br>1: enable                                                                                                                                        |
| 6      | LBRKIE   | LBRKIE   | LIN Break character detect interrupt enable<br>0: disable<br>1: enable                                                                                                                   |
| 5      | LBRKDL   | LBRKDL   | LIN Mode break detect length<br>0: 10 bits<br>1: 11bits                                                                                                                                  |
| 4      | SDBRK    | SDBRK    | LIN Mode whether transmit 13 0s<br>Note: set by software and cleared by MCU internal hardware during<br>the stop bit of the break.<br>0: disable<br>1: enable transmit 13 '0's right now |
| 3      | LABAUDEN | LABAUDEN | LABAUDEN<br>0: 0X55 not used to auto baud rate detection<br>1:0x55 used to auto baud rate detection                                                                                      |

AutoChips Confidential

# 10 ADC

## **10.1 ADC introduction**

**NutoChips** 

Analog to digital converter (ADC) is a system used for translating the analog quantities, which are characteristic of most phenomena in the real world, to digital language, used in information processing, computing, data transmission, and control systems. ADC can operate under 2 power modes: normal mode and low power mode.

## 10.2 ADC features

- ADC channel input voltage range: AVSS < Vin < AVDD.
- Maximum conversion rate: 500K at maximum ADC operation clock.
- 18 channels with sample time configurable for each: 16 external channels, 2 internal channels (T-sensor, Bandgap).
- Conversion sequence classified as regular group and injection group.
  - Regular group: configurable maximum 16 channels.
  - Injection group: configurable maximum 4 channels.
- 8 operation modes (called mode x for convenience, x=1~8):
  - Single regular group channel single conversion (mode1).
  - Single regular group channel continuous conversion (mode2).
  - o Multiple regular group channels single scan with injection trigger (mode3).
  - Multiple regular group channels single scan with automatically injection (mode4).
  - Multiple regular group channels continuous scan with injection trigger (mode5).
  - Multiple regular group channels continuous scan with automatically injection (mode6).
  - Multiple regular group channels under discontinuous conversion mode (mode7).
  - Multiple injection group channels under discontinuous conversion mode(mode8).
- Start ADC by internal software trigger or external hardware trigger.
- Analog monitor function:
  - Checking none, single or all channels voltage by configuration.
  - Monitor whether the channel voltage is less than low threshold or not less than high threshold.
  - If ADC operates under low power mode, configuration should refer to the table.
- Interrupts:
  - End Of Conversion (EOC) for regular or injection group.
  - End Of Injection Group Conversion (IEOC).
  - Analog Monitor event (AMO).
- DMA access: just for regular group channels.

## **10.3 ADC functional description**

Figure 10-1 below shows the ADC block diagram:



Figure 10-1 UART block diagram

In block diagram, ADC is mainly composed of ADC converter unit, input channel selector, clock divisor, and analog monitor and so on. As illustrated in **Figure 10-1**, A/D converter unit operates at ADC clock, called ADCCLK for short and the other circuit parts operate at bus clock, called BCLK for short. A typical operation flow is introduced in the following paragraph.

Firstly, ADC should be powered on, which will be described in **10.3.1**. And then, ADC can be triggered to start by the internal SWSTART or external trigger source, which is derived from the CTU module. After trigger, ADC converter unit starts to work and sends out the selecting signal to input channel selector to select the desired channel one by one based on the regular or injection group channels sequence. After one channel has finished the conversion, the conversion result is stored into the RDR or IDRx based on which group the current conversion channel belongs to. Meanwhile, the analog monitor starts to work and the related statuses flag appear if the corresponding event occurs. Until now, a single channel conversion flow goes to the end. To point out, there exist some differences for different operation mode and detailed information will be illustrated later.

### 10.3.1 ADC power on sequence

Before starting all the functions, ADC should be powered on at first. Then a valid trigger can start the ADC to operate based on configured mode. The power on sequence is illustrated as follows.



#### Figure 10-2 ADC Power on sequence

As illustrated in the Figure 10-2, bit ADC\_CTRL2[ADON] is set to 1 to control the power on process. After the ADON is set to 1, the settle time for A/D Converter unit power on is not less than 100us, which is the basic configuration.

#### 10.3.2 ADC power modes

**NutoChips** 

For ADC, there are two power modes available. One is the normal mode, the other is low power mode. In Table 10-1, the ADC clock is lower at low power mode in order to get lower power. The low power mode for ADC is used when CPU runs into sleep mode by WFI instruction. The ADC analog monitor event under low power mode can wake up the CPU from sleep mode to normal mode. The normal mode for ADC is used when CPU runs at normal mode and all the ADC registers and functions can be achieved.

| Modes                 | Normal mode       | Low power mode     |  |  |  |  |
|-----------------------|-------------------|--------------------|--|--|--|--|
| ADC clock<br>(ADCCLK) | 0.1 MHz to 10 MHz | 0.1 MHz to 1.6 MHz |  |  |  |  |
| channel               | 0 to 17           | 0 to 17            |  |  |  |  |

To explain the ADC low power mode clearly, a simple flow for CPU operation mode switching is showed as Figure 10-3. For example, user can let the CPU into sleep mode by WFI instruction if there is no need to make the CPU operate at normal mode and low power is an urgent requirement. And a desired condition that an analog monitor event occurs will wake up the CPU to work at normal mode.



Figure 10-3 CPU normal mode and sleep mode condition

AutoChips Confidential

### 10.3.3 ADC operation modes

**NutoChips** 

This chapter is the key section that introduces the detailed information for different ADC operation modes. Different modes can be used flexibly based on the practical application. After power on and a valid trigger, ADC operates at one of the following modes.

| ADC operation mode | MODE_BITS  | Trigger source       | Channel                           |
|--------------------|------------|----------------------|-----------------------------------|
| mode1              | 5'b0000x   | regular trigger      | single regular group channel      |
| mode2              | 5'b0100x   | regular trigger      | single regular group channel      |
| mode3              | 5'b10000   | regular trigger      | multiple regular group channels   |
| modes              | 5 5 10000  | (+injection trigger) | (+injection group channels)       |
| mode4              | 5'b10001   | regular trigger      | multiple regular group channels + |
| mode4              | 5 5 1000 1 | regular trigger      | injection group channels          |
| mode5              | 5'b11000   | regular trigger      | multiple regular group channels   |
| modeo              | 5 5 1 1000 | (+injection trigger) | (+injection group channels)       |
| mode6              | 5'b11001   | regular trigger      | multiple regular group channels + |
| modeo              | 5 511001   | regular ingger       | injection group channels          |
| mode7              | 5'b1x10x   | regular trigger      | regular group channels            |
| mode8              | 5'b1x01x   | injection trigger    | injection group channels          |

 Table 10-2 ADC operation modes and its corresponding configuration

#### Note: MODE\_BITS = {SCAN, CONT, DISCEN, JDISEN, JAUTO}.

Before describing each mode operation flow, it's necessary to introducing some terminologies, such as regular group, injection group and so on. For ADC input channels, they are called  $ch0 \sim ch17$ , of which  $ch0 \sim ch15$  are the external input channels, ch16 is corresponding to thermal sensor channel, and ch17 represents the bandgap reference voltage channel.

Regular group is the input channels arranged to convert in order. Based on register ADC\_RSQR1, ADC\_RSQR2 and ADC\_RSQR3, the regular group is composed of maximum 16 channels in sequence from RSQ1 to RSQ16.

For example, if the RSQ1 ~ RSQ16 are set to 9, 8,16,1,5,4,7,3,17,2,0,0,0,17,6,15 respectively, a regular group is arranged as Figure 10-4.

|               |     |     |      |     |     |     |     |     |      |     |     | sa  | mple |      | con | vertion |
|---------------|-----|-----|------|-----|-----|-----|-----|-----|------|-----|-----|-----|------|------|-----|---------|
|               |     |     |      |     |     |     |     |     |      |     |     |     |      |      |     |         |
| regular group | ch9 | ch8 | ch16 | ch1 | ch5 | ch4 | ch7 | ch3 | ch17 | ch2 | ch0 | ch0 | ch0  | ch17 | ch6 | ch15    |

#### Figure 10-4 Regular group sequence

If the RSQL is set to 13, the last 3 channels will be invalid and not be converted. So, valid regular group sequence is illustrated as Figure 10-5.

|               |     |     |      |     |     |     |     |     |      |     |     | sar | nple | convertion |
|---------------|-----|-----|------|-----|-----|-----|-----|-----|------|-----|-----|-----|------|------------|
|               | _   |     |      |     |     |     |     |     |      | _   |     |     |      |            |
| regular group | ch9 | ch8 | ch16 | ch1 | ch5 | ch4 | ch7 | ch3 | ch17 | ch2 | ch0 | ch0 | ch0  |            |

#### Figure 10-5 Valid regular group sequence

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

In the same way, injection group is the input channels arranged to convert in order. Based on register ADC\_ISQR, the injection group is composed of maximum 4 channels in sequence from ISQ1 to ISQ4. For example, if the ISQ1 ~ ISQ4 are set to 16, 7, 17, 2 respectively, an injection group is arranged as Figure 10-6.

|                 |                   | sample | convertion |
|-----------------|-------------------|--------|------------|
| injection group | ch16 ch7 ch17 ch2 |        |            |

#### Figure 10-6 Injection group sequence

If the ISQL is set to 3, the last 1 channel will be invalid and not be converted. So, valid injection group sequence is illustrated as Figure 10-7.

|                               | sample | convertion |
|-------------------------------|--------|------------|
| injection group ch16 ch7 ch17 |        |            |

Figure 10-7 Valid injection group sequence

Obviously, regular group trigger and injection group trigger are the corresponding signals to start conversion of the regular and injection group sequence. The trigger is derived from the internal SWSTART or external trigger source illustrated in the ADC block diagram. And the regular trigger is invalid when ADC is in the process of regular group channel conversion. Based on the basic introduction, detailed information for each mode is described as follows. Meanwhile, the Figure 10-4 and Figure 10-6 will be used to explain the operation flow for each mode.

#### 10.3.3.1 Mode 1

**NutoChips** 

This mode just aims at the first channel in regular group no matter what the RSQL is. After the mode is configured as Table 10-2, a valid trigger can make the ADC work at this mode.



#### Figure 10-8 Mode 1 operation flow

As the Figure 10-8 shows, the first channel in regular group is converted once after a valid regular trigger. Then the ADC goes to idle until the next valid regular trigger for the next conversion.

#### 10.3.3.2 Mode 2

This mode also just aims at the first channel in regular group no matter what the RSQL is. After the mode configuration as Table 10-2, a valid trigger can make the ADC work at this mode.



#### Figure 10-9 Mode 2 operation flow

As the Figure 10-9 shows, the first channel in regular group is converted forever except power down, top reset or mode change after a valid regular trigger.

#### 10.3.3.3 Mode 3

This mode aims at the regular group channels and injection group channels, which must be triggered by injection trigger. The valid regular and injection group channel number are decided by RSQL and ISQL respectively. With the mode configuration as Table 10-2, a valid trigger can make the ADC work at this mode. For example, RSQL is set to 7 and ISQL is set to 3. A typical operation shows as Figure 10-10. The initial regular trigger starts conversion of the first 7 channels in group. When ADC converts the channel 1 in regular group, an injection trigger switches the conversion to 3 injection group channels after the end of channel 1 conversion. After 3 injection group channels has been converted completely, conversion switches back to regular group channels automatically and the last 3 channels start to convert. When finishing the valid regular channels conversion, ADC runs to idle until the next trigger.



#### Figure 10-10 Mode 3 typical operation flow

Especially, if the injection trigger occurs when the ADC is idle, the ADC will finish the conversion of the valid injection group channels as the following Figure 10-11. Basically, the regular or injection group channels are converted once by a valid trigger at this mode.



#### Figure 10-11 Mode 3 operation flow with injection trigger at ADC idle state

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 127 of 360

#### 10.3.3.4 Mode 4

This mode aims at a single conversion for all the regular group channels and injection group channels, which are converted following the regular group channel automatically. The valid regular channels and injection group channels are decided by RSQL and ISQL respectively. With the mode configuration as Table 10-2, a valid trigger can make the ADC work at this mode. For example, SQL is set to 7 and ISQL is set to 3. A typical operation shows as Figure 10-12. A regular trigger starts conversion of the first 7 regular group channels followed by 3 injection group channels automatically. After the total 10 channels has been converted completely, ADC runs to idle state until the next valid regular trigger.



#### Figure 10-12 Mode 4 operation flow with auto injection trigger

#### 10.3.3.5 Mode 5

This mode just aims at the regular group channels and injection group channels, which must be triggered by injection trigger. The valid regular channels and injection group channels are decided by SQL and ISQL respectively. With the mode configuration as Table 10-2, a valid trigger can make the ADC work at this mode. A key feature for this mode is that a single regular trigger can make the ADC work all the time except power down, top reset and mode change. For example, RSQL is set to 7 and ISQL is set to 3. A typical operation shows as Figure 10-13. The ADC works on regular group channels in order circularly after a regular trigger or works on the injection group channels if an injection trigger occurs.



Figure 10-13 Mode 5 typical operation flow

Especially, if the injection trigger occurs when the ADC is idle, the ADC will finish the conversion of the valid injection group channels at first as the following Figure 10-14.



Figure 10-14 Mode 5 operation flow with injection trigger at ADC idle state

#### 10.3.3.6 Mode 6

This mode aims at the regular group channels and injection group channels. The valid regular channels and injection group channels are decided by RSQL and ISQL respectively. With the mode configuration as Table 10-2, a valid regular trigger can make the ADC work at this mode. A key feature for this mode is that a single regular trigger can make the ADC work all the time except power down, top reset and mode change. For example, RSQL is set to 7 and ISQL is set to 3. An operation flow shows as Figure 10-15. The ADC works on regular group channels in order followed by injection group channels circularly after a regular trigger.



Figure 10-15 Mode 6 operation flow

#### 10.3.3.7 Mode 7

This mode just aims at the regular group channels. The valid regular channels group channels are decided by RSQL. With the mode configuration as Table 10-2, ADC can work at this mode. The valid regular channels are divided into several subgroups every DISCNUM channels.

For example, RSQL is set to 7 and DISCNUM is set to 2.

First regular trigger: ch9, ch8;

Second regular trigger: ch16, ch1;

Third regular trigger: ch5, ch4;

Fourth regular trigger: ch7, generates EOC flag;

Fifth regular trigger: ch9, ch8;

Sixth regular trigger: ch16, ch1;

#### •••

So, the practical conversion flow is illustrated as Figure 10-16.

© 2013 - 2021 AutoChips Inc.



Figure 10-16 Mode 7 operation flow

#### 10.3.3.8 Mode 8

This mode just aims at the injection group channels. The valid injection channels group channels are decided by ISQL. With the mode configuration as Table 10-2, ADC can work at this mode. The valid injection channels are divided into several subgroups every one channel.

For example, ISQL is set to 3.

First regular trigger: ch16;

Second regular trigger: ch7;

Third regular trigger: ch17, generates EOC and IEOC flag;

Fourth regular trigger: ch16;

Fifth regular trigger: ch9, ch7;

```
••••
```

So, the practical conversion flow is illustrated as Figure 10-17.



Figure 10-17 Mode 8 operation flow

## 10.4 Analog monitor

If the monitored channels voltage is more than the high threshold or less than the low threshold, analog monitor set the AMO flag to 1, which is cleared by writing 0 to it. Meanwhile, the interrupt occurs if AMO flag is 1 and AMOIE is configured to 1.

The high and low threshold is decided by AWDH and AWDL respectively. Analog monitor can be used to monitor none, single channel, multiple channels based on bits AMOEN, IAMOEN, AMOSGL and AMOCH.



#### Figure 10-18 Analog monitor detecting region

| Analog monitor<br>channel                       | {AMOEN,IAMOEN,AMOSGL} | Configurable operation mode | Comment                                                                                                 |
|-------------------------------------------------|-----------------------|-----------------------------|---------------------------------------------------------------------------------------------------------|
| None                                            | 3'b00x                | All modes                   | -                                                                                                       |
| All injection group channels                    | 3'b010                | mode3 ~ mode6,<br>mode8     | -                                                                                                       |
| All regular group channels                      | 3'b100                | Except mode8                | -                                                                                                       |
| All channels                                    | 3'b110                | All modes                   | -                                                                                                       |
| Single injection<br>group channel               | 3'b011                | mode3 ~ mode6,<br>mode8     | Conversion sequence<br>must contain the injection<br>channel determined by<br>AMDCH[4:0].               |
| Single regular<br>group channel                 | 3'b101                | mode1 ~ mode7               | Conversion sequence<br>must contain the regular<br>channel determined by<br>AMDCH[4:0].                 |
| Single regular or<br>injection group<br>channel | 3'b111                | All modes                   | Conversion sequence<br>must contain the regular<br>or injection channel<br>determined by<br>AMDCH[4:0]. |

Table 10-3 Analog monitor configuration

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 131 of 360

# **NutoChips**

## 10.5 Status flag description

For ADC, there are three flags to indicate the conversion status. One is the EOC, another is IEOC, the last is AMO. The EOC flag indicates the end of the conversion for both regular and injection group channels. The IEOC flag indicates whether all the injection group channels are converted completely. The AMO flag indicates whether the analog monitor event occurs. The analog monitor event is whether the current conversion result is more than high threshold or less than low threshold based on the configuration. The flag EOC and IEOC are generated at different time for different modes, but can be classified to three conditions. The flag AMO is generated at the same time for all the modes. The following descriptions are introduced with the assumption that ch5 is less than AWDL, ch7 is more than the AWDH, and the analog monitor is configured to check all the channels including regular group channels and injection group channels for example.

The flags EOC and IEOC is generated at the same time for mode 1 to mode 6. The flag AMO is generated at the same time for all the 8 modes. The detailed information about three flags is illustrated as Figure 10-19 based on mode 6.



#### Figure 10-19 Three flags under condition 1

In Figure 10-19, EOC is set to 1 when a channel conversion is finished for both regular and injection group channels. And the EOC is cleared by writing 0 to it or reading the ADC\_RDR register. For IEOC flag, it is set to 1 when all the valid injection group channels have been converted completely and cleared by writing 0 to IEOC bit. AMO flag is set to 1 when the channel voltage is out of the analog monitor normal region, such as ch5, ch7. To point out, the duration of the flag maintaining 1 is decided by the CPU response time, which is related with the current loading of the CPU at that moment. The time when the flags are generated is different between mode7 and mode 1 to mode 6. The

detailed information about three flags is illustrated as Figure 10-20.

Page 132 of 360

#### **NutoChips** AC781x Reference Manual General regular trigger ch9 ch8 ch16 ch1 ch5 ch7 ch4 ch9 ch8 ch16 ch1 ch5 ch4 regular group



#### Figure 10-20 Three flags under condition 2

In Figure 10-20, EOC is set to 1 when the channel conversions are finished for regular group channels. And the EOC is cleared by writing 0 to it or reading the ADC\_RDR register. For IEOC flag, it is still 0 all the time for this mode. AMO flag is set to 1 when the channel voltage is out of the analog monitor normal region, such as ch5, ch7. To point out, the duration of the flag maintaining 1 is decided by the CPU response time, which is related with the current loading of the CPU at that moment.

The flags also show a different scenario under mode 8. It's easy to describe the flag information because ADC conversion just aims at injection group channels.



#### Figure 10-21 Three flags under condition 3

In Figure 10-21, EOC and IEOC are set to 1 when the channel conversions are finished for all the injection group channels. And the EOC is cleared by writing 0 to it or reading the ADC\_RDR register. For IEOC flag, it is cleared by writing 0 to IEOC bit. AMO flag is set to 1 when the channel voltage is out of the analog monitor normal region, such as ch7. To point out, the duration of the flag maintaining

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 133 of 360

. . .

1 is decided by the CPU response time, which is related with the current loading of the CPU at that moment.

## 10.6 Calibration

**NutoChips** 

The calibration function can make the ADC conversion result more accurate and correct the errors caused by GE (Gain Error) and OE (Offset Error).

During chip production, machine testing is required, and the measured GE & OE values are stored in a specific area of the chip. When the calibration function is enabled, the data register gives the final result of using GE & OE for calibration.

### 10.7 Sampling conversion time

The ADC uses several ADC\_CLK cycles to sample the input voltage. The number of sampling cycles can be changed by the SPT [2:0] bits in the ADC\_SPT register. Each channel can be sampled at different times.

#### Total conversion time: (SPT+ 12) \* ADC cycles + 5 APB cycles

For example, if APB=48MHz, ADCCLK=8MHz, SPT=3 ADCCLK, total conversion time=  $(3+12)/8+(5/48) \approx 1.98 \mu s$ .

### 10.8 Temperature sensor

The temperature sensor can be used to measure the ambient temperature (TA) of the device. The temperature sensor is internally connected to the ADC channel which is used to convert the sensor output voltage into a digital value.

The internal temperature sensor is more suited to applications that detect temperature variations instead of absolute temperatures. If accurate temperature readings are needed, an external temperature sensor part should be used.

#### Temperature using the following formula:

Temperature (°C) = {(VTEMP25 - VSENSE) / Slope} + 25

VTEMP25: VSENSE value for 25°C

VSENSE: VSENSE value

Slope = Average slope for Temperature ( $mV/^{\circ}C$ ).

Refer to the Electrical characteristics section for the actual values of VTEMP25 and Slope.

### 10.9 DMA access

Because of just one data register for regular group channels, DMA function is recommended to avoid conversion result lose when there are many regular group channels for conversion. Therefore, DMA function just is dedicated for regular group channels.

# **//utoChips**

## 10.10 Program guide

### 10.10.1 Normal power mode

The basic programming steps are described as three steps, which briefly introduces the configuration process at macro level. And the detailed configuration can be found in the following example. Basic three steps at macro level:

- First step: ADC operation clock configuration and power on.
- Second step: mode configuration and other configuration.
- Last step: a valid trigger.

For example, ADC works with the following configuration:

- (1) Mode 5, ADC operation clock:8.33MHz @ bus clock = 50MHz.
- (2) Regular sequence: ch9, ch8, ch16, ch1, ch5, ch4, ch7, ch3, ch17, ch2, ch0, ch0, ch0, ch17, ch6, chf.

- (3) Injection sequence: ch16, ch7, ch17, ch2. ISQL=3;
- (4) Analog monitor: for all the channels.
- (5) Others: default.

### 10.10.2 Low power mode

ADC configuration for low power mode is the same with the normal mode configuration, and ADC enters low power mode and wakes up from low power mode just following the Figure 10-3.

## **10.11 ADC register definition**

#### Table 10-4 ADC register map

#### BaseAddress = 0x40003000.

#### Address = BaseAddress + OffsetAddress.

| Offset<br>Address | Name      | Width | Register function                     |
|-------------------|-----------|-------|---------------------------------------|
| 00000000          | ADC_STR   | 32    | ADC status register                   |
| 0000004           | ADC_CTRL1 | 32    | ADC control register1                 |
| 0000008           | ADC_CTRL2 | 32    | ADC control register2                 |
| 000000C           | ADC_SPT1  | 32    | ADC sample time selection register 1  |
| 00000010          | ADC_SPT2  | 32    | ADC sample time selection register 2  |
| 00000014          | ADC_IOFR1 | 32    | ADC injection group offset register 1 |
| 00000018          | ADC_IOFR2 | 32    | ADC injection group offset register 2 |
| 0000001C          | ADC_IOFR3 | 32    | ADC injection group offset register 3 |
| 0000020           | ADC_IOFR4 | 32    | ADC injection group offset register 4 |
| 00000024          | AWDH      | 32    | ADC AWD high threshold register       |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 135 of 360

RSQL=7;

| Offset<br>Address | Name      | Width | Register function                               |
|-------------------|-----------|-------|-------------------------------------------------|
| 0000028           | AWDL      | 32    | ADC AWD low threshold register                  |
| 0000002C          | ADC_RSQR1 | 32    | ADC regular group sequence configure register 1 |
| 0000030           | ADC_RSQR2 | 32    | ADC regular group sequence configure register 2 |
| 0000034           | ADC_RSQR3 | 32    | ADC regular group sequence configure register 3 |
| 0000038           | ADC_ISQR  | 32    | ADC injection group sequence configure register |
| 000003C           | ADC_IDR1  | 32    | ADC injection group data register 1             |
| 00000040          | ADC_IDR2  | 32    | ADC injection group data register 2             |
| 00000044          | ADC_IDR3  | 32    | ADC injection group data register 3             |
| 00000048          | ADC_IDR4  | 32    | ADC injection group data register 4             |
| 0000004C          | ADC_RDR   | 32    | ADC regular group data register                 |

| 000000 | 00 <u>AD</u> | <u>с_sт</u> | <u>R</u> |      |    | Α | DC St | atus I | Regis | ter |   | 00000000     |   |      |     |     |
|--------|--------------|-------------|----------|------|----|---|-------|--------|-------|-----|---|--------------|---|------|-----|-----|
| Bit    |              |             |          | 31~1 | 18 |   |       |        | 7     | 6   | 5 | 4            | 3 | 2    | 1   | 0   |
| Name   |              |             |          |      |    |   |       |        |       |     |   | ADC_ID<br>LE |   | IEOC | EOC | AMO |
| Туре   |              |             |          |      |    |   |       |        |       |     |   | R            |   | R    | R   | R   |

| Bit(s) | Mnemonic | Name | Description                                                             |
|--------|----------|------|-------------------------------------------------------------------------|
| 4      | ADC_IDLE |      | ADC idle state indicates (is useful for sleep function)                 |
|        |          |      | 0: ADC not idle                                                         |
|        |          |      | 1: ADC idle                                                             |
| 2      | IEOC     |      | Injection group conversion completed flag                               |
|        |          |      | 0: injection group conversion not completed                             |
|        |          |      | 1: injection group conversion completed, write 0 to clear               |
| 1      | EOC      |      | Regular group conversion completed flag                                 |
|        |          |      | 0: Regular group conversion not completed                               |
|        |          |      | 1: Regular group conversion completed, write 0 or read ADC_RDR to clear |
| 0      | AMO      |      | Analog monitor event occurs                                             |
|        |          |      | 0: no analog monitor event                                              |
|        |          |      | 1: analog monitor event occurs, write 0 to clear                        |

| 000000 | 04 <u>AD</u>    | C_CTF            | <u>RL1</u> | ADC Control Register 1 |               |        |        |       |               |                    |                  |                 |                   |           | 0000000    |           |
|--------|-----------------|------------------|------------|------------------------|---------------|--------|--------|-------|---------------|--------------------|------------------|-----------------|-------------------|-----------|------------|-----------|
| Bit    | 31              | 30               | 29         | 28                     | 27            | 26     | 25     | 24    | 23            | 22                 | 21               | 20              | 19                | 18        | 17         | 16        |
| Name   | SW<br>STA<br>RT | ISW<br>STA<br>RT |            |                        |               |        |        |       |               | AL<br>IG<br>N      | IEX<br>TTR<br>IG | EXT<br>TRI<br>G | D<br>M<br>AE<br>N | AM<br>OIE | IEO<br>CIE | EOC<br>IE |
| Туре   |                 |                  |            |                        |               |        |        |       |               | R<br>W             | RW               | RW              | R<br>W            | RW        | RW         | RW        |
| Bit    | 15              | 14               | 13         | 12                     | 11            | 10     | 9      | 8     | 7             | 6                  | 5                | 4               | 3                 | 2         | 1          | 0         |
| Name   | SCA<br>N        | CO<br>NT         | DIS<br>CEN | IDIS<br>CEN            | IA<br>UT<br>O | DIS    | CNUM   | [2:0] | AM<br>OE<br>N | IA<br>M<br>OE<br>N | AM<br>OS<br>GL   |                 | Α                 | МОСН[4    | 4:0]       |           |
| Туре   | RW              | RW               | RW         | RW                     | R<br>W        | R<br>W | R<br>W | RW    |               |                    |                  | RW              | R<br>W            | RW        | RW         | RW        |

| Bit(s)  | Mnemonic       | Name              | Description                                                                                   |
|---------|----------------|-------------------|-----------------------------------------------------------------------------------------------|
| 31      | SWSTART        | SWSTART           | Software trigger for regular channels                                                         |
|         |                |                   | write 1 to trigger; read as 0                                                                 |
| 30      | ISWSTART       | ISWSTART          | Software trigger for inject channels                                                          |
|         |                |                   | write 1 to trigger; read as 0                                                                 |
| 22      | ALIGN          | ALIGN             | Data alignment                                                                                |
|         |                |                   | 0: right alignment.                                                                           |
|         |                |                   | 1: left alignment.                                                                            |
| 21      | IEXTTRIG       | IEXTTRIG          | Inject group trig source select                                                               |
|         |                |                   | 1: external                                                                                   |
|         |                |                   | 0: internal(software trig)                                                                    |
| 20      | EXTTRIG        | EXTTRIG           | Regular group trig source select                                                              |
|         |                |                   | 1: external                                                                                   |
|         |                |                   | 0: internal(software trig)                                                                    |
| 19      | DMAEN          | DMAEN             | DMA function enable                                                                           |
|         |                |                   | 1: enable                                                                                     |
|         |                |                   | 0: disable                                                                                    |
| 18 ~ 16 |                | AMOIE,EOCIE,IEOCI | Interrupt function enable                                                                     |
|         | OCIE           | E                 | 1: enable                                                                                     |
|         |                |                   | 0: disable                                                                                    |
| 15 ~ 11 | Modes control  | -                 | ADC operation mode                                                                            |
|         | bits           |                   | detailed configuration in table Table 10-2                                                    |
| 10 ~ 8  | DISCNUM        | DISCNUM           | Discontinuous conversion length of channel                                                    |
|         |                |                   | 0 ~ 7: decide the subgroup length under mode 7                                                |
| 7~5     | Analog monitor | -                 | Analog monitor function configuration                                                         |
|         | control bits   |                   | detailed configuration in Table 10-3.                                                         |
| 4 ~ 0   | AMOCH          | AMOCH             | Analog monitor detecting channel                                                              |
|         |                |                   | Specify the monitored channel when analog monitor is configured to detect just single channel |

AutoChips Confidential

| 000000 | 08 <u>AD</u> | С_СТ | <u>RL2</u> |    |    |    | AD | C Con | trol R | egist | er 2 |    |    |    | 0000 | F002     |
|--------|--------------|------|------------|----|----|----|----|-------|--------|-------|------|----|----|----|------|----------|
| Bit    | 31           | 30   | 29         | 28 | 27 | 26 | 25 | 24    | 23     | 22    | 21   | 20 | 19 | 18 | 17   | 16       |
| Name   |              |      |            |    |    |    |    |       |        |       |      |    |    |    |      |          |
| Туре   |              |      |            |    |    |    |    |       |        |       |      |    |    |    |      |          |
| Bit    | 15           | 14   | 13         | 12 | 11 | 10 | 9  | 8     | 7      | 6     | 5    | 4  | 3  | 2  | 1    | 0        |
| Name   |              | PSC  | [3:0]      |    |    |    |    |       |        |       |      |    |    |    |      | AD<br>ON |
| Туре   | RW           | RW   | RW         | RW |    |    |    |       |        |       |      |    |    |    |      | RW       |

| Bit  | (s) Mnemonic  | Name | Description                                                                               |
|------|---------------|------|-------------------------------------------------------------------------------------------|
| 15 ~ | 12 <b>PSC</b> | PSC  | Bus clock(Tbusclk) Prescale to get ADC operation<br>clock(Tadcclk).                       |
|      |               |      | <b>NOTE:</b> psc value must guarantee that ADC operation clock is less than 10 MHz.       |
|      |               |      | 0 ~ 15 : 1 ~ 16 divisor.                                                                  |
| 0    | ADON          | ADON | ADC Power on                                                                              |
|      |               |      | Write 1: ADC power on.                                                                    |
|      |               |      | Write 0: ADC power down and reset the ADC (but the configure registers are not be reset). |

| 000000 | 0C <u>AC</u> | C_SP | <u>'T1</u> AI | C                                                |    |    | Sar | nple T | le Time Register 1 |        |     |    |         |     |      | 0000000 |  |  |
|--------|--------------|------|---------------|--------------------------------------------------|----|----|-----|--------|--------------------|--------|-----|----|---------|-----|------|---------|--|--|
| Bit    | 31           | 30   | 29            | 28                                               | 27 | 26 | 25  | 24     | 23                 | 22     | 21  | 20 | 19      | 18  | 17   | 16      |  |  |
| Name   |              |      |               |                                                  |    |    |     |        | SF                 | PT17[2 | :0] | SF | PT16[2  | :0] | SPT1 | 5[2:0]  |  |  |
| Туре   |              |      |               |                                                  |    |    |     |        |                    |        |     | F  | RM      |     |      |         |  |  |
| Bit    | 15           | 14   | 13            | 12                                               | 11 | 10 | 9   | 8      | 7                  | 6      | 5   | 4  | 3       | 2   | 1    | 0       |  |  |
| Name   |              | SI   | PT14[2:       | 14[2:0] SPT13[2:0] SPT12[2:0] SPT11[2:0] SPT10[2 |    |    |     |        |                    |        |     |    | SPT10[2 | :0] |      |         |  |  |
| Туре   |              |      |               |                                                  |    |    |     | I      | RW                 |        |     |    |         |     |      |         |  |  |

**Note:** *x*=10 to 17

| Bit(s) Mnemonic  | Name | Description                                |
|------------------|------|--------------------------------------------|
| 23:0 <b>SPTx</b> | SPTx | Sample time selection for each channels    |
|                  |      | 000 to 111: 6/14/29/42/56/72/215/3 ADCCLK. |

| 000000 | 10 <u>AD</u> | C_SP | <u>T2</u> |                                              |    | A  | DC Sa | ample Time Register 2 |    |        |    |    |        |    |     | 0000000 |  |  |
|--------|--------------|------|-----------|----------------------------------------------|----|----|-------|-----------------------|----|--------|----|----|--------|----|-----|---------|--|--|
| Bit    | 31           | 30   | 29        | 28                                           | 27 | 26 | 25    | 24                    | 23 | 22     | 21 | 20 | 19     | 18 | 17  | 16      |  |  |
| Name   |              |      | S         | PT9[2:0                                      | ]  | S  | PT8[2 | :0]                   | S  | PT7[2: | 0] | S  | PT6[2: | 0] | SPT | 5[2:0]  |  |  |
| Туре   |              |      |           |                                              |    |    |       |                       |    | RW     |    |    |        |    |     |         |  |  |
| Bit    | 15           | 14   | 13        | 12                                           | 11 | 10 | 9     | 8                     | 7  | 6      | 5  | 4  | 3      | 2  | 1   | 0       |  |  |
| Name   |              | s    | 6PT4[2:0  | 2:0] SPT3[2:0] SPT2[2:0] SPT1[2:0] SPT0[2:0] |    |    |       |                       |    |        |    |    | 0]     |    |     |         |  |  |
| Туре   |              |      |           |                                              |    |    |       | I                     | RW |        |    |    |        |    |     |         |  |  |

*Note: x*=0 to 9

| Bit(s) Mn      | nemonic | Name | Description                                |
|----------------|---------|------|--------------------------------------------|
| 23:0 <b>SP</b> | Тх      | SPT  | Sample time selection for each channels    |
|                |         |      | 000 to 111: 6/14/29/42/56/72/215/3 ADCCLK. |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 138 of 360

| 000000 | 14~20 | ADC_ | lofr | x(x=1- | ~4) |    | ADC |             | 0000000 |    |    |    |    |    |    |    |
|--------|-------|------|------|--------|-----|----|-----|-------------|---------|----|----|----|----|----|----|----|
| Bit    | 31    | 30   | 29   | 28     | 27  | 26 | 25  | 24          | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   |       |      |      |        |     |    |     |             |         |    |    |    |    |    |    |    |
| Туре   |       |      |      |        |     |    |     |             |         |    |    |    |    |    |    |    |
| Bit    | 15    | 14   | 13   | 12     | 11  | 10 | 9   | 8           | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   |       |      |      |        |     |    |     | IOFRx[11:0] |         |    |    |    |    |    |    |    |
| Туре   |       |      |      |        |     |    |     | RW          |         |    |    |    |    |    |    |    |

*Note: x*= 1 to 4

| Bit(s) Mnemonic   | Name  | Description                                           |
|-------------------|-------|-------------------------------------------------------|
| 11:0 <b>IOFRx</b> | IOFRx | Injection group offset value                          |
|                   |       | Final conversion result will be minus by Offset value |

| 000000 | 24 <u>AW</u> | /DH |    |    | ADC AWD High threshold Register |            |    |    |    |    |    |    |    |    |    | 0000000 |  |  |
|--------|--------------|-----|----|----|---------------------------------|------------|----|----|----|----|----|----|----|----|----|---------|--|--|
| Bit    | 31           | 30  | 29 | 28 | 27                              | 26         | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      |  |  |
| Name   |              |     |    | -  | -                               | -          | -  | -  | -  | -  |    |    | -  | -  | -  |         |  |  |
| Туре   |              |     |    |    |                                 |            |    |    |    |    |    |    |    |    |    |         |  |  |
| Bit    | 15           | 14  | 13 | 12 | 11                              | 10         | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0       |  |  |
| Name   |              |     |    | -  |                                 | AWDH[11:0] |    |    |    |    |    |    |    |    |    |         |  |  |
| Туре   |              |     |    |    |                                 | RW         |    |    |    |    |    |    |    |    |    |         |  |  |

| Bit(s) Mnemonic  | Name | Description                               |
|------------------|------|-------------------------------------------|
| 11:0 <b>AWDH</b> | AWDH | High threshold value for analog Watch dog |
|                  |      | Define the high threshold value .         |

| 000000 | 28 <u>AW</u> | /DL |    |    | ADC AWD Low Threshold Register |    |    |    |    |    |    |    |    |    |    | 0000000 |  |  |
|--------|--------------|-----|----|----|--------------------------------|----|----|----|----|----|----|----|----|----|----|---------|--|--|
| Bit    | 31           | 30  | 29 | 28 | 27                             | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      |  |  |
| Name   |              |     |    |    |                                |    |    |    |    |    |    |    |    |    |    |         |  |  |
| Туре   |              |     |    |    |                                |    |    |    |    |    |    |    |    |    |    |         |  |  |
| Bit    | 15           | 14  | 13 | 12 | 11                             | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0       |  |  |
| Name   |              |     |    |    | AWDL[11:0]                     |    |    |    |    |    |    |    |    |    |    |         |  |  |
| Туре   | RW           |     |    |    |                                |    |    |    |    |    |    |    |    |    |    |         |  |  |

| Bit(s) Mnemonic  | Name | Description                              |
|------------------|------|------------------------------------------|
| 11:0 <b>AWDL</b> | AWDL | Low threshold value for analog Watch dog |
|                  |      | Define the low threshold value .         |

AutoChips Confidential

| 000000 | 2C <u>AC</u> | C_RS | QR1 |         | ADC | regu | lar gr | oup s | sequence configure register 1 |     |        |    |    |         |         | 0000000 |  |  |
|--------|--------------|------|-----|---------|-----|------|--------|-------|-------------------------------|-----|--------|----|----|---------|---------|---------|--|--|
| Bit    | 31           | 30   | 29  | 28      | 27  | 26   | 25     | 24    | 23                            | 22  | 21     | 20 | 19 | 18      | 17      | 16      |  |  |
| Name   |              | _    |     | -       | -   | -    | -      | _     |                               | RSQ | L[3:0] |    |    | RSQ     | 16[4:0] |         |  |  |
| Туре   |              |      |     |         |     |      |        |       |                               |     |        | F  | RM |         |         |         |  |  |
| Bit    | 15           | 14   | 13  | 12      | 11  | 10   | 9      | 8     | 7                             | 6   | 5      | 4  | 3  | 2       | 1       | 0       |  |  |
| Name   |              |      | RS  | Q15[4:0 | )]  |      |        | R     | SQ14[4:                       | :0] |        |    | I  | RSQ13[4 | 4:0]    |         |  |  |
| Туре   |              |      |     |         |     |      |        |       | RW                            |     |        |    |    |         |         |         |  |  |

| Bit(s) | Mnemonic | Name | Description                                                                             |
|--------|----------|------|-----------------------------------------------------------------------------------------|
| 23:20  | RSQL     | RSQL | Length of the regular group                                                             |
|        |          |      | <b>Note:</b> length must be less than the number of actual valid regular group sequence |
|        |          |      | 0 ~ 15:define the regular group length.                                                 |
| 19:0   | RSQx     | RSQx | Channel selection for regular group                                                     |
|        |          |      | 0~15: external channels                                                                 |
|        |          |      | 16: BG voltage                                                                          |
|        |          |      | 17: Thermal sensor voltage                                                              |

#### 00000030 ADC\_RSQR2

ADC regular group sequence configure register 2 00000000

| Bit  | 31 | 30 | 29 28 27 26 25 24 23 22 21 20 19 18 17 |          |         |    |   |            |        | 16 |   |   |   |            |     |   |  |
|------|----|----|----------------------------------------|----------|---------|----|---|------------|--------|----|---|---|---|------------|-----|---|--|
| Name |    |    |                                        | RSC      | 212[4:0 | 0] |   | RSQ11[4:0] |        |    |   |   |   | RSQ10[4:0] |     |   |  |
| Туре |    |    |                                        |          |         |    |   |            |        | RW |   |   |   |            |     |   |  |
| Bit  | 15 | 14 | 13                                     | 12       | 11      | 10 | 9 | 8          | 7      | 6  | 5 | 4 | 3 | 2          | 1   | 0 |  |
| Name |    |    | RS                                     | 6Q9[4:0] |         |    |   | R          | SQ8[4: | 0] |   |   |   | RSQ7[4     | :0] |   |  |
| Туре |    | RW |                                        |          |         |    |   |            |        |    |   |   |   |            |     |   |  |

| Bit(s) Mnemonic  | Name | Description                         |
|------------------|------|-------------------------------------|
| 29:0 <b>RSQx</b> | RSQx | Channel selection for regular group |
|                  |      | 0~15: external channels             |
|                  |      | 16: BG voltage                      |
|                  |      | 17: Thermal sensor voltage          |

| 000000 | 34 <u>AD</u> |    |    |               |        |    | gular group sequence configure re |           |    |    |    |    | egister 3 00000 |     |    | 0000 |
|--------|--------------|----|----|---------------|--------|----|-----------------------------------|-----------|----|----|----|----|-----------------|-----|----|------|
| Bit    | 31           | 30 | 29 | 29 28 27 26 2 |        |    |                                   |           | 23 | 22 | 21 | 20 | 19              | 18  | 17 | 16   |
| Name   |              |    |    | RS            | Q6[4:0 | )] |                                   | RSQ5[4:0] |    |    |    |    | RSQ4[4:0]       |     |    |      |
| Туре   |              |    |    |               |        |    |                                   | RW        |    |    |    |    |                 |     |    |      |
| Bit    | 15           | 14 | 13 | 12            | 11     | 10 | 9                                 | 8         | 7  | 6  | 5  | 4  | 3               | 2   | 1  | 0    |
| Name   |              |    | RS | GQ3[4:0]      |        |    | R                                 | SQ2[4:    | 0] |    |    |    | RSQ1[4          | :0] |    |      |
| Туре   |              | RW |    |               |        |    |                                   |           |    |    |    |    |                 |     |    |      |

| Bit(s) Mnemonic  | Name | Description                         |  |
|------------------|------|-------------------------------------|--|
| 29:0 <b>RSQx</b> | RSQx | Channel selection for regular group |  |
|                  |      | 0~15: external channels             |  |
|                  |      | 16: BG voltage                      |  |
|                  |      | 17: Thermal sensor voltage          |  |

#### 00000038 <u>ADC\_ISQR</u> ADC injection group sequence configure register 00000000

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 140 of 360

| Bit  | 31        | 30 | 29 | 28 | 27 | 26 | 25 | 24                  | 23 | 22 | 21                  | 20 | 19 | 18 | 17 | 16 |
|------|-----------|----|----|----|----|----|----|---------------------|----|----|---------------------|----|----|----|----|----|
| Name |           |    |    |    |    |    |    |                     |    |    | ISQL[1:0] ISQ4[4:0] |    |    |    |    |    |
| Туре |           |    |    |    |    |    |    |                     |    |    |                     |    | F  | ۲W |    |    |
| Bit  | 15        | 14 | 13 | 12 | 11 | 10 | 9  | 8                   | 7  | 6  | 5                   | 4  | 3  | 2  | 1  | 0  |
| Name | ISQ3[4:0] |    |    |    |    |    |    | ISQ2[4:0] ISQ1[4:0] |    |    |                     |    |    |    |    |    |
| Туре |           | RW |    |    |    |    |    |                     |    |    |                     |    |    |    |    |    |

| Bit(s) | Mnemonic | Name | Description                                                                                    |
|--------|----------|------|------------------------------------------------------------------------------------------------|
| 21:20  | ISQL     | ISQL | Length of the injection group                                                                  |
|        |          |      | <b>Note:</b> The length must be less than the number of actual valid injection group sequence. |
|        |          |      | 0 ~ 15: define the regular group length.                                                       |
| 19:0   | ISQx     | ISQx | Channel selection for regular group                                                            |
|        |          |      | 0~15: external channels                                                                        |
|        |          |      | 16: BG voltage                                                                                 |
|        |          |      | 17: Thermal sensor voltage                                                                     |

#### 0000003C~48 ADC\_IDRx(x=1~4) ADC Injection group data register 00000000

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21       | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|
| Name |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |
| Туре |    |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5        | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    | ID | Rx[11:0] | l  |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    | RO       |    |    |    |    |    |

*Note: x*=1 to 4

| Bit(s) Mnemonic  | Name | Description                                           |
|------------------|------|-------------------------------------------------------|
| 11:0 <b>IDRx</b> | IDR  | Data registers for injection group                    |
|                  |      | Note: there are 4 data registers for injection group. |

| 000000 | 004C ADC_RDR |    |    |    |    |    | ADC Regular group data register |    |    |    |         |    |    |    |    | 00000000 |  |
|--------|--------------|----|----|----|----|----|---------------------------------|----|----|----|---------|----|----|----|----|----------|--|
| Bit    | 31           | 30 | 29 | 28 | 27 | 26 | 25                              | 24 | 23 | 22 | 21      | 20 | 19 | 18 | 17 | 16       |  |
| Name   |              |    |    | -  | -  | -  | -                               |    | -  | -  | -       |    | -  |    | -  | _        |  |
| Туре   |              |    |    |    |    |    |                                 |    |    |    |         |    |    |    |    |          |  |
| Bit    | 15           | 14 | 13 | 12 | 11 | 10 | 9                               | 8  | 7  | 6  | 5       | 4  | 3  | 2  | 1  | 0        |  |
| Name   |              |    |    |    |    |    |                                 |    |    | RD | R[11:0] |    |    |    |    |          |  |
| Туре   |              |    |    |    |    |    |                                 |    |    |    | RO      |    |    |    |    |          |  |

| Bit(s) Mnemonic | Name | Description                                                                                                                                                                                                                                                  |
|-----------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0 <b>RDR</b> | RDR  | <b>Data register for regular group</b><br><b>Note:</b> there is just one register for regular group. If ADC is operating<br>at high speed and the cpu can't handle in time, so user must open<br>the DMA function for ADC to avoid the data from being lost. |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 141 of 360

## AC781x Reference Manual General

# 11 ACMP

### 11.1 Introduction

**NutoChips** 

The ACMP module includes ACMP0 and ACMP1. Both ACMP0 and ACMP1 contain a comparator and a 6-bit DAC. The analog MUX provides a circuit for selecting an analog input signal from six channels. One channel provided by the 6-bit DAC, and others by external input.

The polling mode and hall output function of ACMP0 are designed for motor application. ACMP1 is a normal module without polling and hall output.

### 11.2 Features

- On-chip 6-bit resolution DAC with selectable reference voltage from VDD or internal bandgap.
- Configurable hysteresis.
- Selectable interrupt on rising edge, falling edge, or both rising or falling edges of comparator output.
- Up to six selectable comparator inputs.
- Support low power mode wakeup.
- Support CTU trigger.
- ACMP0 support polling mode.
- ACMP0 support hall output.

#### 11.2.1 Block diagram



#### Figure 11-1 ACMP block diagram

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 142 of 360

## 11.3 Functional description

The ACMP0/ACMP1 module is functionally composed of two parts: digital-to-analog (DAC) and comparator (CMP).

The DAC includes a 64-level DAC (digital to analog converter) and relevant control logic. DAC can select one of two reference inputs, Vdd or on-chip bandgap, as the DAC input Vin by setting DAC\_REF. After the DAC is enabled, it converts the data set in DAC\_VAL to a stepped analog output, which is fed into ACMP as an internal reference input.

The ACMP0/ACMP1 can achieve the analog comparison between positive input and negative input, and then give out a digital output and relevant interrupt. Both the positive input and negative input of analog comparator can be selected from the six common inputs: five external reference inputs and one internal reference input from the DAC output.

### 11.3.1 ACMP0

### 11.3.1.1 Normal mode

After the ACMP0 is enabled by setting ACMP0\_CR0[ACMP0\_EN], the comparison result appears as a digital output. Whenever a valid edge defined in ACMP0\_CR0[ACMP0\_MOD] occurs, ACMP0\_SR[ACMP0\_F] is asserted. If ACMP0\_CR0[ACMP0\_IE] is set, a CPU interrupt occurs.

The ACMP0 output is synchronized by the bus clock to generate ACMP0\_DR[ACMP0\_O] so that CPU can read the comparison. ACMP0\_DR[ACMP0\_O] changes following the comparison result, so it can serve as a tracking flag that continuously indicates the voltage delta on the inputs.

### 11.3.1.2 Polling mode

ACMP0 can switch the input channel for comparator's positive or negative input. The switch sequence is defined in ACMP0\_CR4[ACMP0\_PL\_SEQ], and the frequency is controlled by ACMP0\_FD[ACMP0\_PL\_FD]. ACMP0\_PS\_PLEN and ACMP0\_NS\_PLEN is the enable bit of polling mode. ACMP0\_PS\_PLEN and ACMP0\_NS\_PLEN can't be enabled simultaneously. Both ACMP0\_PS\_PLEN and ACMP0\_NS\_PLEN enabled will not trigger the polling mode. So software must ensure that one of the two fields above is enabled.

This page gives an example of polling mode now. ACMP0 positive input polling, polling frequency is source\_clk/100, external channel 1-4 and DAC out act polling, ACMP0 negative input selects external input 0, falling edge trigger interrupt.

Step1:  $ACMP0_IE = 1'b1$ ,  $ACMP0_MOD = 2'b01$ .

Step2: set DAC0\_VAL, DAC0\_EN = 1'b1.

Step3: ACMP0\_PS\_PLEN = 1'b1, ACMP0\_NS\_PLEN = 1'b0.

Step4: ACMP0\_PL\_FD = 2'b01, ACMP0\_PL\_SEQ = 6'b111110.

Step5: ACMP0\_NSEL = 3'b000.

Step6: ACMP0\_EN = 1'b1.





#### Figure 11-2 Polling mode

#### 11.3.1.3 HALL output mode

**NutoChips** 

ACMP0 has three hall outputs, acmp0\_out\_pwt\_a, acmp0\_out\_pwt\_b and acmp0\_out\_pwt\_c. These signals are connected to PWDT module inside the chip. These hall outputs complete the motor control cooperated with the polling function. Every hall output can be selected one of the six channels with polling mode.

For example, if polling mode ACMP0\_PL\_SEQ = 6'b001110. The polling sequence is external input 1->external input 2 -> external input 3(channel 1 -> channel 2 -> channel 3).

Set ACMP0\_OPA[ACMP0\_OPA\_SEL] = 3'b010, then the acmp0\_out\_pwt\_a is the ACMP0\_D0[ACMP0\_O3].

#### 11.3.2 ACMP1

ACMP1 is normal function module without polling mode and hall out similar to ACMP0.

#### 11.3.3 Low power wakeup

When in low power mode, a valid edge on ACMP output generates an asynchronous interrupt that can wake the MCU from low power mode. This interrupt can be cleared by writing a 1 to the ACMP0\_WUF/ACMP1\_WUF. Note that the wakeup function is valid for normal mode only.

**Note**: When Using ACMP to Wakeup MCU, it is recommended to select rising edge. Since the ACMP clock is disabled in the MCU low power mode to save power consumption, it is sensitive to external signals and the MCU will be woken up incorrectly if there is noise in the external signal when the falling edge is used.

### **11.4 Memory map and register definition**

Table 11-1 ACMP register map

#### Module name: ACMP Base address: (+40005000h)

| Address  | Name      | Width | Register Function              |
|----------|-----------|-------|--------------------------------|
| 40005000 | ACMP0_CR0 | 32    | ACMP0 configuration register 0 |
| 40005004 | ACMP0_CR1 | 32    | ACMP0 configuration register 1 |
| 40005008 | ACMP0_CR2 | 32    | ACMP0 configuration register 2 |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 144 of 360

| 4000500C | ACMP0_CR3   | 32 | ACMP0 configuration register 3           |
|----------|-------------|----|------------------------------------------|
| 40005010 | ACMP0_CR4   | 32 | ACMP0 configuration register 4           |
| 40005014 | ACMP0_DR    | 32 | ACMP0 data output register 0             |
| 40005018 | ACMP0_SR    | 32 | ACMP0 status register 0                  |
| 4000501C | ACMP0_FD    | 32 | ACMP0 polling frequency divider register |
| 40005020 | ACMP0_OPA   | 32 | ACMP0 hall output A set register         |
| 40005024 | ACMP0_OPB   | 32 | ACMP0 hall output B set register         |
| 40005028 | ACMP0_OPC   | 32 | ACMP0 hall output C set register         |
| 4000502C | ACMP_DACSR  | 32 | ACMP DAC reference select register       |
| 40005030 | ACMP1_CR0   | 32 | ACMP1 configuration register 0           |
| 40005034 | ACMP1_CR1   | 32 | ACMP1 configuration register 1           |
| 40005038 | ACMP1_CR2   | 32 | ACMP1 configuration register 2           |
| 4000503C | ACMP1_DSR   | 32 | ACMP1 data and status register           |
| 40008820 | ACMPDAC_CFG | 32 | ACMPDAC CFG0 register                    |
|          |             |    |                                          |

40005000

ACMP0\_CR0 AC

ACMP0 configuration register 0

0000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23           | 22                 | 21 | 20           | 19 | 18                | 17   | 16 |
|-------|----|----|----|----|----|----|----|----|--------------|--------------------|----|--------------|----|-------------------|------|----|
| Name  |    |    |    |    |    |    |    |    |              |                    |    |              |    |                   |      |    |
| Туре  |    |    |    |    |    |    |    |    |              |                    |    |              |    |                   |      |    |
| Reset |    |    |    |    |    |    |    |    |              |                    |    |              |    |                   |      |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7            | 6                  | 5  | 4            | 3  | 2                 | 1    | 0  |
| Name  |    |    |    |    |    |    |    |    | ACMP<br>0_EN | ACMP<br>0_HYS<br>T |    | ACMP<br>0_IE |    | ACMP<br>0_OP<br>E | ACMP |    |
| Туре  |    |    |    |    |    |    |    |    | RW           | RW                 |    | RW           |    | RW                | R    | W  |
| Reset |    |    |    |    |    |    |    |    | 0            | 0                  |    | 0            |    | 0                 | 0    | 0  |

| Bit(s) | Name       | Description                                                     |
|--------|------------|-----------------------------------------------------------------|
| 7      | ACMP0_EN   | ACMP0 enable                                                    |
|        |            | 0: disable                                                      |
|        |            | 1: enable                                                       |
| 6      | ACMP0_HYST | analog comparator 0 hysteresis selection                        |
|        |            | 0: 10mV                                                         |
|        |            | 1: 20mV                                                         |
| 4      | ACMP0_IE   | ACMP0 interrupt enable                                          |
|        |            | 0: disable                                                      |
|        |            | 1: enable                                                       |
| 2      | ACMP0_OPE  | ACMP0 hall output enable                                        |
|        |            | 0: disable                                                      |
|        |            | 1: enable                                                       |
| 1:0    | ACMP0_MOD  | determines the ACMP0 sensitivity modes of the interrupt trigger |
|        |            | 00: ACMP0 interrupt on output falling edge.                     |
|        |            | 01: ACMP0 interrupt on output rising edge.                      |
|        |            | 10: ACMP0 interrupt on output falling edge.                     |
|        |            | 11: ACMP0 interrupt on output falling or rising edge.           |

| 4000500 | 0005004 <u>ACMP0_CR1</u> |    |    | <u> 11</u> | ACMP0 configuration register 1 |    |    |    |    |     |       |     |    |     |       | 0000000 |  |  |
|---------|--------------------------|----|----|------------|--------------------------------|----|----|----|----|-----|-------|-----|----|-----|-------|---------|--|--|
| Bit     | 31                       | 30 | 29 | 28         | 27                             | 26 | 25 | 24 | 23 | 22  | 21    | 20  | 19 | 18  | 17    | 16      |  |  |
| Name    |                          |    |    |            |                                |    |    |    |    |     |       |     |    |     |       |         |  |  |
| Туре    |                          |    |    |            |                                |    |    |    |    |     |       |     |    |     |       |         |  |  |
| Reset   |                          |    |    |            |                                |    |    |    |    |     |       |     |    |     |       |         |  |  |
| Bit     | 15                       | 14 | 13 | 12         | 11                             | 10 | 9  | 8  | 7  | 6   | 5     | 4   | 3  | 2   | 1     | 0       |  |  |
| Name    |                          |    |    |            |                                |    |    |    |    | ACI | MP0_P | SEL |    | ACI | MP0_N | SEL     |  |  |
| Туре    |                          |    |    |            |                                |    |    |    |    | RW  |       |     |    |     | RW    |         |  |  |
| Reset   |                          |    |    |            |                                |    |    |    |    | 0   | 0     | 0   |    | 0   | 0     | 0       |  |  |

| Bit(s) | Name       | Description                                                                                                                                                                                                                        |
|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6:4    | ACMP0_PSEL | ACMP0 positive input select<br>000: external input 0<br>001: external input 1<br>010: external input 2<br>011: external input 3<br>100: external input 4<br>101: DAC0 output<br>110: ACMP0 output tie 0<br>111: ACMP0 output tie 0 |
| 2:0    | ACMP0_NSEL | ACMP0 negative input select<br>000: external input 0<br>001: external input 1<br>010: external input 2<br>011: external input 3<br>100: external input 4<br>101: DAC0 output<br>110: ACMP0 output tie 0<br>111: ACMP0 output tie 0 |

| 4000500 | 40005008 <u>ACMP0_CR2</u> |    |    |    |    | PO COI | nfigur | ation | regist      | 0000000 |    |    |      |      |    |    |  |
|---------|---------------------------|----|----|----|----|--------|--------|-------|-------------|---------|----|----|------|------|----|----|--|
| Bit     | 31                        | 30 | 29 | 28 | 27 | 26     | 25     | 24    | 23          | 22      | 21 | 20 | 19   | 18   | 17 | 16 |  |
| Name    |                           |    |    |    |    |        |        |       |             |         |    |    |      |      |    |    |  |
| Туре    |                           |    |    |    |    |        |        |       |             |         |    |    |      |      |    |    |  |
| Reset   |                           |    |    |    |    |        |        |       |             |         |    |    |      |      |    |    |  |
| Bit     | 15                        | 14 | 13 | 12 | 11 | 10     | 9      | 8     | 7           | 6       | 5  | 4  | 3    | 2    | 1  | 0  |  |
| Name    |                           |    |    |    |    |        |        |       | DAC0<br>_EN |         |    |    | DACO | _VAL |    |    |  |
| Туре    |                           |    |    |    |    |        |        |       | RW          |         | RW |    |      |      |    |    |  |
| Reset   |                           |    |    |    |    |        |        |       | 0           |         | 0  | 0  | 0    | 0    | 0  | 0  |  |

| Bit(s) | Name     | Description                 |
|--------|----------|-----------------------------|
| 7      | DAC0_EN  | DAC0 enable                 |
|        |          | 0: disable                  |
|        |          | 1: enable                   |
| 5:0    | DAC0_VAL | DAC0 output level selection |



| 4000500 | 4000500C <u>ACMP0_CR3</u> |    |    | <u> २३</u> | ACM | PO COI | nfigur | ation | registe              | er 3 | I. |    |                      |    |    | 00000000 |  |  |
|---------|---------------------------|----|----|------------|-----|--------|--------|-------|----------------------|------|----|----|----------------------|----|----|----------|--|--|
| Bit     | 31                        | 30 | 29 | 28         | 27  | 26     | 25     | 24    | 23                   | 22   | 21 | 20 | 19                   | 18 | 17 | 16       |  |  |
| Name    |                           |    |    |            |     |        |        |       |                      |      |    |    |                      |    |    |          |  |  |
| Туре    |                           |    |    |            |     |        |        |       |                      |      |    |    |                      |    |    |          |  |  |
| Reset   |                           |    |    |            |     |        |        |       |                      |      |    |    |                      |    |    |          |  |  |
| Bit     | 15                        | 14 | 13 | 12         | 11  | 10     | 9      | 8     | 7                    | 6    | 5  | 4  | 3                    | 2  | 1  | 0        |  |  |
| Name    |                           |    |    |            |     |        |        |       | ACMP0<br>_PSPL<br>EN |      |    |    | ACMP0<br>_NSPL<br>EN |    |    |          |  |  |
| Туре    |                           |    |    |            |     |        |        |       | RW                   |      |    |    | RW                   |    |    |          |  |  |
| Reset   |                           |    |    |            |     |        |        |       | 0                    |      |    |    | 0                    |    |    |          |  |  |

| Bit(s) | Name         | Description                                                         |
|--------|--------------|---------------------------------------------------------------------|
| 7      | ACMP0_PSPLEN | ACMP0 positive input polling mode enable<br>0: disable<br>1: enable |
| 3      | ACMP0_NSPLEN | ACMP0 negative input polling mode enable<br>0: disable<br>1: enable |

| 4000501 | 40005010 <u>ACMP0_CR4</u> |    |    |    | ACMF | 20 COI | nfigur | ation | regis | ter 4 |    |    |       |       | 000 | 00000 |  |
|---------|---------------------------|----|----|----|------|--------|--------|-------|-------|-------|----|----|-------|-------|-----|-------|--|
| Bit     | 31                        | 30 | 29 | 28 | 27   | 26     | 25     | 24    | 23    | 22    | 21 | 20 | 19    | 18    | 17  | 16    |  |
| Name    |                           |    |    |    |      |        |        |       |       |       |    |    |       |       |     |       |  |
| Туре    |                           |    |    |    |      |        |        |       |       |       |    |    |       |       |     |       |  |
| Reset   |                           |    |    |    |      |        |        |       |       |       |    |    |       |       |     |       |  |
| Bit     | 15                        | 14 | 13 | 12 | 11   | 10     | 9      | 8     | 7     | 6     | 5  | 4  | 3     | 2     | 1   | 0     |  |
| Name    |                           |    |    |    |      |        |        |       |       |       |    | Α  | CMP0_ | PL_SE | Q   |       |  |
| Туре    |                           |    |    |    |      |        |        |       |       |       | RW |    |       |       |     |       |  |
| Reset   |                           |    |    |    |      |        |        |       |       |       |    |    |       |       |     |       |  |

| Bit(s) | Name         | Description                        |
|--------|--------------|------------------------------------|
| 5:0    | ACMP0_PL_SEQ | ACMP0 polling channel sequence set |
|        |              | 0: disable corresponding channel   |
|        |              | 1: enable corresponding channel    |

| 40005014 <u>ACMP0_DR</u> |    |    |    |    | ACMP0 data output register 0 |    |    |    |      |    |      |      |      |      |      | 0000000 |  |
|--------------------------|----|----|----|----|------------------------------|----|----|----|------|----|------|------|------|------|------|---------|--|
| Bit                      | 31 | 30 | 29 | 28 | 27                           | 26 | 25 | 24 | 23   | 22 | 21   | 20   | 19   | 18   | 17   | 16      |  |
| Name                     |    |    |    |    |                              |    |    |    |      |    |      |      |      |      |      |         |  |
| Туре                     |    |    |    |    |                              |    |    |    |      |    |      |      |      |      |      |         |  |
| Reset                    |    |    |    |    |                              |    |    |    |      |    |      |      |      |      |      |         |  |
| Bit                      | 15 | 14 | 13 | 12 | 11                           | 10 | 9  | 8  | 7    | 6  | 5    | 4    | 3    | 2    | 1    | 0       |  |
| Name                     |    |    |    |    |                              |    |    |    | ACMP |    | ACMP | ACMP | ACMP | ACMP | ACMP | ACMP    |  |
| Name                     |    |    |    |    |                              |    |    |    | 0_0  |    | 0_05 | 0_04 | 0_O3 | 0_02 | 0_01 | 0_00    |  |
| Туре                     |    |    |    |    |                              |    |    |    | RO   |    | RO   | RO   | RO   | RO   | RO   | RO      |  |
| Reset                    |    |    |    |    |                              |    |    |    | 0    |    | 0    | 0    | 0    | 0    | 0    | 0       |  |

| Bit(s) | Name     | Description                         |
|--------|----------|-------------------------------------|
| 7      | ACMP0_O  | ACMP0 normal mode output            |
| 5      | ACMP0_O5 | ACMP0 polling mode channel 5 output |
| 4      | ACMP0_O4 | ACMP0 polling mode channel 4 output |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 147 of 360

| Bit(s) | Name     | Description                         |
|--------|----------|-------------------------------------|
| 3      | ACMP0_O3 | ACMP0 polling mode channel 3 output |
| 2      | ACMP0_O2 | ACMP0 polling mode channel 2 output |
| 1      | ACMP0_01 | ACMP0 polling mode channel 1 output |
| 0      | ACMP0_O0 | ACMP0 polling mode channel 0 output |

| 4000501 | 8       | ACM   | PO_SR | <u> </u> | ACM                                        | P0 sta | tus re  | egiste  | r 0         |                   |              |    |              |    | 000 | 00000 |  |
|---------|---------|-------|-------|----------|--------------------------------------------|--------|---------|---------|-------------|-------------------|--------------|----|--------------|----|-----|-------|--|
| Bit     | 31      | 30    | 29    | 28       | 27                                         | 26     | 25      | 24      | 23          | 22                | 21           | 20 | 19           | 18 | 17  | 16    |  |
| Name    |         |       |       |          |                                            |        |         |         |             |                   |              |    |              |    |     |       |  |
| Туре    |         |       |       |          |                                            |        |         |         |             |                   |              |    |              |    |     |       |  |
| Reset   |         |       |       |          |                                            |        |         |         |             |                   |              |    |              |    |     |       |  |
| Bit     | 15      | 14    | 13    | 12       | 11                                         | 10     | 9       | 8       | 7           | 6                 | 5            | 4  | 3            | 2  | 1   | 0     |  |
| Name    |         |       |       |          |                                            |        |         |         | ACMP<br>0_F | ACMP<br>0_WP<br>F | ACMP<br>0_F5 |    | ACMP<br>0_F3 |    |     |       |  |
| Туре    |         |       |       |          |                                            |        |         |         | RW          | RW                | RW           | RW | RW           | RW | RW  | RW    |  |
| Reset   |         |       |       |          |                                            |        |         |         | 0           | 0                 | 0            | 0  | 0            | 0  | 0   | 0     |  |
| Bit(s)  | Nam     | e     |       | D        | escri                                      | otion  |         |         |             |                   |              |    |              |    |     |       |  |
| 7       | ACM     | P0_F  |       | Α        | CMP0                                       | norma  | al moc  | le inte | rrupt f     | lag               |              |    |              |    |     |       |  |
|         |         |       |       | w        | rite 1 c                                   | lear   |         |         |             |                   |              |    |              |    |     |       |  |
| 6       | ACM     | P0_WI | PF    | Α        | ACMP0 low power mode wakeup interrupt flag |        |         |         |             |                   |              |    |              |    |     |       |  |
| -       | -       | _     |       |          | write 1 clear                              |        |         |         |             |                   |              |    |              |    |     |       |  |
| 5       | ACM     | P0_F5 |       | Δ        | CMP0                                       | nollin | a mod   | le cha  | nnel 5      | interri           | int fla      | a  |              |    |     |       |  |
| Ũ       | / 10111 | . 0 0 |       |          | rite 1 c                                   | -      | 9       | le ena  |             |                   | apt neg      | 9  |              |    |     |       |  |
| 4       | ACM     | P0 F4 |       | Δ        | CMP0                                       | nollin | a mod   | le cha  | nnel 4      | interri           | int fla      | n  |              |    |     |       |  |
| -       | AOM     | 10_14 |       |          | rite 1 c                                   | -      | g mot   |         |             | interre           | apt na       | 9  |              |    |     |       |  |
| 3       |         |       |       |          |                                            |        | ~ ~ ~ ~ | la aha  | nnol 2      | Intorr            | unt fla      | ~  |              |    |     |       |  |
| 3       | ACIM    | P0_F3 |       |          | CMP0<br>rite 1 c                           | -      | g moo   | le cha  | nner 3      | interri           | upt nag      | g  |              |    |     |       |  |
|         |         |       |       |          |                                            |        |         |         |             |                   |              |    |              |    |     |       |  |
| 2       | ACM     | P0_F2 |       |          | CMP0                                       | -      | g mod   | le cha  | nnel 2      | interru           | upt flag     | g  |              |    |     |       |  |
|         |         |       |       | W        | rite 1 c                                   | lear   |         |         |             |                   |              |    |              |    |     |       |  |
| 1       | ACM     | P0_F1 |       | Α        | CMP0                                       | pollin | g mod   | le cha  | nnel 1      | interru           | upt flag     | g  |              |    |     |       |  |
|         |         |       |       | W        | rite 1 c                                   | lear   |         |         |             |                   |              |    |              |    |     |       |  |
| 0       | ACM     | P0_F0 |       | Α        | CMP0                                       | pollin | g mod   | le cha  | nnel 0      | interru           | upt flag     | g  |              |    |     |       |  |
|         |         |       |       | w        | rite 1 c                                   | lear   |         |         |             |                   |              |    |              |    |     |       |  |
|         |         |       |       |          |                                            |        |         |         |             |                   |              |    |              |    |     |       |  |

| 4000501 | C  | ACMF | 20_FC | <u>)</u> | ACM | CMP0 polling frequency divider register |    |    |    |    |    |    | 0000000 |    |           |    |
|---------|----|------|-------|----------|-----|-----------------------------------------|----|----|----|----|----|----|---------|----|-----------|----|
| Bit     | 31 | 30   | 29    | 28       | 27  | 26                                      | 25 | 24 | 23 | 22 | 21 | 20 | 19      | 18 | 17        | 16 |
| Name    |    |      |       |          |     |                                         |    |    |    |    |    |    |         |    |           |    |
| Туре    |    |      |       |          |     |                                         |    |    |    |    |    |    |         |    |           |    |
| Reset   |    |      |       |          |     |                                         |    |    |    |    |    |    |         |    |           |    |
| Bit     | 15 | 14   | 13    | 12       | 11  | 10                                      | 9  | 8  | 7  | 6  | 5  | 4  | 3       | 2  | 1         | 0  |
| Name    |    |      |       |          |     |                                         |    |    |    |    |    |    |         |    | ACMP<br>F |    |
| Туре    |    |      |       |          |     |                                         |    |    |    |    |    |    |         |    | R         | W  |
| Reset   |    |      |       |          |     |                                         |    |    |    |    |    |    |         |    | 0         | 0  |

| Bit(s) | Name        | Description                                                    |
|--------|-------------|----------------------------------------------------------------|
| 1:0    | ACMP0_PL_FD | ACMP0 polling mode frequency divider                           |
|        |             | this divider controls the switch frequency of polling channels |
|        |             | 00: source_clk/256                                             |
|        |             | 01: source_clk/100                                             |
|        |             |                                                                |

© 2013 - 2021 AutoChips Inc.



| Bit(s) Name | Description       |  |
|-------------|-------------------|--|
|             | 10: source_clk/70 |  |
|             | 11: source_clk/50 |  |

| 4000502 | 20 |    | <u> 0_0F</u> | <u>PA</u> | ACMP0 hall output A set register |    |    |    |    | 0000000 |    |    |    |     |       |       |
|---------|----|----|--------------|-----------|----------------------------------|----|----|----|----|---------|----|----|----|-----|-------|-------|
| Bit     | 31 | 30 | 29           | 28        | 27                               | 26 | 25 | 24 | 23 | 22      | 21 | 20 | 19 | 18  | 17    | 16    |
| Name    |    |    |              |           |                                  |    |    |    |    |         |    |    |    |     |       |       |
| Туре    |    |    |              |           |                                  |    |    |    |    |         |    |    |    |     |       |       |
| Reset   |    |    |              |           |                                  |    |    |    |    |         |    |    |    |     |       |       |
| Bit     | 15 | 14 | 13           | 12        | 11                               | 10 | 9  | 8  | 7  | 6       | 5  | 4  | 3  | 2   | 1     | 0     |
| Name    |    |    |              |           |                                  |    |    |    |    |         |    |    |    | ACM | 20_OP | A_SEL |
| Туре    |    |    |              |           |                                  |    |    |    |    |         |    |    |    |     | RW    |       |
| Reset   |    |    |              |           |                                  |    |    |    |    |         |    |    |    | 0   | 0     | 0     |

| Bit(s) | Name          | Description             |
|--------|---------------|-------------------------|
| 2:0    | ACMP0_OPA_SEL | ACMP0 hall output A set |
|        |               | 000: polling channel 0  |
|        |               | 001: polling channel 1  |
|        |               | 010: polling channel 2  |
|        |               | 011: polling channel 3  |
|        |               | 100: polling channel 4  |
|        |               | 101: polling channel 5  |
|        |               | 110: output tie0        |
|        |               | 111: output tie0        |

| 40005024 | ACMP0_OPB | ACMP0 hall output B set register |
|----------|-----------|----------------------------------|
|----------|-----------|----------------------------------|

#### 0000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17    | 16  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|-----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |       |     |
| Туре  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |       |     |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |      |       |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2    | 1     | 0   |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    | ACMF | 0_OPE | SEL |
| Туре  |    |    |    |    |    |    |    |    |    |    |    |    |    |      | RW    |     |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 0    | 0     | 0   |

| Bit(s) | Name          | Description                                                                                                                                                                                                                   |
|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0    | ACMP0_OPB_SEL | ACMP0 hall output B set<br>000: polling channel 0<br>001: polling channel 1<br>010: polling channel 2<br>011: polling channel 3<br>100: polling channel 4<br>101: polling channel 5<br>110: output tie 0<br>111: output tie 0 |

| <b>VutoChips</b> |
|------------------|
|------------------|

| 4000502 | 28 | ACMP0_OPC |    |    | ACMF | 00000000 |    |    |    |    |    |    |    |      |       |     |  |  |
|---------|----|-----------|----|----|------|----------|----|----|----|----|----|----|----|------|-------|-----|--|--|
| Bit     | 31 | 30        | 29 | 28 | 27   | 26       | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17    | 16  |  |  |
| Name    |    |           |    |    |      |          |    |    |    |    |    |    |    |      |       |     |  |  |
| Туре    |    |           |    |    |      |          |    |    |    |    |    |    |    |      |       |     |  |  |
| Reset   |    |           |    |    |      |          |    |    |    |    |    |    |    |      |       |     |  |  |
| Bit     | 15 | 14        | 13 | 12 | 11   | 10       | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2    | 1     | 0   |  |  |
| Name    |    |           |    |    |      |          |    |    |    |    |    |    |    | ACMF | 0_OPC | SEL |  |  |
| Туре    |    |           |    |    |      |          |    |    |    |    |    |    |    | RW   |       |     |  |  |
| Reset   |    |           |    |    |      |          |    |    |    |    |    |    |    | 0    | 0     | 0   |  |  |

| Bit(s) | Name          | Description                                                                                                                                                                                              |
|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0    | ACMP0_OPC_SEL | ACMP0 hall output C set<br>000: polling channel 0<br>001: polling channel 1<br>010: polling channel 2<br>011: polling channel 3<br>100: polling channel 4<br>101: polling channel 5<br>110: output tie 0 |
|        |               | 111: output tie 0                                                                                                                                                                                        |

| 4000502 |    |    |    |    |    | ACMP DAC reference select register |    |    |    |    |    |    |    |    |    |             |  |
|---------|----|----|----|----|----|------------------------------------|----|----|----|----|----|----|----|----|----|-------------|--|
| Bit     | 31 | 30 | 29 | 28 | 27 | 26                                 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16          |  |
| Name    |    |    |    |    |    |                                    |    |    |    |    |    |    |    |    |    |             |  |
| Туре    |    |    |    |    |    |                                    |    |    |    |    |    |    |    |    |    |             |  |
| Reset   |    |    |    |    |    |                                    |    |    |    |    |    |    |    |    |    |             |  |
| Bit     | 15 | 14 | 13 | 12 | 11 | 10                                 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0           |  |
| Name    |    |    |    |    |    |                                    |    |    |    |    |    |    |    |    |    | DAC_<br>REF |  |
| Туре    |    |    |    |    |    |                                    |    |    |    |    |    |    |    |    |    | RW          |  |
| Reset   |    |    |    |    |    |                                    |    |    |    |    |    |    |    |    |    | 0           |  |

| Bit(s) | Name    | Description                                 |
|--------|---------|---------------------------------------------|
| 0      | DAC_REF | DAC reference select                        |
|        |         | 0: The DAC selects bandgap as the reference |
|        |         | 1: The DAC selects Vdd as the reference     |
|        |         |                                             |

| 4000503 | 0  |    | 21_CF | <u> 10</u> | ACMF | P1 coi | nfigur | ation | regis | ter 0              |    |              |    |    | 000  | 00000      |
|---------|----|----|-------|------------|------|--------|--------|-------|-------|--------------------|----|--------------|----|----|------|------------|
| Bit     | 31 | 30 | 29    | 28         | 27   | 26     | 25     | 24    | 23    | 22                 | 21 | 20           | 19 | 18 | 17   | 16         |
| Name    |    |    |       |            |      |        |        |       |       |                    |    |              |    |    |      |            |
| Туре    |    |    |       |            |      |        |        |       |       |                    |    |              |    |    |      |            |
| Reset   |    |    |       |            |      |        |        |       |       |                    |    |              |    |    |      |            |
| Bit     | 15 | 14 | 13    | 12         | 11   | 10     | 9      | 8     | 7     | 6                  | 5  | 4            | 3  | 2  | 1    | 0          |
| Name    |    |    |       |            |      |        |        |       |       | ACMP<br>1_HYS<br>T |    | ACMP<br>1_IE |    |    | ACMP | י1_MO<br>ס |
| Туре    |    |    |       |            |      |        |        |       | RW    | RW                 |    | RW           |    |    | R    | W          |
| Reset   |    |    |       |            |      |        |        |       | 0     | 0                  |    | 0            |    |    | 0    | 0          |

| Bit(s) | Name     | Description                             |
|--------|----------|-----------------------------------------|
| 7      | ACMP1_EN | ACMP1 enable<br>0: disable<br>1: enable |

© 2013 - 2021 AutoChips Inc.

Page 150 of 360

| Bit(s) | Name       | Description                                                     |
|--------|------------|-----------------------------------------------------------------|
| 6      | ACMP1_HYST | analog comparator 1 hysterisis selection                        |
|        |            | 0: 20mV                                                         |
|        |            | 1: 30mV                                                         |
| 4      | ACMP1_IE   | ACMP1 interrupt enable                                          |
|        |            | 0: disable                                                      |
| _      |            | 1: enable                                                       |
| 1:0    | ACMP1_MOD  | determines the ACMP1 sensitivity modes of the interrupt trigger |
|        |            | 00: ACMP1 interrupt on output falling edge.                     |
|        |            | 01: ACMP1 interrupt on output rising edge.                      |
|        |            | 10: ACMP1 interrupt on output falling edge.                     |
|        |            | 01: ACMP1 interrupt on output falling or rising edge.           |

| 4000503      | 40005034 <u>ACMP1_CR1</u>                      |       |     |    |                             | ACMP1 configuration register 1 0 |         |         |     |    |    |    |    |            |       |     |  |  |  |
|--------------|------------------------------------------------|-------|-----|----|-----------------------------|----------------------------------|---------|---------|-----|----|----|----|----|------------|-------|-----|--|--|--|
| Bit          | 31                                             | 30    | 29  | 28 | 27                          | 26                               | 25      | 24      | 23  | 22 | 21 | 20 | 19 | 18         | 17    | 16  |  |  |  |
| Name         |                                                |       |     |    |                             |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
| Type         |                                                |       |     |    |                             |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
| Reset<br>Bit | 15                                             | 14    | 13  | 12 | 11                          | 10                               | 9       | 8       | 7   | 6  | 5  | 4  | 3  | 2          | 1     | 0   |  |  |  |
| Name         | 15                                             | 14    | 13  | 12 | 11                          | ACMP1 PSEL                       |         |         |     |    |    |    | 3  | ACMP1 NSEL |       |     |  |  |  |
| Туре         |                                                |       |     |    |                             |                                  |         |         |     |    | RW |    |    |            | RW    | JLL |  |  |  |
| Reset        |                                                |       |     |    |                             |                                  |         |         |     | 0  | 0  | 0  |    | 0          | 0 0 0 |     |  |  |  |
| Bit(s)       | Nam                                            | e     |     | D  | escri                       | otion                            |         |         |     |    |    |    |    |            |       |     |  |  |  |
| 6:4          | ACM                                            | P1_PS | BEL |    | ACMP1 positive input select |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
|              | 000: external input 0<br>001: external input 1 |       |     |    |                             |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
|              |                                                |       |     |    | 10: ext                     |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
|              |                                                |       |     |    | 11: ext                     |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
|              |                                                |       |     |    | 00: ext                     |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
|              |                                                |       |     |    | 01: DA                      |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
|              |                                                |       |     |    | 10: AC                      |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
|              |                                                |       |     | 1  | 111: ACMP1 output tie 0     |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
| 2:0          | ACM                                            | P1_NS | SEL | Α  | CMP1                        | negat                            | ive inp | out sel | ect |    |    |    |    |            |       |     |  |  |  |
|              |                                                |       |     |    | 00: ext                     |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
|              |                                                |       |     |    | 01: ext                     |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
|              |                                                |       |     |    | 10: ext                     |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
|              |                                                |       |     |    | 11: ext                     |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
|              |                                                |       |     |    | 00: ext<br>01: DA           |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |
|              |                                                |       |     |    | 10: AC                      |                                  |         | ie ()   |     |    |    |    |    |            |       |     |  |  |  |
|              |                                                |       |     |    | 11: AC                      |                                  |         |         |     |    |    |    |    |            |       |     |  |  |  |

| 4000503 | 40005038 <u>ACMP1_CR2</u> |    |    |    |    | P1 coi | nfigur | ation | regis       |    |          |    |    | 000 | 00000 |    |  |
|---------|---------------------------|----|----|----|----|--------|--------|-------|-------------|----|----------|----|----|-----|-------|----|--|
| Bit     | 31                        | 30 | 29 | 28 | 27 | 26     | 25     | 24    | 23          | 22 | 21       | 20 | 19 | 18  | 17    | 16 |  |
| Name    |                           |    |    |    |    |        |        |       |             |    |          |    |    |     |       |    |  |
| Туре    |                           |    |    |    |    |        |        |       |             |    |          |    |    |     |       |    |  |
| Reset   |                           |    |    |    |    |        |        |       |             |    |          |    |    |     |       |    |  |
| Bit     | 15                        | 14 | 13 | 12 | 11 | 10     | 9      | 8     | 7           | 6  | 5        | 4  | 3  | 2   | 1     | 0  |  |
| Name    |                           |    |    |    |    |        |        |       | DAC1<br>_EN |    | DAC1_VAL |    |    |     |       |    |  |
| Туре    |                           |    |    |    |    |        |        |       | RW          |    | RW       |    |    |     |       |    |  |
| Reset   |                           |    |    |    |    |        |        |       | 0           |    | 0        | 0  | 0  | 0   | 0     | 0  |  |

| Bit(s) Name | Description |
|-------------|-------------|
| 7 DAC1_EN   | DAC1 enable |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 151 of 360

| Bit(s) | Name     | Description                 |
|--------|----------|-----------------------------|
|        |          | 0: disable<br>1: enable     |
| 5:0    | DAC1_VAL | DAC1 output level selection |

| 4000503 | 1000503C <u>ACMP1_DSR</u> |    |    | <u>8R</u> | ACMP1 data and status register |    |    |    |    |                   |    |             |    |    |    | 0000000     |  |  |
|---------|---------------------------|----|----|-----------|--------------------------------|----|----|----|----|-------------------|----|-------------|----|----|----|-------------|--|--|
| Bit     | 31                        | 30 | 29 | 28        | 27                             | 26 | 25 | 24 | 23 | 22                | 21 | 20          | 19 | 18 | 17 | 16          |  |  |
| Name    |                           |    |    |           |                                |    |    |    |    |                   |    |             |    |    |    |             |  |  |
| Туре    |                           |    |    |           |                                |    |    |    |    |                   |    |             |    |    |    |             |  |  |
| Reset   |                           |    |    |           |                                |    |    |    |    |                   |    |             |    |    |    |             |  |  |
| Bit     | 15                        | 14 | 13 | 12        | 11                             | 10 | 9  | 8  | 7  | 6                 | 5  | 4           | 3  | 2  | 1  | 0           |  |  |
| Name    |                           |    |    |           |                                |    |    |    |    | ACMP<br>1_WU<br>F |    | ACMP<br>1_F |    |    |    | ACMP<br>1_0 |  |  |
| Туре    |                           |    |    |           |                                |    |    |    |    | RW                |    | RW          |    |    |    | RW          |  |  |
| Reset   |                           |    |    |           |                                |    |    |    |    | 0                 |    | 0           |    |    |    | 0           |  |  |

| Bit(s) | Name      | Description                 |
|--------|-----------|-----------------------------|
| 6      | ACMP1_WUF | ACMP1 low power wakeup flag |
|        |           | write 1 clear               |
| 4      | ACMP1_F   | ACMP1 interrupt flag        |
|        |           | write 1 clear               |
| 0      | ACMP1_O   | ACMP1 output                |

| 40008820 | ACMPDAC_CFG0 | ACMPDAC Configure register 0 |
|----------|--------------|------------------------------|
|----------|--------------|------------------------------|

01FFFC00

| Bit   | 31       | 30 | 29   | 28 | 27 | 26 | 25       | 24 | 23 | 22 | 21  | 20    | 19 | 18 | 17 | 16 |
|-------|----------|----|------|----|----|----|----------|----|----|----|-----|-------|----|----|----|----|
| Name  | Reserved |    |      |    |    |    | Reserved |    |    |    |     |       |    |    |    |    |
| Туре  | RW       |    |      |    |    |    |          | RW |    |    |     |       |    |    |    |    |
| Reset | 0        | 0  | 0    | 0  | 0  | 0  | 0        | 1  | 1  | 1  | 1   | 1     | 1  | 1  | 1  | 1  |
| Bit   | 15       | 14 | 13   | 12 | 11 | 10 | 9        | 8  | 7  | 6  | 5   | 4     | 3  | 2  | 1  | 0  |
| Name  |          |    | MPXS | EL |    |    |          |    | -  |    | Res | erved | -  | -  |    |    |
| Туре  | RW       |    |      |    |    | RO |          |    |    |    |     |       |    |    |    |    |
| Reset | 1        | 1  | 1    | 1  | 1  | 1  | 0        | 0  | 0  | 0  | 0   | 0     | 0  | 0  | 0  | 0  |

| Bit(s)  | Name            | Description                                                                                            |                 |
|---------|-----------------|--------------------------------------------------------------------------------------------------------|-----------------|
|         |                 | ACMP LPF Select                                                                                        |                 |
|         |                 | ACMP0 and ACMP1 share the Same LPF Setting, S<br>for Better performance and Select 200KHz to filter of |                 |
|         |                 | 111 1 MHz                                                                                              |                 |
|         |                 | 110 1 MHz                                                                                              |                 |
| 12:10   | LPFSEL          | 101 750 kHz                                                                                            |                 |
|         |                 | 100 750 kHz                                                                                            |                 |
|         |                 | 011 500 kHz                                                                                            |                 |
|         |                 | 010 500 kHz                                                                                            |                 |
|         |                 | 001 200 kHz                                                                                            |                 |
|         |                 | 000 200 kHz                                                                                            |                 |
|         |                 | ACMP0 Hysteresis Enable Bit                                                                            |                 |
| 13      | HYST0           | 0: Disable                                                                                             |                 |
|         |                 | 1: Enable                                                                                              |                 |
| 4.4     |                 | ACMP1 Hysteresis Enable Bit                                                                            |                 |
| 14      | HYST1           | 0: Disable                                                                                             |                 |
| AutoChi | os Confidential | © 2013 - 2021 AutoChips Inc                                                                            | Page 152 of 360 |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

This document contains information that is proprietary to AutoChips Inc.

| Bit(s) | Name | Description                                                                                   |
|--------|------|-----------------------------------------------------------------------------------------------|
|        |      | 1:Enable                                                                                      |
| 15     | MODE | <b>ACMP Mode Select</b><br>0: Low Power Mode (for Saving Power Consumption)<br>1: Normal Mode |

### 11.5 Interrupts

#### Table 11-2 ACMP interrupt table

| Interrupt | Bit field            | Enable   | Clear   |
|-----------|----------------------|----------|---------|
| ACMP0     | ACMP0_SR[ACMP0_F0]   | ACMP0_IE | Write 1 |
| ACMP0     | ACMP0_SR[ACMP0_F1]   | ACMP0_IE | Write 1 |
| ACMP0     | ACMP0_SR[ACMP0_F2]   | ACMP0_IE | Write 1 |
| ACMP0     | ACMP0_SR[ACMP0_F3]   | ACMP0_IE | Write 1 |
| ACMP0     | ACMP0_SR[ACMP0_F4]   | ACMP0_IE | Write 1 |
| ACMP0     | ACMP0_SR[ACMP0_F5]   | ACMP0_IE | Write 1 |
| ACMP0     | ACMP0_SR[ACMP0_WUF]  | ACMP0_IE | Write 1 |
| ACMP1     | ACMP1_DSR[ACMP1_F]   | ACMP1_IE | Write 1 |
| ACMP1     | ACMP1_DSR[ACMP1_WUF] | ACMP1_IE | Write 1 |

### 12 PWM

### 12.1 Introduction

**NutoChips** 

The PWM module is a two-to-six channel timer that supports input capture, output compare, and the generation of PWM signals to control electric motor and power management applications. The PWM time reference is a 16-bit counter.

The device contains up to four PWM modules of one 6-channel PWM with Full functions and three 2channel PWM with basic TPM functions. Each PWM module can use independent external clock input. The table below summarizes the configuration of PWM modules.

| Feature                        | PWM0/PWM1/PWM3 | PWM2 |
|--------------------------------|----------------|------|
| Number of Channels             | 2              | 6    |
| Periodic TOF                   | Yes            | Yes  |
| Input Capture Mode             | Yes            | Yes  |
| Channel input filter           | No             | Yes  |
| Output Compare mode            | Yes            | Yes  |
| Edge-Aligned PWM               | Yes            | Yes  |
| Center-Aligned PWM             | Yes            | Yes  |
| Combine Mode                   | Yes            | Yes  |
| Complementary Mode             | Yes            | Yes  |
| Inverting                      | Yes            | Yes  |
| Software Output Control        | Yes            | Yes  |
| Deadtime insertion             | Yes            | Yes  |
| Output Mask                    | Yes            | Yes  |
| Fault Control                  | No             | Yes  |
| Number of fault inputs         | No             | Yes  |
| Fault input filter             | No             | Yes  |
| Polarity Control               | Yes            | Yes  |
| Capture Test Mode              | Yes            | Yes  |
| Dual edge capture mode         | Yes            | Yes  |
| Quadrature decode mode         | Yes            | Yes  |
| Quadrature decode input filter | Yes            | Yes  |

#### Table 12-1 PWM modules configuration

#### 12.1.1 **PWM** features

The PWM features include:

- PWM source clock is selectable.
  - Source clock can be the system clock, the internal RC clock, or an external clock.
  - Selecting external clock connects PWM clock to a chip level input pin, therefore allowing to synchronize the PWM counter with an off chip clock source.
- 16-bit Prescaler divide-by 1, 2, 3 to 65535.
- 16-bit counter.
  - It can be a free-running counter or a counter with initial and final value.
  - The counting can be up or up-down.
- Each channel can be configured for input capture, output compare, or edge-aligned PWM mode.
- In Input Capture mode, the capture can occur on rising edges, falling edges or both edges.
- An input filter can be selected for some channels.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 154 of 360

#### AC781x Reference Manual General

- In Output Compare mode, the output signal can be set, cleared, or toggled on match.
- All channels can be configured for center-aligned PWM mode.
- Each pair of channels can be combined to generate a PWM signal with independent control of both edges of PWM signal.
- The PWM channels can operate as pairs with equal outputs, pairs with complementary outputs, or independent channels with independent outputs.
- The deadtime insertion is available for each complementary pair.
- Generation of match triggers.

**NutoChips** 

- Software control of PWM outputs.
- Up to 4 fault inputs for global fault control.
- The polarity of each channel is configurable.
- The generation of an interrupt per channel.
- The generation of an interrupt when the counter overflows.
- The generation of an interrupt when the fault condition is detected.
- Synchronized loading of write buffered PWM registers.
- Write protection for critical registers.
- Dual edge capture for pulse and period width measurement.
- Quadrature decoder with input filters, relative position counting, and interrupt on position count or capture of position count on external event.

#### 12.1.2 Block diagram

The PWM uses one input/output (I/O) pin per channel, CHn (PWM channel (n)), where n is the channel number (0–5).

The following figure shows the PWM structure. The central component of the PWM is the 16-bit counter with programmable initial and final values and its counting can be up or up-down.



#### Figure 12-1 PWM block diagram

# **NutoChips**

### 12.2 Memory map and register definition

Table 12-2 PWM register map and reset values

PWM0 Base address: (0x40013000h) PWM1 Base address: (0x40014000h)

PWM2 Base address: (0x40015000h)

PWM3 Base address: (0x4001e000h)

#### Address = Base address + Offset address

| Module name | Base address | Offset address |
|-------------|--------------|----------------|
| PWM0        | 0x40013000   | 0x00 ~ 0x94    |
| PWM1        | 0x40014000   | 0x00 ~ 0x94    |
| PWM2        | 0x40015000   | 0x00 ~ 0x94    |
| PWM3        | 0x4001e000   | 0x00 ~ 0x94    |

| Offset Address | Name           | Width | Register Function                        |
|----------------|----------------|-------|------------------------------------------|
| 0x00           | PWMx_INIT      | 32    | PWM Initialization Register              |
| 0x04           | PWMx_CNT       | 32    | PWM counter value                        |
| 0x08           | PWMx_MCVR      | 32    | Max Count Value Register                 |
| 0x0C           | PWMx_CH0SCR    | 32    | Channel (0) Status And Control Register  |
| 0x10           | PWMx_CH0V      | 32    | Channel (0) Value                        |
| 0x14           | PWMx_CH1SCR    | 32    | Channel (1) Status And Control Register  |
| 0x18           | PWMx_CH1V      | 32    | Channel (1) Value                        |
| 0x1C           | PWMx_CH2SCR    | 32    | Channel (2) Status And Control Register  |
| 0x20           | PWMx_CH2V      | 32    | Channel (2) Value                        |
| 0x24           | PWMx_CH3SCR    | 32    | Channel (3) Status And Control Register  |
| 0x28           | PWMx_CH3V      | 32    | Channel (3) Value                        |
| 0x2C           | PWMx_CH4SCR    | 32    | Channel (4) Status And Control Register  |
| 0x30           | PWMx_CH4V      | 32    | Channel (4) Value                        |
| 0x34           | PWMx_CH5SCR    | 32    | Channel (5) Status And Control Register  |
| 0x38           | PWMx_CH5V      | 32    | Channel (5) Value                        |
| 0x4C           | PWMx_CNTIN     | 32    | Counter Initial Value                    |
| 0x50           | PWMx_STR       | 32    | Capture And Compare Status Register      |
| 0x54           | PWMx_FUNCSEL   | 32    | Features Mode Selection                  |
| 0x58           | PWMx_SYNC      | 32    | Synchronization                          |
| 0x5C           | PWMx_OUTINIT   | 32    | Initial State For Channels Output        |
| 0x60           | PWMx_OMCR      | 32    | Output Mask Control Register             |
| 0x64           | PWMx_MODESEL   | 32    | Mode Selection Register                  |
| 0x68           | PWMx_DTSET     | 32    | Deadtime Setting Register                |
| 0x6C           | PWMx_EXTTRIG   | 32    | PWM External Trigger                     |
| 0x70           | PWMx_CHOPOLCR  | 32    | Channel Output Polarity Control Register |
| 0x74           | PWMx_FDSR      | 32    | Fault Detect Status Register             |
| 0x78           | PWMx_CAPFILTER | 32    | Input Capture Mode Filter Control        |
| 0x7C           | PWMx_FFAFER    | 32    | Fault Filter and Fault Enable Register   |
| 0x80           | PWMx_QEI       | 32    | Quadrature Decoder Control And Status    |
| 0x84           | PWMx_CONF      | 32    | Configuration                            |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

PWM1 Base address: (0x40014000h) PWM2 Base address: (0x40015000h) PWM3 Base address: (0x4001e000h)

#### Address = Base address + Offset address

| Module name | Base address | Offset address |
|-------------|--------------|----------------|
| PWM0        | 0x40013000   | 0x00 ~ 0x94    |
| PWM1        | 0x40014000   | 0x00 ~ 0x94    |
| PWM2        | 0x40015000   | 0x00 ~ 0x94    |
| PWM3        | 0x4001e000   | 0x00 ~ 0x94    |

| 0x88 | PWMx_FLTPOL  | 32 | PWM Fault Input Polarity                 |
|------|--------------|----|------------------------------------------|
| 0x8C | PWMx_SYNCONF | 32 | Synchronization Configuration            |
| 0x90 | PWMx_INVCR   | 32 | PWM Inverting Control                    |
| 0x94 | PWMx_CHOSWCR | 32 | Channel Software Output Control Register |

| 0x00  | <u>PWMx_INIT</u> PWM Initiali |             |    |    |    |    | lization Register |                |                     |     |     | 0000000 |         |    |    |    |
|-------|-------------------------------|-------------|----|----|----|----|-------------------|----------------|---------------------|-----|-----|---------|---------|----|----|----|
| Bit   | 31                            | 30          | 29 | 28 | 27 | 26 | 25                | 24             | 23                  | 22  | 21  | 20      | 19      | 18 | 17 | 16 |
| Name  |                               |             |    |    |    |    |                   | -              |                     |     |     | CLKPS   | C[15:8] |    |    |    |
| Туре  |                               |             |    |    |    |    |                   |                |                     |     |     | R       | W       |    |    |    |
| Reset |                               |             |    |    |    |    |                   |                | 0                   | 0   | 0   | 0       | 0       | 0  | 0  | 0  |
| Bit   | 15                            | 14          | 13 | 12 | 11 | 10 | 9                 | 8              | 7                   | 6   | 5   | 4       | 3       | 2  | 1  | 0  |
| Name  |                               | CLKPSC[7:0] |    |    |    |    | CN<br>TO<br>F     | CN<br>TOI<br>E | CN<br>TM<br>OD<br>E | CLK | SRC |         |         |    |    |    |
| Туре  |                               | RW          |    |    |    |    |                   | RO             | RW                  | RW  | R   | W       |         |    |    |    |
| Reset | 0                             | 0           | 0  | 0  | 0  | 0  | 0                 | 0              | 0                   | 0   | 0   | 0       | 0       |    |    |    |

| Bit(s)    | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                               |  |  |  |  |  |  |  |  |
|-----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
|           |              | PWM CLK prescaler                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                               |  |  |  |  |  |  |  |  |
| 23:8      | CLKPSC       | The new prescaler factor affects the clock source on th<br>cycle after the new value is updated into the register bi<br>protected. It can be written only when FUNCSEL[WPD                                                                                                                                                                                                                                                                                                                  | ts. This field is write                                                                       |  |  |  |  |  |  |  |  |
|           |              | Timer Overflow Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                               |  |  |  |  |  |  |  |  |
| 7         | CNTOF        | <ul> <li>Set by hardware when the PWM counter passes the varegister. The CNTOF bit is cleared by reading the INIT is set and then writing a 0 to CNTOF bit. Writing a 1 to If another PWM overflow occurs between the read and write operation has no effect. Therefore, CNTOF remain overflow has occurred. In this case, a CNTOF interrupt to the clearing sequence for a previous CNTOF.</li> <li>0 : PWM counter has not overflowed.</li> <li>1: PWM counter has overflowed.</li> </ul> | register while CNTOF<br>CNTOF has no effect.<br>write operations, the<br>ns set indicating an |  |  |  |  |  |  |  |  |
|           |              | Timer Overflow Interrupt Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                               |  |  |  |  |  |  |  |  |
|           |              | Enables PWM overflow interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                               |  |  |  |  |  |  |  |  |
| 6         | CNTOIE       | 0 : Disable CNTOF interrupts. Use software polling.                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                               |  |  |  |  |  |  |  |  |
|           |              | 1 : Enable CNTOF interrupts. An interrupt is generated<br>one.                                                                                                                                                                                                                                                                                                                                                                                                                              | when CNTOF equals                                                                             |  |  |  |  |  |  |  |  |
| 5         | CNTMODE      | Center-Aligned PWM Select                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                               |  |  |  |  |  |  |  |  |
| 5         | CINTWICDE    | Select CPWM mode. This mode configures the PWM to                                                                                                                                                                                                                                                                                                                                                                                                                                           | o operate in Up-Down                                                                          |  |  |  |  |  |  |  |  |
| AutoChips | Confidential | © 2013 - 2021 AutoChips Inc.                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Page 158 of 360                                                                               |  |  |  |  |  |  |  |  |
|           |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                               |  |  |  |  |  |  |  |  |

This document contains information that is proprietary to AutoChips Inc.

| Bit(s) | Name   | Description                                                                                                                          |
|--------|--------|--------------------------------------------------------------------------------------------------------------------------------------|
|        |        | Counting mode. This field is write protected. It can be written only when<br>FUNCSEL[WPDIS] = 1.                                     |
|        |        | 0 : PWM counter operates in Up Counting mode.                                                                                        |
|        |        | 1 : PWM counter operates in Up-Down Counting mode.                                                                                   |
|        |        | Clock Source Selection                                                                                                               |
|        |        | Select one of the three PWM counter clock sources. This field is write<br>protected. It can be written only when FUNCSEL[WPDIS] = 1. |
| 4:3    | CLKSRC | 00: No clock selected. This in effect disables the PWM counter.                                                                      |
|        |        | 01: System clock                                                                                                                     |
|        |        | 10 :Fixed frequency clock                                                                                                            |
|        |        | 11: External clock                                                                                                                   |

| 0x04  | PWMx_CNT         PWM counter value                                                                                                                    |    |    |    |    |    |   |    |     |   |   |   |   |    | 0000000 |   |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|---|----|-----|---|---|---|---|----|---------|---|--|
| Bit   | <u>31</u> <u>30</u> <u>29</u> <u>28</u> <u>27</u> <u>26</u> <u>25</u> <u>24</u> <u>23</u> <u>22</u> <u>21</u> <u>20</u> <u>19</u> <u>18</u> <u>17</u> |    |    |    |    |    |   |    |     |   |   |   |   | 16 |         |   |  |
| Name  |                                                                                                                                                       |    |    |    |    |    |   |    |     |   |   |   |   |    |         |   |  |
| Туре  |                                                                                                                                                       |    |    |    |    |    |   |    |     |   |   |   |   |    |         |   |  |
| Reset |                                                                                                                                                       |    |    |    |    |    |   |    |     |   |   |   |   |    |         |   |  |
| Bit   | 15                                                                                                                                                    | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7   | 6 | 5 | 4 | 3 | 2  | 1       | 0 |  |
| Name  |                                                                                                                                                       |    |    |    |    |    |   | CO | UNT |   |   |   |   |    |         |   |  |
| Туре  |                                                                                                                                                       |    |    |    |    |    |   | R  | W   |   |   |   |   |    |         |   |  |
| Reset | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                     |    |    |    |    |    |   |    |     |   |   | 0 |   |    |         |   |  |
|       |                                                                                                                                                       |    |    |    |    |    |   |    |     |   |   |   |   |    |         |   |  |

| Bit(s) | Name  | Description                                                                                                                                                                                |
|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | COUNT | <b>PWM counter value.</b><br>The CNT register contains the PWM counter value. Reset clears the CNT register. Writing any value to COUNT updates the counter with its initial value, CNTIN. |

| 0x08  | PWMx_MCVR         Max Count Value Register         00000 |                                                                                                                                                                         |    |    |    |    |   |    |    |   |   |   |   |   | 0000 |   |
|-------|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|----|----|---|---|---|---|---|------|---|
| Bit   | 31                                                       | 31         30         29         28         27         26         25         24         23         22         21         20         19         18         17         16 |    |    |    |    |   |    |    |   |   |   |   |   | 16   |   |
| Name  |                                                          |                                                                                                                                                                         |    |    |    |    |   |    |    |   |   |   |   |   |      |   |
| Туре  |                                                          |                                                                                                                                                                         |    |    |    |    |   |    |    |   |   |   |   |   |      |   |
| Reset |                                                          |                                                                                                                                                                         |    |    |    |    |   |    |    |   |   |   |   |   |      |   |
| Bit   | 15                                                       | 14                                                                                                                                                                      | 13 | 12 | 11 | 10 | 9 | 8  | 7  | 6 | 5 | 4 | 3 | 2 | 1    | 0 |
| Name  |                                                          |                                                                                                                                                                         |    |    |    |    |   | MC | VR |   |   |   |   |   |      |   |
| Туре  |                                                          |                                                                                                                                                                         |    |    |    |    |   | R  | W  |   |   |   |   |   |      |   |
| Reset | 0                                                        | 0                                                                                                                                                                       | 0  | 0  | 0  | 0  | 0 | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0    | 0 |

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | MCVR | Max Count Value Register<br>The MCVR register contains the modulo value for the PWM counter. After the<br>PWM counter reaches the MCVR value, the overflow flag (CNTOF) becomes<br>set at the next clock, and the next value of PWM counter depends on the<br>selected counting method. Writing to the MCVR register latches the value into<br>a buffer. The MCVR register is updated with the value of its write buffer<br>according to Registers updated from write buffers. Initialize the PWM counter,<br>by writing to CNT, before writing to the MCVR register to avoid confusion<br>about when the first counter overflow will occur. |

| 0x0C                                                                                                    |                                                                          | PW       | Mx C | HOSC | R  | Cha                          | nnel ( | ter | 0000000 |  |  |  |  |    |         |        |
|---------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|----------|------|------|----|------------------------------|--------|-----|---------|--|--|--|--|----|---------|--------|
| Bit                                                                                                     | 31                                                                       | 30       | 29   | 28   | 27 | 26 25 24 23 22 21 20 19      |        |     |         |  |  |  |  | 18 | 17      | 16     |
| AutoChi                                                                                                 | ips Co                                                                   | nfidenti | al   |      |    | © 2013 - 2021 AutoChips Inc. |        |     |         |  |  |  |  |    | e 159 c | of 360 |
|                                                                                                         | This document contains information that is proprietary to AutoChips Inc. |          |      |      |    |                              |        |     |         |  |  |  |  |    |         |        |
| Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited. |                                                                          |          |      |      |    |                              |        |     |         |  |  |  |  |    |         |        |

| 0x0C          |    | PW                                                                                                                                                                                                       | /Mx_C | HOSC | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R Channel (0) Status And Control Register |         |         |          |          |          |          |                    |           |   | 00000000 |  |  |
|---------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|---------|---------|----------|----------|----------|----------|--------------------|-----------|---|----------|--|--|
| Name          |    | -                                                                                                                                                                                                        |       |      | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                           |         |         |          |          |          |          |                    |           |   |          |  |  |
| Type<br>Reset |    |                                                                                                                                                                                                          |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                           |         |         |          |          |          |          |                    |           |   |          |  |  |
| Bit           | 15 | 14                                                                                                                                                                                                       | 13    | 12   | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 10                                        | 9       | 8       | 7        | 6        | 5        | 4        | 3                  | 2         | 1 | 0        |  |  |
| Name          |    |                                                                                                                                                                                                          |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                           |         |         | CHI<br>F | CHI<br>E | MS<br>R1 | MS<br>R0 | ELS<br>R1          | ELS<br>R0 |   |          |  |  |
| Туре          |    |                                                                                                                                                                                                          |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                           |         |         | RO       | RW       | RW       | RW       | RW                 | RW        |   |          |  |  |
| Reset         |    |                                                                                                                                                                                                          |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                           |         |         | 0        | 0        | 0        | 0        | 0                  | 0         |   |          |  |  |
| Dit(a)        |    | No                                                                                                                                                                                                       |       |      | Deed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | rintia                                    |         |         |          |          |          |          |                    |           |   |          |  |  |
| Bit(s)        |    | Na                                                                                                                                                                                                       | me    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | riptio                                    |         |         |          |          |          |          |                    |           |   |          |  |  |
| 7             |    | CH                                                                                                                                                                                                       | ΗF    |      | Channel Interrupt Flag<br>Set by hardware when an event occurs on the channel. CHIF is cleared by<br>reading the CSC register while CHnIF is set and then writing a 0 to the CHIF<br>bit. Writing a 1 to CHIF has no effect. If another event occurs between the<br>read and write operations, the write operation has no effect. Therefore, CHIF<br>remains set indicating an event has occurred. In this case, a CHIF interrupt<br>request is not lost due to the clearing sequence for a previous CHIF.<br>0 : No channel event has occurred.<br>1 : A channel event has occurred. |                                           |         |         |          |          |          |          |                    |           |   |          |  |  |
| 6             |    | CH                                                                                                                                                                                                       | lΙΕ   |      | Channel Interrupt Enable<br>Enables channel interrupts.<br>0 : Disable channel interrupts. Use software polling.<br>1: Enable channel interrupts.                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                           |         |         |          |          |          |          |                    |           |   |          |  |  |
| 5             |    | MS                                                                                                                                                                                                       | R1    |      | Channel Mode Select Register 1<br>Used for further selections in the channel logic. Its functionality is dependent<br>on the channel mode. This field is write protected. It can be written only when<br>FUNCSEL[WPDIS] = 1.                                                                                                                                                                                                                                                                                                                                                          |                                           |         |         |          |          |          |          |                    |           |   |          |  |  |
| 4             |    | MS                                                                                                                                                                                                       | R0    |      | Used<br>on the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | for fur<br>e chan                         | ther se | de. Thi | s in the | chanr    |          |          | inctiona<br>can be |           |   |          |  |  |
| 3             |    | Edge or Level Select Register 1           ELSR1         The functionality of ELSR1 and ELSR0 depends on the channel mode. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1. |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                           |         |         |          |          |          |          |                    |           |   |          |  |  |
| 2             |    | ELS                                                                                                                                                                                                      | SR0   |      | Edge or Level Select Register 0<br>The functionality of ELSR1 and ELSR0 depends on the channel mode. This<br>field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.                                                                                                                                                                                                                                                                                                                                                                                                |                                           |         |         |          |          |          |          |                    |           |   |          |  |  |

| 0x10  | PWMx_CH0VChannel (0) Value0000000 |                                                 |    |    |    |    |   |     |     |   |   |   |   |   | 0000 |   |
|-------|-----------------------------------|-------------------------------------------------|----|----|----|----|---|-----|-----|---|---|---|---|---|------|---|
| Bit   | 31                                | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |    |    |    |    |   |     |     |   |   |   |   |   | 16   |   |
| Name  |                                   |                                                 |    |    |    |    |   |     |     |   |   |   |   |   |      |   |
| Туре  |                                   |                                                 |    |    |    |    |   |     |     |   |   |   |   |   |      |   |
| Reset |                                   |                                                 |    |    |    |    |   |     |     |   |   |   |   |   |      |   |
| Bit   | 15                                | 14                                              | 13 | 12 | 11 | 10 | 9 | 8   | 7   | 6 | 5 | 4 | 3 | 2 | 1    | 0 |
| Name  |                                   |                                                 |    |    |    |    |   | CHC | VAL |   |   |   |   |   |      |   |
| Туре  |                                   |                                                 |    |    |    |    |   | R   | W   |   |   |   |   |   |      |   |
| Reset | 0                                 | 0                                               | 0  | 0  | 0  | 0  | 0 | 0   | 0   | 0 | 0 | 0 | 0 | 0 | 0    | 0 |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                             |
|--------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | CHCVAL       | <b>Channel Count Value</b><br>These registers contain the captured PWM counter value for the input modes<br>or the match value for the output modes. In Input Capture, Capture Test, and<br>Dual Edge Capture modes, any write to a CHnV register is ignored. In output |
|        | Orafidantial | modes, writing to a CHnV register latches the value into a buffer. A CHnV                                                                                                                                                                                               |

AutoChips Confidential

**NutoChips** 

© 2013 - 2021 AutoChips Inc.

Page 160 of 360

| Bit(s) | Name | Description                                                                                               |
|--------|------|-----------------------------------------------------------------------------------------------------------|
|        |      | register is updated with the value of its write buffer according to Registers updated from write buffers. |

| 0x4C  | PWMx_CNTIN         Counter Initial Value         00000 |                                                                                                                                                                         |    |    |    |    |   |     |      |   |   |   |   |   | 0000 |   |
|-------|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|-----|------|---|---|---|---|---|------|---|
| Bit   | 31                                                     | 31         30         29         28         27         26         25         24         23         22         21         20         19         18         17         16 |    |    |    |    |   |     |      |   |   |   |   |   | 16   |   |
| Name  |                                                        |                                                                                                                                                                         |    |    |    |    |   |     |      |   |   |   |   |   |      |   |
| Туре  |                                                        |                                                                                                                                                                         |    |    |    |    |   |     |      |   |   |   |   |   |      |   |
| Reset |                                                        |                                                                                                                                                                         |    |    |    |    |   |     |      |   |   |   |   |   |      |   |
| Bit   | 15                                                     | 14                                                                                                                                                                      | 13 | 12 | 11 | 10 | 9 | 8   | 7    | 6 | 5 | 4 | 3 | 2 | 1    | 0 |
| Name  |                                                        |                                                                                                                                                                         |    |    |    |    |   | CNT | INIT |   |   |   |   |   |      |   |
| Туре  |                                                        |                                                                                                                                                                         |    |    |    |    |   | R   | W    |   |   |   |   |   |      |   |
| Reset | 0                                                      | 0                                                                                                                                                                       | 0  | 0  | 0  | 0  | 0 | 0   | 0    | 0 | 0 | 0 | 0 | 0 | 0    | 0 |

| Bit(s) | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | CNTINIT | <b>Counter Initial Value</b><br>The Counter Initial Value register contains the initial value for the PWM counter. Writing to the CNTIN register latches the value into a buffer. The CNTIN register is updated with the value of its write buffer according to Registers updated from write buffers. When the PWM clock is initially selected, by writing a non-zero value to the CLKS bits, the PWM counter starts with the value 0x0000. To avoid this behavior, before the first write to select the PWM clock, write the new value to the CNTIN register and then initialize the PWM counter by writing any value to the CNT register. |

| 0x50  |    | PW | Mx S | <u>STR</u> |    | Capt |    | 0000000 |    |    |           |           |           |           |           |           |
|-------|----|----|------|------------|----|------|----|---------|----|----|-----------|-----------|-----------|-----------|-----------|-----------|
| Bit   | 31 | 30 | 29   | 28         | 27 | 26   | 25 | 24      | 23 | 22 | 21        | 20        | 19        | 18        | 17        | 16        |
| Name  |    |    |      |            |    |      |    |         |    |    |           |           |           |           |           |           |
| Туре  |    |    |      |            |    |      |    |         |    |    |           |           |           |           |           |           |
| Reset |    |    |      |            |    |      |    |         |    |    |           |           |           |           |           |           |
| Bit   | 15 | 14 | 13   | 12         | 11 | 10   | 9  | 8       | 7  | 6  | 5         | 4         | 3         | 2         | 1         | 0         |
| Name  |    |    |      |            |    |      |    |         |    |    | CH<br>5SF | CH<br>4SF | CH3<br>SF | CH<br>2SF | CH<br>1SF | CH<br>0SF |
| Туре  |    |    |      |            |    |      |    |         |    |    | RO        | RO        | RO        | RO        | RO        | RO        |
| Reset |    |    |      |            |    |      |    |         |    |    | 0         | 0         | 0         | 0         | 0         | 0         |

| Bit(s)      | Name         | Description                        |                 |
|-------------|--------------|------------------------------------|-----------------|
|             |              | Channel 5 Status Flag              |                 |
| 5           | CH5SF        | 0 : No channel event has occurred. |                 |
|             |              | 1: A channel event has occurred.   |                 |
|             |              | Channel 4 Status Flag              |                 |
| 4           | CH4SF        | 0 : No channel event has occurred. |                 |
|             |              | 1: A channel event has occurred.   |                 |
|             |              | Channel 3 Status Flag              |                 |
| 3           | CH3SF        | 0: No channel event has occurred.  |                 |
|             |              | 1: A channel event has occurred.   |                 |
|             |              | Channel 2 Status Flag              |                 |
| 2           | CH2SF        | 0: No channel event has occurred.  |                 |
|             |              | 1: A channel event has occurred.   |                 |
|             |              | Channel 1 Status Flag              |                 |
| 1           | CH1SF        | 0: No channel event has occurred.  |                 |
|             |              |                                    |                 |
| AutoChips ( | Confidential | © 2013 - 2021 AutoChips Inc.       | Page 161 of 360 |
|             | _            |                                    |                 |

This document contains information that is proprietary to AutoChips Inc.

| Bit(s) | Name  | Description                                                |
|--------|-------|------------------------------------------------------------|
| 0      | CH0SF | Channel 0 Status Flag<br>0: No channel event has occurred. |
|        |       | 1: A channel event has occurred.                           |

| 0x54      |    | PWM | x_FUN | CSEL |    |    | Fea | eatures Mode Selection |                 |               |    |                     |                     |           |          | 0000004        |  |  |
|-----------|----|-----|-------|------|----|----|-----|------------------------|-----------------|---------------|----|---------------------|---------------------|-----------|----------|----------------|--|--|
| Bit       | 31 | 30  | 29    | 28   | 27 | 26 | 25  | 24                     | 23              | 22            | 21 | 20                  | 19                  | 18        | 17       | 16             |  |  |
| Nam<br>e  |    |     |       |      |    |    |     |                        |                 |               |    |                     |                     |           |          |                |  |  |
| Туре      |    |     |       |      |    |    |     |                        |                 |               |    |                     |                     |           |          |                |  |  |
| Res<br>et |    |     |       |      |    |    |     |                        |                 |               |    |                     |                     |           |          |                |  |  |
| Bit       | 15 | 14  | 13    | 12   | 11 | 10 | 9   | 8                      | 7               | 6             | 5  | 4                   | 3                   | 2         | 1        | 0              |  |  |
| Nam<br>e  |    |     |       |      |    |    |     |                        | FA<br>UL<br>TIE | FAULTMO<br>DE |    | CA<br>PT<br>ES<br>T | PW<br>MS<br>YN<br>C | WP<br>DIS | INI<br>T | PW<br>ME<br>N2 |  |  |
| Туре      |    |     |       |      |    |    |     |                        | RW              | R             | W  | RW                  | RW                  | RW        | RW       | RW             |  |  |
| Res<br>et |    |     |       |      |    |    |     |                        | 0               | 0             | 0  | 0                   | 0                   | 1         | 0        | 0              |  |  |

| Bit(s)    | Name           | Description                                                                                                                                                                                                                       |                           |  |  |  |  |  |
|-----------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--|--|--|--|--|
|           |                | Fault Interrupt Enable                                                                                                                                                                                                            |                           |  |  |  |  |  |
| 7         | FAULTIE        | Enables the generation of an interrupt when a fault i<br>the PWM fault control is enabled.                                                                                                                                        | s detected by PWM and     |  |  |  |  |  |
|           |                | 0: Fault control interrupt is disabled.                                                                                                                                                                                           |                           |  |  |  |  |  |
|           |                | 1: Fault control interrupt is enabled.                                                                                                                                                                                            |                           |  |  |  |  |  |
|           |                | Fault Control Mode                                                                                                                                                                                                                |                           |  |  |  |  |  |
|           |                | Defines the PWM fault control mode. This field is wr<br>written only when FUNCSEL[WPDIS] = 1.                                                                                                                                     | ite protected. It can be  |  |  |  |  |  |
|           |                | 00 : Fault control is disabled for all channels.                                                                                                                                                                                  |                           |  |  |  |  |  |
| 6:5       | FAULTMODE      | 01: Fault control is enabled for even channels only (                                                                                                                                                                             | channels 0, 2, 4, and 6), |  |  |  |  |  |
| 0.0       | TROEIMODE      | and the selected mode is the manual fault clearing.                                                                                                                                                                               |                           |  |  |  |  |  |
|           |                | 10: Fault control is enabled for all channels, and the                                                                                                                                                                            | selected mode is the      |  |  |  |  |  |
|           |                | manual fault clearing.                                                                                                                                                                                                            |                           |  |  |  |  |  |
|           |                | 11: Fault control is enabled for all channels, and the automatic fault clearing.                                                                                                                                                  | selected mode is the      |  |  |  |  |  |
|           |                | Capture Test Mode Enable                                                                                                                                                                                                          |                           |  |  |  |  |  |
| 4         | CAPTEST        | Enables the capture test mode. This field is write pro<br>only when FUNCSEL[WPDIS] = 1.                                                                                                                                           | tected. It can be written |  |  |  |  |  |
|           |                | 0: Capture test mode is disabled.                                                                                                                                                                                                 |                           |  |  |  |  |  |
|           |                | 1: Capture test mode is enabled.                                                                                                                                                                                                  |                           |  |  |  |  |  |
|           |                | PWM Synchronization Mode                                                                                                                                                                                                          |                           |  |  |  |  |  |
|           |                | Selects which triggers can be used by MCVR, CHN<br>counter synchronization. The PWMSYNC bit configu<br>when SYNCMODE is zero.                                                                                                     |                           |  |  |  |  |  |
| 3         | PWMSYNC        | 0 : No restrictions. Software and hardware triggers of<br>CHnV, OMCR and PWM counter synchronization.                                                                                                                             | an be used by MCVR,       |  |  |  |  |  |
|           |                | <ol> <li>Software trigger can only be used by MCVR and<br/>and hardware triggers can only be used by OMCR a<br/>synchronization.</li> </ol>                                                                                       |                           |  |  |  |  |  |
|           |                | Write Protection Disable                                                                                                                                                                                                          |                           |  |  |  |  |  |
| 2         | WPDIS          | When write protection is enabled (WPDIS = 0), write protected bits cannot be written. When write protection is disabled (WPDIS = 1), write protected bits can be written. The WPDIS bit is the negation of the WPEN bit. WPDIS is |                           |  |  |  |  |  |
| AutoChips | S Confidential | © 2013 - 2021 AutoChips Inc.                                                                                                                                                                                                      | Page 162 of 360           |  |  |  |  |  |

| Bit(s) | Name   | Description                                                                                                                                                                                                             |
|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |        | cleared when 1 is written to WPEN. WPDIS is set when WPEN bit is read as a 1 and then 1 is written to WPDIS. Writing 0 to WPDIS has no effect. 0: Write protection is enabled.                                          |
|        |        | 1: Write protection is disabled.                                                                                                                                                                                        |
|        |        | Initialize The Channels Output                                                                                                                                                                                          |
| 1      | INIT   | When a 1 is written to INIT bit, the channels output is initialized according to the state of their corresponding bit in the OUTINIT register. Writing a 0 to INIT bit has no effect. The INIT bit is always read as 0. |
|        |        | PWM Enable                                                                                                                                                                                                              |
|        |        | This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.                                                                                                                                          |
| 0      | PWMEN2 | <ol><li>Only the TPM-compatible registers (first set of registers) can be used<br/>without any restriction. Do not use the PWM-specific registers.</li></ol>                                                            |
|        |        | 1: All registers including the PWM-specific registers (second set of registers) are available for use with no restrictions.                                                                                             |
|        |        |                                                                                                                                                                                                                         |

| 0x58  |    | PWI | Mx_S` | YNC |                                 |                                                     |                                  | Sync                                   | hroniz         | ation          |                      |                      |                     |            | 0000000              |                      |  |
|-------|----|-----|-------|-----|---------------------------------|-----------------------------------------------------|----------------------------------|----------------------------------------|----------------|----------------|----------------------|----------------------|---------------------|------------|----------------------|----------------------|--|
| Bit   | 31 | 30  | 29    | 28  | 27                              | 26                                                  | 25                               | 24                                     | 23             | 22             | 21                   | 20                   | 19                  | 18         | 17                   | 16                   |  |
| Name  |    |     |       |     |                                 |                                                     |                                  |                                        |                |                |                      |                      |                     |            |                      |                      |  |
| Туре  |    |     |       |     |                                 |                                                     |                                  |                                        |                |                |                      |                      |                     |            |                      |                      |  |
| Reset |    |     |       |     |                                 |                                                     |                                  |                                        |                |                |                      |                      |                     |            |                      |                      |  |
| Bit   | 15 | 14  | 13    | 12  | 11                              | 10                                                  | 9                                | 8                                      | 7              | 6              | 5                    | 4                    | 3                   | 2          | 1                    | 0                    |  |
| Name  |    |     |       |     | PW<br>M_<br>SY<br>NC<br>PO<br>L | PW<br>M_<br>TRI<br>G2_<br>CL<br>EA<br>R_<br>CN<br>T | PW_II_U<br>MRI_ULA_R_N<br>GULA_C | PW_RI_G_LA_R_N<br>GCLA_R_N<br>C ER_C F | SW<br>SY<br>NC | SW<br>TRI<br>G | PW<br>M0<br>TRI<br>G | AC<br>MP<br>TRI<br>G | OM<br>SY<br>NC<br>P | REI<br>NIT | MA<br>XS<br>YN<br>CP | MIN<br>SY<br>NC<br>P |  |
| Туре  |    |     |       |     | RW                              | RW                                                  | RW                               | RW                                     | RW             | RW             | RW                   | RW                   | RW                  | RW         | RW                   | RW                   |  |
| Reset |    |     |       |     | 0                               | 0                                                   | 0                                | 0                                      | 0              | 0              | 0                    | 0                    | 0                   | 0          | 0                    | 0                    |  |

| Bit(s) | Name                    | Description                                                                                                                                                                                                                                                                                                                 |
|--------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11     | PWM_SYNCPOL             | <ul> <li>PWM_SYNCPOL</li> <li>Selects when the POL register is updated with the value of its buffer.</li> <li>0: POL register is updated with the value of its buffer in all rising edges of the system clock.</li> <li>1: POL register is updated with the value of its buffer only by the PWM synchronization.</li> </ul> |
| 10     | PWM_TRIG2_CLEA<br>R_CNT | <b>PWM_TRIG2_CLEAR_CNT</b><br>0: when TRIG 2 event happened, not clear the CNT core<br>1: when TRIG2 event happened, clear the CNT core                                                                                                                                                                                     |
| 9      | PWM_TRIG1_CLEA<br>R_CNT | <b>PWM_TRIG1_CLEAR_CNT</b> 0: when TRIG1 event happened, not clear the CNT core 1: when TRIG1 event happened, clear the CNT core                                                                                                                                                                                            |
| 8      | PWM_TRIG0_CLEA<br>R_CNT | <b>PWM_TRIG0_CLEAR_CNT</b><br>0: when TRIG0 event happened, not clear the CNT core<br>1: when TRIG0 event happened, clear the CNT core                                                                                                                                                                                      |
| 7      | SWSYNC                  | <b>PWM Synchronization Software Trigger</b><br>Selects the software trigger as the PWM synchronization trigger. The<br>software trigger happens when a 1 is written to SWSYNC bit.<br>0 : Software trigger is not selected.                                                                                                 |

© 2013 - 2021 AutoChips Inc.

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |          | 1 : Software trigger is selected.                                                                                                                                                                                                                                                                                                                                                                                      |
| 6      | SWTRIG   | <ul> <li>PWM Synchronization Hardware Trigger 2</li> <li>Enables hardware trigger 2 to the PWM synchronization. Hardware trigger 2 happens when a rising edge is detected at the trigger 2 input signal.</li> <li>0: Trigger is disabled.</li> <li>1: Trigger is enabled.</li> </ul>                                                                                                                                   |
| 5      | PWM0TRIG | <ul> <li>PWM Synchronization Hardware Trigger 1</li> <li>Enables hardware trigger 1 to the PWM synchronization. Hardware trigger 1 happens when a rising edge is detected at the trigger 1 input signal.</li> <li>0: Trigger is disabled.</li> <li>1: Trigger is enabled.</li> </ul>                                                                                                                                   |
|        |          | PWM Synchronization Hardware Trigger 0                                                                                                                                                                                                                                                                                                                                                                                 |
| 4      | ACMPTRIG | Enables hardware trigger 0 to the PWM synchronization. Hardware trigger 0 happens when a rising edge is detected at the trigger 0 input signal.<br>0: Trigger is disabled.<br>1 : Trigger is enabled.                                                                                                                                                                                                                  |
|        |          | Output Mask Synchronization                                                                                                                                                                                                                                                                                                                                                                                            |
| 3      | OMSYNCP  | Selects when the OMCR register is updated with the value of its buffer.<br>0 : OMCR register is updated with the value of its buffer in all rising edges of<br>the system clock.<br>1: OMCR register is updated with the value of its buffer only by the PWM                                                                                                                                                           |
|        |          | synchronization.                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2      | REINIT   | <ul> <li>PWM Counter Reinitialization by Synchronization</li> <li>Determines if the PWM counter is reinitialized when the selected trigger for the synchronization is detected. The REINIT bit configures the synchronization when SYNCMODE is zero.</li> <li>0 : PWM counter continues to count normally.</li> <li>1: PWM counter is updated with its initial value when the selected trigger is detected.</li> </ul> |
|        |          | Maximum Loading Point Enable                                                                                                                                                                                                                                                                                                                                                                                           |
| 1      | MAXSYNCP | Selects the maximum loading point to PWM synchronization. If CNTMAX is<br>one, the selected loading point is when the PWM counter reaches its<br>maximum value (MCVR register).<br>0: The maximum loading point is disabled.<br>1 : The maximum loading point is enabled.                                                                                                                                              |
|        |          | Minimum Loading Point Enable                                                                                                                                                                                                                                                                                                                                                                                           |
| 0      | MINSYNCP | Selects the minimum loading point to PWM synchronization. If CNTMIN is one, the selected loading point is when the PWM counter reaches its minimum value (CNTIN register).                                                                                                                                                                                                                                             |
|        |          | 0 : The minimum loading point is disabled.<br>1 ; The minimum loading point is enabled.                                                                                                                                                                                                                                                                                                                                |

| 0x5C      |    | PWN | lx_OU | <u>FINIT</u> |    | Initial State For Channels Output |    |    |    |    |                |                |                |                | 0000000        |                |  |
|-----------|----|-----|-------|--------------|----|-----------------------------------|----|----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|--|
| Bit       | 31 | 30  | 29    | 28           | 27 | 26                                | 25 | 24 | 23 | 22 | 21             | 20             | 19             | 18             | 17             | 16             |  |
| Nam<br>e  |    |     |       |              |    |                                   |    |    |    |    |                |                |                |                |                |                |  |
| Тур<br>е  |    |     |       |              |    |                                   |    |    |    |    |                |                |                |                |                |                |  |
| Res<br>et |    |     |       |              |    |                                   |    |    |    |    |                |                |                |                |                |                |  |
| Bit       | 15 | 14  | 13    | 12           | 11 | 10                                | 9  | 8  | 7  | 6  | 5              | 4              | 3              | 2              | 1              | 0              |  |
| Nam<br>e  |    |     |       |              |    |                                   |    |    |    |    | CH<br>50I<br>V | CH<br>40I<br>V | CH<br>301<br>V | CH<br>201<br>V | CH<br>10I<br>V | CH<br>00I<br>V |  |

AutoChips Confidential

#### © 2013 - 2021 AutoChips Inc.

Page 164 of 360



| 0x5C      | <u>PWN</u> | lx_OU | <u>FINIT</u> | Initi | ial Sta | ate Fo | r Cha | nnels | s Outp |    | 0000000 |    |    |   |
|-----------|------------|-------|--------------|-------|---------|--------|-------|-------|--------|----|---------|----|----|---|
| Тур<br>е  |            |       |              |       |         |        |       | RW    | RW     | RW | RW      | RW | RW |   |
| Res<br>et |            |       |              |       |         |        |       |       | 0      | 0  | 0       | 0  | 0  | 0 |

| Bit(s) | Name   | Description                                                                                                                                                                                                                                         |
|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5      | CH5OIV | <ul> <li>Channel 5 Output Initialization Value</li> <li>Selects the value that is forced into the channel output when the initialization occurs.</li> <li>0: The initialization value is 0.</li> <li>1: The initialization value is 1.</li> </ul>   |
| 4      | CH4OIV | <ul> <li>Channel 4 Output Initialization Value</li> <li>Selects the value that is forced into the channel output when the initialization occurs.</li> <li>0 : The initialization value is 0.</li> <li>1: The initialization value is 1.</li> </ul>  |
| 3      | CH3OIV | <ul> <li>Channel 3 Output Initialization Value</li> <li>Selects the value that is forced into the channel output when the initialization occurs.</li> <li>0 : The initialization value is 0.</li> <li>1 : The initialization value is 1.</li> </ul> |
| 2      | CH2OIV | <ul> <li>Channel 2 Output Initialization Value</li> <li>Selects the value that is forced into the channel output when the initialization occurs.</li> <li>0: The initialization value is 0.</li> <li>1: The initialization value is 1.</li> </ul>   |
| 1      | CH10IV | <ul> <li>Channel 1 Output Initialization Value</li> <li>Selects the value that is forced into the channel output when the initialization occurs.</li> <li>0 : The initialization value is 0.</li> <li>1 : The initialization value is 1.</li> </ul> |
| 0      | CH00IV | <ul> <li>Channel 0 Output Initialization Value</li> <li>Selects the value that is forced into the channel output when the initialization occurs.</li> <li>0 : The initialization value is 0.</li> <li>1: The initialization value is 1.</li> </ul>  |

| 0x60  |    | PWN | lx_O | MCR |    | Output Mask Control Register |    |    |    |    |                     |                     |                 |                     |                     | 0000000             |  |
|-------|----|-----|------|-----|----|------------------------------|----|----|----|----|---------------------|---------------------|-----------------|---------------------|---------------------|---------------------|--|
| Bit   | 31 | 30  | 29   | 28  | 27 | 26                           | 25 | 24 | 23 | 22 | 21                  | 20                  | 19              | 18                  | 17                  | 16                  |  |
| Name  |    |     |      |     |    |                              |    |    |    |    |                     |                     |                 |                     |                     |                     |  |
| Туре  |    |     |      |     |    |                              |    |    |    |    |                     |                     |                 |                     |                     |                     |  |
| Reset |    |     |      |     |    |                              |    |    |    |    |                     |                     |                 |                     |                     |                     |  |
| Bit   | 15 | 14  | 13   | 12  | 11 | 10                           | 9  | 8  | 7  | 6  | 5                   | 4                   | 3               | 2                   | 1                   | 0                   |  |
| Name  |    |     |      |     |    |                              |    |    |    |    | CH<br>50<br>ME<br>N | CH<br>40<br>ME<br>N | CH3<br>OM<br>EN | CH<br>2O<br>ME<br>N | CH<br>1O<br>ME<br>N | CH<br>0O<br>ME<br>N |  |
| Туре  |    |     |      |     |    |                              |    |    |    |    | RW                  | RW                  | RW              | RW                  | RW                  | RW                  |  |
| Reset |    |     |      |     |    |                              |    |    |    |    | 0                   | 0                   | 0               | 0                   | 0                   | 0                   |  |

| Bit(s) | Name    | Description           |
|--------|---------|-----------------------|
| 5      | CH5OMEN | Channel 5 Output Mask |

© 2013 - 2021 AutoChips Inc.

| Bit(s) | Name           | Description                                                        |
|--------|----------------|--------------------------------------------------------------------|
|        |                | Defines if the channel output is masked or unmasked.               |
|        |                | 0: Channel output is not masked. It continues to operate normally. |
|        |                | 1: Channel output is masked. It is forced to its inactive state.   |
|        |                | Channel 4 Output Mask                                              |
| 4      | CH4OMEN        | Defines if the channel output is masked or unmasked.               |
| 4      | CH4OMEN        | 0: Channel output is not masked. It continues to operate normally. |
|        |                | 1: Channel output is masked. It is forced to its inactive state.   |
|        |                | Channel 3 Output Mask                                              |
| 3      | <b>CH3OMEN</b> | Defines if the channel output is masked or unmasked.               |
| 3      | CH3OMEN        | 0: Channel output is not masked. It continues to operate normally. |
|        |                | 1: Channel output is masked. It is forced to its inactive state.   |
|        |                | Channel 2 Output Mask                                              |
| 2      | CH2OMEN        | Defines if the channel output is masked or unmasked.               |
| 2      | CHZOWEN        | 0: Channel output is not masked. It continues to operate normally. |
|        |                | 1: Channel output is masked. It is forced to its inactive state.   |
|        |                | Channel 1 Output Mask                                              |
|        |                | Defines if the channel output is masked or unmasked.               |
| 1      | CH10MEN        | 0: Channel output is not masked. It continues to operate normally. |
|        |                |                                                                    |
|        |                | 1: Channel output is masked. It is forced to its inactive state.   |
|        |                | Channel 0 Output Mask                                              |
| 0      | CH00MEN        | Defines if the channel output is masked or unmasked.               |
| Ŭ      | ONCOMEN        | 0: Channel output is not masked. It continues to operate normally. |
|        |                | 1: Channel output is masked. It is forced to its inactive state.   |

| 0x64      |    | PW                       | /Mx_M                   | <b>ODESEL</b> |                            | PW                               | /M Fi                       | inctio                            | on Mo | ode S                            | electi                      | ion                   |                            | 0000000                          |                             |                                   |  |
|-----------|----|--------------------------|-------------------------|---------------|----------------------------|----------------------------------|-----------------------------|-----------------------------------|-------|----------------------------------|-----------------------------|-----------------------|----------------------------|----------------------------------|-----------------------------|-----------------------------------|--|
| Bit       | 31 | 30                       | 29                      | 28            | 27                         | 26                               | 25                          | 24                                | 23    | 22                               | 21                          | 20                    | 19                         | 18                               | 17                          | 16                                |  |
| Na<br>me  |    |                          |                         |               |                            |                                  |                             |                                   |       | PAI<br>R2<br>FA<br>UL<br>TE<br>N | PAI<br>R2<br>SY<br>NC<br>EN | PAI<br>R2<br>DT<br>EN | PAI<br>R2<br>DE<br>CA<br>P | PAI<br>R2<br>DE<br>CA<br>PE<br>N | PAI<br>R2<br>CO<br>MP<br>EN | PAI<br>R2<br>CO<br>MB<br>IN<br>EN |  |
| Тур<br>е  |    |                          |                         |               |                            |                                  |                             |                                   |       | R<br>W                           | R<br>W                      | R<br>W                | RW                         | R<br>W                           | R<br>W                      | R<br>W                            |  |
| Res<br>et |    |                          |                         |               |                            |                                  |                             |                                   |       | 0                                | 0                           | 0                     | 0                          | 0                                | 0                           | 0                                 |  |
| Bit       | 15 | 14                       | 13                      | 12            | 11                         | 10                               | 9                           | 8                                 | 7     | 6                                | 5                           | 4                     | 3                          | 2                                | 1                           | 0                                 |  |
| Na<br>me  |    | PAIR<br>1FA<br>ULT<br>EN | PAIR<br>1SY<br>NCE<br>N | PAIR1DTEN     | PAI<br>R1<br>DE<br>CA<br>P | PAI<br>R1<br>DE<br>CA<br>PE<br>N | PAI<br>R1<br>CO<br>MP<br>EN | PAI<br>R1<br>C0<br>MB<br>IN<br>EN |       | PAI<br>R0<br>FA<br>UL<br>TE<br>N | PAI<br>R0<br>SY<br>NC<br>EN | PAI<br>R0<br>DT<br>EN | PAI<br>R0<br>DE<br>CA<br>P | PAI<br>R0<br>DE<br>CA<br>PE<br>N | PAI<br>R0<br>CM<br>PE<br>N  | PAI<br>R0<br>CO<br>MB<br>IN<br>EN |  |
| Тур<br>е  |    | RW                       | RW                      | RW            | R<br>W                     | R<br>W                           | R<br>W                      | R<br>W                            |       | R<br>W                           | R<br>W                      | R<br>W                | RW                         | R W                              | R<br>W                      | R<br>W                            |  |
| Res<br>et |    | 0                        | 0                       | 0             | 0                          | 0                                | 0                           | 0                                 |       | 0                                | 0                           | 0                     | 0                          | 0                                | 0                           | 0                                 |  |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                   |
|--------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22     | PAIR2FAULTEN | <b>Fault Control Enable for n = 4</b><br>Enables the fault control in channels (n) and (n+1). This field is write<br>protected. It can be written only when FUNCSEL[WPDIS] = 1.<br>0: The fault control in this pair of channels is disabled. |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 166 of 360

# **//utoChips**

| Bit(s)   | Name           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                | 1: The fault control in this pair of channels is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 21       | PAIR2SYNCEN    | Synchronization Enable for n = 4<br>Enables PWM synchronization of registers CH(n)V and CH(n+1)V.<br>0: The PWM synchronization in this pair of channels is disabled.<br>1: The PWM synchronization in this pair of channels is enabled.                                                                                                                                                                                                                                                                                      |
| 20       | PAIR2DTEN      | <ul> <li>Deadtime Enable for n = 4</li> <li>Enables the deadtime insertion in the channels (n) and (n+1). This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The deadtime insertion in this pair of channels is disabled.</li> <li>1: The deadtime insertion in this pair of channels is enabled.</li> </ul>                                                                                                                                                                          |
| 19       | PAIR2DECAP     | <ul> <li>Dual Edge Capture Mode Captures for n = 4</li> <li>Enables the capture of the PWM counter value according to the channel (n) input event and the configuration of the dual edge capture bits. This field applies only when PWMEN2 = 1 and DECAPEN = 1. DECAP bit is cleared automatically by hardware if dual edge capture one-shot mode is selected and when the capture of channel (n+1) event is made.</li> <li>0: The dual edge captures are inactive.</li> <li>1: The dual edge captures are active.</li> </ul> |
|          |                | Dual Edge Capture Mode Enable for n = 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 18       | PAIR2DECAPEN   | Enables the Dual Edge Capture mode in the channels (n) and (n+1). This bit reconfigures the function of MSnR0, ELSnR1:ELSnR0 and ELS(n+1) R1: ELS(n+1) R0 bits in Dual Edge Capture mode. This field applies only when PWMEN2 = 1. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.                                                                                                                                                                                                             |
|          |                | <ul><li>0: The Dual Edge Capture mode in this pair of channels is disabled.</li><li>1: The Dual Edge Capture mode in this pair of channels is enabled.</li></ul>                                                                                                                                                                                                                                                                                                                                                              |
| 17       | PAIR2COMPEN    | <ul> <li>Complement of Channel (n) for n = 4</li> <li>Enables Complementary mode for the combined channels. In</li> <li>Complementary mode the channel (n+1) output is the inverse of the channel</li> <li>(n) output. This field is write protected. It can be written only when</li> <li>FUNCSEL[WPDIS] = 1.</li> <li>0: The channel (n+1) output is the same as the channel (n) output.</li> <li>1: The channel (n+1) output is the complement of the channel (n) output.</li> </ul>                                       |
| 16       | PAIR2COMBINEN  | <ul> <li>Combine Channels for n = 4</li> <li>Enables the combine feature for channels (n) and (n+1). This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: Channels (n) and (n+1) are independent.</li> <li>1: Channels (n) and (n+1) are combined.</li> </ul>                                                                                                                                                                                                                           |
| 14       | PAIR1FAULTEN   | <ul> <li>Fault Control Enable for n = 2</li> <li>Enables the fault control in channels (n) and (n+1). This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The fault control in this pair of channels is disabled.</li> <li>1: The fault control in this pair of channels is enabled.</li> </ul>                                                                                                                                                                                        |
| 13       | PAIR1SYNCEN    | <ul> <li>Synchronization Enable for n = 2</li> <li>Enables PWM synchronization of registers CH(n)V and CH(n+1) V.</li> <li>0: The PWM synchronization in this pair of channels is disabled.</li> <li>1: The PWM synchronization in this pair of channels is enabled.</li> </ul>                                                                                                                                                                                                                                               |
| 12       | PAIR1DTEN      | <ul> <li>Deadtime Enable for n = 2</li> <li>Enables the deadtime insertion in the channels (n) and (n+1). This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The deadtime insertion in this pair of channels is disabled.</li> <li>1: The deadtime insertion in this pair of channels is enabled.</li> </ul>                                                                                                                                                                          |
| 11       | PAIR1DECAP     | Dual Edge Capture Mode Captures for n = 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| AutoChip | s Confidential | © 2013 - 2021 AutoChips Inc. Page 167 of 360                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

This document contains information that is proprietary to AutoChips Inc.

| Bit(s)   | Name           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |
|----------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
|          |                | Enables the capture of the PWM counter value according to the channel (n) input event and the configuration of the dual edge capture bits. This field applies only when PWMEN2 = 1 and DECAPEN = 1. DECAP bit is cleared automatically by hardware if dual edge capture one-shot mode is selected and when the capture of channel (n+1) event is made.<br>0: The dual edge captures are inactive.<br>1: The dual edge captures are active.                                                                                                               |  |  |  |  |  |  |  |  |  |  |
| 10       | PAIR1DECAPEN   | <ul> <li>Dual Edge Capture Mode Enable for n = 2</li> <li>Enables the Dual Edge Capture mode in the channels (n) and (n+1). This bit reconfigures the function of MSnR0, ELSnR1:ELSnR0 and ELS(n+1) R1: ELS(n+1) R0 bits in Dual Edge Capture mode This field applies</li> <li>only when PWMEN2 = 1. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>.0: The Dual Edge Capture mode in this pair of channels is disabled.</li> <li>1: The Dual Edge Capture mode in this pair of channels is enabled.</li> </ul> |  |  |  |  |  |  |  |  |  |  |
| 9        | PAIR1COMPEN    | <ul> <li>Complement of Channel (n) for n = 2</li> <li>Enables Complementary mode for the combined channels. In</li> <li>Complementary mode the channel (n+1) output is the inverse of the channel</li> <li>(n) output. This field is write protected. It can be written only when</li> <li>FUNCSEL[WPDIS] = 1.</li> <li>0: The channel (n+1) output is the same as the channel (n) output.</li> <li>1: The channel (n+1) output is the complement of the channel (n) output.</li> </ul>                                                                  |  |  |  |  |  |  |  |  |  |  |
| 8        | PAIR1COMBINEN  | <ul> <li>Combine Channels for n = 2</li> <li>Enables the combine feature for channels (n) and (n+1). This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: Channels (n) and (n+1) are independent.</li> <li>1: Channels (n) and (n+1) are combined.</li> </ul>                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |
| 6        | PAIR0FAULTEN   | <ul> <li>Fault Control Enable for n = 0</li> <li>Enables the fault control in channels (n) and (n+1). This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The fault control in this pair of channels is disabled.</li> <li>1: The fault control in this pair of channels is enabled.</li> </ul>                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |
| 5        | PAIR0SYNCEN    | <b>Synchronization Enable for n = 0</b><br>Enables PWM synchronization of registers CH(n)V and CH(n+1) V.<br>0: The PWM synchronization in this pair of channels is disabled.<br>1: The PWM synchronization in this pair of channels is enabled.                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |
| 4        | PAIR0DTEN      | <ul> <li>Deadtime Enable for n = 0</li> <li>Enables the deadtime insertion in the channels (n) and (n+1). This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The deadtime insertion in this pair of channels is disabled.</li> <li>1:The deadtime insertion in this pair of channels is enabled.</li> </ul>                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |
| 3        | PAIR0DECAP     | <ul> <li>Dual Edge Capture Mode Captures for n = 0</li> <li>Enables the capture of the PWM counter value according to the channel (n) input event and the configuration of the dual edge capture bits. This field applies only when PWMEN2 = 1 and DECAPEN = 1. DECAP bit is cleared automatically by hardware if dual edge capture one-shot mode is selected and when the capture of channel (n+1) event is made.</li> <li>0: The dual edge captures are inactive.</li> <li>1: The dual edge captures are active.</li> </ul>                            |  |  |  |  |  |  |  |  |  |  |
| 2        | PAIR0DECAPEN   | <b>Dual Edge Capture Mode Enable for n = 0</b><br>Enables the Dual Edge Capture mode in the channels (n) and (n+1). This bit                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |
| AutoChip | s Confidential | © 2013 - 2021 AutoChips Inc. Page 168 of 360                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |

© 2013 - 2021 AutoChips Inc.

| Bit(s) | Name              | Description                                                                                          |
|--------|-------------------|------------------------------------------------------------------------------------------------------|
|        |                   | reconfigures the function of MSnR0, ELSnR1:ELSnR0 and                                                |
|        |                   | ELS(n+1) R1: ELS(n+1) R0 bits in Dual Edge Capture mode This field<br>applies                        |
|        |                   | only when PWMEN2 = 1. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1. |
|        |                   | 0: The Dual Edge Capture mode in this pair of channels is disabled.                                  |
|        |                   | 1: The Dual Edge Capture mode in this pair of channels is enabled.                                   |
|        |                   | Complement of Channel (n) for n = 0                                                                  |
|        |                   | Enables Complementary mode for the combined channels. In                                             |
|        |                   | Complementary mode the channel (n+1) output is the inverse of the channel                            |
| 1      | <b>PAIR0CMPEN</b> | (n) output. This field is write protected. It can be written only when                               |
|        |                   | FUNCSEL[WPDIS] = 1.                                                                                  |
|        |                   | 0 The channel (n+1) output is the same as the channel (n) output.                                    |
|        |                   | 1 The channel (n+1) output is the complement of the channel (n) output.                              |
|        |                   | Combine Channels for n = 0                                                                           |
|        |                   | Enables the combine feature for channels (n) and (n+1). This field is write                          |
| 0      | PAIR0COMBINEN     | protected. It can be written only when FUNCSEL[WPDIS] = 1.                                           |
|        |                   | 0: Channels (n) and (n+1) are independent.                                                           |
|        |                   | 1: Channels (n) and (n+1) are combined.                                                              |

| 0x68  | PWMx_DTSET Deadtime Insertion Control |    |    |    |    |    |    |    |    |     |    |    | 0000000 |     |    |    |  |
|-------|---------------------------------------|----|----|----|----|----|----|----|----|-----|----|----|---------|-----|----|----|--|
| Bit   | 31                                    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21 | 20 | 19      | 18  | 17 | 16 |  |
| Name  |                                       |    |    |    |    |    |    |    |    |     |    |    |         |     |    |    |  |
| Туре  |                                       |    |    |    |    |    |    |    |    |     |    |    |         |     |    |    |  |
| Reset |                                       |    |    |    |    |    |    |    |    |     |    |    |         |     |    |    |  |
| Bit   | 15                                    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6   | 5  | 4  | 3       | 2   | 1  | 0  |  |
| Name  |                                       |    |    |    |    |    |    |    | DT | PSC |    |    | DT۱     | /AL |    |    |  |
| Туре  |                                       |    |    |    |    |    |    |    | R  | W   | RW |    |         |     |    |    |  |
| Reset |                                       |    |    |    |    |    |    |    | 0  | 0   | 0  | 0  | 0       | 0   | 0  | 0  |  |

| Bit(s) | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6    | DTPSC | <ul> <li>Deadtime Prescaler Value</li> <li>Selects the division factor of the system clock. This prescaled clock is used by the deadtime counter. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0x: Divide the system clock by 1.</li> <li>10: Divide the system clock by 4.</li> <li>11: Divide the system clock by 16.</li> </ul>                                                                                                                                                                 |
| 5:0    | DTVAL | Deadtime ValueSelects the deadtime insertion value for the deadtime counter. The deadtimecounter is clocked by a scaled version of the system clock. See thedescription of DTPS. Deadtime insert value = (DTPSC x DTVAL). DTVALselects the number of deadtime counts inserted as follows:When DTVAL is 0, no counts are inserted.When DTVAL is 1, 1 count is inserted.When DTVAL is 2, 2 counts are inserted.This pattern continues up to a possible 63 counts. This field is write protected.It can be written only when FUNCSEL[WPDIS] = 1. |

© 2013 - 2021 AutoChips Inc.

0000000

PWMx\_EXTTRIG

0x6C

|             |                                                                   |           |     |            |                                                                                                                                         |                   |          |           |           | <u> </u>  | yei               |        |       |         | 00000    | 0000  |  |  |
|-------------|-------------------------------------------------------------------|-----------|-----|------------|-----------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------|-----------|-----------|-----------|-------------------|--------|-------|---------|----------|-------|--|--|
| Bit         | 31                                                                | 30        | 29  | 28         | 27                                                                                                                                      | 26                | 25       | 24        | 23        | 22        | 21                | 20     | 19    | 18      | 17       | 16    |  |  |
| Nam         |                                                                   |           |     |            |                                                                                                                                         |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
| e           |                                                                   |           |     |            |                                                                                                                                         |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
| Type<br>Res |                                                                   |           |     |            |                                                                                                                                         |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
| et          |                                                                   |           |     |            |                                                                                                                                         |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
| Bit         | 15                                                                | 14        | 13  | 12         | 11                                                                                                                                      | 10                | 9        | 8         | 7         | 6         | 5                 | 4      | 3     | 2       | 1        | 0     |  |  |
| Nam         |                                                                   |           |     |            |                                                                                                                                         |                   |          |           | -         | INI       | СН                | СН     | СН    | СН      | СН       | СН    |  |  |
| Nam<br>e    |                                                                   |           |     |            |                                                                                                                                         |                   |          |           | TRI<br>GF | TT<br>RIG | 5T                | 4T     | 3T    | 2T      | 1T       | 0Т    |  |  |
| Ū.          |                                                                   |           |     |            |                                                                                                                                         |                   |          |           | •         | EN        | RIG               | RIG    | RIG   | RIG     | RIG      | RIG   |  |  |
| Туре        |                                                                   |           |     |            |                                                                                                                                         |                   |          |           | RW        | RW        | RW                | RW     | RW    | RW      | RW       | RW    |  |  |
| Res<br>et   |                                                                   |           |     |            |                                                                                                                                         |                   |          |           | 0         | 0         | 0                 | 0      | 0     | 0       | 0        | 0     |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
| D'((-)      | Name Description                                                  |           |     |            |                                                                                                                                         |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
| Bit(s)      | )                                                                 | Nam       | ne  | De         | escrip                                                                                                                                  | tion              |          |           |           |           |                   |        |       |         |          |       |  |  |
|             |                                                                   |           |     | Ch         | Channel Trigger Flag                                                                                                                    |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            | Set by hardware when a channel trigger is generated. Clear TRIGF by                                                                     |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            | reading EXTTRIG while TRIGF is set and then writing a 0 to TRIGF. Writing a                                                             |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
| 7           |                                                                   | TRIG      | θF  |            | 1 to TRIGF has no effect. If another channel trigger is generated before the                                                            |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            | clearing sequence is completed, the sequence is reset so TRIGF remains set after the clear sequence is completed for the earlier TRIGF. |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            | o: No channel trigger was generated.                                                                                                    |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            | 1: A channel trigger was generated.                                                                                                     |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
|             | 1: A channel trigger was generated. Initialization Trigger Enable |           |     |            |                                                                                                                                         |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         |                   |          |           |           |           | an the            |        | nunta | r is pa | ual to t | he    |  |  |
| 6           |                                                                   | INITTRI   | GEN |            | Enables the generation of the trigger when the PWM counter is equal to the<br>CNTIN register.                                           |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
| 0           |                                                                   | INTIA     |     |            |                                                                                                                                         | •                 |          | nitializa | ation tr  | iaaer i   | s disat           | oled   |       |         |          |       |  |  |
|             |                                                                   |           |     |            | -                                                                                                                                       |                   |          |           |           |           | s enab            |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         |                   | ger Ei   |           |           | 3301      |                   |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         | -                 | -        |           | chanr     | nel tria  | aer wh            | en the | PWM   | count   | er is eo | nual  |  |  |
| 5           |                                                                   | CH5TF     | RIG |            |                                                                                                                                         | InV reg           |          |           | er la li  |           | ge                |        |       |         |          | 100.  |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         |                   |          | he cha    | nnel tr   | iaaer i   | s disat           | oled.  |       |         |          |       |  |  |
|             |                                                                   |           |     | 1:         | The ge                                                                                                                                  | enerati           | on of tl | he cha    | nnel tr   | igger i   | s enab            | led.   |       |         |          |       |  |  |
|             |                                                                   |           |     | Ch         | annel                                                                                                                                   | 4 Trig            | ger Ei   | nable     |           |           |                   |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            | Channel 4 Trigger Enable<br>Enable the generation of the channel trigger when the PWM counter is equal                                  |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
| 4           |                                                                   | CH4TF     | RIG |            | to the CHnV register.                                                                                                                   |                   |          |           |           |           |                   |        |       |         |          |       |  |  |
|             |                                                                   |           |     | 0:         | The ge                                                                                                                                  | enerati           | on of t  | he cha    | nnel tr   | igger i   | s disat           | oled.  |       |         |          |       |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         |                   |          |           | nnel tr   | igger i   | s enab            | ied.   |       |         |          |       |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         | -                 | ger Ei   |           |           |           |                   |        |       |         |          |       |  |  |
| 2           |                                                                   | СНЗТЕ     |     |            |                                                                                                                                         | -                 |          | of the    | cnanr     | nel trig  | ger wh            | en the | PWM   | count   | er is eo | lnal  |  |  |
| 3           |                                                                   | CHOIL     |     |            |                                                                                                                                         | InV reg           | -        | 00 oh -   | nnal +-   | iaac- '   |                   |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         |                   |          |           |           |           | s disat<br>s enab |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            | -                                                                                                                                       |                   |          |           |           | 9901      | Junal             |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         | -                 | ger Ei   |           | chan      | nal tria  | aar wh            | on the |       | count   | er is eo | leur  |  |  |
| 2           |                                                                   | CH2TF     | RIG |            |                                                                                                                                         | ie gen<br>InV reg |          |           | Undrif    | iei ilig  | Acı M             |        |       | count   |          | lnai  |  |  |
| £           |                                                                   | 0.1211    |     |            |                                                                                                                                         |                   | -        | he cha    | nnel tr   | iaaer i   | s disat           | oled   |       |         |          |       |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         |                   |          |           |           |           | s enab            |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            | -                                                                                                                                       |                   | ger Er   |           |           |           |                   |        |       |         |          |       |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         | -                 | -        |           | chanr     | nel tria  | ger wh            | en the | PWM   | count   | er is eo | qual  |  |  |
| 1           |                                                                   | CH1TF     | RIG |            |                                                                                                                                         | InV reg           |          |           |           | 3         | <b>_</b>          |        |       |         | -        | •     |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         |                   | -        | he cha    | nnel tr   | igger i   | s disat           | oled.  |       |         |          |       |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         |                   |          |           |           |           | s enab            |        |       |         |          |       |  |  |
| 0           | -                                                                 | CHOTE     | RIG | Ch         | annel                                                                                                                                   | 0 Trig            | iger Ei  | nable     |           |           |                   |        |       |         |          |       |  |  |
| AutoCh      | nips Co                                                           | nfidentia | l   |            | C                                                                                                                                       | 2013              | - 2021   | Auto      | Chips I   | nc.       |                   |        |       | Page    | 170 o    | f 360 |  |  |
|             |                                                                   |           |     | nis docume |                                                                                                                                         |                   |          |           |           |           | oChips Ir         | IC.    |       |         |          | -     |  |  |
|             |                                                                   |           |     |            |                                                                                                                                         |                   |          |           |           | ,         |                   |        |       |         |          |       |  |  |

**PWM External Trigger** 

This document contains information that is proprietary to AutoChips Inc.

| Bit(s) | Name | Description                                                                |
|--------|------|----------------------------------------------------------------------------|
|        |      | Enable the generation of the channel trigger when the PWM counter is equal |
|        |      | to the CHnV register.                                                      |
|        |      | 0: The generation of the channel trigger is disabled.                      |
|        |      | 1: The generation of the channel trigger is enabled.                       |

| 0x70  |    | PWM2 | <u>OLCR</u> | Channels Output Polarity Control<br>Register |    |    |    |    |    |    |                    |                    |                | 00000000           |                    |             |  |
|-------|----|------|-------------|----------------------------------------------|----|----|----|----|----|----|--------------------|--------------------|----------------|--------------------|--------------------|-------------|--|
| Bit   | 31 | 30   | 29          | 28                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21                 | 20                 | 19             | 18                 | 17                 | 16          |  |
| Name  |    |      |             |                                              |    |    |    |    |    |    |                    |                    |                |                    |                    |             |  |
| Туре  |    |      |             |                                              |    |    |    |    |    |    |                    |                    |                |                    |                    |             |  |
| Reset |    |      |             |                                              |    |    |    |    |    |    |                    |                    |                |                    |                    |             |  |
| Bit   | 15 | 14   | 13          | 12                                           | 11 | 10 | 9  | 8  | 7  | 6  | 5                  | 4                  | 3              | 2                  | 1                  | 0           |  |
| Name  |    |      |             |                                              |    |    |    |    |    |    | C<br>H5<br>P<br>OL | C<br>H4<br>P<br>OL | CH<br>3P<br>OL | C<br>H2<br>P<br>OL | C<br>H1<br>P<br>OL | C H P<br>DL |  |
| Туре  |    |      |             |                                              |    |    |    |    |    |    | R<br>W             | R<br>W             | R<br>W         | R<br>W             | R<br>W             | R<br>W      |  |
| Reset |    |      |             |                                              |    |    |    |    |    |    | 0                  | 0                  | 0              | 0                  | 0                  | 0           |  |

| Bit(s) | Name   | Description                                                                                                                                                                                                                                                                 |
|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5      | CH5POL | <ul> <li>Channel 5 Polarity</li> <li>Defines the polarity of the channel output. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The channel polarity is active high.</li> <li>1: The channel polarity is active low.</li> </ul> |
| 4      | CH4POL | <ul> <li>Channel 4 Polarity</li> <li>Defines the polarity of the channel output. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The channel polarity is active high.</li> <li>1: The channel polarity is active low.</li> </ul> |
| 3      | CH3POL | <ul> <li>Channel 3 Polarity</li> <li>Defines the polarity of the channel output. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The channel polarity is active high.</li> <li>1: The channel polarity is active low.</li> </ul> |
| 2      | CH2POL | <ul> <li>Channel 2 Polarity</li> <li>Defines the polarity of the channel output. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The channel polarity is active high.</li> <li>1: The channel polarity is active low.</li> </ul> |
| 1      | CH1POL | <ul> <li>Channel 1 Polarity</li> <li>Defines the polarity of the channel output. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The channel polarity is active high.</li> <li>1: The channel polarity is active low.</li> </ul> |
| 0      | CH0POL | <ul> <li>Channel 0 Polarity</li> <li>Defines the polarity of the channel output. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The channel polarity is active high.</li> <li>1: The channel polarity is active low.</li> </ul> |

| 0x74          |         | PW       | Mx Fl | DSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Fault Detect Status Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |                   |                                               |                      |                     |    |                  | 00000000         |                                 |                  |  |
|---------------|---------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-------------------|-----------------------------------------------|----------------------|---------------------|----|------------------|------------------|---------------------------------|------------------|--|
| Bit           | 31      | 30       | 29    | 28                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 27                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 26                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 25                          | 24                | 23                                            | 22                   | 21                  | 20 | 19               | 18               | 17                              | 16               |  |
| Name<br>Type  |         |          |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |                   |                                               |                      |                     |    |                  |                  |                                 |                  |  |
| Reset         |         |          |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |                   |                                               |                      |                     |    |                  |                  |                                 |                  |  |
| Bit           | 15      | 14       | 13    | 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 9                           | 8                 | 7                                             | 6                    | 5                   | 4  | 3                | 2                | 1                               | 0                |  |
| Name          |         |          |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |                   | FA<br>ULT<br>DF                               | WP<br>EN             | FA<br>ULT<br>IN     |    | FAU<br>LTD<br>F3 | FA<br>ULT<br>DF2 | FA<br>ULT<br>DF1                | FA<br>ULT<br>DF0 |  |
| Type<br>Reset |         |          |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |                   | RO<br>0                                       | RW<br>0              | RO<br>0             |    | RO<br>0          | RO<br>0          | RO<br>0                         | RO<br>0          |  |
| Nesei         |         |          |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |                   | 0                                             | 0                    | 0                   |    | 0                | 0                | 0                               | 0                |  |
| Bit(s)        |         | Na       | me    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |                   |                                               | Descr                | iption              | l  |                  |                  |                                 |                  |  |
| 7             |         | FAUI     | _TDF  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Repre<br>Clear<br>writing<br>enabl<br>condi<br>comp<br>seque<br>cleare<br>0: No                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <b>Fault Detection Flag</b><br>Represents the logic OR of the individual FAULTDF j bits where $j = 3, 2, 1, 0$ .<br>Clear FAULTDF by reading the FDSR register while FAULTDF is set and then<br>writing a 0 to FAULTDF while there is no existing fault condition at the<br>enabled fault inputs. Writing a 1 to FAULTDF has no effect. If another fault<br>condition is detected in an enabled fault input before the clearing sequence is<br>completed, the sequence is reset so FAULTDF remains set after the clearing<br>sequence is completed for the earlier fault condition. FAULTDF is also<br>cleared when FAULTDF j bits are cleared individually.<br>0: No fault condition was detected. |                             |                   |                                               |                      |                     |    |                  |                  |                                 |                  |  |
| 6             |         | WF       | PEN   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1: A fault condition was detected.<br>Write Protection Enable<br>The WPEN bit is the negation of the WPDIS bit. WPEN is set when 1 is<br>written to it. WPEN is cleared when WPEN bit is read as a 1 and then 1 is<br>written to WPDIS. Writing 0 to WPEN has no effect.<br>0: Write protection is disabled. Write protected bits can be written.<br>1: Write protection is enabled. Write protected bits cannot be written.                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |                   |                                               |                      |                     |    |                  |                  |                                 | s                |  |
| 5             |         | FAU      | LTIN  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Repre<br>filter i<br>0: The                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | s enab<br>e logic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | the log<br>led) wl<br>OR of | hen fau<br>the en | of the e<br>ilt contr<br>abled fa<br>abled fa | ol is ei<br>ault inp | nabled<br>outs is ( | ). | after th         | eir filte        | r (if the                       | ir               |  |
| 3             |         | FAUL     | TDF3  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <ul> <li>Fault Detection Flag 3</li> <li>Set by hardware when fault control is enabled, the corresponding fault input is enabled and a fault condition is detected at the fault input. Clear FAULTDF 3 by reading the FDSR register while FAULTDF 3 is set and then writing a 0 to FAULTDF 3 while there is no existing fault condition at the corresponding fault input. Writing a 1 to FAULTDF 3 has no effect. FAULTDF 3 bit is also cleared when FAULTDF bit is cleared. If another fault condition is detected at the corresponding fault input before the clearing sequence is completed, the sequence is reset so FAULTDF 3 remains set after the clearing sequence is completed for the earlier fault condition.</li> <li>0: No fault condition was detected at the fault input.</li> <li>1: A fault condition was detected at the fault input.</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |                   |                                               |                      |                     |    |                  |                  | 0F 3<br>0 to<br>1 fault<br>ared |                  |  |
| 2             |         |          | TDF2  | <ul> <li>Fault Detection Flag 2</li> <li>Set by hardware when fault control is enabled, the corresponding fault input i enabled and a fault condition is detected at the fault input. Clear FAULTDF 2 by reading the FDSR register while FAULTDF 2 is set and then writing a 0 to FAULTDF 2 while there is no existing fault condition at the corresponding fault input. Writing a 1 to FAULTDF 2 has no effect. FAULTDF 2 bit is also cleared when FAULTDF bit is cleared. If another fault condition is detected at the corresponding fault input before the clearing sequence is completed, the sequence is reset so FAULTDF 2 remains set after the clearing sequence is completed for the earlier fault condition.</li> <li>O: No fault condition was detected at the fault input.</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |                   |                                               |                      |                     |    |                  |                  | 0F 2<br>0 to<br>1 fault<br>ared |                  |  |
| AutoChi       | ips Coi | nfidenti | ial   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | © 20 <sup>.</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 13 - 20                     | <b>)21</b> Au     | toChip                                        | s Inc.               |                     |    |                  | Page             | e 172 c                         | f 360            |  |

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | FAULTDF1 | <ul> <li>Fault Detection Flag 1</li> <li>Set by hardware when fault control is enabled, the corresponding fault input is enabled and a fault condition is detected at the fault input. Clear FAULTDF 1 by reading the FDSR register while FAULTDF 1 is set and then writing a 0 to FAULTDF 1 while there is no existing fault condition at the corresponding fault input. Writing a 1 to FAULTDF 1 has no effect. FAULTDF 1 bit is also cleared when FAULTDF bit is cleared. If another fault condition is detected at the corresponding fault input before the clearing sequence is completed, the sequence is reset so FAULTDF 1 remains set after the clearing sequence is completed for the earlier fault condition.</li> <li>0: No fault condition was detected at the fault input.</li> <li>1: A fault condition was detected at the fault input.</li> </ul> |
| 0      | FAULTDF0 | <ul> <li>Fault Detection Flag 0</li> <li>Set by hardware when fault control is enabled, the corresponding fault input is enabled and a fault condition is detected at the fault input. Clear FAULTDF 0 by reading the FDSR register while FAULTDF 0 is set and then writing a 0 to FAULTDF 0 while there is no existing fault condition at the corresponding fault input. Writing a 1 to FAULTDF 0 has no effect. FAULTDF 0 bit is also cleared when FAULTDF bit is cleared. If another fault condition is detected at the corresponding fault input before the clearing sequence is completed, the sequence is reset so FAULTDF 0 remains set after the clearing sequence is completed for the earlier fault condition.</li> <li>0: No fault condition was detected at the fault input.</li> <li>1: A fault condition was detected at the fault input.</li> </ul> |

| 0x78      |                      | <u>PWM</u> > | CAPF | <u>ILTER</u> | I  | nput Capture Filter Control |    |     |       |     |    |    | 0000000    |       |        |      |  |
|-----------|----------------------|--------------|------|--------------|----|-----------------------------|----|-----|-------|-----|----|----|------------|-------|--------|------|--|
| Bit       | 31                   | 30           | 29   | 28           | 27 | 26                          | 25 | 24  | 23    | 22  | 21 | 20 | 19         | 18    | 17     | 16   |  |
| Nam<br>e  |                      |              |      |              |    |                             |    |     |       |     |    |    | СН         | 3CAPI | FVAL[4 | 4:1] |  |
| Туре      |                      |              |      |              |    |                             |    |     |       |     |    |    |            | R     | W      |      |  |
| Rese<br>t |                      |              |      |              |    |                             |    |     |       |     |    |    | 0          | 0     | 0      | 0    |  |
| Bit       | 15                   | 14           | 13   | 12           | 11 | 10                          | 9  | 8   | 7     | 6   | 5  | 4  | 3          | 2     | 1      | 0    |  |
| Nam<br>e  | CH3F<br>VAL[0<br>:0] |              | CH2C | APFVAL       |    |                             |    | CH1 | ICAPF | VAL |    |    | CH0CAPFVAL |       |        |      |  |
| Туре      | RW                   | RW           |      |              |    |                             | RW |     |       |     |    |    | RW         |       |        |      |  |
| Rese<br>t | 0                    | 0            | 0    | 0            | 0  | 0                           | 0  | 0   | 0     | 0   | 0  | 0  | 0          | 0     | 0      | 0    |  |

| 19:15CH3CAPFVALChannel 3 Input Filter<br>Selects the filter value for the channel input.<br>The filter is disabled when the value is zero.14:10CH2CAPFVALChannel 2 Input Filter<br>Selects the filter value for the channel input.<br>The filter is disabled when the value is zero.9:5CH1CAPFVALSelects the filter value for the channel input.<br>The filter is disabled when the value is zero.9:5CH1CAPFVALSelects the filter value for the channel input.<br>The filter is disabled when the value is zero.4:0CH0CAPFVALSelects the filter value for the channel input.<br>The filter is disabled when the value is zero.4:0CH0CAPFVALSelects the filter value for the channel input.<br>The filter is disabled when the value is zero. | Bit(s) | Name              | Description                                     |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------|-------------------------------------------------|
| The filter is disabled when the value is zero.         14:10       CH2CAPFVAL         Selects the filter value for the channel input.<br>The filter is disabled when the value is zero.         9:5       CH1CAPFVAL         Selects the filter value for the channel input.<br>The filter is disabled when the value is zero.         9:5       CH1CAPFVAL         Selects the filter value for the channel input.<br>The filter is disabled when the value is zero.         4:0       CH0CAPFVAL         Selects the filter value for the channel input.         4:0       CH0CAPFVAL                                                                                                                                                      |        |                   | Channel 3 Input Filter                          |
| 14:10       CH2CAPFVAL       Channel 2 Input Filter         14:10       CH2CAPFVAL       Selects the filter value for the channel input.<br>The filter is disabled when the value is zero.         9:5       CH1CAPFVAL       Channel 1 Input Filter<br>Selects the filter value for the channel input.<br>The filter is disabled when the value is zero.         4:0       CH0CAPFVAL       Selects the filter value for the channel input.<br>Selects the filter value for the channel input.                                                                                                                                                                                                                                              | 19:15  | <b>CH3CAPFVAL</b> | Selects the filter value for the channel input. |
| 14:10       CH2CAPFVAL       Selects the filter value for the channel input.<br>The filter is disabled when the value is zero.         9:5       CH1CAPFVAL       Channel 1 Input Filter<br>Selects the filter value for the channel input.<br>The filter is disabled when the value is zero.         4:0       CH0CAPFVAL       Channel 0 Input Filter<br>Selects the filter value for the channel input.                                                                                                                                                                                                                                                                                                                                   |        |                   | The filter is disabled when the value is zero.  |
| The filter is disabled when the value is zero.         9:5       CH1CAPFVAL         Selects the filter value for the channel input.<br>The filter is disabled when the value is zero.         4:0       CH0CAPFVAL         Selects the filter value for the channel input.         Selects the filter value for the channel input.         Selects the filter value for the channel input.                                                                                                                                                                                                                                                                                                                                                   |        |                   | Channel 2 Input Filter                          |
| 9:5       CH1CAPFVAL       Channel 1 Input Filter         9:5       CH1CAPFVAL       Selects the filter value for the channel input.<br>The filter is disabled when the value is zero.         4:0       CH0CAPFVAL       Channel 0 Input Filter         4:0       CH0CAPFVAL       Selects the filter value for the channel input.                                                                                                                                                                                                                                                                                                                                                                                                          | 14:10  | CH2CAPFVAL        | Selects the filter value for the channel input. |
| 9:5       CH1CAPFVAL       Selects the filter value for the channel input.<br>The filter is disabled when the value is zero.         4:0       CH0CAPFVAL       Channel 0 Input Filter<br>Selects the filter value for the channel input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        |                   | The filter is disabled when the value is zero.  |
| 4:0       CH0CAPFVAL         CH0CAPFVAL       Celects the filter value for the channel input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |                   | Channel 1 Input Filter                          |
| 4:0     CH0CAPFVAL     Selects the filter value for the channel input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 9:5    | CH1CAPFVAL        | Selects the filter value for the channel input. |
| 4:0 CH0CAPFVAL Selects the filter value for the channel input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        |                   | The filter is disabled when the value is zero.  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |                   | Channel 0 Input Filter                          |
| The filter is disabled when the value is zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 4:0    | CH0CAPFVAL        | Selects the filter value for the channel input. |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |                   | The filter is disabled when the value is zero.  |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 173 of 360

| 0x7C      |    | PWN | 1x_FFA | FER |    | Fault | Filter | and | Fault Enable Register |           |           |           |                |                | 0000000        |                |  |
|-----------|----|-----|--------|-----|----|-------|--------|-----|-----------------------|-----------|-----------|-----------|----------------|----------------|----------------|----------------|--|
| Bit       | 31 | 30  | 29     | 28  | 27 | 26    | 25     | 24  | 23                    | 22        | 21        | 20        | 19             | 18             | 17             | 16             |  |
| Nam<br>e  |    |     |        |     |    |       |        |     |                       |           |           |           |                |                |                |                |  |
| Туре      |    |     |        |     |    |       |        |     |                       |           |           |           |                |                |                |                |  |
| Res<br>et |    |     |        |     |    |       |        |     |                       |           |           |           |                |                |                |                |  |
| Bit       | 15 | 14  | 13     | 12  | 11 | 10    | 9      | 8   | 7                     | 6         | 5         | 4         | 3              | 2              | 1              | 0              |  |
| Nam<br>e  |    |     |        |     |    | FF\   | /AL    |     | FF3<br>EN             | FF2<br>EN | FF1<br>EN | FF0<br>EN | FE<br>R3<br>EN | FE<br>R2<br>EN | FE<br>R1<br>EN | FE<br>R0<br>EN |  |
| Туре      |    |     |        |     |    | R     | W      |     | RW                    | RW        | RW        | RW        | RW             | RW             | RW             | RW             |  |
| Res<br>et |    |     |        |     | 0  | 0     | 0      | 0   | 0                     | 0         | 0         | 0         | 0              | 0              | 0              | 0              |  |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                             |
|--------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8   | FFVAL        | Fault Input Filter<br>Selects the filter value for the fault inputs. The fault filter is disabled when the<br>value is zero.                                                                                                                                            |
| 7      | FF3EN        | <ul> <li>Fault Input 3 Filter Enable</li> <li>Enables the filter for the fault input. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: Fault input filter is disabled.</li> <li>1: Fault input filter is enabled.</li> </ul>  |
| 6      | FF2EN        | <ul> <li>Fault Input 2 Filter Enable</li> <li>Enables the filter for the fault input. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: Fault input filter is disabled.</li> <li>1: Fault input filter is enabled.</li> </ul>  |
| 5      | FF1EN        | <ul> <li>Fault Input 1 Filter Enable</li> <li>Enables the filter for the fault input. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: Fault input filter is disabled.</li> <li>1: Fault input filter is enabled.</li> </ul>  |
| 4      | <b>FF0EN</b> | <ul> <li>Fault Input 0 Filter Enable</li> <li>Enables the filter for the fault input. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: Fault input filter is disabled.</li> <li>1 ; Fault input filter is enabled.</li> </ul> |
| 3      | FER3EN       | <ul> <li>Fault Input 3 Enable</li> <li>Enables the fault input. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: Fault input is disabled.</li> <li>1: Fault input is enabled.</li> </ul>                                      |
| 2      | FER2EN       | <ul> <li>Fault Input 2 Enable</li> <li>Enables the fault input. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: Fault input is disabled.</li> <li>1; Fault input is enabled.</li> </ul>                                      |
| 1      | FER1EN       | <ul> <li>Fault Input 1 Enable</li> <li>Enables the fault input. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: Fault input is disabled.</li> <li>1: Fault input is enabled.</li> </ul>                                      |

| Fault Input 0 Enable         Enables the fault input. This field is write protected. It can be written only         when FUNCSEL[WPDIS] = 1.         Fault input is disabled.         1: Fault input is enabled. | Bit(s) | Name          | Description                                                                                                                            |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                  | 0      | <b>FER0EN</b> | Enables the fault input. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.<br>0: Fault input is disabled. |

| 0x80  |    | <u>PV</u> | /Mx_C | <u>2EI</u> | Quadrature Encoder/Decoder Interface<br>Configuration Register |    |    |    |                       |                       |                |                |                      |                | 00000000       |           |  |
|-------|----|-----------|-------|------------|----------------------------------------------------------------|----|----|----|-----------------------|-----------------------|----------------|----------------|----------------------|----------------|----------------|-----------|--|
| Bit   | 31 | 30        | 29    | 28         | 27                                                             | 26 | 25 | 24 | 23                    | 22                    | 21             | 20             | 19                   | 18             | 17             | 16        |  |
| Name  |    |           |       |            |                                                                |    |    |    |                       |                       |                |                |                      |                |                |           |  |
| Туре  |    |           |       |            |                                                                |    |    |    |                       |                       |                |                |                      |                |                |           |  |
| Reset |    |           |       |            |                                                                |    |    |    |                       |                       |                |                |                      |                |                |           |  |
| Bit   | 15 | 14        | 13    | 12         | 11                                                             | 10 | 9  | 8  | 7                     | 6                     | 5              | 4              | 3                    | 2              | 1              | 0         |  |
| Name  |    |           |       |            |                                                                |    |    |    | PH<br>AFL<br>TR<br>EN | PH<br>BFL<br>TR<br>EN | PH<br>AP<br>OL | PH<br>BP<br>OL | QU<br>AD<br>MO<br>DE | QU<br>ADI<br>R | to<br>Fdi<br>R | QEI<br>EN |  |
| Туре  |    |           |       |            |                                                                |    |    |    | RW                    | RW                    | RW             | RW             | RW                   | RO             | RO             | RW        |  |
| Reset |    |           |       |            |                                                                |    |    |    | 0                     | 0                     | 0              | 0              | 0                    | 0              | 0              | 0         |  |

| Bit(s)   | Name           | Description                                                                                                                                                                                                                                                                                                                         |                        |
|----------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| 7        | PHAFLTREN      | Phase A Input Filter Enable<br>Enables the filter for the quadrature decoder phase A ir<br>the phase A input is defined by the CH0FVAL field of Fil<br>filter is also disabled when CH0FVAL is zero.<br>0: Phase A input filter is disabled.<br>1: Phase A input filter is enabled.                                                 |                        |
| 6        | PHBFLTREN      | Phase B Input Filter Enable<br>Enables the filter for the quadrature decoder phase B in<br>for the phase B input is defined by the CH1FVAL field of<br>B filter is also disabled when CH1FVAL is zero.<br>0: Phase B input filter is disabled.<br>1; Phase B input filter is enabled.                                               |                        |
| 5        | PHAPOL         | <ul> <li>Phase A Input Polarity</li> <li>Selects the polarity for the quadrature decoder phase A</li> <li>0: Normal polarity. Phase A input signal is not inverted rising and falling edges of this signal.</li> <li>1: Inverted polarity. Phase A input signal is inverted bef rising and falling edges of this signal.</li> </ul> | before identifying the |
| 4        | PHBPOL         | <ul> <li>Phase B Input Polarity</li> <li>Selects the polarity for the quadrature decoder phase B</li> <li>0: Normal polarity. Phase B input signal is not inverted rising and falling edges of this signal.</li> <li>1: Inverted polarity. Phase B input signal is inverted being and falling edges of this signal.</li> </ul>      | before identifying the |
| 3        | QUADMODE       | Quadrature Decoder Mode<br>Selects the encoding mode used in the Quadrature De<br>0: Phase A and phase B encoding mode.<br>1: Count and direction encoding mode.                                                                                                                                                                    | coder mode.            |
| 2        | QUADIR         | <b>PWM Counter Direction in Quadrature Decoder Mod</b><br>Indicates the counting direction.<br>0: Counting direction is decreasing (PWM counter decr                                                                                                                                                                                |                        |
| AutoChip | s Confidential | © 2013 - 2021 AutoChips Inc                                                                                                                                                                                                                                                                                                         | Page 175 of 360        |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

This document contains information that is proprietary to AutoChips Inc.

| Bit(s) | Name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |        | 1: Counting direction is increasing (PWM counter increment).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1      | TOFDIR | <ul> <li>Timer Overflow Direction in Quadrature Decoder Mode</li> <li>Indicates if the TOF bit was set on the top or the bottom of counting.</li> <li>0: TOF bit was set on the bottom of counting. There was an PWM counter decrement and PWM counter changes from its minimum value (CNTIN register) to its maximum value (MCVR register).</li> <li>1: TOF bit was set on the top of counting. There was an PWM counter increment and PWM counter changes from its maximum value (MCVR register).</li> <li>1: TOF bit was set on the top of counting. There was an PWM counter increment and PWM counter changes from its maximum value (MCVR register) to its minimum value (CNTIN register).</li> </ul> |
| 0      | QEIEN  | Quadrature Decoder Mode Enable         Enables the Quadrature Decoder mode. In this mode, the phase A and B input signals control the PWM counter direction. The Quadrature Decoder mode has precedence over the other modes. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.         0: Quadrature Decoder mode is disabled.         1: Quadrature Decoder mode is enabled.                                                                                                                                                                                                                                                                                                 |

| 0x84  |    | PWI | Mx C | <u>ONF</u> |    | Configuration           |    |    |    |          |    |    |    |    | 0000000 |            |  |
|-------|----|-----|------|------------|----|-------------------------|----|----|----|----------|----|----|----|----|---------|------------|--|
| Bit   | 31 | 30  | 29   | 28         | 27 | 26                      | 25 | 24 | 23 | 22       | 21 | 20 | 19 | 18 | 17      | 16         |  |
| Name  |    |     |      |            |    | EVENT5_P EVENT<br>SC SC |    |    |    |          |    |    |    |    |         | ITO_P<br>C |  |
| Туре  |    |     |      |            | R  | W                       | RW |    | R  | W RW     |    | RW |    | RW |         |            |  |
| Reset |    |     |      |            | 0  | 0                       | 0  | 0  | 0  | 0        | 0  | 0  | 0  | 0  | 0       | 0          |  |
| Bit   | 15 | 14  | 13   | 12         | 11 | 10                      | 9  | 8  | 7  | 6        | 5  | 4  | 3  | 2  | 1       | 0          |  |
| Name  |    |     |      |            |    |                         |    |    |    | CNTOFNUM |    |    |    |    |         |            |  |
| Туре  |    |     |      |            |    |                         |    |    |    | RW       |    |    |    |    |         |            |  |
| Reset |    |     |      |            |    |                         |    |    |    | 0        | 0  | 0  | 0  | 0  | 0       | 0          |  |

| Bit(s)   | Name           | Description                                                      |                 |
|----------|----------------|------------------------------------------------------------------|-----------------|
| 27:26    | EVENT5_PSC     | Channel 5 input event PSC<br>00:1<br>01:2<br>10:4<br>11:8        |                 |
| 25:24    | EVENT4_PSC     | <b>Channel 4 input event PSC</b><br>00:1<br>01:2<br>10:4<br>11:8 |                 |
| 23:22    | EVENT3_PSC     | Channel 3 input event PSC<br>00:1<br>01:2<br>10:4<br>11:8        |                 |
| 21:20    | EVENT2_PSC     | Channel 2 input event PSC<br>00:1<br>01:2<br>10:4<br>11:8        |                 |
| 19:18    | EVENT1_PSC     | Channel 1 input event PSC<br>00:1<br>01:2                        |                 |
| AutoChip | s Confidential | © 2013 - 2021 AutoChine Inc                                      | Page 176 of 360 |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

This document contains information that is proprietary to AutoChips Inc.

| Bit(s) | Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |            | 10:4<br>11:8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 17:16  | EVENT0_PSC | Channel 0 input event PSC<br>00:1<br>01:2<br>10:4<br>11:8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6:0    | CNTOFNUM   | <ul> <li>TOF Frequency</li> <li>Selects the ratio between the number of counter overflows to the number of times the CNTOF bit is set.</li> <li>NUMTOF = 0: The CNTOF bit is set for each counter overflow.</li> <li>CNTOFNUM = 1: The CNTOF bit is set for the first counter overflow but not for the next overflow.</li> <li>CNTOFNUM = 2: The CNTOF bit is set for the first counter overflow but not for the next 2 overflows.</li> <li>CNTOFNUM = 3: The CNTOF bit is set for the first counter overflow but not for the next 3 overflows.</li> </ul> |

| 0x88  |    | PWN | <u>Ix FLT</u> | POL |    |    | PWN | 0000000 |    |    |    |    |                 |                 |                 |                 |
|-------|----|-----|---------------|-----|----|----|-----|---------|----|----|----|----|-----------------|-----------------|-----------------|-----------------|
| Bit   | 31 | 30  | 29            | 28  | 27 | 26 | 25  | 24      | 23 | 22 | 21 | 20 | 19              | 18              | 17              | 16              |
| Name  |    |     |               |     |    |    |     |         |    |    |    |    |                 |                 |                 |                 |
| Туре  |    |     |               |     |    |    |     |         |    |    |    |    |                 |                 |                 |                 |
| Reset |    |     |               |     |    |    |     |         |    |    |    |    |                 |                 |                 |                 |
| Bit   | 15 | 14  | 13            | 12  | 11 | 10 | 9   | 8       | 7  | 6  | 5  | 4  | 3               | 2               | 1               | 0               |
| Name  |    |     |               |     |    |    |     |         |    |    |    |    | FLT<br>3P<br>OL | FLT<br>2P<br>OL | FLT<br>1P<br>OL | FLT<br>0P<br>OL |
| Туре  |    |     |               |     |    |    |     |         |    |    |    |    | RW              | RW              | RW              | RW              |
| Reset |    |     |               |     |    |    |     |         |    |    |    |    | 0               | 0               | 0               | 0               |

| Name    | Description                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FLT3POL | <ul> <li>Fault Input 3 Polarity</li> <li>Defines the polarity of the fault input. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The fault input polarity is active high. A one at the fault input indicates a fault.</li> <li>1: The fault input polarity is active low. A zero at the fault input indicates a fault.</li> </ul> |
| FLT2POL | <ul> <li>Fault Input 2 Polarity</li> <li>Defines the polarity of the fault input. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The fault input polarity is active high. A one at the fault input indicates a fault.</li> <li>1: The fault input polarity is active low. A zero at the fault input indicates a fault.</li> </ul> |
| FLT1POL | <ul> <li>Fault Input 1 Polarity</li> <li>Defines the polarity of the fault input. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The fault input polarity is active high. A one at the fault input indicates a fault.</li> <li>1: The fault input polarity is active low. A zero at the fault input indicates a fault.</li> </ul> |
|         | FLT3POL<br>FLT2POL                                                                                                                                                                                                                                                                                                                                                            |

AutoChips Confidential

| Bit(s) | Name    | Description                                                                                                                                                                                                                                                                                                                                                                   |
|--------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | FLT0POL | <ul> <li>Fault Input 0 Polarity</li> <li>Defines the polarity of the fault input. This field is write protected. It can be written only when FUNCSEL[WPDIS] = 1.</li> <li>0: The fault input polarity is active high. A one at the fault input indicates a fault.</li> <li>1: The fault input polarity is active low. A zero at the fault input indicates a fault.</li> </ul> |

| 0x8C  |    | PWM | <u>x_SYNC</u> | CONF              | ONF Synchronization Configuration |                               |                                 |                                |                          |          |                   |                      |           | 0000000                 |                                |                                 |  |
|-------|----|-----|---------------|-------------------|-----------------------------------|-------------------------------|---------------------------------|--------------------------------|--------------------------|----------|-------------------|----------------------|-----------|-------------------------|--------------------------------|---------------------------------|--|
| Bit   | 31 | 30  | 29            | 28                | 27                                | 26                            | 25                              | 24                             | 23                       | 22       | 21                | 20                   | 19        | 18                      | 17                             | 16                              |  |
| Name  |    |     |               |                   |                                   |                               |                                 |                                |                          | H W PO L | S<br>W<br>PO<br>L | S<br>WH<br>WSY<br>NC | N H Ŵ Z C | O MV<br>H W<br>SY<br>NC | P<br>WS<br>VH<br>W<br>SY<br>NC | CN<br>TV<br>H<br>WS<br>YN<br>C  |  |
| Туре  |    |     |               |                   |                                   |                               |                                 |                                |                          | R<br>W   | R<br>W            | R<br>W               | R<br>W    | R<br>W                  | R<br>W                         | R<br>W                          |  |
| Reset |    |     |               |                   |                                   |                               |                                 |                                |                          | 0        | 0                 | 0                    | 0         | 0                       | 0                              | 0                               |  |
| Bit   | 15 | 14  | 13            | 12                | 11                                | 10                            | 9                               | 8                              | 7                        | 6        | 5                 | 4                    | 3         | 2                       | 1                              | 0                               |  |
| Name  |    |     |               | SWVS<br>WSYN<br>C | IN<br>VS<br>W<br>SY<br>NC         | O<br>MV<br>S<br>W<br>SY<br>NC | P<br>W<br>S<br>S<br>S<br>S<br>C | CN<br>TV<br>S<br>W<br>SY<br>NC | SY<br>NC<br>M<br>OD<br>E |          | S<br>W<br>OC      | IN<br>VC             |           | CN<br>TI<br>NC          |                                | H<br>WT<br>GM<br>OD<br>ES<br>EL |  |
| Туре  |    |     |               | RW                | R<br>W                            | R<br>W                        | R W                             | R<br>W                         | R<br>W                   |          | R<br>W            | R<br>W               |           | R<br>W                  |                                | R<br>W                          |  |
| Reset |    |     |               | 0                 | 0                                 | 0                             | 0                               | 0                              | 0                        |          | 0                 | 0                    |           | 0                       |                                | 0                               |  |

| Bit(s)   | Name            | Description                                                                                                                                                                                                                                                                    |                        |  |  |  |  |  |
|----------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--|--|--|--|--|
| 22       | HWPOL           | Channel CHPOLCR synchronization is activated b<br>0: A hardware trigger does not activate the CHPOLCR<br>synchronization.<br>1: A hardware trigger activates CHPOLCR register syn                                                                                              | register               |  |  |  |  |  |
| 21       | SWPOL           | Channel CHPOLCR synchronization is activated b<br>0: The software trigger does not activate the CHPOLC<br>synchronization.<br>1: The software trigger activates CHPOLCR register s                                                                                             | CR register            |  |  |  |  |  |
| 20       | SWVHWSYNC       | Software output control synchronization is activat<br>trigger.<br>0: A hardware trigger does not activate the CHOSWC<br>synchronization.<br>1: A hardware trigger activates the CHOSWCR register                                                                               | R register             |  |  |  |  |  |
| 19       | INVHWSYNC       | Inverting control synchronization is activated by a<br>0: A hardware trigger does not activate the INVCR reg<br>1: A hardware trigger activates the INVCR register syr                                                                                                         | ister synchronization. |  |  |  |  |  |
| 18       | OMVHWSYNC       | Output mask synchronization is activated by a har<br>0: A hardware trigger does not activate the OMCR reg<br>1: A hardware trigger activates the OMCR register syr                                                                                                             | ister synchronization. |  |  |  |  |  |
| 17       | PWMSVHWSYNC     | <ul> <li>MCVR, CNTIN, and CV registers synchronization is activated by a hardware trigger.</li> <li>0: A hardware trigger does not activate MCVR, CNTIN, and CHV registers synchronization.</li> <li>1: A hardware trigger activates MCVR, CNTIN, and CHV registers</li> </ul> |                        |  |  |  |  |  |
| AutoChip | os Confidential | © 2013 - 2021 AutoChips Inc.                                                                                                                                                                                                                                                   | Page 178 of 360        |  |  |  |  |  |

This document contains information that is proprietary to AutoChips Inc.

| Bit(s) | Name          | Description                                                                                                                                                                                                                                                                                           |
|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R      |               | synchronization.                                                                                                                                                                                                                                                                                      |
| 16     | CNTVHWSYNC    | <ul> <li>PWM counter synchronization is activated by a hardware trigger.</li> <li>0: A hardware trigger does not activate the PWM counter synchronization.</li> <li>1: A hardware trigger activates the PWM counter synchronization.</li> </ul>                                                       |
| 12     | SWVSWSYNC     | Software output control synchronization is activated by the software trigger.<br>0: The software trigger does not activate the CHOSWCR register synchronization.<br>1: The software trigger activates the CHOSWCR register synchronization.                                                           |
| 11     | INVSWSYNC     | Inverting control synchronization is activated by the software trigger.<br>0: The software trigger does not activate the INVCR register synchronization.<br>1: The software trigger activates the INVCR register synchronization.                                                                     |
| 10     | OMVSWSYNC     | Output mask synchronization is activated by the software trigger.<br>0: The software trigger does not activate the OMCR register synchronization.<br>1: The software trigger activates the OMCR register synchronization.                                                                             |
| 9      | PWMSVSWSYNC   | <ul> <li>MCVR, CNTIN, and CV registers synchronization is activated by the software trigger.</li> <li>0: The software trigger does not activate MCVR, CNTIN, and CHV registers synchronization.</li> <li>1: The software trigger activates MCVR, CNTIN, and CHV registers synchronization.</li> </ul> |
| 8      | CNTVSWSYNC    | <b>PWM counter synchronization is activated by the software trigger.</b><br>0: The software trigger does not activate the PWM counter synchronization.<br>1: The software trigger activates the PWM counter synchronization.                                                                          |
| 7      | SYNCMODE      | Synchronization Mode<br>Selects the PWM Synchronization mode.<br>0: Legacy PWM synchronization is selected.<br>1: Enhanced PWM synchronization is selected.                                                                                                                                           |
| 5      | SWOC          | CHOSWCR Register Synchronization<br>0: CHOSWCR register is updated with its buffer value at all rising edges of<br>system clock.<br>1: CHOSWCR register is updated with its buffer value by the PWM<br>synchronization.                                                                               |
| 4      | INVC          | <ul> <li>INVCR Register Synchronization</li> <li>0: INVCR register is updated with its buffer value at all rising edges of system clock.</li> <li>1: INVCR register is updated with its buffer value by the PWM synchronization.</li> </ul>                                                           |
| 2      | CNTINC        | <ul> <li>CNTIN Register Synchronization</li> <li>0: CNTIN register is updated with its buffer value at all rising edges of system clock.</li> <li>1: CNTIN register is updated with its buffer value by the PWM synchronization.</li> </ul>                                                           |
| 0      | HWTRIGMODESEL | Hardware Trigger Mode<br>0: PWM clears the TRIGj bit when the hardware trigger j is detected, where j<br>= 0, 1,2.<br>1: PWM does not clear the TRIGj bit when the hardware trigger j is detected,<br>where j = 0, 1,2.                                                                               |

| 0x90 |    | PWN | /Ix_IN | VCR |    | PWM Inverting Control Register |  |  |  |  |  |  |  |  |  |    |
|------|----|-----|--------|-----|----|--------------------------------|--|--|--|--|--|--|--|--|--|----|
| Bit  | 31 | 30  | 29     | 28  | 27 | 26 25 24 23 22 21 20 19 18     |  |  |  |  |  |  |  |  |  | 16 |
| Name |    |     |        |     |    |                                |  |  |  |  |  |  |  |  |  |    |
| Туре |    |     |        |     |    |                                |  |  |  |  |  |  |  |  |  |    |
|      |    |     |        |     |    |                                |  |  |  |  |  |  |  |  |  |    |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 179 of 360

| 0x90  |    | PWN | /Ix_IN | VCR |    | PWM Inverting Control Register |   |   |   |   |   |   |                        |                        | 0000000                |                        |  |  |
|-------|----|-----|--------|-----|----|--------------------------------|---|---|---|---|---|---|------------------------|------------------------|------------------------|------------------------|--|--|
| Reset |    |     |        |     |    |                                |   |   |   |   |   |   |                        |                        |                        |                        |  |  |
| Bit   | 15 | 14  | 13     | 12  | 11 | 10                             | 9 | 8 | 7 | 6 | 5 | 4 | 3                      | 2                      | 1                      | 0                      |  |  |
| Name  |    |     |        |     |    |                                |   |   |   |   |   |   | PAI<br>R3I<br>NV<br>EN | PAI<br>R2I<br>NV<br>EN | PAI<br>R1I<br>NV<br>EN | PAI<br>ROI<br>NV<br>EN |  |  |
| Туре  |    |     |        |     |    |                                |   |   |   |   |   |   | RW                     | RW                     | RW                     | RW                     |  |  |
| Reset |    |     |        |     |    |                                |   |   |   |   |   |   | 0                      | 0                      | 0                      | 0                      |  |  |

| Bit(s) | Name       | Description                                                                               |
|--------|------------|-------------------------------------------------------------------------------------------|
| 3      | PAIROINVEN | Pair Channels 3 Inverting Enable<br>0: Inverting is disabled.<br>1: Inverting is enabled. |
| 2      | PAIR1INVEN | Pair Channels 2 Inverting Enable<br>0: Inverting is disabled.<br>1: Inverting is enabled. |
| 1      | PAIR2INVEN | Pair Channels 1 Inverting Enable<br>0: Inverting is disabled.<br>1: Inverting is enabled. |
| 0      | PAIR3INVEN | Pair Channels 0 Inverting Enable<br>0: Inverting is disabled.<br>1: Inverting is enabled. |

| 0x94      |    | PWMx_CHOSWCR |             |             |                     | PWM Channel Software Output Control<br>Register |                     |                     |    |    |                     |                     |                     |                     | 00000000            |                     |  |
|-----------|----|--------------|-------------|-------------|---------------------|-------------------------------------------------|---------------------|---------------------|----|----|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|--|
| Bit       | 31 | 30           | 29          | 28          | 27                  | 26                                              | 25                  | 24                  | 23 | 22 | 21                  | 20                  | 19                  | 18                  | 17                  | 16                  |  |
| Nam<br>e  |    |              |             |             |                     |                                                 |                     |                     |    |    |                     |                     |                     |                     |                     |                     |  |
| Туре      |    |              |             |             |                     |                                                 |                     |                     |    |    |                     |                     |                     |                     |                     |                     |  |
| Rese<br>t |    |              |             |             |                     |                                                 |                     |                     |    |    |                     |                     |                     |                     |                     |                     |  |
| Bit       | 15 | 14           | 13          | 12          | 11                  | 10                                              | 9                   | 8                   | 7  | 6  | 5                   | 4                   | 3                   | 2                   | 1                   | 0                   |  |
| Nam<br>e  |    |              | CH5S<br>WCV | CH4S<br>WCV | CH<br>3S<br>WC<br>V | CH<br>2S<br>WC<br>V                             | CH<br>1S<br>WC<br>V | CH<br>OS<br>WC<br>V |    |    | CH<br>5S<br>WE<br>N | CH<br>4S<br>WE<br>N | CH<br>3S<br>WE<br>N | CH<br>2S<br>WE<br>N | CH<br>1S<br>WE<br>N | CH<br>OS<br>WE<br>N |  |
| Туре      |    |              | RW          | RW          | RW                  | RW                                              | RW                  | RW                  |    |    | RW                  | RW                  | RW                  | RW                  | RW                  | RW                  |  |
| Rese<br>t |    |              | 0           | 0           | 0                   | 0                                               | 0                   | 0                   |    |    | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   |  |

| Bit(s)                 | Name    | Description                                                    |                 |  |  |  |  |
|------------------------|---------|----------------------------------------------------------------|-----------------|--|--|--|--|
|                        |         | Channel 5 Software Output Control Value                        |                 |  |  |  |  |
| 13                     | CH5SWCV | 0: The software output control forces 0 to the channel output. |                 |  |  |  |  |
|                        |         | 1: The software output control forces 1 to the channel output  | [.              |  |  |  |  |
| 12                     |         | Channel 4 Software Output Control Value                        |                 |  |  |  |  |
|                        | CH4SWCV | 0: The software output control forces 0 to the channel output  |                 |  |  |  |  |
|                        |         | 1: The software output control forces 1 to the channel output  | t.              |  |  |  |  |
| 11                     |         | Channel 3 Software Output Control Value                        |                 |  |  |  |  |
|                        | CH3SWCV | 0: The software output control forces 0 to the channel output  |                 |  |  |  |  |
|                        |         | 1: The software output control forces 1 to the channel output  | t.              |  |  |  |  |
| 10                     |         | Channel 2 Software Output Control Value                        |                 |  |  |  |  |
|                        | CH2SWCV | 0: The software output control forces 0 to the channel output  | t.              |  |  |  |  |
|                        |         | 1: The software output control forces 1 to the channel output  | t.              |  |  |  |  |
| 9                      | CH1SWCV | Channel 1 Software Output Control Value                        |                 |  |  |  |  |
|                        |         | 0: The software output control forces 0 to the channel output  | t.              |  |  |  |  |
| AutoChips Confidential |         | © 2013 - 2021 AutoChips Inc.                                   | Page 180 of 360 |  |  |  |  |

This document contains information that is proprietary to AutoChips Inc.

# **//utoChips**

| Bit(s) | Name    | Description                                                                                                                                               |
|--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |         | 1: The software output control forces 1 to the channel output.                                                                                            |
|        |         | Channel 0 Software Output Control Value                                                                                                                   |
| 8      | CH0SWCV | <ul><li>0: The software output control forces 0 to the channel output.</li><li>1: The software output control forces 1 to the channel output.</li></ul>   |
|        |         | Channel 5 Software Output Control Enable                                                                                                                  |
| 5      | CH5SWEN | <ul><li>0: The channel output is not affected by software output control.</li><li>1: The channel output is affected by software output control.</li></ul> |
|        |         | Channel 4 Software Output Control Enable                                                                                                                  |
| 4      | CH4SWEN | <ul><li>0: The channel output is not affected by software output control.</li><li>1: The channel output is affected by software output control.</li></ul> |
|        |         | Channel 3 Software Output Control Enable                                                                                                                  |
| 3      | CH3SWEN | <ul><li>0: The channel output is not affected by software output control.</li><li>1: The channel output is affected by software output control.</li></ul> |
|        |         | Channel 2 Software Output Control Enable                                                                                                                  |
| 2      | CH2SWEN | <ul><li>0: The channel output is not affected by software output control.</li><li>1: The channel output is affected by software output control.</li></ul> |
|        |         | Channel 1 Software Output Control Enable                                                                                                                  |
| 1      | CH1SWEN | <ul><li>0: The channel output is not affected by software output control.</li><li>1: The channel output is affected by software output control.</li></ul> |
|        |         | Channel 0 Software Output Control Enable                                                                                                                  |
| 0      | CHOSWEN | <ul><li>0: The channel output is not affected by software output control.</li><li>1: The channel output is affected by software output control.</li></ul> |

## 12.3 Functional description

#### 12.3.1 Clock source

The PWM has only one clock domain: the system clock (Timer clock).



Figure 12-2 PWM clock source

The CLKSRC[1:0] bits in the PWMx\_INIT register select one of three possible clock sources for the PWM counter or disable the PWM counter. After any MCU reset, CLKSRC[1:0] = 00, so no clock source is selected. The CLKSRC[1:0] bits may be read or written at any time. Disabling the PWM counter by writing 00 to the CLKSRC[1:0] bits does not affect the PWM counter value or other registers.

The fixed frequency clock is an internal LFOSC clock source for the PWM counter that allows the selection of a clock other than the system clock or an external clock. This clock frequency are almost equal 8 MHz.

The external clock passes through a synchronizer clocked by the system clock to assure that counter transitions are properly aligned to system clock transitions. Therefore, to meet Nyquist criteria

© 2013 - 2021 AutoChips Inc.

considering also jitter, the frequency of the external clock source must not exceed 1/4 of the system clock frequency.

#### 12.3.2 Prescaler

**NutoChips** 

The selected counter clock source passes through a prescaler that is a 16-bit counter. The value of the prescaler is selected by the PWMx\_INIT register PWM\_PSC[15:0] bits. The following figure shows an example of the prescaler counter and PWM counter.



Figure 12-3 Prescaler

#### 12.3.3 Counter

The PWM has a 16-bit counter that is used by the channels either for input or output modes. The PWM counter clock is the selected clock divided by the prescaler. The PWM counter has these modes of operation:

- Up counting.
- Up-down counting.
- Quadrature Decoder mode.

#### 12.3.3.1 Up counting

Up counting is selected when QEIEN=0 and CNTMODE=0. CNTIN defines the starting value of the count and MCVR defines the final value of the count, see the following figure. The value of CNTIN is loaded into the PWM counter, and the counter increments until the value of MCVR is reached, at which point the counter is reloaded with the value of CNTIN. The PWM period when using up counting is (MCVR – CNTIN + 0x0001) × period of the PWM counter clock. The TOF bit is set to 1 when the PWM counter changes from MCVR to CNTIN.



Figure 12-4 Up counting

#### 12.3.3.2 Up-Down counting

Up-down counting is selected when QEIEN = 0 and CNTMODE = 1. CNTIN defines the starting value of the count and MCVR defines the final value of the count. The value of CNTIN is loaded into the PWM counter, and the counter increments until the value of MCVR is reached, at which point the counter is decremented until it returns to the value of CNTIN and the up-down counting restarts.

The PWM period when using up-down counting is  $2 \times (MCVR - CNTIN) \times period of the PWM counter clock. The TOF bit is set to 1 when the PWM counter changes from MCVR to (MCVR - 1). See the following figure.$ 



Figure 12-5 Up-Down counting

#### 12.3.4 Operation mode

PWM can be configured for input capture, output compare, or edge-aligned PWM mode, centeraligned PWM mode, combination mode, Quadrature decoder mode. Please refer to the following table in detail.

| Table 12-3 | Operation | mode | configuration |
|------------|-----------|------|---------------|
|------------|-----------|------|---------------|

| PAIRn<br>DECAPEN | PAIRn<br>COMBINEN | CNTMODE | MSR1:<br>MSR0 | ELSR1:<br>ELSR0 | Operation<br>mode | Configuration     |
|------------------|-------------------|---------|---------------|-----------------|-------------------|-------------------|
| 0                | 0                 | 0       | 00            | 01              | Input             | Capture on Rising |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 183 of 360



| PAIRn<br>DECAPEN | PAIRn<br>COMBINEN | CNTMODE | MSR1:<br>MSR0 | ELSR1:<br>ELSR0 | Operation<br>mode | Configuration          |  |
|------------------|-------------------|---------|---------------|-----------------|-------------------|------------------------|--|
|                  |                   |         |               |                 | capture           | Edge Only              |  |
|                  |                   |         |               | 10              |                   | Capture on Falling     |  |
|                  |                   |         |               | 10              |                   | Edge Only              |  |
|                  |                   |         |               | 11              |                   | Capture on Rising or   |  |
|                  |                   |         |               |                 |                   | Falling Edge           |  |
|                  |                   |         |               | 01              |                   | Toggle Output on       |  |
|                  |                   |         | 01            | 01              | Output            | match                  |  |
|                  |                   |         | 01            | 10              | compare           | Clear Output on match  |  |
|                  |                   |         |               | 11              |                   | Set Output on match    |  |
|                  |                   |         |               |                 |                   | High-true pulses       |  |
|                  |                   |         |               | 10              | Edge-             | (Clear Output on       |  |
|                  |                   |         | 1X            |                 | aligned           | match)                 |  |
|                  |                   |         |               | VA              | PWM               | High-true pulses (Set  |  |
|                  |                   |         |               | X1              |                   | Output on match)       |  |
|                  |                   |         |               |                 |                   | High-true pulses       |  |
|                  |                   | 1 XX 10 | 10            | Center-         | (Clear Output on  |                        |  |
|                  |                   |         |               | aligned         | match-up)         |                        |  |
|                  |                   |         | X1            | VA              | PWM               | Low-true pulses (Set   |  |
|                  |                   |         |               | X1              |                   | Output on match-up)    |  |
|                  |                   |         |               |                 |                   | High-true pulses (Set  |  |
|                  |                   |         |               |                 |                   | on channel             |  |
|                  |                   |         |               | 10              |                   | (n) match, and         |  |
|                  |                   |         |               |                 |                   | clear on channel       |  |
|                  |                   |         |               |                 | Oamhina           | (n+1) match)           |  |
|                  | 1                 | 0       | XX            |                 | Combine           | Low-true pulses (Clear |  |
|                  |                   |         |               |                 | PWM               | on                     |  |
|                  |                   |         |               | VI              |                   | channel (n)            |  |
|                  |                   |         |               | X1              |                   | match, and set         |  |
|                  |                   |         |               |                 |                   | on channel (n          |  |
|                  |                   |         |               |                 |                   | +1) match)             |  |
|                  |                   |         |               |                 |                   |                        |  |
|                  |                   |         | VO            |                 |                   | One-Shot Capture       |  |
|                  |                   |         | X0            |                 |                   | mode                   |  |
|                  |                   |         |               | See the         | Dual edge         |                        |  |
| 1                | 0                 | 0       |               | following       | capture           |                        |  |
|                  |                   |         |               | table           |                   | Continuous Capture     |  |
|                  |                   |         | X1            |                 |                   | mode                   |  |
|                  |                   |         |               |                 |                   |                        |  |
| 1                |                   |         |               |                 |                   |                        |  |

|   | ELSR1 | ELSR0 | Channel Port Enable | Detected Edges |
|---|-------|-------|---------------------|----------------|
| Ī | 0     | 0     | Disabled            | No edge        |
|   | 0     | 1     | Enabled             | Rising edge    |

AutoChips Confidential

 $\ensuremath{\textcircled{}}$  2013 - 2021 AutoChips Inc.

| ELSR1 | ELSR0 | Channel Port Enable | Detected Edges           |
|-------|-------|---------------------|--------------------------|
| 1     | 0     | Enabled             | Falling edge             |
| 1     | 1     | Enabled             | Rising and falling edges |

#### 12.3.5 Input capture mode

The Input Capture mode is selected when:

- DECAPEN = 0
- COMBINE = 0
- CNTMODE = 0
- MSnR1:MSnR0 = 0:0
- ELSnR1:ELSnR0 != 0:0

When a selected edge occurs on the channel input, the current value of the PWM counter is captured into the CHnV register. At the same time, the CHnIF bit is set and the channel interrupt is generated if enabled by CHnIE = 1. When a channel is configured for input capture, the PWMxCHn pin is an edge-sensitive input. ELSnR1:ELSnR0 control bits determine which edge, falling or rising, triggers input capture event. Note that the maximum frequency for the channel input signal to be detected correctly is system clock divided by 4, which is required to meet Nyquist criteria for signal sampling. Writes to the CHnV register is ignored in Input Capture mode.



#### Figure 12-6 Input Capture mode

For PWM2 Channel0 to Channel3, there exist additional capture filter to make input signal clean. The filter is 5-bit counter and can be configured through register CHnCAPFVAL(n = 0,1,2,3). When the CHnCAPFVAL[4:0] = 0, the filter function is disabled, if CHnCAPFVAL[4:0]  $\neq$  00000, the input signal will be delayed CHnCAPFVAL[4:0] x 4 system Clock, and then be transported to the input capture function.

Please note that only PWM2 exists input capture filter function.

#### 12.3.6 Output Compare mode

The Output Compare mode is selected when:

- DECAPEN = 0
- COMBINE = 0
- CNTMODE = 0, and

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 185 of 360



• MSnR1:MSnR0 = 0:1

**NutoChips** 

In Output Compare mode, the PWM can generate timed pulses with programmable position, polarity, duration, and frequency. When the counter matches the value in the CHnV register of an output compare channel, the channel (n) output can be set, cleared, or toggled. When a channel is initially configured to Toggle mode, the previous value of the channel output is held until the first output compare event occurs. The CHnIF bit is set and the channel (n) interrupt is generated if CHnIE = 1 at the channel(n) match (PWM counter = CHnV).



#### Figure 12-7 Output Compare mode

#### 12.3.7 Edge-Aligned PWM(EPWM) mode

The Edge-Aligned mode is selected when:

- QEIEN = 0
- DECAPEN = 0
- COMBINE = 0
- CNTMODE = 0, and
- MSnR1 = 1

The EPWM period is determined by (MCVR - CNTIN + 0x0001) and the pulse width (duty cycle) is determined by (CHnV - CNTIN). The CHnIF bit is set and the channel (n) interrupt is generated if CHnIE = 1 at the channel (n) match (PWM counter = CHnV), that is, at the end of the pulse width. This type of PWM signal is called edge-aligned because the leading edges of all PWM signals are aligned with the beginning of the period, which is the same for all channels within an PWM.



#### Figure 12-8 Edge-aligned PWM mode

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

#### 12.3.8 Center-Aligned PWM(CPWM) mode

The Center-Aligned mode is selected when:

- QEIEN = 0
- DECAPEN = 0
- COMBINE = 0, and

**NutoChips** 

• CNTMODE = 1

The CPWM pulse width (duty cycle) is determined by  $2 \times (CHnV - CNTIN)$  and the period is determined by  $2 \times (MCVR - CNTIN)$ . See the following figure. MCVR must be kept in the range of 0x0001 to 0x7FFF because values outside this range can produce ambiguous results. In the CPWM mode, the PWM counter counts up until it reaches MCVR and then counts down until it reaches CNTIN. The CHnIF bit is set and channel (n) interrupt is generated (if CHnIE = 1) at the channel (n) match (PWM counter = CHnV) when the PWM counting is down (at the begin of the pulse width) and when the PWM counting is up (at the end of the pulse width). This type of PWM signal is called center-aligned because the pulse width centers for all channels are aligned with the value of CNTIN.

| CHnV        |   | 2 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| PWM counter | 0 | 1 | 2 | 3 | 4 | 3 | 2 | 1 | 0 | 1 | 2 | 3 | 4 | 3 | 2 | 1 | 0 | 1 | 2 | 3 |
| CHn out     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |

Figure 12-9 Center-aligned PWM mode

#### 12.3.9 Combine mode

The Combine mode is selected when:

- PWMEN2 = 1
- QEIEN = 0
- DECAPEN = 0
- COMBINE = 1, and
- CNTMODE = 0

In Combine mode, an even channel (n) and adjacent odd channel (n+1) are combined to generate a PWM signal in the channel (n) output. In the Combine mode, the PWM period is determined by (MCVR - CNTIN + 0x0001) and the PWM pulse width (duty cycle) is determined by (|CH(n+1)V - CH(n)V|).The CHnIF bit is set and the channel (n) interrupt is generated (if CHnIE = 1) at the channel (n) match (PWM counter = CH(n)V). The CH(n+1)F bit is set and the channel (n+1) interrupt is generated, if CH(n+1)IE = 1, at the channel (n+1) match (PWM counter = CH(n+1)V). If (ELSnR1:ELSnR0 = 1:0), then the channel (n) output is forced low at the beginning of the period (PWM counter = CNTIN) and at the channel (n+1) match (PWM counter = CH(n+1)V). It is forced high at the channel (n) output is forced high at the channel (n) output is forced high at the beginning of the period (PWM counter = CNTIN) and at the channel (n+1) N). It is forced high at the channel (n) output is forced high at the beginning of the period (PWM counter = CNTIN) and at the channel (n+1) N). It is forced high at the channel (n) output is forced high at the beginning of the period (PWM counter = CNTIN) and at the channel (n) N). See the following figure. If (ELSnR1:ELSnR0 = X:1), then the channel (n) output is forced high at the beginning of the period (PWM counter = CNTIN) and at the channel (n) N). It is forced high at the channel (n+1) match (PWM counter = CNTIN) and at the channel (n) N).

Page 187 of 360



(PWM counter = CH(n)V). See the following figure. In Combine mode, the ELS(n+1)R1 and ELS(n+1)R0 bits are not used in the generation of the channels (n) and (n+1) output.



Figure 12-10 Combine mode

#### 12.3.10 Complementary mode

**NutoChips** 

The Complementary mode is selected when:

- PWMEN2 = 1
- QEIEN = 0
- DECAPEN = 0
- COMBINE = 1
- CNTMODE = 0, and
- COMP = 1

In Complementary mode, the channel (n+1) output is the inverse of the channel (n)output. If (PWMEN2 = 1), (QEIEN = 0), (DECAPEN = 0), (COMBINE = 1), (CNTMODE = 0), and (COMP = 0), then the channel (n+1) output is the same as the channel (n) output.



AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 188 of 360



#### 12.3.11 Registers updated from write buffers

#### 12.3.11.1 PWM\_CNTIN register update buffer

#### Table 12-4 PWM\_CNTIN register update buffer

| Condition                                  | Update opportunity                                   |
|--------------------------------------------|------------------------------------------------------|
| CLKSRC[1:0] = 0:0                          | When PWM_CNTIN register is written                   |
| $CLKSRC[1:0] \neq 0:0 \&$<br>PWMSYNCEN = 0 | At the next system clock after PWM_CNTIN was written |
| CLKSRC[1:0] ≠ 0:0 &<br>PWMSYNCEN = 1       | By the PMW_CNTIN register synchronization            |

#### 12.3.11.2 PWM\_CH(n)V register update buffer

| Table 12-5 PWM_ | CH(n)V registe | r update buffer |
|-----------------|----------------|-----------------|
|-----------------|----------------|-----------------|

| Condition           | Update opportunity                                                               |
|---------------------|----------------------------------------------------------------------------------|
| CLKSRC[1:0]=0:0     | When PWM_CH(n)V register is written                                              |
|                     | <ul> <li>If the selected mode is EPWM, then register is updated after</li> </ul> |
| CLKSRC[1:0] ≠ 0:0 & | the PWM counter changes from MCVR to CNTIN.                                      |
| PWMSYNCEN = 0       | <ul> <li>If the selected mode is CPWM, then register is updated after</li> </ul> |
|                     | the PWM counter changes from MCVR to (MCVR – 0x0001).                            |
| CLKSRC[1:0] ≠ 0:0 & | By the PWM_CH(n)V register synchronization                                       |
| PWMSYNCEN = 1       |                                                                                  |

#### 12.3.11.3 PWM\_MCVR register update buffer

#### Table 12-6 PWM\_MCVR register update buffer

| Condition           | Update opportunity                                                               |
|---------------------|----------------------------------------------------------------------------------|
| CLKSRC[1:0]=0:0     | When PWM_MCVR register is written                                                |
|                     | <ul> <li>If the selected mode is EPWM, then register is updated after</li> </ul> |
| CLKSRC[1:0] ≠ 0:0 & | the PWM counter changes from MCVR to CNTIN.                                      |
| PWMSYNCEN = 0       | <ul> <li>If the selected mode is CPWM, then register is updated after</li> </ul> |
|                     | the PWM counter changes from MCVR to (MCVR – 0x0001).                            |
| CLKSRC[1:0] ≠ 0:0 & | By the PWM_MCVR register synchronization                                         |
| PWMSYNCEN = 1       | , _ , ,                                                                          |

AutoChips Confidential © 2013 - 2021 AutoChips Inc. This document contains information that is proprietary to AutoChips Inc.

Page 189 of 360

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

#### 12.3.12 PWM synchronization

**NutoChips** 

The PWM synchronization provides an opportunity to update the MCVR, CNTIN, CHnV, OMCR, INVCR and CHOSWCR registers with their buffered value and force the PWM counter to the CNTIN register value.

#### Note:

- The PWM synchronization must be used only in Combine mode.
- The legacy PWM synchronization (SYNCMODE = 0) is a subset of the enhanced PWM synchronization (SYNCMODE = 1). Thus, only the enhanced PWM synchronization must be used.

#### 12.3.12.1 Hardware trigger

Three hardware trigger signal inputs of the PWM module are enabled when TRIGn = 1, where n = 0, 1 or 2 corresponding to each one of the input signals, respectively. The hardware trigger input n is synchronized by the system clock. The PWM synchronization with hardware trigger is initiated when a rising edge is detected at the enabled hardware trigger inputs If (HWTRIGMODESEL = 0) then the TRIGn bit is cleared when 0 is written to it or when the trigger n event is detected. In this case, if two or more hardware triggers are enabled (for example, TRIG0 and TRIG1 = 1) and only trigger 1 event occurs, then only TRIG1 bit is cleared. If a trigger an event occurs together with a write setting TRIGn bit, then the synchronization is initiated, but TRIGn bit remains set due to the write operation.

#### 12.3.12.2 Software trigger

A software trigger event occurs when 1 is written to the SYNC[SWSYNC] bit. The SWSYNC bit is cleared when 0 is written to it or when the PWM synchronization, initiated by the software event, is completed.

If another software trigger event occurs (by writing another 1 to the SWSYNC bit) at the same time, the PWM synchronization initiated by the previous software trigger event is ending, a new PWM synchronization is started and the SWSYNC bit remains equal to 1.

If SYNCMODE = 0, then the SWSYNC bit is also cleared by PWM according to PWMSYNC and REINIT bits. In this case, if (PWMSYNC = 1) or (PWMSYNC = 0 and REINIT = 0) then SWSYNC bit is cleared at the next selected loading point after that the software trigger event occurred.

If (PWMSYNC = 0) and (REINIT = 1), then SWSYNC bit is cleared when the software trigger event occurs.

If SYNCMODE = 1, then the SWSYNC bit is also cleared by PWM according to the CNTVSWSYNC bit. If CNTVSWSYNC=0, then SWSYNC bit is cleared at the next selected loading point after that the software trigger event occurred. If CNTVSWSYNC = 1, then SWSYNC bit is cleared when the software trigger event occurs.

#### 12.3.13 Inverting

The Invert functionality swaps the signals between channel(n) and channel(n+1) outputs. The Inverting operation is selected when:

- PWMEN2 = 1
- QEIEN = 0
- DECAPEN = 0
- COMBINE = 1
- CNTMODE = 0, and

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 190 of 360

• PAIR(n)INVEN = 1, n=0,1,2 and 3

**NutoChips** 

#### 12.3.14 Channel trigger output

If CHjTRIG = 1, where j = 0, 1, 2, 3, 4, or 5, then the PWM generates a trigger when the

channel (j) match occurs (PWM counter = CH(j)V). The channel trigger output provides a trigger signal that is used for on-chip modules.

Functional description: The PWM is able to generate multiple triggers in one PWM period. Because each trigger is generated for a specific channel, several channels are required to implement this functionality.

#### 12.3.15 Initialization trigger

If INITTRIGEN = 1, then the PWM generates a trigger when the PWM counter is updated with the CNTIN register value in the following cases.

- The PWM counter is automatically updated with the CNTIN register value by the selected counting mode.
- When there is a write to CNT register.
- When there is the PWM counter synchronization.

#### 12.3.16 Capture Test mode

The Capture Test mode allows to test the CHnV registers, the PWM counter and the interconnection logic between the PWM counter and CHnV registers. In this test mode, all channels must be configured for Input Capture mode and PWM counter must be configured to the Up counting.

When the Capture Test mode is enabled (CAPTEST = 1), the PWM counter is frozen and any write to CNT register updates directly the PWM counter. After it was written, all CHnV registers are updated with the written value to CNT register and CHnIF bits are set. Therefore, the PWM counter is updated with its next value according to its configuration. Its next value depends on CNTIN, MCVR, and the written value to PWM counter. The next reads of CHnV registers return the written value to the PWM counter and the next reads of CNT register return PWM counter next value.

#### 12.3.17 Dual Edge Capture mode

The Dual Edge Capture mode is selected if PWMEN2 = 1 and DECAPEN = 1. This mode allows to measure a pulse width or period of the signal on the input of channel (n). In the mode, only channel (n) input is used and channel (n+1) input is ignored. The channel (n) filter can be active in this mode when n is 0 or 2. The ELS(n)R1:ELS(n)R0 bits select the edge that is captured by channel (n), and ELS(n+1)R1:ELS(n+1)R0 bits select the edge that is captured by channel (n+1).

If both ELS(n)R1:ELS(n)R0 and ELS(n+1)R1:ELS(n+1)R0 bits select the same edge, then it is the period measurement. If these bits select different edges, then it is a pulse width measurement. If the selected edge by channel (n) bits is detected at channel (n) input, then CH(n)IF bit is set and the channel (n) interrupt is generated (if CH(n)IE = 1). The Dual edge capture does not support enabling channel (n) and channel (n+1) interrupts simultaneously.

If the selected edge by channel (n+1) bits is detected at channel (n) input and (CH(n)IF = 1), then CH(n+1)IF bit is set and the channel (n+1) interrupt is generated (if CH(n+1)IE = 1). The CH(n)V register stores the value of PWM counter when the selected edge by channel(n) is detected at channel (n) input. The CH(n+1)V register stores the value of PWM counter when the selected edge by

AutoChips Confidential

# **NutoChips**

channel (n+1) is detected at channel (n) input. In this mode, a coherency mechanism ensures coherent data when the CH(n)V and CH(n+1)V registers are read. The only requirement is that CH(n)V must be read before CH(n+1)V.



Figure 12-12 Dual edge capture mode

#### 12.3.18 Software output control

The software output control forces the channel output according to software defined values at a specific time in the PWM generation.

The software output control is selected when:

- PWMEN2 = 1
- DECAPEN = 0
- COMBINE = 1
- CNTMODE = 0, and
- CH(n)SWEN = 1, n=0,1,2,3,4 and 5

The CH(n)SWEN bit enables the software output control, and the CH(n)SWCV selects the value that is forced to this channel output. Software output control forces the following values on channs(n) and (n+1) when the COMP bit is zero.

| CH(n)SWE | CH(n+1)SWE | CH(n)SW<br>CV | CH(n+1)SWC | Channel(n)Outp<br>ut | Channel(n+1)Outp<br>ut |
|----------|------------|---------------|------------|----------------------|------------------------|
| IN       | IN         | CV            | v          |                      |                        |
| 0        | 0          | Х             | Х          | Software control     | Software control not   |
|          |            |               |            | not enable           | enable                 |
| 1        | 1          | 0             | 0          | 0                    | 0                      |
| 1        | 1          | 0             | 1          | 0                    | 1                      |
| 1        | 1          | 1             | 0          | 1                    | 0                      |
| 1        | 1          | 1             | 1          | 1                    | 1                      |

Software output control forces the following values on channs(n) and (n+1) when the COMP bit is one:

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 192 of 360

| CH(n)SWE | CH(n+1)SWE | CH(n)SW | CH(n+1)SWC | Channel(n)Outp   | Channel(n+1)Outp     |
|----------|------------|---------|------------|------------------|----------------------|
| N        | N          | CV      | V          | ut               | ut                   |
| 0        | 0          | x       | x          | Software control | Software control not |
| 0        | 0          | ~       | ^          | not enable       | enable               |
| 1        | 1          | 0       | 0          | 0                | 0                    |
| 1        | 1          | 0       | 1          | 0                | 1                    |
| 1        | 1          | 1       | 0          | 1                | 0                    |
| 1        | 1          | 1       | 1          | 1                | 0                    |

 Table 12-8 Software output control when COMP bit is one

#### 12.3.19 Deadtime insertion

The deadtime insertion is enabled when (DTEN = 1) and (DTVAL[5:0] is non-zero). DTSET register defines the deadtime delay that can be used for all PWM channels. The DTPSC[1:0] bits define the prescaler for the system clock and the DTVAL[5:0] bits define the deadtime modulo, that is, the number of the deadtime prescaler clocks. The deadtime delay insertion ensures that no two complementary signals (channels (n)and (n+1)) drive the active state at the same time.

If CH(n)POL = 0, CH(n+1)POL = 0, and the deadtime is enabled, then when the channel (n) match (PWM counter = C(n)V) occurs, the channel (n) output remains at the low value until the end of the deadtime delay when the channel (n) output is set. Similarly, when the channel (n+1) match (PWM counter = C(n+1)V) occurs, the channel (n+1) output remains at the low value until the end of the deadtime delay when the channel (n+1) output is set.

If CH(n)POL = 1, CH(n+1)POL = 1, and the deadtime is enabled, then when the channel (n)match (PWM counter = CH(n)V) occurs, the channel (n) output remains at the high value until the end of the deadtime delay when the channel (n) output is cleared. Similarly, when the channel (n+1) match (PWM counter = CH(n+1)V) occurs, the channel (n+1) output remains at the high value until the end of the deadtime delay when the channel (n+1) output is cleared.

#### 12.3.20 Fault control

There exists 4 Fault input Source, 2 internal and 2 external, ACMP0\_OUT and ACMP1\_OUT can be chosen for Internal Fault Input, while external Fault1 and Fault2 can be chosen for external Fault Input.

| Fault Source    | Fault Input Number | Comment              |
|-----------------|--------------------|----------------------|
| ACMP0_OUT       | FAULT0             | Internal Fault Input |
| External Fault1 | FAULT1             | External Fault Input |
| External Fault2 | FAULT2             | External Fault Input |
| ACMP1_OUT       | FAULT3             | Internal Fault Input |

 Table 12-9 Fault source and number table

#### 12.3.20.1 Automatic fault clearing

If the automatic fault clearing is selected (FAULTMODE[1:0]=1:1), then the channels output disabled by fault control is again enabled when the fault input signal returns to zero and a new PWM cycle begins.

#### 12.3.20.2 Manual fault clearing

If the manual fault clearing is selected (FAULTMODE[1:0]=0:1 or 1:0), then the channels output disabled by fault control is again enabled when the FAULTDF bit is cleared and a new PWM cycle begins.

#### 12.3.20.3 Fault inputs polarity control

The FLTnPOL bit selects the fault input n polarity, when n=0,1,2 and 3:

(1) If FLTnPOL = 0, the fault n input polarity is high, so the logical one at the fault input n indicates a fault.

(2) If FLTnPOL = 1, the fault n input polarity is low, so the logical zero at the fault input n indicates a fault.

#### 12.3.21 Polarity control

The CHnPOL bit selects the channel(n) output polarity, when n=0,1,2,3,4 and 5:

(1) If CHnPOL = 0, the channel(n) output polarity is high, so the logical one is the active state and logical zero is the inactive state.

(2) If CHnPOL = 1, the channel(n) output polarity is low, so the logical zero is the active state and logical one is the inactive state.

#### 12.3.22 Features priority

The following figure shows the priority of the features used at the generation of CH(n) and CH(n+1) outputs signals.





### 12.4 PWM interrupts

#### 12.4.1 Count Overflow interrupt

The Count Overflow interrupt is generated when (CNTOIE=1) and (CNTOF=1).

#### 12.4.2 Channel interrupt

The Channel(n) interrupt is generated when (CHnIE=1) and (CHnIF = 1).

#### 12.4.3 Fault interrupt

The Fault interrupt is generated when (FAULTIE =1) and (FAULTDF = 1).

# **13 Pulse Width Detect Timer(PWDT)**

### 13.1 Introduction

PWDT (Pulse Width Detect Timer) module is used as a tool to measure the pulse width or as a 16-bit timer.

### 13.2 Features

- 2 selectable clock sources: bus clock and back-up clock.
- 4 selectable pulse input.
- Support 2 functions: pulse width measurement function and timer function.
  - For pulse width measurement function:
    - Programmable start trigger edge.
    - 4 programmable measurement modes.
    - Support 3 hall sensors' signal input measurement.
    - Support 3 inputs from analog comparator.
  - For timer function:
    - modify the timer load value when timer is disabled or on normal operation.
- 16-bit counter used for pulse width measurement or timer function.
- Interrupts:
  - o OVF: PWDT counter overflows on pulse width measurement function or timer function.
  - RDYF: PWDT pulse width measurement value update.

## 13.3 Functional description

The following is the block diagram of the PWDT Module.



Figure 13-1 PWDT block diagram

#### 13.3.1 Pulse Width Measurement function

To get the pulse width measurement value, the PWDTC counter runs based on the **pwtclk** described in block diagram after PWDTEN=1. And **pwtclk** is deriving from the bus clock division by the PSC[2:0]. So, in order to get more accurate measurement value, user had better take the smaller value of PSC[2:0] for narrower pulse input and larger value of PSC[2:0] for wider pulse input. The measurable pulse width is listed in Table 13-1.

| Item                         | Clock                     | Time             |
|------------------------------|---------------------------|------------------|
| Measurable pulse width range | 4 bcllk to 128*65535 bclk | 0.08us to 0.168s |

Firstly, for pulse width measurement, user must clearly know the application scenarios, which mainly include two conditions: one is just single channel input for basic measurement and the other is 3 channel inputs for hall measurement. For basic measurement, user choose to measure specific channel input by setting PINSEL[1:0] and can choose one of the 4 measurement modes by setting EDGE[1:0] based on the practical applications.

For hall measurement, the module measure the pulse input deriving from XOR of the 3 channel inputs and user should set the EDGE[1:0]=2'b01. Further, the configuration of the internal 3 channel comparator inputs is similar to the hall measurement and just CMPEN should be configured to 1'b1 simultaneously.

For basic measurement, 4 measurement modes can be selected based on practical applications and are illustrated as Figure 13-2.



Figure 13-2 Four basic measurement modes

For hall measurement or 3 internal comparator inputs, just one mode can be selected for motor speed calculation or commutation and is illustrated as Figure 13-3.

In the motors, installation of hall devices is used for detecting location of the rotor to commutate properly. Hall devices are usually installed in two ways, as shown in Figure 13-4. One is 120 electrical degree interval and the other is 60 electrical degree interval.



Figure 13-3 Hall measurement modes

AutoChips Confidential

**NutoChips** 







Secondly, filter in module is designed for filter the noise signal which high or low level is less than specific width described in the paragraph. The FILT\_PSC[7:4] and FILTVAL[3:0] settings determine the maximum and minimum noise pulse width. The Figure 13-5 and Figure 13-6 introduce the noise width settings, judgement and filter. When user configures the FILTVAL=15 and FILT\_PSC=2, the filter pulse width is 60 bclk and pulses less than 60 bclk are judged as noise pulse and will be filtered. The filterable pulse width is listed in Table 13-2.

#### Table 13-2 Filterable pulse width range

| ltem                         | Clock                   | Time              |
|------------------------------|-------------------------|-------------------|
| Filterable pulse width range | 4 bcllk to 16*4096 bclk | 0.08us to 1.311ms |



Figure 13-5 Example for low level noise and filter



#### Figure 13-6 Example for high level noise and filter

Thirdly, RDYF and OVF status or interrupt when corresponding enable is 1'b1 are used for pulse width measurement function. The RDYF status occurs under the condition described above. The OVF status occurs when the PWDTC counter overflows.

At last, user should understand the measurement accuracy for pulse width measurement to configure proper value of PSC[2:0] to reach a more accurate measurement value. A basic principle is that more accurate measurement value can be gotten with smaller PSC[2:0]. Obviously, more narrow input pulse, more relative measurement error. The Figure 13-7 describes the error when it operates for pulse width measurement function. In the Figure 13-7, the PWDTC counter and the pwtclk divisor counter reset to 0 simultaneously when the pwtin pulse changes from high to low or from low to high. And exactly here the counting error occurs which is deriving from the last counting value illustrated in Figure 13-7. The practical width value is less than measurement value by less than a pwtclk period.





#### 13.3.2 Timer function

For timer function, just OVF status is valid and occurs when PWDTC counter overflows. The counter load value TIMCNTVAL[15:0] can be modified all the time, but different time of modifying the value leads to different operation in microcosm in Figure 13-8 and Figure 13-9.



Figure 13-8 Modify the TIMCNTVAL between the TIMEN=0 and TIMEN=1



#### Figure 13-9 Modify the TIMCNTVAL during TIMEN=1

#### 13.3.3 Reset operation

Here just introduce the module software reset operation. User writes 1 to bit SR can trigger a software reset for the module. Once software reset is triggered, the following operations will occur:

- PWDTC reset to 0.
- PWDTC divisor reset to 0.
- Edge detecting logic reset.
- Width latch mechanism reset.
- PPWCV and NPWCV reset to 0.
- RDYF and OVF reset to 0.
- Other control bits don't reset.

Meanwhile, Configuring the PWDTEN to 0 can reach the same goal of reset above.

## 13.4 Program guide

#### 13.4.1 Pulse Width Measurement function program guide

User must keep in mind that PWDTEN should be configured to 1 after all other controlling bits. Otherwise, abnormal condition may occur. Especially, HALLEN and CMPEN should be configured to 1 for the internal 3 comparator inputs.

#### 13.4.2 Timer function program guide

Timer function is used easily with just configuration of the TIMCNTVAL, PRESCALE and TIMEN and so on. And user should set TIMEN to 1 at last and must not set the PWDTEN to 1because the pulse width measurement function is prior to timer function.

# 13.5 Register definition

#### Table 13-3 PWDT register map and reset values

#### Base address: 0x40017000

| Address                 | Name       | Width | Register function                                              |
|-------------------------|------------|-------|----------------------------------------------------------------|
| Base address+0x00000000 | PWDT_INIT0 | 32    | General control, status bits and positive pulse width contents |
| Base address+0x00000004 | PWDT_NPWCV | 32    | Negative pulse width content and 16-bit free running counter   |
| Base address+0x0000008  | PWDT_INIT1 | 32    | Hall function control and timer function control               |

| 000000 | 00 P      | WDT                 | INIT | 0      |    | PV | VDT | Initia | lizati | ion Re         | giste  | er O           |          |    | 0000     | 0000    |
|--------|-----------|---------------------|------|--------|----|----|-----|--------|--------|----------------|--------|----------------|----------|----|----------|---------|
| Bit    | 31~16     | 15                  | 14   | 13~12  | 11 | 10 | 9   | 8      | 7      | 6              | 5      | 4              | 3        | 2  | 1        | 0       |
| Name   | PPWC<br>V | PC<br>LK<br>SE<br>L |      | PINSEL | ED | GE |     | PSC    |        | PW<br>DTE<br>N | IE     | PR<br>DY<br>IE | OVI<br>E | SR | RD<br>YF | OV<br>F |
| Туре   | R         | R<br>W              |      | RW     | R  | W  |     | RW     |        | RW             | R<br>W | R<br>W         | RW       | W  | R        | R       |
| Reset  | 0         | 0                   |      | 0      | 0  | 0  | 0   | 0      | 0      | 0              | 0      | 0              | 0        | 0  | 0        | 0       |

**Note:** PWDTEN (pwm function) enable prior to TIMEN (timer function), so when timer function is going to be enabled, PWDTEN must be disabled.

| Bit(s) N       | Inemonic | Name    | Description                                                                                                      |
|----------------|----------|---------|------------------------------------------------------------------------------------------------------------------|
| 31:16 <b>P</b> | PWCV     | PPWCV   | Positive Pulse Width or Timer Count Value                                                                        |
|                |          |         | Indicate the negative pulse width value.                                                                         |
| 15 <b>P</b>    | CLKSEL   | PCLKSEL | PWDT Clock source selection                                                                                      |
|                |          |         | 0: timer clock for PWDT counter.                                                                                 |
|                |          |         | 1: alternative clock for PWDT counter.                                                                           |
| 13~12 <b>P</b> | INSEL    | PINSEL  | Pin selection                                                                                                    |
|                |          |         | Note: Pwdt_in3 is from the CTU module internally.                                                                |
|                |          |         | 00/01/10/11: respectively select pwdt_in0/ pwdt_in1/ pwdt_in2/ internal_pwdtin.                                  |
| 11~10 <b>E</b> | DGE      | EDGE    | Selects the input edge trigger type                                                                              |
|                |          |         | 00: first falling edge start, and all the subsequent falling edge trigge the pulse width to be captured.         |
|                |          |         | 01: first rising edge starts, and all the subsequent rising edge and falling edge trigger width to be captured.  |
|                |          |         | 10: first falling edge starts, and all the subsequent rising edge and falling edge trigger width to be captured. |
|                |          |         | 11: first rising edge start, and all the subsequent rising edge trigger<br>the pulse width to be captured.       |
|                |          |         | Note: details described in the subsequent diagram .                                                              |
| 9~7 <b>P</b>   | sc       | PSC     | PWDT counter prescale                                                                                            |
|                |          |         | 000 ~ 111: respectively represents 1/2/4/8//128.                                                                 |
| 5 IE           | E        | IE      | PWDT module interrupt enable                                                                                     |
|                |          |         | 0: disable                                                                                                       |
|                |          |         | 1: enable                                                                                                        |
|                |          |         |                                                                                                                  |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit(s) | Mnemonic | Name   | Description                                     |
|--------|----------|--------|-------------------------------------------------|
| 4      | PRDYIE   | PRDYIE | PWDT pulse width data ready interrupt enable    |
|        |          |        | 0: disable                                      |
|        |          |        | 1: enable                                       |
| 3      | OVIE     | OVIE   | PWDT counter overflow interrupt enable          |
|        |          |        | 0: disable                                      |
|        |          |        | 1: enable                                       |
| 2      | SR       | SR     | PWDT soft reset                                 |
|        |          |        | Note: read as 0                                 |
|        |          |        | 0: no effect                                    |
|        |          |        | 1: enable                                       |
| 1      | RDYF     | RDYF   | PWDT pulse width valid                          |
|        |          |        | Note: write 0 to clear                          |
|        |          |        | 0: PWDT pulse width register is not up to date. |
|        |          |        | 1: PWDT pulse width register has been updated.  |
| 0      | OVF      | OVF    | PWDT counter overflolw                          |
|        |          |        | Note: write 0 to clear                          |
|        |          |        | 0: no overflow                                  |
|        |          |        | 1: runs from 0x 0000 to 0x FFFF.                |

| 0000000 | 4 PWDT_NPWCV | PWD | 0000000 |  |
|---------|--------------|-----|---------|--|
| Bit     | 31~16        |     | 15~0    |  |
| Name    | PWDTC        |     | NPWCV   |  |
| Туре    | R            |     | R       |  |
| Reset   | 0            |     | 0       |  |

| Bit(s) Mnemonic    | Name  | Description                                             |
|--------------------|-------|---------------------------------------------------------|
| 31:16 <b>PWDTC</b> | PWDTC | Pulse Width Counter                                     |
|                    |       | Used to count for pulse width measurement or for timer. |
| 15:0 NPWCV         | NPWCV | Negative Pulse Width Count Value                        |
|                    |       | Indicate the negative pulse width value.                |

| 000000 | 08 | PWI       | DT_IN     | IT1       | <b>PWDT Initialization</b> | PWDT Initialization Register 1 |               |                |                |          |                 |  |  |
|--------|----|-----------|-----------|-----------|----------------------------|--------------------------------|---------------|----------------|----------------|----------|-----------------|--|--|
| Bit    | 31 | 30        | 29        | 28        | 27~12                      | 10                             | 9             | 8              | 7~4            | 3~0      |                 |  |  |
| Name   |    | HAL<br>LA | HAL<br>LB | HALL<br>C | TIMCNTVAL                  | CM<br>PEN                      | TI<br>ME<br>N | HA<br>LL<br>EN | FIL<br>TE<br>N | FILT_PSC | FIL<br>TVA<br>L |  |  |
| Туре   |    | R         | R         | R         | RW                         | RW                             | R<br>W        | R<br>W         | RW             | RW       | R               |  |  |
| Reset  |    | 0         | 0         | 0         | 0                          | 0                              | 0             | 0              | 0              | 0        | 0               |  |  |

**Note:** To make the filter function work, PWDT\_INIT1[FILTVAL] must be set more than 1, Otherwise filter function will not work.

| Bit(s) Mnemonic | Name      | Description                                                                                                                                                                                                                                                                                                 |
|-----------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:28 HALLA/B/C | halla/b/c | HALLA/HALLB/HALLC status value                                                                                                                                                                                                                                                                              |
|                 |           | If 3 hall sensors installed spacing 60 electrical degree:<br>$100 \rightarrow 110 \rightarrow 111 \rightarrow 011 \rightarrow 001 \rightarrow 000$<br>else 3 hall sensors installed spacing 120 electrical degree:<br>$101 \rightarrow 100 \rightarrow 110 \rightarrow 010 \rightarrow 011 \rightarrow 001$ |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 203 of 360

| Bit(s)  | Mnemonic  | Name      | Description                                                                                                                                                                                                                                                    |
|---------|-----------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27 ~ 12 | TIMCNTVAL | timcntval | Timer counter load value                                                                                                                                                                                                                                       |
|         |           |           | Counter runs from 0x0000 to TIMCNTVAL.                                                                                                                                                                                                                         |
| 11      | CMPEN     | cmpen     | Switch the source of pwdt_in0 ~ pwdt_in2                                                                                                                                                                                                                       |
|         |           |           | <b>Note:</b> When CMPEN=1, pwdt_in0 ~ pwdt_in2 are derived from acmp0_0 ~ acmp0_2 internally. And then acmp0_0 ~ acmp0_2 signals will be measured by the behavior of HALL sensor if HALLEN=1, otherwise just one of them will be measured based on the PINSEL. |
|         |           |           | <ol> <li>enable the pwdt_in0 ~ pwdt_in2 derived from acmp0_0 ~<br/>acmp0_2 internally.</li> </ol>                                                                                                                                                              |
|         |           |           | 0: enable the pwdt_in0 ~ pwdt_in2 derived from pad PWDT_IN0 ~ PWDT_IN2 externally.                                                                                                                                                                             |
| 10      | TIMEN     | timen     | Enable the timer function when PWDTEN = 0                                                                                                                                                                                                                      |
|         |           |           | 0: disable.                                                                                                                                                                                                                                                    |
|         |           |           | 1: enable timer function.                                                                                                                                                                                                                                      |
| 9       | HALLEN    | hallen    | Enable hall sensor signal detect function when PWDTEN = 1                                                                                                                                                                                                      |
|         |           |           | 0: disable the hall sensor signal detect function.                                                                                                                                                                                                             |
|         |           |           | 1: enable the hall sensor signal detect function.                                                                                                                                                                                                              |
| 8       | FILTEN    | filten    | Enable the PWDT input filter function when PWDTEN =1                                                                                                                                                                                                           |
|         |           |           | 0: disable.                                                                                                                                                                                                                                                    |
|         |           |           | 1: enable the filter function.                                                                                                                                                                                                                                 |
| 7 ~ 4   | FILT_PSC  | filt_psc  | Prescaler for filter                                                                                                                                                                                                                                           |
|         |           |           | 1~ 12: respectively represent 2/4/8/4096 divisor.                                                                                                                                                                                                              |
|         |           |           | 0, 13 ~ 15: not divide the filter clock.                                                                                                                                                                                                                       |
| 3 ~ 0   | FILTVAL   | filtval   | Filter value                                                                                                                                                                                                                                                   |
|         |           |           | 0 ~ 15 : for filter different width pulse.                                                                                                                                                                                                                     |

# **//utoChips**

# 14 TIMER

### 14.1 Introduction

The TIMER module is an array of timers that can be used to raise interrupts and triggers.

### 14.2 Features

- Ability of timers to generate trigger pulses.
- Ability of timers to generate interrupts.
- Maskable interrupts.
- Independent timeout periods for each timer.
- Maxim timer number is 8.
  - o 2 \* 32bit timer.
  - o 6 \* 16bit timer.
- Chain Mode.

# 14.3 Functional description

The following is the block diagram of the TIMER module.



#### Figure 14-1 TIMER block diagram

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 205 of 360

#### 14.3.1 General operation

The timers generate triggers at periodic intervals, when enabled. The timers load the start values as specified in their LDVAL registers, count down to 0 and then load the respective start value again. Each time a timer reaches 0, it will generate a trigger pulse and set the interrupt flag.

All interrupts can be enabled or masked by setting INIT[TIE]. A new interrupt can be generated only after the previous one is cleared. If desired, the current counter value of the timer can be read via the CVAL registers. The counter period can be restarted, by first disabling, and then enabling the timer with INIT[TIMEREN].

#### 14.3.2 Chained timers

When a timer has chain mode enabled, it will only count after the previous timer has expired. So if timer n-1 has counted down to 0, counter n will decrement the value by one. This allows chaining some of the timers together to form a longer timer. The first timer (timer 0) cannot be chained to any other timer.

As TIMER block has 8 timers, Chains can more than one. For example, Time 0/1/2 in one chain, and Time 3/4/5/6 in another one, the rest of Timer in third one.

### 14.4 Memory map and register definition

#### Table 14-1 TIMER register map

| ٦ | FIMER: | 0x4001 | 1000 |  |
|---|--------|--------|------|--|
| - |        |        |      |  |

| ADDRESS       | TITLE                  | DESCRIPTION                                                  |  |  |  |  |  |  |
|---------------|------------------------|--------------------------------------------------------------|--|--|--|--|--|--|
| TIMER+ 0x000  | MCR TIMER MCR register |                                                              |  |  |  |  |  |  |
| TIMER + 0x100 | INITVAL                | TIMER INITVAL register<br>OFFSET ADDR = 0x100+16*x(x=0 to 7) |  |  |  |  |  |  |
| TIMER + 0x104 | CVAL                   | TIMER CVAL register OFFSET ADDR =<br>0x104+16*x (x=0d to 7d) |  |  |  |  |  |  |
| TIMER + 0x108 | INIT                   | TIMER INIT register OFFSET ADDR =<br>0x108+16*x (x=0 to 7)   |  |  |  |  |  |  |
| TIMER + 0x10C | TF                     | TIMER TF register OFFSET ADDR =<br>0x10C+16*x(x=0 to 7)      |  |  |  |  |  |  |

| MCR     |    | TIMER MCR register OFFSET A                                                                                                                                             |    |    |    |    |   |   |   |   |   |   |   |   |      | DDR = 0x00 |  |
|---------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|---|---|---|---|---|---|---|------|------------|--|
| BIT     | 31 | 31         30         29         28         27         26         25         24         23         22         21         20         19         18         17         16 |    |    |    |    |   |   |   |   |   |   |   |   |      | 16         |  |
| R       |    |                                                                                                                                                                         |    |    |    |    |   |   |   |   |   |   |   |   |      |            |  |
| W       |    |                                                                                                                                                                         |    |    |    |    |   |   |   |   |   |   |   |   |      |            |  |
| Default |    | 0                                                                                                                                                                       |    |    |    |    |   |   |   |   |   |   |   |   |      |            |  |
| BIT     | 15 | 14                                                                                                                                                                      | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0          |  |
| R       |    |                                                                                                                                                                         |    |    |    |    |   |   |   |   |   |   |   |   | MDIS |            |  |
| W       |    |                                                                                                                                                                         |    |    |    |    |   |   |   |   |   |   |   |   |      |            |  |
| Default |    | 0                                                                                                                                                                       |    |    |    |    |   |   |   |   |   |   |   |   | 1    |            |  |

| Bit(s) | Name | Description                                                                           |
|--------|------|---------------------------------------------------------------------------------------|
|        |      | Module Disable - (TIMER section)                                                      |
| 1      | MDIS | Disables the timer module. This field must be enabled before any other setup is done. |
|        |      | 0: TIMER module is enabled.                                                           |
|        |      | 1: TIMER module is disabled.                                                          |

| INITVAL |    | TIMER INITVAL register OFFSET ADDR = 0x100+16*x(x=0 to 7) |    |    |    |    |    |    |        |    |    |    |    |    |    |    |
|---------|----|-----------------------------------------------------------|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|
| BIT     | 31 | 30                                                        | 29 | 28 | 27 | 26 | 25 | 24 | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| R       |    | LDVAL[31:16]                                              |    |    |    |    |    |    |        |    |    |    |    |    |    |    |
| W       |    |                                                           |    |    |    |    |    |    |        |    |    |    |    |    |    |    |
| Default |    |                                                           |    |    |    |    |    |    |        |    |    |    |    |    |    |    |
| BIT     | 15 | 14                                                        | 13 | 12 | 11 | 10 | 9  | 8  | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R       |    |                                                           |    |    |    |    |    |    | [15.0] |    |    |    |    |    |    |    |
| W       |    | LDVAL[15:0]                                               |    |    |    |    |    |    |        |    |    |    |    |    |    |    |
| Default |    |                                                           |    |    |    |    |    |    |        |    |    |    |    |    |    |    |

| Bit(s) | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |       | LDVAL: Load Value Register                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:0   | LDVAL | Sets the timer start value. The timer will count down until it reaches 0, then<br>it will generate an interrupt and load this register value again. Writing a<br>new value to this register will not restart the timer. Instead the value will be<br>loaded after the timer expires. To abort the current cycle and start a timer<br>period with the new value, the timer must be disabled and enabled again.<br><b>Note:</b> when $x > 1,LDVAL$ bit width is 16. |

| CVAL    |    | TIMER CVAL register OFFSET ADDR = 0x104+16*x (x=0d to 7d) |    |    |    |    |    |       |        |    |    |    |    |    |    |    |
|---------|----|-----------------------------------------------------------|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
| BIT     | 31 | 30                                                        | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| R       |    | CVAL[31:16]                                               |    |    |    |    |    |       |        |    |    |    |    |    |    |    |
| W       |    | CVAL[31:10]                                               |    |    |    |    |    |       |        |    |    |    |    |    |    |    |
| Default |    |                                                           |    |    |    |    |    |       |        |    |    |    |    |    |    |    |
| BIT     | 15 | 14                                                        | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R       |    |                                                           |    |    |    |    |    | CVAI  | [15:0] |    |    |    |    |    |    |    |
| w       |    |                                                           |    |    |    |    |    | 01/12 | []     |    |    |    |    |    |    |    |
| Default |    |                                                           |    |    |    |    |    |       |        |    |    |    |    |    |    |    |

| Bit(s) | Name                      | Description                                                  |
|--------|---------------------------|--------------------------------------------------------------|
|        | CVALx : Current Timer Val | CVALx : Current Timer Value Register                         |
| 31:0   | CVALx                     | Current Timer Value                                          |
| 31.0   | GVALX                     | Represents the current timer value, if the timer is enabled. |
|        |                           | <i>Note:</i> when x >1,CVALx bit width is 16.                |

© 2013 - 2021 AutoChips Inc.

| INIT    |    | TIMER INIT registerOFFSET ADDR = 0x108+16*x (x=0 to 7) |    |    |    |    |    |    |    |    |    |    |    |        |     | (x=0 to 7) |
|---------|----|--------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|--------|-----|------------|
| BIT     | 31 | 30                                                     | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18     | 17  | 16         |
| R       |    |                                                        |    |    |    |    |    |    |    |    |    |    |    |        |     |            |
| W       |    |                                                        |    |    |    |    |    |    |    |    |    |    |    |        |     |            |
| Default |    |                                                        |    |    |    |    |    |    |    | 0  |    |    |    |        |     |            |
| BIT     | 15 | 14                                                     | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2      | 1   | 0          |
| R       |    |                                                        |    |    |    |    |    |    |    |    |    |    |    | LINKEN | TIE | TIMEREN    |
| W       |    |                                                        |    |    |    |    |    |    |    |    |    |    |    |        |     |            |
| Default |    |                                                        |    |    |    |    | 0  |    |    |    |    |    |    | 0      | 0   | 0          |

| Bit(s) | Name     | Description                                                                                                           |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------|
|        |          | LINKEN: Chain Mode                                                                                                    |
|        |          | When activated, Timer n-1 needs to expire before timer n can decrement                                                |
| 2      | LINKEN   | by 1. Timer 0 cannot be chained.                                                                                      |
| 2      |          | 0: Timer is not chained.                                                                                              |
|        |          | 1: Timer is chained to previous timer. For example, for Timer 2, if this field is set, Timer 2 is chained to Timer 1. |
|        |          | TIE: Timer Interrupt Enable                                                                                           |
|        |          | When an interrupt is pending, or, TFLGn[TIF] is set, enabling the interrupt                                           |
| 1      | TIE      | will immediately cause an interrupt event. To avoid this, the associated                                              |
| •      |          | TFLGn[TIF] must be cleared first.                                                                                     |
|        |          | 0: Interrupt requests from Timer n are disabled.                                                                      |
|        |          | 1: Interrupt will be requested whenever TIF is set.                                                                   |
|        |          | TIMEREN: Timer Enable                                                                                                 |
| 0      | TIMEREN  | Enables or disables the timer.                                                                                        |
| U      | TIVIEREN | 0: Timer n is disabled.                                                                                               |
|        |          | 1: Timer n is enabled.                                                                                                |

| TF      |    |    |    |    | TIN | IER T | OFFSET ADDR = 0x10C+16*x(x=0 to 7) |    |    |    |    |    | ) to 7) |    |    |     |
|---------|----|----|----|----|-----|-------|------------------------------------|----|----|----|----|----|---------|----|----|-----|
| BIT     | 31 | 30 | 29 | 28 | 27  | 26    | 25                                 | 24 | 23 | 22 | 21 | 20 | 19      | 18 | 17 | 16  |
| R       |    |    |    |    |     |       |                                    |    |    |    |    |    |         |    |    |     |
| w       |    |    |    |    |     |       |                                    |    |    |    |    |    |         |    |    |     |
| default |    |    |    |    |     |       |                                    |    | 0  |    |    |    |         |    |    |     |
| BIT     | 15 | 14 | 13 | 12 | 11  | 10    | 9                                  | 8  | 7  | 6  | 5  | 4  | 3       | 2  | 1  | 0   |
| R       |    |    |    |    |     |       |                                    |    |    |    |    |    |         |    |    | TIF |
| W       |    |    |    |    |     |       |                                    |    |    |    |    |    |         |    |    |     |
| default |    |    |    |    |     |       |                                    | 0  |    |    |    |    |         |    |    | 0   |

| Bit(s)                 | Name | Description                                                              |                                                                           |  |  |  |  |
|------------------------|------|--------------------------------------------------------------------------|---------------------------------------------------------------------------|--|--|--|--|
|                        |      | TIF: Timer Interrupt Flag                                                |                                                                           |  |  |  |  |
|                        |      | Sets to 1 at the end of the timer period. Writing 1 to th                | is flag clears it.                                                        |  |  |  |  |
| 0                      | TIF  | Writing 0 has no effect. If enabled, or, when TCTRLx[                    | Writing 0 has no effect. If enabled, or, when TCTRLx[TIE] = 1, TIF causes |  |  |  |  |
|                        |      | an interrupt request.                                                    |                                                                           |  |  |  |  |
|                        |      | 0: Timeout has not yet occurred.                                         |                                                                           |  |  |  |  |
| AutoChips Confidential |      | © 2013 - 2021 AutoChips Inc. Page 208                                    |                                                                           |  |  |  |  |
|                        |      | This document contains information that is proprietary to AutoChips Inc. |                                                                           |  |  |  |  |

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.



| Bit(s) | Name | Description              |
|--------|------|--------------------------|
|        |      | 1: Timeout has occurred. |

## 14.5 Interrupts

All the timers support interrupt generation.

Timer interrupts can be enabled by setting INIT[TIE].TF[TIF] flag are set to 1 when a timeout occurs on the associated timer. and are cleared to 0 by writing a 1 to the corresponding TF[TIF].

# **//utoChips**

# 15 CTU

### **15.1 Introduction**

The CTU module defines module-to-module interconnections for this device.

### 15.2 Features

- UART TX modulation.
- UART RX capture.
- UART RX filter.
- RTC capture.
- ADC trigger.
- PWM2 synchronization.

## **15.3 Function description**

The following is the block diagram of CTU.



#### Figure 15-1 CTU block diagram

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 210 of 360

#### **15.3.1 ACMP** output capture

**NutoChips** 

The CONFIG1[ACIC] bit enables the output of ACMP0 to be connected to PWM1\_CH0, and the PWM1\_CH0 pin is released to give other multiplexing functions.

Setting CONFIG1[RXDFE] to 01b selects the ACMP0 output to be connected to the receiver channel of UART1.

Setting CONFIG1[RXDFE] to 10b selects the ACMP1 output to be connected to the receiver channel of UART1.

The ACMP0 and ACMP1 outputs can be connected to the PWDT input (for BLDC use) or can be used as PWM2 trigger/fault input and ADC hardware trigger.

#### 15.3.2 ADC hardware trigger

ADC module may initiate a conversion via a hardware trigger. The following table shows the available ADC hardware trigger1 sources by setting CTU\_CFG1 [ADHWT1]. And be like to ADC hardware trigger1, ADC hardware trigger2 sources by setting CTU\_CFG2 [ADHWT2].

| ADHWT1 | ADC hardware trigger1                            |
|--------|--------------------------------------------------|
| 000    | RTC overflow                                     |
| 001    | PWM0 init trigger                                |
| 010    | PWM2 init trigger with 8-bit programmable delay  |
| 011    | PWM2 match trigger with 8-bit programmable delay |
| 100    | TIMER ch0 overflow                               |
| 101    | TIMER ch1 overflow                               |
| 110    | ACMP0 out                                        |
| 111    | ACMP1 out                                        |

#### Table 15-1 ADC hardware trigger1 source

When ADC hardware trigger selects the output of PWM2 triggers, an 8-bit delay block will be enabled. This logic delays any trigger from PWM2 with an 8-bit counter whose value is specified by CTU\_CFG1 [DELAY]. The reference clock to this module is the bus clock with selectable predivider specified by CTU\_CFG1 [BUSREF].

### 15.4 Register definition

#### Table 15-2 CTU register map

| ADDRESS     | TITLE   | DESCRIPTION          |
|-------------|---------|----------------------|
| CTU + 0x000 | Config1 | CTU Config1 register |
| CTU + 0x004 | Config2 | CTU Config2 register |

#### CTU: 0x40016000

AutoChips Confidential

| СТU С  | onfig             | g1 reg              | jister |       | 00   |          |     |        |    |        |       |        |    |      |    |    |
|--------|-------------------|---------------------|--------|-------|------|----------|-----|--------|----|--------|-------|--------|----|------|----|----|
| BIT    | 31                | 30                  | 29     | 28    | 27   | 26       | 25  | 24     | 23 | 22     | 21    | 2<br>0 | 19 | 18   | 17 | 16 |
| R<br>W |                   |                     |        | DELA  | AY . |          |     | DLYACT |    | ADHWT1 |       |        | В  | USRE | F  |    |
| RESET  |                   |                     |        | 0     |      | 0        | 0   |        |    | 0      |       |        |    |      |    |    |
| BIT    | 15                | 14                  | 13     | 12    | 11   | 10       | 9   | 8      | 7  | 6      | 5     | 4      | 3  | 2    | 1  | 0  |
| R<br>W | TX<br>D<br>M<br>E | PW<br>MS<br>YN<br>C | 0      | RXDCE | ACIC | RTC<br>C | RXI | DFE    | 0  |        | ACTRG |        |    | 0    |    |    |
| RESET  | 0                 | 0                   | 0      | 0     | 0    | 0 0      |     |        | 0  |        | 0     |        |    | 0    |    |    |

| Bit(s)      | Name      | Description                                                                                                                                                                                                                                                                                                                                                                        |                                |
|-------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|
|             |           | Trigger Delay                                                                                                                                                                                                                                                                                                                                                                      |                                |
| 31:24       | DELAY     | This write-once bit enables window mode. Specifies the delay fur-<br>initial or match trigger to ADC hardware trigger when 1 is written<br>ADHWT. The 8-bit modulo value allows the delay from 0 to 255<br>BUSREF clock settings. This is a one-shot counter that starts the<br>the trigger arrives and stops ticking when the counter value read<br>modulo value that is defined. | n to<br>upon the<br>cking when |
|             |           | Trigger Delay Active                                                                                                                                                                                                                                                                                                                                                               |                                |
| 23          | DLYACT    | This read-only field specifies the status if the PWM2 initial or mais active. This field is set when an PWM2 trigger arrives and the counter is ticking. Otherwise, this field will be clear.<br>0: The delay is inactive.<br>1: The delay is active.                                                                                                                              |                                |
|             |           | ADC Regular Group Hardware Trigger Source1                                                                                                                                                                                                                                                                                                                                         |                                |
|             |           | Selects the ADC hardware trigger source. All trigger sources sta<br>conversion on rising-edge.<br>000: RTC overflow as the ADC hardware trigger                                                                                                                                                                                                                                    | art ADC                        |
|             |           | 001: PWM0 as the ADC hardware trigger                                                                                                                                                                                                                                                                                                                                              |                                |
| 22:20       | ADHWT1    | 010: PWM2 init trigger with 8-bit programmable counter delay                                                                                                                                                                                                                                                                                                                       |                                |
|             |           | 011: PWM2 match trigger with 8-bit programmable counter dela                                                                                                                                                                                                                                                                                                                       | у                              |
|             |           | 100: TIMER channel0 overflow as the ADC hardware trigger                                                                                                                                                                                                                                                                                                                           |                                |
|             |           | 101: TIMER channel1 overflow as the ADC hardware trigger                                                                                                                                                                                                                                                                                                                           |                                |
|             |           | 110: ACMP0 out as the ADC hardware trigger.                                                                                                                                                                                                                                                                                                                                        |                                |
|             |           | 111: ACMP1 out as the ADC hardware trigger                                                                                                                                                                                                                                                                                                                                         |                                |
|             |           | BUS Clock Output select                                                                                                                                                                                                                                                                                                                                                            |                                |
|             |           | Enables bus clock output via an optional prescaler.                                                                                                                                                                                                                                                                                                                                |                                |
|             |           | 000: Bus                                                                                                                                                                                                                                                                                                                                                                           |                                |
| 18:16       | CLK       | 001: Bus divided by 2                                                                                                                                                                                                                                                                                                                                                              |                                |
| 10.10       | ULK       | 010: Bus divided by 4                                                                                                                                                                                                                                                                                                                                                              |                                |
|             |           | 011: Bus divided by 8                                                                                                                                                                                                                                                                                                                                                              |                                |
|             |           | 100: Bus divided by 16                                                                                                                                                                                                                                                                                                                                                             |                                |
|             |           | 101: Bus divided by 32                                                                                                                                                                                                                                                                                                                                                             |                                |
| the Chime C | Calan Cal |                                                                                                                                                                                                                                                                                                                                                                                    | 040 (0                         |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

| Bit(s) | Name    | Description                                                                                                                                                                                                  |
|--------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |         | 110: Bus divided by 64                                                                                                                                                                                       |
|        |         | 111: Bus divided by 128                                                                                                                                                                                      |
|        |         | UART1_TX Modulation Select                                                                                                                                                                                   |
| 15     |         | Enables the UART1_TX output modulated by PWM0 channel 0.                                                                                                                                                     |
| 10     | TXDME   | 0: UART1_TX output is connected to pinout directly.                                                                                                                                                          |
|        |         | <ol> <li>UART1_TX output is modulated by PWM0 channel 0 before mapped to<br/>pinout.</li> </ol>                                                                                                              |
|        |         | PWM Synchronization Select                                                                                                                                                                                   |
| 14     | PWMSYNC | Generates a PWM synchronization trigger to the PWM module if 1 is written<br>to this field. Note that when set PWMSYNC = 1 to generate a trigger<br>behavior, the PWMSYNC bit should be write to 0 manually. |
|        |         | 0: No synchronization triggered.                                                                                                                                                                             |
|        |         | 1: Generates a PWM synchronization trigger to the PWM modules.                                                                                                                                               |
| 12     |         | UART1_RX Capture Select                                                                                                                                                                                      |
|        | DVDOF   | Enables the UART1_RX to be captured by PWM0 channel 1.                                                                                                                                                       |
|        | RXDCE   | 0: UART1_RX input signal is connected to the UART0 module only.                                                                                                                                              |
|        |         | 1: UART1_RX input signal is connected to the UART0 module and PWM0 channel 1.                                                                                                                                |
|        |         | Analog Comparator to Input Capture Enable                                                                                                                                                                    |
| 11     | ACIC    | Connects the output of ACMP0 to PWM1 input channel 0.                                                                                                                                                        |
|        | 7010    | 0: ACMP0 output is not connected to PWM1 input channel 0.                                                                                                                                                    |
|        |         | 1: ACMP0 output is connected to PWM1 input channel 0.                                                                                                                                                        |
|        |         | Real-Time Counter Capture                                                                                                                                                                                    |
| 10     | RTCC    | Allows the Real-time Counter (RTC) overflow to be captured by PWM1 channel 1.                                                                                                                                |
|        |         | 0: RTC overflow is not connected to PWM1 input channel 1.                                                                                                                                                    |
|        |         | 1: RTC overflow is connected to PWM1 input channel 1.                                                                                                                                                        |
|        |         | UART1 RxD Filter Select                                                                                                                                                                                      |
| 9:8    | RXDFE   | Enables the UART1 RxD input to be filtered by ACMP. When this function is enabled, any signal tagged with ACMP inputs can be regarded UART1.<br>00: RXD input signal is connected to UART1 module directly.  |
|        |         | 01: RXD input signal is filtered by ACMP0, then injected to UART1.                                                                                                                                           |
|        |         | 10: RXD input signal is filtered by ACMP1, then injected to UART1.                                                                                                                                           |
|        |         | 11: Reserved.                                                                                                                                                                                                |
|        |         | ACMP Trigger PWM2 selection                                                                                                                                                                                  |
| 5      | ACTRG   | Selects the two ACMP outputs as the trigger0 input of PWM2.                                                                                                                                                  |
| 5      | AUING   | 0: ACMP0 out                                                                                                                                                                                                 |
|        |         | 1: ACMP1 out                                                                                                                                                                                                 |

| CTU Co | nfig2 | 2 reg | ister |    |    | OF | FSE | r ad | DR = | 12'h       | 04    |      |         |    |    |    |
|--------|-------|-------|-------|----|----|----|-----|------|------|------------|-------|------|---------|----|----|----|
| BIT    | 31    | 30    | 29    | 28 | 27 | 26 | 25  | 24   | 23   | 22         | 21    | 20   | 19      | 18 | 17 | 16 |
| R      |       |       |       |    |    |    |     |      |      | 0          |       |      |         |    |    |    |
| W      |       |       |       |    |    |    |     |      |      |            |       |      |         |    |    |    |
| RESET  | 0     | 0     | 0     | 0  | 0  | 0  | 0   | 0    | 0    | 0          | 0     | 0    | 0       | 0  | 0  | 0  |
| BIT    | 15    | 14    | 13    | 12 | 11 | 10 | 9   | 8    | 7    | 6          | 5     | 4    | 3       | 2  | 1  | 0  |
| R      |       |       |       | 0  |    |    |     | Δ    | DHW  | <b>[</b> 2 | UARTP | NDTS | ACPWDTS |    |    |    |
| W      |       |       |       |    |    |    |     |      |      | 2          | UANTI |      |         |    |    |    |
| RESET  | 0     | 0     | 0     | 0  | 0  | 0  | 0   | 0    | 1    | 0          | 0     | 0    | 0       | 0  | 0  | 0  |

| Bit(s)       | Name      | Description                                                                    |
|--------------|-----------|--------------------------------------------------------------------------------|
|              |           | ADC Injection Group Hardware Trigger Source2                                   |
|              |           | Selects the ADC hardware trigger source. All trigger sources start ADC         |
|              |           | conversion on rising-edge.                                                     |
|              |           | 000: RTC overflow as the ADC hardware trigger                                  |
|              |           | 001: PWM0 as the ADC hardware trigger                                          |
| 8:6          | ADHWT2    | 010: PWM2 init trigger with 8-bit programmable counter delay                   |
|              |           | 011: PWM2 match trigger with 8-bit programmable counter delay                  |
|              |           | 100: TIMER channel0 overflow as the ADC hardware trigger                       |
|              |           | 101: TIMER channel1 overflow as the ADC hardware trigger                       |
|              |           | 110: ACMP0 out as the ADC hardware trigger.                                    |
|              |           | 111: ACMP1 out as the ADC hardware trigger                                     |
|              |           | PWDT UART RX select                                                            |
|              |           | This field selects PWDTIN3 input signal                                        |
| <b>F</b> . 4 | UARTPWDTS | 00: UART1 RX is connected to PWDTIN3(Internal PWDT Channel).                   |
| 5:4          | UARIPWDIS | 01: UART2 RX is connected to PWDTIN3(Internal PWDT Channel).                   |
|              |           | 10: UART3 RX is connected to PWDTIN3(Internal PWDT Channel).                   |
|              |           | 11: Reserved.                                                                  |
|              |           | PWDT ACMP_OUT select                                                           |
| 0            |           | Note that if this function wants to be used, Please Set UARTPWDTS = 11 firstly |
| 3            | ACPWDTS   | This field selects PWDTIN3 input signal.                                       |
|              |           | 0: ACMP1_OUT is connected to PWDTIN3(Internal PWDT Channel).                   |
|              |           | 1: ACMP0_OUT is connected to PWDTIN3(Internal PWDT Channel).                   |

# **NutoChips**

# 16 CRC

### 16.1 Introduction

The cyclic redundancy check (CRC) module generates 16-/32-bit CRC code for error detection. The CRC module provides a programmable polynomial, WAS, and other parameters required to implement a 16-bit or 32-bit CRC standard.

The 16-/32-bit code is calculated for 32 bits of data at a time.

## 16.2 Features

- Hardware CRC generator circuit using a 16-bit or 32-bit programmable shift register.
- Programmable initial seed value and polynomial.
- Option to transpose input data or output data (the CRC result) bitwise or bytewise.
- This option is required for certain CRC standards. A bytewise transpose operation is not possible when accessing the CRC data register via 8-bit accesses. In this case, the user's software must perform the bytewise transpose function.
- Option for inversion of final CRC result.
- 32-bit CPU register programming interface.

## 16.3 Block diagram





### 16.4 Memory map and register descriptions

#### Table 16-1 CRC register map

#### CRC: 0x20081000

| ADDRESS     | TITLE    | DESCRIPTION          |
|-------------|----------|----------------------|
| CRC + 0x000 | CRC_DATA | CRC Data register    |
| CRC + 0x004 | CRC_DATA | CRC Data register    |
| CRC + 0x008 | CRC_CTRL | CRC control register |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 215 of 360

| 0x000 |                                  | <u>CRC</u> | DATA | <u> </u> | CRC | CRC Data register |  |      |       |    |     |    |    |    | 00 |  |  |  |
|-------|----------------------------------|------------|------|----------|-----|-------------------|--|------|-------|----|-----|----|----|----|----|--|--|--|
| Bit   | 31 30 29 28 27 26 25 24 23 22 21 |            |      |          |     |                   |  |      |       | 20 | 19  | 18 | 17 | 16 |    |  |  |  |
| Name  | Byte3                            |            |      |          |     |                   |  |      | Byte2 |    |     |    |    |    |    |  |  |  |
| Туре  | ŴR                               |            |      |          |     |                   |  | WR   |       |    |     |    |    |    |    |  |  |  |
| Reset | 0x00                             |            |      |          |     |                   |  |      | 0x00  |    |     |    |    |    |    |  |  |  |
| Bit   | 15 14 13 12 11 10 9 8 7          |            |      |          |     |                   |  | 6    | 5     | 4  | 3   | 2  | 1  | 0  |    |  |  |  |
| Name  | Byte1                            |            |      |          |     |                   |  |      |       | Ву | te0 |    |    |    |    |  |  |  |
| Туре  | WR WR                            |            |      |          |     |                   |  |      |       |    |     |    |    |    |    |  |  |  |
| Reset | 0x00                             |            |      |          |     |                   |  | 0x00 |       |    |     |    |    |    |    |  |  |  |

| Bit(s)  | Mnemonic | Name  | Description                                                                                                                                                                                                                                                                                                                                           |
|---------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Byte3    | Byte3 | CRC DATA Byte3                                                                                                                                                                                                                                                                                                                                        |
|         |          |       | In 16-bit CRC mode (CTRL[TCRC] is 0), this field is not used for<br>programming a seed value. In 32-bit CRC mode (CTRL[TCRC] is 1),<br>values written to this field are part of the seed value when<br>CTRL[WAS] is 1. When CTRL[WAS] is 0, data written to this field is<br>used for CRC checksum generation in both 16-bit and 32-bit CRC<br>modes. |
| [23:16] | Byte2    | Byte2 | CRC DATA Byte2                                                                                                                                                                                                                                                                                                                                        |
|         |          |       | In 16-bit CRC mode (CTRL[TCRC] is 0), this field is not used for programming a seed value. In 32-bit CRC                                                                                                                                                                                                                                              |
|         |          |       | mode (CTRL[TCRC] is 1), values written to this field are part of the seed value when CTRL[WAS] is 1.                                                                                                                                                                                                                                                  |
|         |          |       | When CTRL[WAS] is 0, data written to this field is used for CRC checksum generation in both 16-bit and 32-bit CRC modes.                                                                                                                                                                                                                              |
| [15:8]  | Byte1    | Byte1 | CRC DATA Byte1                                                                                                                                                                                                                                                                                                                                        |
|         |          |       | When CTRL[WAS] is 1, values written to this field are part of the seed value. When CTRL[WAS] is 0, data written to this field is used for CRC checksum generation.                                                                                                                                                                                    |
| [7:0]   | Byte0    | Byte0 | CRC DATA Byte0                                                                                                                                                                                                                                                                                                                                        |
|         |          |       | When CTRL[WAS] is 1, values written to this field are part of the seed value. When CTRL[WAS] is 0, data written to this field is used for CRC checksum generation.                                                                                                                                                                                    |

| 0x004 | CRC_DATA |    |    |    | CRC | Data | regist | er |    |    |    |    |    |    |    | 00 |
|-------|----------|----|----|----|-----|------|--------|----|----|----|----|----|----|----|----|----|
| Bit   | 31       | 30 | 29 | 28 | 27  | 26   | 25     | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | High     |    |    |    |     |      |        |    |    |    |    |    |    |    |    |    |
| Туре  | WR       |    |    |    |     |      |        |    |    |    |    |    |    |    |    |    |
| Reset | 0x00     |    |    |    |     |      |        |    |    |    |    |    |    |    |    |    |
| Bit   | 15       | 14 | 13 | 12 | 11  | 10   | 9      | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | Low      |    |    |    |     |      |        |    |    |    |    |    |    |    |    |    |
| Туре  | WR       |    |    |    |     |      |        |    |    |    |    |    |    |    |    |    |
| Reset | 0x00     |    |    |    |     |      |        |    |    |    |    |    |    |    |    |    |

| Bit(s) Mnemonic | Name           | Description                                                      |
|-----------------|----------------|------------------------------------------------------------------|
| 31:16 High      | High Half word | High Polynominal Half-word                                       |
|                 |                | Writable and readable in 32-bit CRC mode (CTRL[TCRC] is 1).      |
|                 |                | This field is not writable in 16-bit CRC mode (CTRL[TCRC] is 0). |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 216 of 360

| Bit(s) | Mnemonic | Name          | Description                                               |
|--------|----------|---------------|-----------------------------------------------------------|
| 15:0   | Low      | Low Half word | Low Polynominal Half-word                                 |
|        |          |               | Writable and readable in both 32-bit and 16-bit CRC modes |

| 0x008 |    | CRC | CTR | <u>L</u> |    |    | CI | RC co | ontrol register |    |    |     |    |      |     | 00   |
|-------|----|-----|-----|----------|----|----|----|-------|-----------------|----|----|-----|----|------|-----|------|
| Bit   | 31 | 30  | 29  | 28       | 27 | 26 | 25 | 24    | 23              | 22 | 21 | 20  | 19 | 18   | 17  | 16   |
| Name  |    |     |     |          |    |    |    |       |                 |    |    |     |    |      |     |      |
| Туре  |    |     |     |          |    |    |    |       |                 |    |    |     |    |      |     |      |
| Reset |    |     |     |          |    |    |    |       |                 |    |    |     |    |      |     |      |
| Bit   | 15 | 14  | 13  | 12       | 11 | 10 | 9  | 8     | 7               | 6  | 5  | 4   | 3  | 2    | 1   | 0    |
| Name  |    | -   |     |          | -  | -  | -  | -     | то              | TW | тс | DTR |    | FXOR | WAS | TCRC |
| Туре  |    |     |     |          |    |    |    |       | N               | /R | V  | /R  |    | WR   | WR  | WR   |
| Reset |    |     |     |          |    |    |    |       | (               | 0  |    | 0   |    | 0    | 0   | 0    |

| State       CRC data register. See the description of the transpose feature for the available transpose options. 00: No transposition. 01: Bits in bytes are transposed; bytes are not transposed. 11: Only bytes are transposed. 11: Only bytes are transposed. 11: Only bytes are transposed.         5:4       TOTR       Type Of Transpose For Read Identifies the transpose configuration of the value read to the CRC Data register. See the description of the value read to the CRC Data register. See the description of the value read to the CRC Data register on the value read to the transpose of the transposed; bytes are not transpose 10: Both bits in bytes are transposed. 11: Only bytes are transpose of the transpose of the transpose of the transpose of | Bit(s) Mnemonic | Name          | Description                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read       Identifies the transpose configuration of the value read in the CRC Data register. See the description of the transpose feature for the available transpose option 00: No transposition.         01: Bits in bytes are transposed; bytes are not transposed.         3       RSV         2       FXOR         Complement Read Of CRC Data Register       Some CRC protocols require the final checksum to be 2 with 0xFFFFFFF or 0xFFFF. Asserting this bit enables the fly complementing of read data.         0: No XOR on reading.       1: Invert or complement the read value of the CRC Data register.         1       WAS         Write as seed       Write CRC Data Register As Seed         When asserted, a value written to the CRC data register is taken as data for CRC computation.       0: Writes to the CRC data register are data values.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 7:6 <b>TOTW</b> |               | <ul> <li>Defines the transpose configuration of the data written to the CRC data register. See the description of the transpose feature for the available transpose options.</li> <li>00: No transposition.</li> <li>01: Bits in bytes are transposed; bytes are not transposed.</li> <li>10: Both bits in bytes and bytes are transposed.</li> <li>11: Only bytes are transposed; no bits in a byte are</li> </ul>            |
| <ul> <li>FXOR</li> <li>Complement Read Of<br/>CRC Data Register</li> <li>Some CRC protocols require the final checksum to be 2<br/>with 0xFFFFFFF or 0xFFFF. Asserting this bit enables<br/>the fly complementing of read data.</li> <li>No XOR on reading.</li> <li>Invert or complement the read value of the CRC Data<br/>register.</li> <li>WAS</li> <li>Write as seed</li> <li>Write CRC Data Register As Seed</li> <li>When asserted, a value written to the CRC data register<br/>considered a seed value. When deasserted, a<br/>value written to the CRC data register is taken as data for<br/>CRC computation.</li> <li>Writes to the CRC data register are data values.</li> <li>Writes to the CRC data register are seed values.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 5:4 <b>TOTR</b> |               | <ul> <li>Identifies the transpose configuration of the value read from<br/>the CRC Data register. See the description of<br/>the transpose feature for the available transpose options.</li> <li>00: No transposition.</li> <li>01: Bits in bytes are transposed; bytes are not transposed.</li> <li>10: Both bits in bytes and bytes are transposed.</li> <li>11: Only bytes are transposed; no bits in a byte are</li> </ul> |
| <ul> <li>CRC Data Register</li> <li>with 0xFFFFFFF or 0xFFFF. Asserting this bit enables the fly complementing of read data.</li> <li>0: No XOR on reading.</li> <li>1: Invert or complement the read value of the CRC Data register.</li> <li>WAS</li> <li>Write as seed</li> <li>Write CRC Data Register As Seed</li> <li>When asserted, a value written to the CRC data register</li> <li>considered a seed value. When deasserted, a value written to the CRC data register is taken as data for CRC computation.</li> <li>Writes to the CRC data register are data values.</li> <li>Writes to the CRC data register are seed values.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 3 <b>RSV</b>    | Reserved      |                                                                                                                                                                                                                                                                                                                                                                                                                                |
| When asserted, a value written to the CRC data register<br>considered a seed value. When deasserted, a<br>value written to the CRC data register is taken as data f<br>CRC computation.<br>0: Writes to the CRC data register are data values.<br>1: Writes to the CRC data register are seed values.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 2 FXOR          |               | <ul><li>0: No XOR on reading.</li><li>1: Invert or complement the read value of the CRC Data</li></ul>                                                                                                                                                                                                                                                                                                                         |
| 0 TCRC Type of CRC 0: 16-bit CRC protocol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1 <b>WAS</b>    | Write as seed | <ul> <li>When asserted, a value written to the CRC data register is considered a seed value. When deasserted, a value written to the CRC data register is taken as data for CRC computation.</li> <li>0: Writes to the CRC data register are data values.</li> </ul>                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0 <b>TCRC</b>   | Type of CRC   | 0: 16-bit CRC protocol.                                                                                                                                                                                                                                                                                                                                                                                                        |



| Bit(s) Mnemonic | Name | Description             |  |
|-----------------|------|-------------------------|--|
|                 |      | 1: 32-bit CRC protocol. |  |

## 16.5 Functional description

### 16.5.1 CRC initialization/reinitialization

To enable the CRC calculation, the user must program CRC\_CTRL[WAS], CRC\_GPOLY, necessary parameters for transposition and CRC result inversion in the applicable registers. Asserting CRC\_CTRL[WAS] enables the programming of the seed value into the CRC\_DATA register.

After a completed CRC calculation, reasserting CRC\_CTRL[WAS] and programming a seed, whether the value is new or a previously used seed value, reinitialize the CRC module for a new CRC computation. All other parameters must be set before programming the seed value and subsequent data values.

### 16.5.2 CRC calculations

In 16-bit and 32-bit CRC modes, data values can be programmed 8 bits, 16 bits, or 32 bits at a time, provided all bytes are contiguous. Noncontiguous bytes can lead to an incorrect CRC computation.

### 16.5.3 Transpose feature

By default, the transpose feature is not enabled. However, some CRC standards require the input data and/or the final checksum to be transposed. The user software has the option to configure each transpose operation separately, as desired by the CRC standard. The data is transposed on the fly while being read or written.

Some protocols use little endian format for the data stream to calculate a CRC. In this

case, the transpose feature usefully flips the bits. This transpose option is one of the types supported by the CRC module.

#### 16.5.4 Types of transpose

The CRC module provides several types of transpose functions to flip the bits and/or bytes, for both writing input data and reading the CRC result, separately using the CTRL[TOTW] or CTRL[TOTR] fields, according to the CRC calculation being used.

The following types of transpose functions are available for writing to and reading from the CRC data register:

1. CTRL[TOTW] or CTRL[TOTR] is 00.

No transposition occurs.

2. CTRL[TOTW] or CTRL[TOTR] is 01.

Bits in a byte are transposed, while bytes are not transposed. reg[31:0] becomes {reg[24:31], reg[16:23], reg[8:15], reg[0:7]}.



### Figure 16-2 CTRL[TOTW] / CTRL[TOTR] is 01

3. CTRL[TOTW] or CTRL[TOTR] is 10.

**NutoChips** 

Both bits in bytes and bytes are transposed.

reg[31:0] becomes = {reg[0:7], reg[8:15], reg[16:23], reg[24:31]}.



#### Figure 16-3 CTRL[TOTW] / CTRL[TOTR] is 10

4. CTRL[TOTW] or CTRL[TOTR] is 11.

Bytes are transposed, but bits are not transposed.

reg[31:0] becomes {reg[7:0], reg[15:8], reg[23:16], reg[31:24]}.



Figure 16-4 CTRL[TOTW] / CTRL[TOTR] is 11

#### NOTE:

For 8-bit and 16-bit write accesses to the CRC data register, the data is transposed with zeros on the unused byte or bytes (taking 32 bits as a whole), but the CRC is calculated on the valid byte(s) only. When reading the CRC data register for a 16-bit CRC result and using transpose options 10 and 11, the resulting value after transposition resides in the CRC[HU: HL] fields. The user software must account for this situation when reading the 16-bit CRC result, so reading 32 bits is preferred.

### 16.5.5 CRC result complement

**NutoChips** 

When CTRL[FXOR] is set, the checksum is complemented. The CRC result complement function outputs the complement of the checksum value stored in the CRC data register every time the CRC data register is read. When CTRL[FXOR] is cleared, reading the CRC data register accesses the raw checksum value.

### 16.5.6 CRC data register (CRC\_DATA)

The CRC Data register contains the value of the seed, data, and checksum. When CTRL[WAS] is set, any write to the data register is regarded as the seed value. When CTRL[WAS] is cleared, any write to the data register is regarded as data for general CRC computation.

In 16-bit CRC mode, the HU and HL fields are not used for programming the seed value, and reads of these fields return an indeterminate value. In 32-bit CRC mode, all fields are used for programming the seed value.

When programming data values, the values can be written 8 bits, 16 bits, or 32 bits at a time, provided all bytes are contiguous; with MSB of data value written first.

After all data values are written, the CRC result can be read from this data register. In 16-bit CRC mode, the CRC result is available in the LU and LL fields. In 32-bit CRC mode, all fields contain the result. Reads of this register at any time return the intermediate CRC value, provided the CRC module is configured.

### 16.5.7 CRC Polynomial register (CRC\_GPOLY)

This register contains the value of the polynomial for the CRC calculation. The HIGH field contains the upper 16 bits of the CRC polynomial, which are used only in 32-bit CRC mode. Writes to the HIGH field are ignored in 16-bit CRC mode. The LOW field contains the lower 16 bits of the CRC polynomial, which are used in both 16- and 32-bit CRC modes.

#### 16.5.8 CRC Control register (CRC\_CTRL)

This register controls the configuration and working of the CRC module. Appropriate bits must be set before starting a new CRC calculation. A new CRC calculation is initialized by asserting CTRL[WAS] and then writing the seed into the CRC data register.

## 16.6 Program guide

#### 16.6.1 16-bit CRC

To compute a 16-bit CRC:

- 1. Clear CRC\_CTRL[TCRC] to enable 16-bit CRC mode.
- 2. Program the transpose and complement options in the CTRL register as required for the CRC calculation. See 16.5.3 Transpose feature and 16.5.5 CRC result complement for details.
- 3. Write a 16-bit polynomial to the CRC\_GPOLY[LOW] field. The CRC\_GPOLY[HIGH] field is not usable in 16-bit CRC mode.
- 4. Set CRC\_CTRL[WAS] to program the seed value.
- 5. Write a 16-bit seed to CRC\_DATA[15:0]. CRC\_DATA[31:16] are not used.
- 6. Clear CRC\_CTRL[WAS] to start writing data values.

© 2013 - 2021 AutoChips Inc.

Page 220 of 360

- 7. Write data values into CRC\_DATA[31:0]. A CRC is computed on every data value write, and the intermediate CRC result is stored back into CRC\_DATA[15:0].
- 8. When all values have been written, read the final CRC result from CRC\_DATA[15:0].

### 16.6.2 32-bit CRC

**NutoChips** 

To compute a 32-bit CRC:

- 1. Set CRC\_CTRL[TCRC] to enable 32-bit CRC mode.
- 2. Program the transpose and complement options in the CTRL register as required for the CRC calculation. See 16.5.3 Transpose feature and 16.5.5 CRC result complement for details.
- 3. Write a 32-bit polynomial to CRC\_GPOLY[HIGH:LOW].
- 4. Set CRC\_CTRL[WAS] to program the seed value.
- 5. Write a 32-bit seed to CRC\_DATA[31:0].
- 6. Clear CRC\_CTRL[WAS] to start writing data values.
- 7. Write data values into CRC\_DATA[31:0]. A CRC is computed on every data value write, and the intermediate CRC result is stored back into CRC\_DATA[31:0].
- 8. When all values have been written, read the final CRC result from CRC\_DATA[31:0]. The CRC is calculated bytewise, and two clocks are required to complete one CRC calculation.

## 17 GPIO

## 17.1 Introduction

**NutoChips** 

The general-purpose input and output (GPIO) module is accessible via APB BUS and also communicates to the processor core via AHB BUS for maximum performance. The GPIO registers support APB 32-bit accesses, and AHB byte accesses.

The GPIO data direction and output data registers control the direction and output data of each pin when the pin is configured for the GPIO function. The GPIO input data register displays the logic value on each pin when the pin is configured for any digital function, provided the corresponding Port Control and Interrupt module for that pin is enabled. Efficient bit manipulation of the general-purpose outputs is supported through the addition of set, clear, and toggle write-only registers for each port output data register.

Also, The MCU I/O pins are connected to onboard peripherals/modules through a multiplexer that allows only one peripheral's alternate function (AF) connected to an I/O pin at a time. In this way, there can be no conflict between peripherals sharing the same I/O pin. Each I/O pin has a multiplexer with alternate function that can be configured through the GPIOx\_Pmux registers.

## 17.2 Features

GPIO pins support the following modes:

- Up to 68 I/Os under control.
- Output states: push-pull or open drain (be related to I2C).
- Output data from output data register (GPIOx\_ODR) or peripheral (alternate function output).
- Driving capability selection for each I/O.
- Input states: floating, pull-up/down, analog(be related to ADC PAD).
- Input data to input data register (GPIOx\_IDR) or peripheral (alternate function input).
- Bit set and reset register (GPIOx\_BSRR) for bitwise write access to GPIOx\_ODR.
- Fast toggle capable of changing every two clock cycles.
- Highly flexible pin multiplexing allows the use of I/O pins as GPIOs or as one of several peripheral functions.
- Configurable rising or falling edge interrupt.
- Low power mode wakes up interrupt.

# **//utoChips**

## 17.3 Block diagram



#### Figure 17-1 GPIO block diagram

## 17.4 Mode of operation

### 17.4.1 External interrupt



Figure 17-2 GPIO external interrupt



### 17.4.2 Multi-Function



Figure 17-3 GPIO multi-function

Each IO have multi-functions, if we want to begin a peripheral communication, we should configure GPIO multi-function first. The corresponding multi-function of each GPIO is as below.

| 80<br>LQF<br>P | 64<br>LQF<br>P | PIN Name | function 0<br>(after reset) | function 1 | function 2 | function 3 | PINMUX       | GPIO<br>(NUM) |
|----------------|----------------|----------|-----------------------------|------------|------------|------------|--------------|---------------|
| 1              | 1              | PA0      | PA0                         | SPI1_NSS   | TRACED3    | FLASH_NSS  | PMUX0[2:0]   | 0             |
| 2              | 2              | PA1      | PA1                         | SPI1_SCK   | TRACECLK   | FLASH_SCK  | PMUX0[5:3]   | 1             |
| 3              | 3              | PA2      | PA2                         | SPI1_MISO  | TRACED0    | FLASH_DQ1  | PMUX0[8:6]   | 2             |
| 4              | 4              | PA3      | PA3                         | SPI1_MOSI  | TRACED1    | FLASH_DQ0  | PMUX0[11:9]  | 3             |
| 5              | 5              | PA4      | PA4                         | UART4_TX   | CAN1_RX    | FLASH_DQ3  | PMUX0[14:12] | 4             |
| 6              | 6              | PA5      | PA5                         | UART4_RX   | CAN1_TX    | FLASH_DQ2  | PMUX0[17:15] | 5             |
| 7              |                | PD3      | PD3                         | PWM1_CH0   | HWLIN_TX   |            | PMUX5[5:3]   | 51            |
| 8              |                | PD4      | PD4                         | PWM1_CH1   | HWLIN_RX   |            | PMUX5[8:6]   | 52            |
| 9              |                | PD5      | PD5                         | FTM_EXT    | CAN1_STDBY |            | PMUX5[11:9]  | 53            |
| 10             | 7              | OSC_OUT  | OSC_OUT                     |            |            |            |              |               |
| 11             | 8              | OSC_IN   | OSC_IN                      |            |            |            |              |               |

Table 17-1 GPIO multi-function

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 225 of 360

| 80<br>LQF<br>P | 64<br>LQF<br>P | PIN Name      | function 0<br>(after reset) | function 1            | function 2     | function 3 | PINMUX       | GPIO<br>(NUM) |
|----------------|----------------|---------------|-----------------------------|-----------------------|----------------|------------|--------------|---------------|
| 12             | 9              | AVSS50        | AVSS50                      |                       |                |            |              |               |
| 13             | 10             | AVDD50        | AVDD50                      |                       |                |            |              |               |
| 14             | 11             | AVDD50_I<br>O | AVDD50_IO                   |                       |                |            |              |               |
| 15             | 12             | AVSS50_I<br>O | AVSS50_IO                   |                       |                |            |              |               |
| 16             | 13             | PA6           | PA6                         | ADC_IN10              | UART1_CTS      | UART4_TX   | PMUX0[20:18] | 6             |
| 17             |                | PD6           | PD6                         | ADC_IN12              | UART1_RTS      | UART4_RX   | PMUX5[14:12] | 54            |
| 18             | 14             | PA7           | PA7                         | ADC_IN0<br>(ACMP_IN0) | UART1_TX       | UART5_TX   | PMUX0[23:21] | 7             |
| 19             | 15             | PA8           | PA8                         | ADC_IN1<br>(ACMP_IN1) | UART1_RX       | UART5_RX   | PMUX0[26:24] | 8             |
| 20             | 16             | PA9           | PA9                         | ADC_IN2<br>(ACMP_IN2) | SPI2_NSS       | HWLIN_TX   | PMUX0[29:27] | 9             |
| 21             | 17             | PA10          | PA10                        | ADC_IN3<br>(ACMP_IN3) | SPI2_SCK       | HWLIN_RX   | PMUX1[2:0]   | 10            |
| 22             | 18             | PA11          | PA11                        | ADC_IN4<br>(ACMP_IN4) | SPI2_MISO      | UART3_RX   | PMUX1[5:3]   | 11            |
| 23             | 19             | PA12          | PA12                        | ADC_IN5               | SPI2_MOSI      | UART3_TX   | PMUX1[8:6]   | 12            |
| 24             | 20             | PA13          | PA13                        | ADC_IN6               | I2C1_SCL       | UART6_RX   | PMUX1[11:9]  | 13            |
| 25             | 21             | PA14          | PA14                        | ADC_IN7               | I2C1_SDA       | UART6_TX   | PMUX1[14:12] | 14            |
| 26             | 22             | PA15          | PA15                        | ADC_IN8               | UART2_RTS      |            | PMUX1[17:15] | 15            |
| 27             | 23             | PB0           | PB0                         | ADC_IN9               | UART2_TX       | CAN2_STDBY | PMUX1[20:18] | 16            |
| 28             | 24             | PB1           | PB1                         | ADC_IN11              | UART2_RX       |            | PMUX1[23:21] | 17            |
| 29             |                | PD7           | PD7                         | ADC_IN13              | PWDT_EXT       | PWM3_CH0   | PMUX5[17:15] | 55            |
| 30             |                | PD8           | PD8                         | ADC_IN14              | CAN2_TX        | PWM3_CH1   | PMUX5[20:18] | 56            |
| 31             |                | PD9           | PD9                         | ADC_IN15              | CAN2_RX        | PWDT_IN0   | PMUX5[23:21] | 57            |
| 32             | 25             | PB2           | PB2                         | NMI_B                 | UART3_TX       | CAN1_STDBY | PMUX1[26:24] | 18            |
| 33             | 26             | NRST          | NRST                        |                       |                |            |              |               |
| 34             | 27             | PB3           | PB3                         | PWDT_IN1              | UART3_RX       |            | PMUX1[29:27] | 19            |
| 35             | 28             | PB4           | PB4                         | PWDT_IN2              | TRACED2        |            | PMUX2[2:0]   | 20            |
| 36             | 29             | PB5           | PB5                         | UART1_TX              | PWDT_IN1       |            | PMUX2[5:3]   | 21            |
| 37             | 30             | PB6           | PB6                         | UART1_RX              | PWDT_IN2       | PWM3_CH0   | PMUX2[8:6]   | 22            |
| 38             | 31             | PB7           | PB7                         | UART1_RTS             | PWM_FAULT<br>1 |            | PMUX2[11:9]  | 23            |
| 39             |                | PD10          | PD10                        | PWM_FAULT<br>1        | I2C2_SCL       |            | PMUX5[26:24] | 58            |
| 40             | 32             | PB8           | PB8                         | PWDT_IN0              | I2C2_SDA       |            | PMUX2[14:12] | 24            |
| 41             | 33             | PB9           | PB9                         | PWM0_CH0              | PWM2_CH0       | CAN1_RX    | PMUX2[17:15] | 25            |
| 42             | 34             | DVSS50_<br>1  | DVSS50_1                    |                       |                |            |              |               |
| 43             | 35             | DVDD50_<br>1  | DVDD50_1                    |                       |                |            |              |               |
| 44             | 36             | VPP           | VPP                         |                       |                |            |              |               |
| 45             | 37             | PB10          | PB10                        | PWM0_CH1              | PWM2_CH1       | CAN1_TX    | PMUX2[20:18] | 26            |
| 46             | 38             | PB11          | PB11                        | SPI2_NSS              | PWM2_CH2       |            | PMUX2[23:21] | 27            |

AutoChips Confidential

 $\ensuremath{\textcircled{}}$  2013 - 2021 AutoChips Inc.

Page 226 of 360

## AC781x Reference Manual General

# **//utoChips**

| 80<br>LQF<br>P | 64<br>LQF<br>P | PIN Name     | function 0<br>(after reset) | function 1        | function 2     | function 3 | PINMUX       | GPIO<br>(NUM) |
|----------------|----------------|--------------|-----------------------------|-------------------|----------------|------------|--------------|---------------|
| 47             | 39             | PB12         | PB12                        | SPI2_SCK          | PWM2_CH3       |            | PMUX2[26:24] | 28            |
| 48             | 40             | PB13         | PB13                        | SPI2_MISO         | PWM2_CH4       | UART5_TX   | PMUX2[29:27] | 29            |
| 49             | 41             | PB14         | PB14                        | SPI2_MOSI         | PWM2_CH5       | UART5_RX   | PMUX3[2:0]   | 30            |
| 50             |                | PD11         | PD11                        | UART5_TX          | UART3_RTS      |            | PMUX5[29:27] | 59            |
| 51             |                | PD12         | PD12                        | UART5_RX          | UART4_RTS      |            | PMUX6[2:0]   | 60            |
| 52             |                | PD13         | PD13                        | PWM2_CH4          | UART5_RTS      |            | PMUX6[5:3]   | 61            |
| 53             |                | PD14         | PD14                        | PWM2_CH5          | UART6_RTS      |            | PMUX6[8:6]   | 62            |
| 54             | 42             | PB15         | PB15                        | PWM2_CH0          | PWM0_EXT       |            | PMUX3[5:3]   | 31            |
| 55             | 43             | PC0          | PC0                         | PWM2_CH1          | PWM1_EXT       |            | PMUX3[8:6]   | 32            |
| 56             | 44             | PC1          | PC1                         | PWM2_CH2          | UART5_RTS      |            | PMUX3[11:9]  | 33            |
| 57             | 45             | PC2          | PC2                         | PWM2_CH3          | UART6_RTS      |            | PMUX3[14:12] | 34            |
| 58             | 46             | PC3          | PC3                         | UARTTX_<br>SFLASH | PWM2_CH4       | PWM2_CH0   | PMUX3[17:15] | 35            |
| 59             | 47             | PC4          | PC4                         | UARTRX_<br>SFLASH | PWM2_CH5       | PWM2_CH1   | PMUX3[20:18] | 36            |
| 60             | 48             | PC5          | PC5                         | I2C2_SCL          | UART1_CTS      |            | PMUX3[23:21] | 37            |
| 61             | 49             | PC6          | PC6                         | I2C2_SDA          | UART1_CTS      |            | PMUX3[26:24] | 38            |
| 62             | 50             | PC7          | PC7                         | JTCK_SWCLK        | UART3_RTS      |            | PMUX3[29:27] | 39            |
| 63             | 51             | PC8          | PC8                         | JTDO_<br>TRACESWO | UART2_RTS      |            | PMUX4[2:0]   | 40            |
| 64             | 52             | PC9          | PC9                         | JTMS_SWDIO        | UART4_RTS      | PWM_FAULT1 | PMUX4[5:3]   | 41            |
| 65             | 53             | PC10         | PC10                        | CAN2_TX           | UART6_TX       | PWM_FAULT2 | PMUX4[8:6]   | 42            |
| 66             | 54             | PC11         | PC11                        | CAN2_RX           | UART6_RX       | PWDT_IN0   | PMUX4[11:9]  | 43            |
| 67             |                | PD15         | PD15                        | JTDI              | CAN1_STDBY     | PWDT_IN1   | PMUX6[11:9]  | 63            |
| 68             | 55             | BOOT         | BOOT                        |                   |                |            |              |               |
| 69             | 56             | PC12         | PC12                        | I2C1_SCL          | UART5_TX       |            | PMUX4[14:12] | 44            |
| 70             | 57             | PC13         | PC13                        | I2C1_SDA          | UART5_RX       |            | PMUX4[17:15] | 45            |
| 71             | 58             | DVSS50_<br>2 | DVSS50_2                    |                   |                |            |              |               |
| 72             | 59             | DVDD50_<br>2 | DVDD50_2                    |                   |                |            |              |               |
| 73             |                | PE0          | PE0                         | NJTRST            | CAN2_STDBY     | PWDT_IN2   | PMUX6[14:12] | 64            |
| 74             | 60             | PC14         | PC14                        | CAN1_RX           | UART4_RX       | PWDT_IN3   | PMUX4[20:18] | 46            |
| 75             | 61             | PC15         | PC15                        | CAN1_TX           | UART4_TX       |            | PMUX4[23:21] | 47            |
| 76             |                | PE1          | PE1                         | HWLIN_TX          | PWM1_CH0       |            | PMUX6[17:15] | 65            |
| 77             |                | PE2          | PE2                         | HWLIN_RX          | PWM1_CH1       |            | PMUX6[20:18] | 66            |
| 78             | 62             | PD0          | PD0                         | UART1_CTS         | PWM_FAULT<br>2 |            | PMUX4[26:24] | 48            |
| 79             | 63             | PD1          | PD1                         | UART2_TX          | PWM0_CH0       | I2C2_SCL   | PMUX4[29:27] | 49            |
| 80             | 64             | PD2          | PD2                         | UART2_RX          | PWM0_CH1       | I2C2_SDA   | PMUX5[2:0]   | 50            |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 227 of 360

Note:

- 1. All the pins are default as gpio on the first time power on except some dedicated pins.
- 2、 GPIO Control NUM is the only way to change gpio status.like set input/output,pull up/down.it's differ from PIN NUM(Importance).
- 3. Eg: if we want to config PIN1 as SPI1\_NSS, we should set PMUX0[2:0]=1.
- 4. VPP pin is used for test and it must be floating.

## 17.5 Application note

**NutoChips** 

#### 17.5.1 External interrupt

The external interrupt/event controller consists of up to 16 edge detectors for generating event/interrupt requests. Each input line can be independently configured to select the type (event or interrupt) and the corresponding trigger event (rising edge, falling edge or both). Each line can also be masked independently. A pending register maintains the status line of the interrupt requests.

#### 17.5.2 Multi-Function

To optimize the functionality in a small package, the pins provide multiple available functions through signal multiplexing. the PINMUX register controls the signals on the external pins. For details, please refer to GPIOx\_PINMUX and section 17.4.2.

#### 17.5.3 GPIO function

During and just after reset, the GPIO functions are active and the I/O ports are configured in input mode, except RST and Arm debug interface. User can program PINMUX Register to change I/O ports from other function to GPIO function.

When the pin is configured as output, the value written to the output data register (GPIOx\_ODR) is output on the I/O pin. It is possible to use the output driver in push-pull mode or open-drain mode (only the N-MOS is activated when 0 is output). The input data register (GPIOx\_IDR) captures the data present on the I/O pin at every AHB clock cycle.

All GPIO pins have weak internal pull-up and pull-down resistors, which can be activated or not depending on the value in the GPIOx\_PU and GPIOx\_PD register.

#### 17.5.4 **Programming guide**

Firstly, after reset, all I/O ports are in GPIO input mode, except RST and Arm debug interface.

Secondly, software can program PINMUX to map/remap I/O function.

The software can program external interrupts for I/O as GPIO functions. When MCU in low power mode, external interrupt uses internal LPOSC with 32 kHz.



## 17.6 Memory map and register descriptions

#### Table 17-2 GPIO register map

#### GPIO: 0x40001000

| ADDRESS       | TITLE        | DESCRIPTION                              |
|---------------|--------------|------------------------------------------|
| GPIO + OFFSET | GPIOx_CR     | Port configuration                       |
| GPIO + OFFSET | GPIOx_IDR    | Port input data                          |
| GPIO + OFFSET | GPIOx_ODR    | Port output data                         |
| GPIO + OFFSET | GPIOx_BSRR   | Port set/reset                           |
| GPIO + OFFSET | GPIOx_BRR    | Port reset                               |
| GPIO + OFFSET | GPIOx_PD     | Pull-down enable                         |
| GPIO + OFFSET | GPIOx_PU     | Pull-up enable                           |
| GPIO + OFFSET | GPIOx_E4_E2  | Driving Capability selection             |
| GPIO + OFFSET | GPIOx_PINMUX | Multi-function selection                 |
| GPIO + OFFSET | GPIOx_PR     | External interrupt flag Pending          |
| GPIO + OFFSET | GPIOx_IMR    | Interrupt mask on line                   |
| GPIO + OFFSET | GPIOx_RTSR   | Rising edge trigger event configuration  |
| GPIO + OFFSET | GPIOx_FTSR   | Falling edge trigger event configuration |
| GPIO + OFFSET | GPIOx_EXTICR | external interrupt                       |

#### GPIOx\_CR register(x=0...4)

#### OFFSET ADDR = (12'h00, 12'h30, 12'h60, 12'h90, 12'hc0)

| BI<br>T | 31   | 30   | 29   | 28   | 27   | 26   | 25   | 24    | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|---------|------|------|------|------|------|------|------|-------|------|------|------|------|------|------|------|------|
| R       |      |      |      |      |      |      |      | Reser | ved  |      |      |      |      |      |      |      |
| W       |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| d       |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| ef      |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| а       |      |      |      |      |      |      |      | 0     |      |      |      |      |      |      |      |      |
| ul      |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| t       |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| BI      | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8     | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| Т       | 10   | ••   | 10   |      |      | 10   | Ũ    | •     | •    | Ũ    | Ŭ    | •    | Ũ    | -    |      | Ũ    |
|         | mod   | mod  | mod  | mod  | mod  | mod  | mod  | mod  | mod  |
| R       | e(16  | e(16 | e(16 | e(16 | e(16 | e(16 | e(16 | e(16 | e(16 |
|         | *x+1 | *x+1 | *x+1 | *x+1 | *x+1 | *x+1 | *x+9 | *x+8  | *x+7 | *x+6 | *x+5 | *x+4 | *x+3 | *x+2 | *x+1 | *x+0 |
|         | 5)   | 4)   | 3)   | 2)   | 1)   | 0)   | )    | )     | )    | )    | )    | )    | )    | )    | )    | )    |

| Bit(s)  | Name     | Description                                                             |
|---------|----------|-------------------------------------------------------------------------|
| [31:16] | Reserved | No use                                                                  |
|         |          | Mode(y): Port y configuration bits                                      |
| [15:0]  | Mode     | These bits are written by software to configure the I/O direction mode. |
| [15:0]  | Mode     | 0: Input (reset state)                                                  |
|         |          | 1: output mode                                                          |

© 2013 - 2021 AutoChips Inc.

# **NutoChips**

| GPI                 | Ox_ID                | R regi               | ister(x              | =04)                 | )                    | OFFS                 | SET AI              | DDR =               | : (12'h             | 04, 12              | 'h34,               | 12'h64              | 4, 12'ł             | <b>194</b> , 12     | 2'hc4)              |                     |
|---------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|
| BI<br>T             | 31                   | 30                   | 29                   | 28                   | 27                   | 26                   | 25                  | 24                  | 23                  | 22                  | 21                  | 20                  | 19                  | 18                  | 17                  | 16                  |
| R<br>W              |                      |                      |                      |                      |                      |                      |                     | Reser               | ved                 |                     |                     |                     |                     |                     |                     |                     |
| de<br>fa<br>ul<br>t |                      |                      |                      |                      |                      |                      |                     | 0                   |                     |                     |                     |                     |                     |                     |                     |                     |
| BI<br>T             | 15                   | 14                   | 13                   | 12                   | 11                   | 10                   | 9                   | 8                   | 7                   | 6                   | 5                   | 4                   | 3                   | 2                   | 1                   | 0                   |
| R                   | IDR(<br>16*x<br>+15) | IDR(<br>16*x<br>+14) | IDR(<br>16*x<br>+13) | IDR(<br>16*x<br>+12) | IDR(<br>16*x<br>+11) | IDR(<br>16*x<br>+10) | IDR<br>(16*<br>x+9) | IDR<br>(16*<br>x+8) | IDR<br>(16*<br>x+7) | IDR<br>(16*<br>x+6) | IDR<br>(16*<br>x+5) | IDR<br>(16*<br>x+4) | IDR<br>(16*<br>x+3) | IDR<br>(16*<br>x+2) | IDR<br>(16*<br>x+1) | IDR<br>(16*<br>x+0) |
| W                   |                      |                      |                      |                      |                      |                      |                     |                     |                     |                     |                     |                     |                     |                     |                     |                     |
| de                  |                      |                      |                      |                      |                      |                      |                     |                     |                     |                     |                     |                     |                     |                     |                     |                     |
| fa                  |                      |                      |                      |                      |                      |                      |                     | 0                   |                     |                     |                     |                     |                     |                     |                     |                     |
| ul<br>t             |                      |                      |                      |                      |                      |                      |                     |                     |                     |                     |                     |                     |                     |                     |                     |                     |

| SPIOx_IDR register(x=04) | OFFSET ADDR = (12'h04, 12'h34, 12'h64, 12'h94, 12'hc4) |
|--------------------------|--------------------------------------------------------|
|--------------------------|--------------------------------------------------------|

| Bit(s) | Name | Description                                                                                                                  |
|--------|------|------------------------------------------------------------------------------------------------------------------------------|
| [15:0] | IDR  | <b>IDR(y):</b> Port y input data<br>These bits are read-only. They contain the input value of the corresponding<br>I/O port. |

#### GPIOx\_ODR register(x=0...4) OFFSET ADDR = (12'h08, 12'h38, 12'h68, 12'h98, 12'hc8)

| BI<br>T | 31   | 30   | 29   | 28   | 27   | 26   | 25   | 24    | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|---------|------|------|------|------|------|------|------|-------|------|------|------|------|------|------|------|------|
| R       |      |      |      |      |      |      | 1    | Reser | ved  | 1    | 1    | 1    |      |      |      |      |
| w       |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| d       |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| ef      |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| a       |      |      |      |      |      |      |      | 0     |      |      |      |      |      |      |      |      |
| ul      |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| t       |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| BI<br>T | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8     | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| R       | OD    | OD   | OD   | OD   | OD   | OD   | OD   | OD   | OD   |
|         | R(16 | R(16 | R(16 | R(16 | R(16 | R(16 | R(1  | R(1   | R(1  | R(1  | R(1  | R(1  | R(1  | R(1  | R(1  | R(1  |
| w       | *x+1 | *x+1 | *x+1 | *x+1 | *x+1 | *x+1 | 6*x+ | 6*x+  | 6*x+ | 6*x+ | 6*x+ | 6*x+ | 6*x+ | 6*x+ | 6*x+ | 6*x+ |
|         | 5)   | 4)   | 3)   | 2)   | 1)   | 0)   | 9)   | 8)    | 7)   | 6)   | 5)   | 4)   | 3)   | 2)   | 1)   | 0)   |
| d       |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| ef      |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| а       |      |      |      |      |      |      |      | 0     |      |      |      |      |      |      |      |      |
| ul      |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| t       |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

| Bit(s) | Name | Description                                                                                                                                                                      |
|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |      | ODR(y): Port(y) output data                                                                                                                                                      |
|        |      | These bits can be read and written by software.                                                                                                                                  |
| [15:0] | ODR  | <b>Note:</b> For PIN set/reset, the ODR bits can be individually set and reset by writing to the GPIOx_BSRR register ( $x = A,B,C,D$ ) and GPIOx_BRR register ( $x = A,B,C,D$ ). |

#### GPIOx\_BSRR register(x=0...4) OFFSET ADDR = (12'h0c, 12'h3c, 12'h6c, 12'h9c, 12'hcc)

| BI<br>T         | 31                      | 30                  | 29                  | 28                  | 27                  | 26                  | 25                 | 24                 | 23                 | 22                 | 21                 | 20                 | 19                 | 18                 | 17                 | 16                 |
|-----------------|-------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|
| R<br>W          | BR<br>(16<br>*x+<br>15) | BR(<br>16*x<br>+14) | BR(<br>16*x<br>+13) | BR(<br>16*x<br>+12) | BR(<br>16*x<br>+11) | BR(<br>16*x<br>+10) | BR(<br>16*x<br>+9) | BR(<br>16*x<br>+8) | BR(<br>16*x<br>+7) | BR(<br>16*x<br>+6) | BR(<br>16*x<br>+5) | BR(<br>16*x<br>+4) | BR(<br>16*x<br>+3) | BR(<br>16*x<br>+2) | BR(<br>16*x<br>+1) | BR(<br>16*x<br>+0) |
| de<br>fa<br>ult |                         |                     |                     |                     |                     |                     |                    | 0                  |                    |                    |                    |                    |                    |                    |                    |                    |
| BI<br>T         | 15                      | 14                  | 13                  | 12                  | 11                  | 10                  | 9                  | 8                  | 7                  | 6                  | 5                  | 4                  | 3                  | 2                  | 1                  | 0                  |
| R<br>W          | BS<br>(16<br>*x+<br>15) | BS(1<br>6*x+<br>14) | BS(1<br>6*x+<br>13) | BS(1<br>6*x+<br>12) | BS(1<br>6*x+<br>11) | BS(1<br>6*x+<br>10) | BS(<br>16*x<br>+9) | BS(<br>16*x<br>+8) | BS(<br>16*x<br>+7) | BS(<br>16*x<br>+6) | BS(<br>16*x<br>+5) | BS(<br>16*x<br>+4) | BS(<br>16*x<br>+3) | BS(<br>16*x<br>+2) | BS(<br>16*x<br>+1) | BS(<br>16*x<br>+0) |
| de<br>fa<br>ult |                         |                     |                     |                     |                     |                     |                    | 0                  |                    |                    |                    |                    |                    |                    |                    |                    |

| Bit(s)  | Name | Description                                                              |
|---------|------|--------------------------------------------------------------------------|
|         |      | BR(y): Port(y) Reset bit y                                               |
| [31:16] | BR   | These bits are write-only. A read to these bits returns the value 0x0000 |
|         | BR   | 0: No action on the corresponding ODRy bit                               |
|         |      | 1: Reset the corresponding ODRy bit                                      |
|         |      | BS(y): Port(y) set bit y                                                 |
|         |      | These bits are write-only and can be accessed in word, half-word or byte |
| [15:0]  | BS   | mode. A read to these bits returns the value 0x0000.                     |
| [15.0]  | 55   | 0: No action on the corresponding ODRy bit                               |
|         |      | 1: Sets the corresponding ODRy bit                                       |
|         |      | <b>Note :</b> if BS and BR both configured, BR has higher priority.      |

AutoChips Confidential

## **//utoChips**

|         | _          |      | g    | •    | ,    |      |      | ,     | ,    |      | •, •= |      |      | ,    | ,    |      |
|---------|------------|------|------|------|------|------|------|-------|------|------|-------|------|------|------|------|------|
| BI<br>T | 31         | 30   | 29   | 28   | 27   | 26   | 25   | 24    | 23   | 22   | 21    | 20   | 19   | 18   | 17   | 16   |
| R       |            |      |      |      |      |      |      | Rese  | rved |      |       |      |      |      |      |      |
| W       |            |      |      |      |      |      |      | 11000 | vou  |      |       |      |      |      |      |      |
| de      |            |      |      |      |      |      |      |       |      |      |       |      |      |      |      |      |
| fa      |            |      |      |      |      |      |      | 0     |      |      |       |      |      |      |      |      |
| ult     |            |      |      |      |      |      |      |       |      |      |       |      |      |      |      |      |
| BI      | 15         | 14   | 13   | 12   | 11   | 10   | 9    | 8     | 7    | 6    | 5     | 4    | 3    | 2    | 1    | 0    |
| Т       |            |      |      |      |      |      | •    | •     | •    | Ũ    | •     | •    | •    | -    | •    | Ũ    |
| R       |            |      |      |      |      |      |      | 0     |      |      |       |      |      |      |      |      |
|         | BR         | BR(   | BR(  | BR(  | BR(   | BR(  | BR(  | BR(  | BR(  | BR(  |
| w       | (16        | 16*x  | 16*x | 16*x | 16*x  | 16*x | 16*x | 16*x | 16*x | 16*x |
|         | *x+<br>15) | +14) | +13) | +12) | +11) | +10) | +9)  | +8)   | +7)  | +6)  | +5)   | +4)  | +3)  | +2)  | +1)  | +0)  |
| de      | 15)        |      |      |      |      |      |      |       |      |      |       |      |      |      |      |      |
| fa      |            |      |      |      |      |      |      | 0     |      |      |       |      |      |      |      |      |
| ult     |            |      |      |      |      |      |      | 0     |      |      |       |      |      |      |      |      |
| uit     |            |      |      |      |      |      |      |       |      |      |       |      |      |      |      |      |

#### GPIOx\_BRR register(x=0...4) OFFSET ADDR = (12'h10, 12'h40, 12'h70, 12'ha0, 12'hd0)

| Bit(s) | Name | Description                                                              |
|--------|------|--------------------------------------------------------------------------|
|        |      | BR(y): Port(y) Reset bit y                                               |
| [45:0] | BR   | These bits are write-only. A read to these bits returns the value 0x0000 |
| [15:0] | DK   | 0: No action on the corresponding ODRy bit                               |
|        |      | 1: Reset the corresponding ODRy bit                                      |

#### GPIOx\_PD register(x=0...4) OFFSET ADDR = (12'h18, 12'h48, 12'h78, 12'ha8, 12'hd8)

| BI  | 31           | 30           | 29           | 28   | 27           | 26           | 25          | 24          | 23          | 22          | 21          | 20          | 19          | 18          | 17          | 16   |
|-----|--------------|--------------|--------------|------|--------------|--------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|------|
| Т   | 51           | 5            | ZJ           | 20   | 21           | 20           | 23          | 24          | 23          | ~~~         | 21          | 20          | 13          | 10          | 17          | 10   |
| R   |              |              |              |      |              |              |             | Reser       | ved         |             |             |             |             |             |             |      |
| W   |              |              |              |      |              |              |             | Reser       | veu         |             |             |             |             |             |             |      |
| de  |              |              |              |      |              |              |             |             |             |             |             |             |             |             |             |      |
| fa  |              |              |              |      |              |              |             | 0           |             |             |             |             |             |             |             |      |
| ult |              |              |              |      |              |              |             |             |             | 1           |             |             |             |             |             |      |
| BI  | 15           | 14           | 13           | 12   | 11           | 10           | 9           | 8           | 7           | 6           | 5           | 4           | 3           | 2           | 1           | 0    |
| Т   |              |              |              |      |              |              |             |             |             |             |             |             |             |             |             |      |
| R   | PD(          | PD(          | PD(          | PD(  | PD(          | PD(          | PD(         | PD(         | PD(         | PD(         | PD(         | PD(         | PD(         | PD(         | PD(         | PD(  |
| w   | 16*x<br>+15) | 16*x<br>+14) | 16*x<br>+13) | 16*x | 16*x<br>+11) | 16*x<br>+10) | 16*x<br>+9) | 16*x<br>+8) | 16*x<br>+7) | 16*x<br>+6) | 16*x<br>+5) | 16*x<br>+4) | 16*x<br>+3) | 16*x<br>+2) | 16*x<br>+1) | 16*x |
| de  | +10)         | +14)         | +13)         | +12) | +11)         | +10)         | +9)         | +0)         | +7)         | +0)         | +3)         | +4)         | +3)         | +2)         | +1)         | +0)  |
| fa  |              |              |              |      |              |              |             |             |             |             |             |             |             |             |             |      |
|     |              |              |              |      |              |              |             |             |             |             |             |             |             |             |             |      |
| ult |              |              |              |      |              |              |             |             |             |             |             |             |             |             |             |      |

| Bit(s) | Name | Description                                         |
|--------|------|-----------------------------------------------------|
| [0]    |      | PD (y): Pull-down enable                            |
| [1]    | PD   | 0: disable pull-down                                |
| [2]    |      | 1: enable pull-down (typical value: 75 K $\Omega$ ) |

© 2013 - 2021 AutoChips Inc.

Page 232 of 360

| Bit(s) | Name | Description                                                           |
|--------|------|-----------------------------------------------------------------------|
|        |      | These bits can be read and written by software.                       |
|        |      | Note: Pull-up and Pull-down are not supported enable at the same time |

#### GPIOx\_PU register(x=0...4) OFFSET ADDR = (12'h1c, 12'h4c, 12'h7c, 12'hac, 12'hdc)

| BI<br>T | 31   | 30   | 29   | 28   | 27   | 26   | 25   | 24    | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|---------|------|------|------|------|------|------|------|-------|------|------|------|------|------|------|------|------|
| R       |      |      |      |      |      |      |      | Reser | ved  |      |      |      |      |      |      |      |
| w       |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| de      |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| fa      |      |      |      |      |      |      |      | 0     |      |      |      |      |      |      |      |      |
| ult     |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| BI      | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8     | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| Т       | 10   | 17   | 10   | 12   |      | 10   | 5    | 0     | '    | U    | 5    | r    | ,    | 2    | -    | U    |
| R       | PU(   | PU(  | PU(  | PU(  | PU(  | PU(  | PU(  | PU(  | PU(  |
| w       | 16*x  | 16*x | 16*x | 16*x | 16*x | 16*x | 16*x | 16*x | 16*x |
|         | +15) | +14) | +13) | +12) | +11) | +10) | +9)  | +8)   | +7)  | +6)  | +5)  | +4)  | +3)  | +2)  | +1)  | +0)  |
| de      |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |
| fa      |      |      |      |      |      |      |      | 0     |      |      |      |      |      |      |      |      |
| ult     |      |      |      |      |      |      |      |       |      |      |      |      |      |      |      |      |

| Bit(s) | Name | Description                                                                                                              |
|--------|------|--------------------------------------------------------------------------------------------------------------------------|
| [0]    |      | PU (y): Pull-up enable                                                                                                   |
| [1]    | PU   | 0: disable pull-up<br>1: enable pull-up (typical value: 75 KΩ)                                                           |
| [2]    |      | These bits can be read and written by software.<br>Note: Pull-up and Pull-down are not supported enable at the same time |

#### GPIOx\_E4\_E2 register(x=0...4) OFFSET ADDR = (12'h20, 12'h50, 12'h80, 12'hb0, 12'he0)

| BIT     | 31                                                                     | 30    | 29    | 28    | 27    | 26    | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18   | 17    | 16   |
|---------|------------------------------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|------|-------|------|
| R       | E4_E2 E4_E2                                                            |       |       |       | E4_E2 | 2     | E4_E2 | E4_E2 |       | E4_E2 |       | 2     | E4_E2 |      | E4_E2 |      |
| w       | (16*×                                                                  | (+15) | (16*× | (+14) | (16*> | (+13) | (16*× | (+12) | (16*> | (+11) | (16*> | (+10) | (16*  | x+9) | (16*  | x+8) |
| default |                                                                        |       |       |       |       |       |       | 0     |       |       |       |       |       |      |       |      |
| BIT     | 15                                                                     | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2    | 1     | 0    |
| R       | E4_E2                                                                  | 2     | E4_ E | 2     | E4_E  | 2    | E4_E  | 2    |
| w       | (16*x+7) (16*x+6) (16*x+5) (16*x+4) (16*x+3) (16*x+2) (16*x+1) (16x+4) |       |       |       |       |       |       |       | x+0)  |       |       |       |       |      |       |      |
| default |                                                                        | 0     |       |       |       |       |       |       |       |       |       |       |       |      |       |      |

| Bit(s) | Name  | Description                                     |
|--------|-------|-------------------------------------------------|
| [1:0]  |       | E4_E2 (y): Driving Capability selection         |
| [3:2]  | E4 E2 | These bits can be read and written by software. |
| [5:4]  | C4_C2 | 00: 4mA                                         |
|        |       | 01: 8mA                                         |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

### AC781x Reference Manual General

| Bit(s) | Name | Description |
|--------|------|-------------|
|        |      | 10: 12mA    |
|        |      | 11: 16mA    |

### GPIOx\_PINMUX register(x=0...6)

#### OFFSET ADDR = (12'h140, 12'h144, 12'h148, 12'h14C, 12'h150, 12'h154, 12'h158)

| BIT          | 31   | 30   | 29              | 28             | 27  | 26             | 25    | 24            | 23           | 22    | 21              | 20 | 19               | 18           | 17              | 16 |  |
|--------------|------|------|-----------------|----------------|-----|----------------|-------|---------------|--------------|-------|-----------------|----|------------------|--------------|-----------------|----|--|
| R            | Rese | rved | PINM            | PINMUXx[29:27] |     | PINMUXx[26:24] |       | PINMUXx[23:21 |              | 3:21] | 21] PINMUXx[20  |    | 20:18] PINMUXx[1 |              | (x[17:15]       |    |  |
| W<br>default | (    | )    | 0               |                |     | 0              |       |               | 0            |       |                 | 0  |                  |              | 0               |    |  |
| BIT          | 15   | 14   | 13              | 13 12 11       |     | 10             | 9     | 8             | 7            | 6     | 5               | 4  | 3                | 2            | 1               | 0  |  |
| R            |      | PIN  | MUXx[14:12] PIN |                | PIN | MUXx[′         | 11:9] | PIN           | IMUXx[       | 8:61  | PINMUXx[5:3]    |    |                  | PINMUXx[2:0] |                 |    |  |
| W            |      |      |                 |                |     |                |       |               | 1110/04[0:0] |       | 1 11110704[0:0] |    |                  |              | 1 11110/04[2:0] |    |  |
| default      |      | 0    |                 |                | 0   |                |       | 0             |              |       | 0               |    |                  | 0            |                 |    |  |

| Bit(s) | Name    | Description                                                             |
|--------|---------|-------------------------------------------------------------------------|
|        |         | PINMUXx (y): Multi-function selection                                   |
|        |         | These bits are written by software to configure alternate function I/Os |
|        |         | 000: function 0                                                         |
| [2:0]  |         | 001: function 1                                                         |
| [5:3]  |         | 010: function 2                                                         |
| [8:6]  | PINMUXx | 011: function 3                                                         |
|        |         | 100: function 4                                                         |
|        |         | 101: function 5                                                         |
|        |         | 110: function 6                                                         |
|        |         | 111: function 7                                                         |

| GPIO | x_PR r | egiste | er(x=0) |     | OFI  | FSET / | ADDR | = (12    | 'h160 | )   |     |     |     |     |     | _   |
|------|--------|--------|---------|-----|------|--------|------|----------|-------|-----|-----|-----|-----|-----|-----|-----|
| BIT  | 31     | 30     | 29      | 28  | 27   | 26     | 25   | 24       | 23    | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
| R    |        |        |         |     |      |        |      | Reserve  | ad    |     |     |     |     |     |     |     |
| w    |        |        |         |     |      |        |      | 11636110 | su    |     |     |     |     |     |     |     |
| defa |        |        |         |     |      |        |      | 0        |       |     |     |     |     |     |     |     |
| ult  |        |        |         |     |      |        |      | 0        |       |     |     |     |     |     |     |     |
| BIT  | 15     | 14     | 13      | 12  | 11   | 10     | 9    | 8        | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| R    | PR(    | PR(    | PR(     | PR( | PR(1 | PR(    | PR(  | PR(      | PR(   | PR( | PR( | PR( | PR( | PR( | PR( | PR( |
|      | 15)    | 14)    | 13)     | 12) | 1)   | 10)    | 9)   | 8)       | 7)    | 6)  | 5)  | 4)  | 3)  | 2)  | 1)  | 0)  |
| w    | W1C    | W1C    | W1C     | W1C | W1   | W1C    | W1   | W1       | W1    | W1  | W1  | W1  | W1  | W1  | W1  | W1  |
| ••   | wie    | wie    | wie     | WIG | С    | WIG    | С    | С        | С     | С   | С   | С   | С   | С   | С   | С   |
| defa | 0      | 0      | 0       | 0   | 0    | 0      | 0    | 0        | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| ult  | 0      | 0      | 0       | 0   | 0    | 0      | 0    | 0        | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

AutoChips Confidential

# **//utoChips**

| Bit(s)       | Name | Description                                                                                                                           |
|--------------|------|---------------------------------------------------------------------------------------------------------------------------------------|
| [0]          |      | PR (y): External interrupt flag Pending bit                                                                                           |
| [1]          |      | 0: No trigger request occurred                                                                                                        |
| [2]          | PR   | 1: The selected trigger request occurred                                                                                              |
| [ <b>2</b> ] |      | This bit is set when the selected edge event arrives on the external interrupt line. This bit is cleared by writing a '1' to the bit. |

#### GPIOx\_IMR register(x=0)

#### OFFSET ADDR = (12'h164)

| BIT  | 31   | 30   | 29   | 28   | 27   | 26   | 25  | 24     | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|------|------|------|------|------|------|-----|--------|-----|-----|-----|-----|-----|-----|-----|-----|
| R    |      |      |      |      |      |      |     | Reserv | ed  |     |     |     |     |     |     |     |
| W    |      |      |      |      |      |      |     | Reserv | cu  |     |     |     |     |     |     |     |
| def  |      |      |      |      |      |      |     | 0      |     |     |     |     |     |     |     |     |
| ault |      |      |      |      |      |      |     | -      |     |     |     |     |     |     |     |     |
| BIT  | 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8      | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| R    | IMR( | IMR( | IMR( | IMR( | IMR( | IMR( | IMR | IMR    | IMR | IMR | IMR | IMR | IMR | IMR | IMR | IMR |
| w    | 15)  | 14)  | 13)  | 12)  | 11)  | 10)  | (9) | (8)    | (7) | (6) | (5) | (4) | (3) | (2) | (1) | (0) |
| def  | 0    | 0    | 0    | 0    | 0    | 0    | 0   | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| ault | Ĵ    | ,    | ,    | Ĵ    | Ĵ    | ,    | ,   | ,      | ,   | 5   | ,   | ,   | ,   | ,   | Ĵ   | 5   |

| Bit(s) | Name  | Description                                    |
|--------|-------|------------------------------------------------|
| [0]    |       | IMR (y): Interrupt mask on line y              |
| [1]    | IMR   | 0: Interrupt request from Line y is masked     |
| [2]    | IIVIR | 1: Interrupt request from Line y is not masked |
|        |       |                                                |

#### GPIOx\_RTSR register(x=0)

#### OFFSET ADDR = (12'h168)

|     |      |      |      | ,    |      |      |     |        | •   | ,   |     |     |     |     |     |     |
|-----|------|------|------|------|------|------|-----|--------|-----|-----|-----|-----|-----|-----|-----|-----|
| BIT | 31   | 30   | 29   | 28   | 27   | 26   | 25  | 24     | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
| R   |      |      |      |      |      |      |     | Reserv | (od |     |     |     |     |     |     |     |
| W   |      |      |      |      |      |      |     | Reserv | /eu |     |     |     |     |     |     |     |
| def |      |      |      |      |      |      |     |        |     |     |     |     |     |     |     |     |
| aul |      |      |      |      |      |      |     | 0      |     |     |     |     |     |     |     |     |
| t   |      |      |      |      |      |      |     |        |     |     |     |     |     |     |     |     |
| BIT | 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8      | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| R   | RTS  | RTS  | RTS  | RTS  | RTS  | RTS  | RT  | RT     | RT  | RT  | RT  | RT  | RT  | RT  | RT  | RT  |
| w   | R(15 | R(14 | R(13 | R(12 | R(11 | R(10 | SR( | SR(    | SR( | SR( | SR( | SR( | SR( | SR( | SR( | SR( |
| vv  | )    | )    | )    | )    | )    | )    | 9)  | 8)     | 7)  | 6)  | 5)  | 4)  | 3)  | 2)  | 1)  | 0)  |
| def |      |      |      |      |      |      |     |        |     |     |     |     |     |     |     |     |
| aul | 0    | 0    | 0    | 0    | 0    | 0    | 0   | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| t   |      |      |      |      |      |      |     |        |     |     |     |     |     |     |     |     |

| Bit(s) | Name | Description                                                                |
|--------|------|----------------------------------------------------------------------------|
| [0]    |      | RTSR (y): Rising edge trigger event configuration bit of line y            |
| [1]    | RTSR | 0: Rising edge trigger disabled (for Event and Interrupt) for input line y |
| [2]    | RIGR | 1: Rising edge trigger enabled (for Event and Interrupt) for input line y  |
|        |      |                                                                            |

#### GPIOx\_FTSR register(x=0)

#### OFFSET ADDR = (12'h16C)

| BIT | 31        | 30        | 29        | 28        | 27        | 26        | 25   | 24     | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|-----|-----------|-----------|-----------|-----------|-----------|-----------|------|--------|------|------|------|------|------|------|------|------|
| R   |           |           |           |           |           |           |      | Reserv | /ed  |      |      |      |      |      |      |      |
| W   |           |           |           |           |           |           |      | Reserv | /04  |      |      |      |      |      |      |      |
| def |           |           |           |           |           |           |      |        |      |      |      |      |      |      |      |      |
| aul |           |           |           |           |           |           |      | 0      |      |      |      |      |      |      |      |      |
| t   |           |           |           |           |           |           |      |        |      | 1    |      |      | 1    |      |      |      |
| BIT | 15        | 14        | 13        | 12        | 11        | 10        | 9    | 8      | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| R   | FTS       | FTS       | FTS       | FTS       | FTS       | FTS       | FTS  | FTS    | FTS  | FTS  | FTS  | FTS  | FTS  | FTS  | FTS  | FTS  |
| w   | R(15<br>) | R(14<br>) | R(13<br>) | R(12<br>) | R(11<br>) | R(10<br>) | R(9) | R(8)   | R(7) | R(6) | R(5) | R(4) | R(3) | R(2) | R(1) | R(0) |
| def |           |           |           |           |           |           |      |        |      |      |      |      |      |      |      |      |
| aul | 0         | 0         | 0         | 0         | 0         | 0         | 0    | 0      | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| t   |           |           |           |           |           |           |      |        |      |      |      |      |      |      |      |      |

| Bit(s) | Name | Description                                                                 |
|--------|------|-----------------------------------------------------------------------------|
| [0]    |      | FTSR (y): Falling edge trigger event configuration bit of line y            |
| [1]    | FTSR | 0: Falling edge trigger disabled (for Event and Interrupt) for input line y |
| [2]    |      | 1: Falling edge trigger enabled (for Event and Interrupt) for input line y  |
|        |      |                                                                             |

#### GPIOx\_EXTICR register(x=0...3) OFFSET ADDR = (12'h170, 12'h174, 12'h178, 12'h17C)

| BIT     | 31       | 30     | 29     | 28 | 27 | 26     | 25     | 24 | 23 | 22     | 21     | 20 | 19 | 18     | 17     | 16 |
|---------|----------|--------|--------|----|----|--------|--------|----|----|--------|--------|----|----|--------|--------|----|
| R       | Reserved |        |        |    |    |        |        | _  |    | _      |        |    |    |        |        |    |
| W       |          |        |        |    |    |        |        |    |    |        |        |    |    |        |        |    |
| default | 0        |        |        |    |    |        |        |    |    |        |        |    |    |        |        |    |
| BIT     | 15       | 14     | 13     | 12 | 11 | 10     | 9      | 8  | 7  | 6      | 5      | 4  | 3  | 2      | 1      | 0  |
| R       |          | EXTI(4 | 4*x+3) |    |    | EXTI(4 | 4*x+2) |    |    | EXTI(4 | 4*x+1) |    |    | EXTI(4 | 4*x+0) |    |
| W       |          |        |        |    |    |        |        |    |    |        |        |    |    |        |        |    |
| default | 0        |        |        | (  | )  |        |        | (  | )  |        |        | (  | )  |        |        |    |

| Bit(s) | Name | Description                                                                   |  |  |  |  |  |
|--------|------|-------------------------------------------------------------------------------|--|--|--|--|--|
|        |      | EXTI (y): EXTI y configuration                                                |  |  |  |  |  |
|        |      | These bits are written by software to select the source input for the EXTI(y) |  |  |  |  |  |
| [3:0]  |      | external interrupt.                                                           |  |  |  |  |  |
| [7:4]  | EXTI | 0000: PA[x] pin                                                               |  |  |  |  |  |
| [11:8] |      | 0001: PB[x] pin                                                               |  |  |  |  |  |
|        |      | 0010: PC[x] pin                                                               |  |  |  |  |  |
|        |      | 0011: PD[x] pin                                                               |  |  |  |  |  |
|        |      | 0100: PE[x] pin                                                               |  |  |  |  |  |

## AC781x Reference Manual General

## 18 I2C

## **18.1 Introduction**

**NutoChips** 

I2C(Inter-IC) is a two-wire serial interface. The two signals are SCL and SDA. SCL is a clock signal that is driven by the master. SDA is bi-directional data signal that can be driven by either the master or the slave. This generic interface supports the master and slave role both, and conforms to the I2C specification.

## 18.2 Features

- Support master and slave mode operation.
- Support I2C standard mode 100 kHz and fast mode 400 kHz.
- Master switch to slave mode automatically while arbitration lost.
- Master programmable transmit bit rate.
- Slave address identification interrupt.
- Slave 10-bit address extension.
- Slave support low power mode wakeup.
- Slave support monitor function.
- Programmable input glitch filter.
- Support SCL stretch.
- Software-controlled acknowledge bit.
- Interrupt-driven byte-by-byte data transfer.
- Bus START/STOP detection.
- Support TX and RX DMA operation.

## 18.3 Block diagram



#### Figure 18-1 I2C block diagram

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 238 of 360

## **18.4 Mode of operation**

I2C module supports wakeup function which can wake up MCU from STOP mode. When I2C is configured as slave mode, user can enable wakeup function by set WUEN bit of CONTROL\_1 register.

When the MCU is entered STOP mode, I2C slave is waiting for an address match. If a master sends a match-address to I2C slave, then MCU will be waked up from STOP mode after receiving all match address.

## 18.5 Memory map and register descriptions

| Table | 18-1 | I2C | register | map |
|-------|------|-----|----------|-----|
|-------|------|-----|----------|-----|

| Address     | Name       | Width | Description                               |  |  |  |
|-------------|------------|-------|-------------------------------------------|--|--|--|
| Address     | Name       | width | Description                               |  |  |  |
| I2Cx +0x000 | ADDR_1     | 8     | Address register 1                        |  |  |  |
| I2Cx +0x004 | ADDR_2     | 8     | Address register 2                        |  |  |  |
| l2Cx +0x008 | SAMPLE_CNT | 8     | Baud rate config register 1               |  |  |  |
| I2Cx +0x00c | STEP_CNT   | 8     | Baud rate config register 2               |  |  |  |
| l2Cx +0x010 | CONTROL_1  | 8     | Control register 1                        |  |  |  |
| l2Cx +0x014 | CONTROL_2  | 8     | Control register 2                        |  |  |  |
| l2Cx +0x018 | CONTROL_3  | 8     | Control register 3                        |  |  |  |
| l2Cx +0x01c | CONTROL_4  | 8     | Control register 4                        |  |  |  |
| I2Cx +0x020 | STATUS_1   | 8     | Status register 1                         |  |  |  |
| I2Cx +0x024 | STATUS_2   | 8     | Status register 2                         |  |  |  |
| I2Cx +0x028 | DGL_CFG    | 8     | Deglitch config register                  |  |  |  |
| I2Cx +0x02c | DATA       | 9     | Data port register                        |  |  |  |
| I2Cx +0x030 | START_STOP | 8     | Master START STOP signal control register |  |  |  |

## I2C1 Base address: 0x4000e000

I2C2 Base address: 0x4000f000

#### I2Cx+0x000 ADDR1 Address Register 1

| Bit   | 31:8 | 7 | 6       | 5 | 4 | 3 | 2 | 1 | 0 |  |
|-------|------|---|---------|---|---|---|---|---|---|--|
| Name  |      |   | AD[7:1] |   |   |   |   |   |   |  |
| Туре  |      |   | R/W     |   |   |   |   |   |   |  |
| Reset |      | 1 | 1       | 1 | 1 | 1 | 1 | 1 |   |  |

| Bit  | Mnemonic | Name          | Description                                                  |
|------|----------|---------------|--------------------------------------------------------------|
| 31:8 |          |               |                                                              |
| 7:1  | AD[7:1]  | Slave Address | Specifies the address when I2Cx is slave mode                |
|      |          |               | for the 7-bit address scheme and the lower seven bits in the |
|      |          |               | 10-bit address scheme.                                       |
| 0    |          |               |                                                              |

AutoChips Confidential



|  | I2Cx+0x004 | ADDR 2 | Address Register 2 |
|--|------------|--------|--------------------|
|--|------------|--------|--------------------|

| Bit   | 31:8 | 7 | 6 | 5 | 4 | 3 | 2        | 1 | 0 |
|-------|------|---|---|---|---|---|----------|---|---|
| Name  |      |   |   |   |   |   | AD[10:8] |   |   |
| Туре  |      |   |   |   |   |   | R/W      |   |   |
| Reset |      |   |   |   |   |   | 1        | 1 | 1 |

| Bit  | Mnemonic | Name          | Description                                                     |
|------|----------|---------------|-----------------------------------------------------------------|
| 31:8 |          |               |                                                                 |
| 7:3  |          |               |                                                                 |
| 2:0  | AD[10:8] | Slave Address | Specifies the address when I2Cx is slave mode                   |
|      |          | Extend        | Contains the upper threes bits of the address in the 10-bit     |
|      |          |               | address scheme. This field is valid only while the ADEXT bit is |
|      |          |               | set.                                                            |

| I2Cx+0x | 008 SAI | MPLE_CN | LE_CNT Baud Rate Config Register 1 |   |   |   |   |   |   |  |  |
|---------|---------|---------|------------------------------------|---|---|---|---|---|---|--|--|
| Bit     | 31:8    | 7       | 7 6 5 4 3 2 1 0                    |   |   |   |   |   |   |  |  |
| Name    |         |         | SAMPLE_CNT_DIV                     |   |   |   |   |   |   |  |  |
| Туре    |         |         | R/W                                |   |   |   |   |   |   |  |  |
| Reset   |         | 0       | 0                                  | 0 | 0 | 0 | 1 | 0 | 0 |  |  |

| Bit  | Mnemonic | Name       | Description                                          |
|------|----------|------------|------------------------------------------------------|
| 31:8 |          |            |                                                      |
| 7:0  | SAMPLE_  | SAMPLE_CNT | This adjusts the width of each sample.               |
| 7.0  | CNT_DIV  | _DIV       | <pre>sample width = (sample_cnt_div +1) *Tbclk</pre> |

I2Cx+0x00c STEP\_CNT Baud Rate Config Register 2

| Bit   | 31:8 | 7 | 6 | 5 | 4      | 3      | 2 | 1 | 0 |
|-------|------|---|---|---|--------|--------|---|---|---|
| Name  |      |   |   |   | STEP_C | NT_DIV |   |   |   |
| Туре  |      |   |   |   | R/     | W      |   |   |   |
| Reset |      | 0 | 0 | 0 | 0      | 0      | 1 | 0 | 0 |

| Bit  | Mnemonic | Name     | Description                                                 |
|------|----------|----------|-------------------------------------------------------------|
| 31:8 |          |          |                                                             |
| 7:0  | STEP_CNT | STEP_CNT | Specifies the number of samples per half pulse width, i.e.  |
|      | _DIV     | _DIV     | each high or low pulse                                      |
|      |          |          | half_baudrate width= ( <i>step_cnt_div</i> +1)*sample width |
|      |          |          | Note: minimum of STEP_CNT_DIV is 3 propose!                 |

| l2Cx+0x | 010 CO | NTROL_1 | Co    | ontrol Reg | gister 1 |      |      |   |   |
|---------|--------|---------|-------|------------|----------|------|------|---|---|
| Bit     | 31:8   | 7       | 6     | 5          | 4        | 3    | 2    | 1 | 0 |
| Name    |        | I2CEN   | I2CIE | MSTR       | ΤХ       | TACK | WUEN |   |   |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 240 of 360

| Туре  | R/W | R/W | R/W | R/W | R/W | R/W |  |
|-------|-----|-----|-----|-----|-----|-----|--|
| Reset | 0   | 0   | 0   | 0   | 0   | 0   |  |

| Bit  | Mnemonic | Name      | Description                                                                                   |
|------|----------|-----------|-----------------------------------------------------------------------------------------------|
| 31:8 |          |           |                                                                                               |
| 7    | I2CEN    | I2C_EN    | I2C module enable                                                                             |
|      |          |           | 1: enable                                                                                     |
|      |          |           | 0: disable                                                                                    |
| 6    | I2CIE    | I2C_IE    | I2C interrupt enable                                                                          |
|      |          |           | 1: enable the IIC module interrupt                                                            |
|      |          |           | 0: disable                                                                                    |
| 5    | MSTR     | MSTR      | I2C operation mode select                                                                     |
|      |          |           | 1: master                                                                                     |
|      |          |           | 0: slave                                                                                      |
|      |          |           | Note: if ARB_LOST is set, this bit auto clear.                                                |
| 4    | ТХ       | TX        | Transmission direction select                                                                 |
|      |          |           | 1: transmit(TX)                                                                               |
|      |          |           | 0: receive(RX)                                                                                |
|      |          |           | Selects the direction of master. In master mode this bit must be                              |
|      |          |           | set according to the type of transmission required. Therefore,                                |
|      |          |           | for master address cycles, this bit is always set.                                            |
| 3    | TACK     | TACK      | Acknowledge control                                                                           |
|      |          |           | Specifies the value driven onto the SDA during data                                           |
|      |          |           | acknowledge cycles for both master and slave receivers.                                       |
|      |          |           | 1: NACK will sent to the bus on the following(next) receiving                                 |
|      |          |           | byte                                                                                          |
|      |          |           | 0: ACK will sent to the bus on the following(next) receiving byte                             |
|      |          |           | Note: slave address byte ACK bit is hardware response auto,                                   |
|      |          |           | software not care this field. ACK is send if slave address match.<br>Otherwise, NACK is sent. |
| 2    | WUEN     | WAKEUP_EN | Wakeup function enable                                                                        |
|      |          |           | The I2C slave mode can wake the MCU from low power mode                                       |
|      |          |           | which no peripheral bus running when slave address matching                                   |
|      |          |           | occurs.                                                                                       |
|      |          |           | 1: enable the wakeup function in low power mode.                                              |
|      |          |           | 0: disable the wakeup function.                                                               |
|      |          |           | Note:when a 7bit address, 2 byte of 10bit address(if ADEXT=1),                                |
|      |          |           | or general call address(GCAEN=1) match occurs when I2C                                        |
|      |          |           | module is in slave mode, the I2C module will generates a                                      |
|      |          |           | request to wake up MCU from low power mode.                                                   |
| 1    |          |           |                                                                                               |
| 0    |          |           |                                                                                               |



| I2Cx+0x014 | CONTROL_2 | Control Register 2 |
|------------|-----------|--------------------|
|------------|-----------|--------------------|

| Bit   | 31:8 | 7     | 6     | 5 | 4      | 3     | 2 | 1 | 0     |
|-------|------|-------|-------|---|--------|-------|---|---|-------|
| Name  |      | GCAEN | ADEXT |   | SYNCEN | ARBEN |   |   | STREN |
| Туре  |      | R/W   | R/W   |   | R/W    | R/W   |   |   | R/W   |
| Reset |      | 0     | 0     |   | 0      | 0     |   |   | 0     |

| Bit  | Mnemonic | Name    | Description                                                                    |
|------|----------|---------|--------------------------------------------------------------------------------|
| 31:8 |          |         |                                                                                |
| 7    | GCAEN    | GCA_EN  | Slave General Call Enable                                                      |
|      |          |         | 1: enable                                                                      |
|      |          |         | 0: disable                                                                     |
| 6    | ADEXT    | ADEXT   | Slave Address Extension                                                        |
|      |          |         | 1: 10-bit address scheme                                                       |
|      |          |         | 0: 7-bit address scheme                                                        |
| 5    |          |         |                                                                                |
| 4    | SYNCEN   | SYNC_EN | Master SCL Sync Enable                                                         |
|      |          |         | enable the SCL synchronization function of master                              |
|      |          |         | 1: enable                                                                      |
|      |          |         | 0: disable                                                                     |
| 3    | ARBEN    | ARB_EN  | Master Arbitration Enable                                                      |
|      |          |         | enable the master's arbitration function.                                      |
|      |          |         | 1: enable                                                                      |
|      |          |         | 0: disable                                                                     |
|      |          |         | Note: if I2C used in multi-master system, multi-master function                |
|      |          |         | must set both SYNC_EN and ARB_EN.                                              |
|      |          |         | Note: if I2C used in single master system, and slave have SCL                  |
|      |          |         | stretch function, then can set SYNC_EN only.                                   |
| 2    |          |         |                                                                                |
| 1    |          |         |                                                                                |
| 0    | STREN    | STR_EN  | Slave SCL stretch enable                                                       |
|      |          |         | enable this bit, slave hardware will stretch SCL low after 9 <sup>th</sup> SCL |
|      |          |         | falling per byte.                                                              |
|      |          |         | 1: enable                                                                      |
|      |          |         | 0: disable                                                                     |
|      |          |         | <b>Note:</b> after SAMF=1, if SRW=1, RXFF=1 will cause SCL                     |
|      |          |         | stretch; otherwise SRW=0, TXEF=1 will cause SCL stretch; so                    |
|      |          |         | when enable STR_EN and slave is transmitter(TX), after 9 <sup>th</sup>         |
|      |          |         | SCL falling per byte (include address byte) slave will stretch                 |
|      |          |         | SCL, until write DATA register; similarly, when slave is                       |
|      |          |         | receiver(RX), after 9 <sup>th</sup> SCL falling per byte(without address       |
|      |          |         | byte), slave will stretch SCL, until read DATA register.                       |
|      |          |         | Note: In slave mode, when enable GCA_EN or MNTEN, slave                        |
|      |          |         | can not stretch SCL.                                                           |

© 2013 - 2021 AutoChips Inc.



| I2Cx+0x018 | CONTROL_3 | Control Register 3 |
|------------|-----------|--------------------|
|------------|-----------|--------------------|

| Bit   | 31:8 | 7          | 6          | 5         | 4          | 3 | 2 | 1          | 0         |
|-------|------|------------|------------|-----------|------------|---|---|------------|-----------|
| Name  |      | RXOF<br>IE | TXUF<br>IE | RXF<br>IE | TXEM<br>IE |   |   | NACK<br>IE | MNT<br>EN |
| Туре  |      | R/W        | R/W        | R/W       | R/W        |   |   | R/W        | R/W       |
| Reset |      | 0          | 0          | 0         | 0          |   |   | 0          | 0         |

| Bit  | Mnemonic | Name        | Description                                          |
|------|----------|-------------|------------------------------------------------------|
| 31:8 |          |             |                                                      |
| 7    | RXOFIE   | SLA_RXOF_IE | Slave RX Buffer Overflow Error Interrupt Enable      |
|      |          |             | 1: enable                                            |
|      |          |             | 0: disable                                           |
| 6    | TXUFIE   | SLA_TXUF_IE | Slave TX Buffer Underflow Error Interrupt Enable     |
|      |          |             | 1: enable                                            |
|      |          |             | 0: disable                                           |
| 5    | RXFIE    | SLA_RXF_IE  | Slave RX Buffer Full Interrupt Enable                |
|      |          |             | 1: enable                                            |
|      |          |             | 0: disable                                           |
| 4    | TXEIE    | SLA_TXE_IE  | Slave TX Buffer Empty Interrupt Enable               |
|      |          |             | 1: enable                                            |
|      |          |             | 0: disable                                           |
| 3    |          |             |                                                      |
| 2    |          |             |                                                      |
| 1    | NACKIE   | NACK_IE     | NACK Get Interrupt Enable                            |
|      |          |             | 1: enable                                            |
|      |          |             | 0: disable                                           |
|      |          |             | Note: do not enable this bit when I2C is slave mode. |
| 0    | MNTEN    | SLA_MNT_EN  | Slave Monitor Function Enable                        |
|      |          |             | 1: enable                                            |
|      |          |             | 0: disable                                           |

| l2Cx+0x | 01c COI | NTROL_4 | Со | ntrol Reg | jister 4 |   |   |             |             |
|---------|---------|---------|----|-----------|----------|---|---|-------------|-------------|
| Bit     | 31:8    | 7       | 6  | 5         | 4        | 3 | 2 | 1           | 0           |
| Name    |         |         |    |           |          |   |   | DMA<br>RXEN | DMA<br>TXEN |
| Туре    |         |         |    |           |          |   |   | R/W         | R/W         |
| Reset   |         |         |    |           |          |   |   | 0           | 0           |

| Bit  | Mnemonic | Name      | Description   |                 |
|------|----------|-----------|---------------|-----------------|
| 31:8 |          |           |               |                 |
| 7    |          |           |               |                 |
| 6:2  |          |           |               |                 |
| 1    | DMARXEN  | DMA_RX_EN | DMA RX Enable |                 |
|      |          |           | 1: enable     |                 |
|      |          |           | 0: disable    |                 |
| 0    | DMATXEN  | DMA_TX_EN | DMA TX Enable |                 |
|      |          |           |               | <b>D</b> 040 (4 |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit | Mnemonic | Name | Description |
|-----|----------|------|-------------|
|     |          |      | 1: enable   |
| _   |          |      | 0: disable  |

| I2Cx+0x020 STA |      | TUS_1 Status Register 1 |      |      |             |       |     |   |      |
|----------------|------|-------------------------|------|------|-------------|-------|-----|---|------|
| Bit            | 31:8 | 7                       | 6    | 5    | 4           | 3     | 2   | 1 | 0    |
| Name           |      | BND                     | SAMF | BUSY | ARB<br>LOST | READY | SRW |   | RACK |
| Туре           |      | R/W                     | R/W  | R    | R/W         | R     | R   |   | R/W  |
| Reset          |      | 0                       | 0    | 0    | 0           | 1     | 0   |   | 0    |

| Bit  | Mnemonic | Name     | Description                                                                     |
|------|----------|----------|---------------------------------------------------------------------------------|
| 31:8 |          |          |                                                                                 |
| 7    | BND      | Byte End | Byte End Flag                                                                   |
|      |          |          | 1: one byte transfer finish(include ACK bit, total 9 SCL)                       |
|      |          |          | 0: transfer in progress, one byte transfer not finish                           |
|      |          |          | After reset, BND is '0'. BND is set only during data transmission               |
|      |          |          | period which between START and STOP signal on the bus.                          |
|      |          |          | BND will set after per 9th SCL falling edge.                                    |
|      |          |          | When I2C is RX, read DATA register will clear this bit.                         |
|      |          |          | Otherwise, when I2C is TX, write DATA register will clear this                  |
|      |          |          | bit.                                                                            |
|      |          |          | Note: when I2C is slave and MNTEN=1, when TCF is '1', then                      |
|      |          |          | read DATA register will clear this bit.                                         |
|      |          |          | <i>Note:</i> write '1' can clear this bit too.                                  |
| 6    | SAMF     | SAMF     | Slave Address Match Flag                                                        |
|      |          |          | 1: address match                                                                |
|      |          |          | 0: address not match                                                            |
|      |          |          | Note: this bit set by one of the following conditions.                          |
|      |          |          | a. 7bit address, address match                                                  |
|      |          |          | b. 10bit address, both 1 <sup>st</sup> byte and 2 <sup>nd</sup> byte match. And |
|      |          |          | set after 2 <sup>nd</sup> byte match.                                           |
|      |          |          | c. general call match                                                           |
|      |          |          | Note: write '1' clear this bit.                                                 |
| 5    | BUSY     | BUSY     | Bus Busy                                                                        |
|      |          |          | Indicates the status of the bus, and valid for both slave and                   |
|      |          |          | master mode. This bit is set when a START signal is detected                    |
|      |          |          | and cleared when a STOP signal is detected on the bus by                        |
|      |          |          | hardware.                                                                       |
|      |          |          | 1: bus is busy.                                                                 |
|      |          |          | 0: bus is idle.                                                                 |
| 4    | ARBLOST  | ARBLOST  | Arbitration Lost Flag                                                           |
|      |          |          | 1: arbitration lost                                                             |
|      |          |          | 0: not lost                                                                     |
|      |          |          | Note: write '1' clear.                                                          |
|      |          |          | Note: when arbitration lost , I2C master will switch to slave                   |
|      |          |          | mode, and MSTR is cleared by hardware.                                          |
|      |          | READY    | Internal Hardware Core Is Ready For New Command                                 |

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

|   |      |      | This bit indicates the internal hardware states, and only valid for                                                                                                                     |
|---|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |      |      | master mode.                                                                                                                                                                            |
|   |      |      | 1: internal hardware is ready for software's new command                                                                                                                                |
|   |      |      | 0: internal hardware is not ready                                                                                                                                                       |
|   |      |      | <b>Note:</b> this bit is valid for master, and maybe used when master generate a START/STOP signal. When I2C module is master mode, write START_STOP[0] will generate a START signal on |
|   |      |      | the bus, then DGL_CFG[4] is set, and this case must wait                                                                                                                                |
|   |      |      | READY bit is 1,software can write DATA register to send address byte.                                                                                                                   |
|   |      |      | Note: similar with START signal, write START_STOP[1] will                                                                                                                               |
|   |      |      | generate a STOP signal on the bus, then DGL_CFG[6] is set.                                                                                                                              |
|   |      |      | This case must wait READY bit is 1, software can write                                                                                                                                  |
|   |      |      | START_STOP[0] , initial a next transmission.                                                                                                                                            |
| 2 | SRW  | SRW  | Slave Read/Write Direction                                                                                                                                                              |
|   |      |      | 1: slave is transmitter(TX), master read from slave                                                                                                                                     |
|   |      |      | 0: slave is receiver(RX), master write to slave                                                                                                                                         |
| 1 |      |      |                                                                                                                                                                                         |
| 0 | RACK | RACK | Acknowledge Received                                                                                                                                                                    |
|   |      |      | This field valid for transmitter(TX)                                                                                                                                                    |
|   |      |      | 1: No acknowledge signal detected                                                                                                                                                       |
|   |      |      | 0: Acknowledge signal was received after one byte of data                                                                                                                               |
|   |      |      | Note: if NACKIE=1, RACK=1 will set interrupt, write 1 clear.                                                                                                                            |

4 STATUS\_2

Status Register 2

| Bit   | 31:8 | 7    | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|-------|------|------|---|---|---|------|------|------|------|
| Name  |      | IDLE |   |   |   | RXOF | TXUF | RXFF | TXEF |
| Туре  |      | R    |   |   |   | R/W  | R/W  | R/W  | R/W  |
| Reset |      | 1    |   |   |   | 0    | 0    | 0    | 1    |

| Bit   | Mnemonic           | Name | Description                                   |                   |
|-------|--------------------|------|-----------------------------------------------|-------------------|
| 31:8  |                    |      |                                               |                   |
| 7     | IDLE               | IDLE | I2C core hardware state                       |                   |
|       |                    |      | 1: idle                                       |                   |
|       |                    |      | 0: not idle                                   |                   |
| 3     | RXOF               | RXOF | Slave RX Buffer Overflow Flag                 |                   |
|       |                    |      | 1: RX buffer overflow                         |                   |
|       |                    |      | 0: Not overflow                               |                   |
|       |                    |      | Note: when RX buffer overflow, new received   | data not store to |
|       |                    |      | RX buffer.                                    |                   |
|       |                    |      | Note: write '1' clear.                        |                   |
| 2     | TXUF               | TXUF | Slave TX Buffer Underflow Flag                |                   |
|       |                    |      | 1: TX buffer underflow                        |                   |
|       |                    |      | 0: No underflow                               |                   |
|       |                    |      | Note: when TX buffer underflow, send the last | DATA again.       |
|       |                    |      | Note: write '1' clear.                        |                   |
| 1     | RXFF               | RXFF | Slave RX Buffer Full Flag                     |                   |
|       |                    |      | 1: RX buffer full                             |                   |
| AutoC | Chips Confidential |      | © 2013 - 2021 AutoChips Inc.                  | Page 245 of 360   |

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.



|   |      |      | 0: Not full                                    |  |
|---|------|------|------------------------------------------------|--|
|   |      |      | Note: read DATA register will clear this bit.  |  |
| 0 | TXEF | TXEF | Slave TX Buffer Empty Flag                     |  |
|   |      |      | 1: TX buffer empty                             |  |
|   |      |      | 0: Not empty                                   |  |
|   |      |      | Note: write DATA register will clear this bit. |  |

#### I2C+0x028 DGL\_CFG Deglitch Config Register

| Bit   | 31:8 | 7     | 6     | 5    | 4      | 3       | 2 | 1 | 0 |
|-------|------|-------|-------|------|--------|---------|---|---|---|
| Name  |      | DGLEN | STOPF | SSIE | STARTF | DGL_CNT |   |   |   |
| Туре  |      | R/W   | R     | R/W  | R      | R/W     |   |   |   |
| Reset |      | 0     | 0     | 0    | 0      | 0       | 0 | 0 | 0 |

| Bit  | Mnemonic | Name      | Description                                                        |
|------|----------|-----------|--------------------------------------------------------------------|
| 31:8 |          |           |                                                                    |
| 7    | DGLEN    | DGL_EN    | Deglitch Filter Enable                                             |
|      |          |           | 1: enable                                                          |
|      |          |           | 0: disable                                                         |
| 6    | STOPF    | STOP FLAG | Bus STOP Flag                                                      |
|      |          |           | hardware set this bit when the STOP signal is detected on the      |
|      |          |           | I2C bus.                                                           |
|      |          |           | 1: STOP detected on I2C bus                                        |
|      |          |           | 0: No STOP detected on I2C bus                                     |
|      |          |           | Note: write "1" clear this bit.                                    |
| 5    | SSIE     | SSIE      | Bus STOP or START Interrupt Enable                                 |
|      |          |           | 1: enable STRAT or STOP detection interrupt                        |
|      |          |           | 0: disable                                                         |
|      |          |           | Note: clear bus START or STOP interrupt: In the interrupt          |
|      |          |           | service routine, write '1 ' clear STARTF or STOPF flag , then      |
|      |          |           | interrupt clear auto.                                              |
| 4    | STARTF   | STARTF    | Bus START Flag                                                     |
|      |          |           | 1: START detected on I2C bus                                       |
|      |          |           | 0: No START detected                                               |
|      |          |           | Note: write '1' clear.                                             |
| 3:0  | DGL_CNT  | DGL_CNT   | Deglitch Counter                                                   |
|      |          |           | control the width of the glitch, in terms of I2C module clock      |
|      |          |           | cycles, that the filter must absorb. For any glitch whose size is  |
|      |          |           | less or equal to this width setting, the filter does not allow the |
|      |          |           | glitch to pass.                                                    |
|      |          |           | 0h: No filter/bypass                                               |
|      |          |           | 1-Fh: Filter glitches up to width of 1-15 clock cycles.            |



1

1

0

1

2

1

| I2C+0x0 | )2c D | ATA | Data | Port Reg | gister |    |    |
|---------|-------|-----|------|----------|--------|----|----|
| Bit     | 31:9  | 8   | 7    | 6        | 5      | 4  | 3  |
| Name    |       | MAK |      |          |        | DA | ТА |
| Туре    |       | R   |      |          |        | R/ | N  |
| Reset   |       | 1   | 1    | 1        | 1      | 1  | 1  |

| Bit  | Mnemonic | Name        | Description                                                         |
|------|----------|-------------|---------------------------------------------------------------------|
| 31:9 |          |             |                                                                     |
| 8    | MAK      | Monitor ACK | Slave Monitor Function ACK Bit                                      |
|      |          |             | For slave monitor, this field is the ACK bit from I2C bus.          |
|      |          |             | Note:                                                               |
|      |          |             | MAK='1', NACK                                                       |
|      |          |             | MAK='0', ACK                                                        |
|      |          |             | Note: for monitor, DATA[7:0] is the data transfer on I2C bus,       |
|      |          |             | and DATA[8] is the ACK bit.                                         |
| 7:0  | DATA     | DATA        | Data                                                                |
|      |          |             | For master transmit(TX) mode, when data is written to this          |
|      |          |             | register, a data transfer is initiated. The most significant bit is |
|      |          |             | sent first. For master receive(RX) mode, reading this register      |
|      |          |             | initiates a receiving sequence of the next byte.                    |
|      |          |             | Note: when making the transition out of master receive mode,        |
|      |          |             | switch the I2C mode before reading the DATA register to             |
|      |          |             | prevent an inadvertent initiation of a master receive data          |
|      |          |             | transfer.                                                           |
|      |          |             | Note: read this register, will return RX buffer data. master        |
|      |          |             | mode, RX buffer default 0xff; slave mode RX buffer default          |
|      |          |             | Ox1ff.                                                              |

#### I2C+0x030 START\_STOP START\_STOP Register

| Bit   | 31:8 | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0     |
|-------|------|---|---|---|---|---|---|------|-------|
| Name  |      |   |   |   |   |   |   | STOP | START |
| Туре  |      |   |   |   |   |   |   | R/W  | R/W   |
| Reset |      |   |   |   |   |   |   | 0    | 0     |

| Bit  | Mnemonic | Name  | Description                                         |
|------|----------|-------|-----------------------------------------------------|
| 31:8 |          |       |                                                     |
| 1    | STOP     | STOP  | Master STOP Trig                                    |
|      |          |       | write "1", master will send START signal.           |
|      |          |       | read this bit always return "0"                     |
| 0    | START    | START | Master START Trig                                   |
|      |          |       | write "1" , master will send START(RESTART) signal. |
|      |          |       | read this bit always return "0"                     |

Note: reserved bit must keep default value, not change it.

Note: not used. read always return 0.

© 2013 - 2021 AutoChips Inc.

Page 247 of 360

# **//utoChips**

## **18.6 Functional description**

### 18.6.1 Data flow & Algorithm

For transmitter, data is written to an 8-bit TX buffer, then load to TX shift refer to baud rate control logic. The output data is most significant bit first. The transmitter sample the acknowledge bit every 9<sup>th</sup> SCL per byte.



#### Figure 18-2 Data flow of transmitter

For receiver, RX shift sample and shift in the SDA line input data. Data received store into an 8-bit RX buffer after every 8<sup>th</sup> SCL per byte with the most significant bit first. The acknowledge bit is put on the SDA line at 9<sup>th</sup> SCL pulse.



Figure 18-3 Data flow of Receiver

### 18.6.2 Input & Output timing

All transactions begin with a START (S) and terminated by a STOP (P). A high to low transition on the SDA line while SCL is high defines a START condition. A low to high transition on the SDA line while SCL is high defines a STOP condition (see Figure 18-4).





Figure 18-4 START and STOP conditions

Every byte put on the SDA line must be eight bits long. The number of bytes that can be transmitted per transfer is unrestricted. Each byte must be followed by an Acknowledge bit. Data is transferred with the Most Significant Bit (MSB) first (see Figure 18-5).



#### Figure 18-5 Data transmission format

#### 18.6.3 Master SCL output timing set

**NutoChips** 





Baud rate: f<sub>SCL</sub>=f<sub>bclk</sub>/(((SAMPLE\_CNT\_DIV+1)\*(STEP\_CNT\_DIV+1))\*2)

f<sub>bclk</sub> is the APB bus clock frequency(50 MHz).

#### 18.6.4 Data transmission

This I2C module is a byte-by-byte completely serial interface, and need CPU's control every byte. Write *START\_STOP[0]* '1' trigger a START signal onto the I2C bus, and initial a transmission. The transmission ends up with a STOP signal on the I2C bus. STOP signal is triggered by the START\_STOP[1] written '1'. The *BND* flag will be set after every data byte finish. Software write or read data refer to the transmission direction after *BND=1*.

Write *BND* '1' can clear *BND* too. Software can write *BND* '1' instead of writing dummy data to *DATA* when the last byte finishes within master write slave mode.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 249 of 360

| S Slave A Data A Data A Data A P<br>BND write DATA write DATA write BDN '1' | <b>/luto</b> | Chips               |                 | AC781x              | Reference Manual<br>General |
|-----------------------------------------------------------------------------|--------------|---------------------|-----------------|---------------------|-----------------------------|
| Figure 18-7 BND sequence of master write slave mode                         | BND _        | Address A           |                 | Data A              |                             |
| i igure 10-7 Diab sequence of master write slave mode                       |              | Figure 18-7 BND sec | quence of maste | er write slave mode | )                           |
| S Slave A Data A Data A P<br>BND                                            | BND          |                     | Data A          |                     | P                           |

Figure 18-8 BND sequence of master read slave mode

## 18.6.5 DMA operation

This I2C module supports byte-by-byte DMA TX/RX requests transmission. DMA requests are generated only for data transfer. DMA valid for data transfer phase only, and START/STOP/RESTART signal triggered by software still. The DMA operation is different between transmitter and receiver. EOT\_1 signal is set after the last but one byte data finish for receiver.

### 18.6.5.1 Master transmitter

For master transmitter, after START signal, the first byte is the slave address which defined in I2C protocol. This address byte is written by software. The DMA TX request (DMA\_TX\_REQ) will be set after 1<sup>st</sup> byte acknowledge bit (9<sup>th</sup> SCL). Notice that DMA\_TX\_REQ be set need an ACK condition (must a slave give back a low on 9<sup>th</sup> SCL). If NACKIE=1, I2C core will generate CPU interrupt request when a NACK occurs.



#### Figure 18-9 Master transmitter case 1

If the slave receiver ACK all the data byte and the DMA transmit finishes, I2C module generates the DMA TX request still because of I2C module can't recognize the transaction length. So software needs to write BND "1" clear this bit filed after DMA transmission finishes.

| <b>//utoChips</b>                     | AC781x Reference Manual<br>General |
|---------------------------------------|------------------------------------|
| Slave     A     Data       DMA_TX_REQ | A Data A P<br>write BND '1'        |
| DMATXEN                               |                                    |

#### Figure 18-10 Master transmitter case 2

#### 18.6.5.2 Master receiver

For the master receiver, START condition and slave address byte are triggered by software. The direction switch and dummy read DATA register action are necessary too. The first DMA RX request is generated by hardware automatically after 1<sup>st</sup> data byte finishes.

When the number of bytes to be received is equal to or greater than two, the DMA controller sends a hardware signal eto\_1=1, corresponding to the last but one data byte (number\_of\_bytes - 1). I2C automatically sends a NACK after the next byte following eto\_1=1. Software can generate a STOP condition in the DMA transfer complete interrupt routine if enabled.

|             | Software write the slave<br>address<br>Slave<br>Address | Software dummy read DATA | N byte | Data | A |
|-------------|---------------------------------------------------------|--------------------------|--------|------|---|
| DMARXEN     |                                                         |                          |        |      |   |
| DMA_RX_REQ_ |                                                         |                          |        |      |   |
| eto_1       |                                                         |                          |        |      |   |

#### Figure 18-11 Master receiver

#### 18.6.5.3 Slave transmitter

The slave is a transmitter if slave address matches and the LSB is "1" of address byte. I2C hardware generates the 1<sup>st</sup> DMA TX request after slave address byte acknowledge bit. DMA TX request will not be generated if master gives a NACK. I2C slave will generates CPU interrupt request if enable the *NACKIE* and *IICIE*.



#### Figure 18-12 Slave transmitter



#### 18.6.5.4 Slave receiver

The first DMA RX request is generated after 1<sup>st</sup> data byte finish for slave receiver. Similar to the master receiver, eto\_1 precedes the last byte of data and replies with a NACK on the next data byte.

| S          | Slave<br>Address | Data | A | Data | A | Data | NA | Ρ |
|------------|------------------|------|---|------|---|------|----|---|
| DMARXEN    |                  |      |   |      |   |      |    |   |
| DMA_RX_REQ |                  |      |   |      |   |      |    |   |
| eto_1      |                  |      |   |      |   |      |    |   |

#### Figure 18-13 Slave receiver

#### 18.6.6 Slave low power wakeup

I2C slave can turn to low power mode. Low power mode I2C slave can generate wake up signal wake up MCU if address matches. I2C slave cannot transmit or receive any data until STOP during wakeup sequence. So slave only ACK address byte if address matches, and all following data transmission is NACK.

I2C slave turn to low power mode must meet the following conditions:

- a. I2C slave is IDLE.
- b. WUEN bit is '1'.
- c. Software WFI instruction.



#### Figure 18-14 Wakeup sequence

#### 18.6.7 Interrupt

I2C has a total of 10 interrupts.

#### Table 18-2 Interrupt summary

| Interrupt             | Flag    | Local enable | Global enable |
|-----------------------|---------|--------------|---------------|
| One Byte Transfer End | BND     |              | IICIE         |
| Slave Address Match   | SAMF    |              | IICIE         |
| Arbitration Lost      | ARBLOST |              | IICIE         |
| Bus START Detected    | START   | SSIE         | IICIE         |
| Bus STOP Detected     | STOP    | SSIE         | IICIE         |
| RX Buffer Overflow    | RXOF    | RXOFIE       | IICIE         |
| TX Buffer Underflow   | TXUF    | TXUFIE       | IICIE         |
| RX Buffer Full        | RXFF    | RXFIE        | IICIE         |
| TX Buffer Empty       | TXEF    | TXEIE        | IICIE         |
| Ack Get               | RACK    | NACKIE       | IICIE         |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 252 of 360

DMARXEN=1 or DMATXEN=1, BDN, RXFF, and TXEF will not generate interrupt even enable corresponding enable bit.

## 18.7 Program guide

## 18.7.1 Description

The transfer of data would proceed as follows:

- 1. Suppose microcontroller A wants to send information to microcontroller B:
  - o Microcontroller A(master), addresses microcontroller B(slave).
  - o Microcontroller A(master-transmitter), sends data to microcontroller B(slave-receiver).
  - Microcontroller A terminates the transfer.
- 2. If microcontroller A wants to receive information from microcontroller B:
  - Microcontroller A(master), addresses microcontroller B(slave).
  - o Microcontroller A(master-receiver) receives data from microcontroller B(slave-transmitter).
  - Microcontroller A terminates the transfer.

XXX Master send to slave

XXX Slave send to master

## 18.7.2 Master transmitter



#### Figure 18-15 Master write operation sequence

① Set the timing(SAMPLE\_CNT,STEP\_CNT) and other function control.

register(*CONTROL\_1,CONTROL\_2,CONTROL\_3,CONTROL\_4*,) first, *CONTROL\_1[4]* must be "1", and then enable I2C.

- ② Write START\_STOP[0] "1", trigger START.
- ③ STATUS\_1[5]="1", STATUS\_1[3]="1", then write data(slave address) to DATA, DATA[0] is the direction bit, this is "0".
- ④ *STATUS\_1[7]=*"1", *STATUS\_1[0]=*"1", write data to *DATA*.
- $\bigcirc$  Repeat step 4 if multi bytes transmission.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 253 of 360

6 Write START\_STOP[1] "1".

**NutoChips** 

### 18.7.3 Master receiver





- Set the timing(SAMPLE\_CNT,STEP\_CNT) and other function control register(CONTROL\_1,CONTROL\_2,CONTROL\_3,CONTROL\_4) first, CONTROL\_1[4] must be "1", and then enable I2C.
- ② Write START\_STOP[0] "1", trigger START.
- ③ STATUS\_1[5]="1", STATUS\_1[3]="1", then write data(slave address) to DATA, DATA[0] is the direction bit, this is "1".
- ④ STATUS\_1[7]="1", STATUS\_1[0]="1", write CONTROL\_1[4] "0", then dummy read DATA, trigger data transmission
- (5) STATUS\_1[7]="1", read DATA. if multi-byte transmission, repeat step (5).
- 6 STATUS\_1[7]="1", write CONTROL\_1[3] "1", then read DATA.
- ⑦ STATUS\_1[7]="1", write CONTROL\_1[4] "1", then read DATA(the last one byte), and then write START\_STOP[1], trigger STOP.

#### 18.7.4 Master combined format



#### Figure 18-17 Combined format option sequence

Combined format can be master write slave first and read slave then, or master read slave first and then write slave.

All program configuration and sequence master write slave refer to 18.7.2 Master transmitter, and master read slave refer to 18.7.3 Master receiver. The only difference is the 'RS'(RESTART). I2C module has not RS trig register, and this is implemented by *START\_STOP[0]*. Write *START\_STOP[0]* "1" will trigger a START signal if I2C bus is idle, and a RESTART signal will be triggered if I2C not idle.

### 18.7.5 Slave

Slave address match will generate a *SAMF* flag, and switch to receiver or transmitter controlled by address byte LMSB hardware auto. *SRW* indicates the direction of data transmission next. Software write data to DATA register after *SAMF* and *SRW*=1(master read). Every byte(9 SCL) finish, *BND* set "1". Software write data to *DATA* register if *SRW*=1, and read data from DATA register if *SRW*=0. ACK bit is sent by slave when master write. *CONTROL\_1[3]* TACK bit control the next byte ACK bit.



#### Figure 18-18 Typical I2C slave interrupt routine

## AC781x Reference Manual General

## 19 SPI

## **19.1 Introduction**

**NutoChips** 

The SPI is a bit-serial, synchronous serial, and full duplex protocol. The SPI interface was developed by Motorola and has become a de facto standard. This SPI module is a 4-wire interface that includes master and slave both.

Figure 19-1 gives an example of the connection between SPI master and SPI slave.



Figure 19-1 SPI system connection

## 19.2 Feature list

- Master mode or slave mode operation.
  - As master, the highest baud rate is fbus/2 Hz (fbus is APB bus clock)
  - As slave, the highest baud rate is 18 MHz
- Full-duplex.
- Master programmable transmit bit rate.
- Serial clock phase and polarity options.
- Configurable continuous or discontinuous CS (slave select) output.
- Mode error flag with CPU interrupt capability.
- Selectable MSB-first or LSB-first shifting.
- Configurable CS setup time, hold time and idle time.
- Configurable SCK high and low period.
- 4-16 bit transfer frame format selection.
- DMA mode.
- TX buffer underflow and RX buffer overflow flag with interrupt capability.
- Slave support low power mode wake up function.

## 19.3 Block diagram



Figure 19-2 SPI block diagram

## 19.4 Data flow & Algorithm

For master mode, data is written to a 16-bit TX buffer, then loaded to shift register refer to baud rate control logic. The output data is most significant first or least significant first controlled by *TMSBF*. After the numbers SCK periods specified by *FRMSIZE*, shift register shift in single-byte data from MISO pin. Data received is stored into a 16-bit RX buffer.



Figure 19-3 Data flow of master

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 257 of 360

For slave mode, data flow is similar to master mode. But the CS pin is the slave select input, and SCK

is the SPI clock input from the master. Before a data transmission occurs, the CS pin of the slave SPI must be low. MOSI is the slave data input pin, and MISO is the data output pin.



Figure 19-4 Data flow of slave

## **19.5 Input & Output timing**

**NutoChips** 

## **19.5.1 CPHA = 0 transfer format**

The first edge on the SCK line is used to clock the first data bit of the slave into the master and the first data bit of the master into the slave. In some peripherals, the first bit of the slave's data is available at the slave's data out pin as soon as the slave is selected. In this format, the first SCK edge is issued a half cycle after CS has become low.

A half SCK cycle later, the second edge appears on the SCK line. When this second edge occurs, the value previously latched from the serial data input pin is shifted into the shift register.

After this second edge, the next bit of the SPI master data is transmitted out of the serial data output pin of the master to the serial input pin on the slave. This process continues for a total 16 edges on the SCK line, with data being latched on odd numbered edges and shifted on even numbered edges.



### Figure 19-5 CPHA=0 Transmission Format

## **19.5.2** CPHA = 1 transfer format

Some peripherals require the first SCK edge before the first data bit becomes available at the data output pin, the second edge clocks data into the system.

The first edge of SCK occurs immediately after the half SCK clock cycle synchronization delay. This first edge commands the slave to transfer its first data bit to the serial data input pin of the master.

A half SCK cycle later, the second edge appears on the SCK pin. This is the latching edge for both the master and slave.

When the third edge occurs, the value previously latched from the serial data input pin is shifted into the shift register. After this edge, the next bit of the master data is coupled out of the serial data output pin of the master to the serial input pin on the slave.

This process continues for a total 16 edges on the SCK line with data being latched on even numbered edges and shifting taking place on odd numbered edges.



### Figure 19-6 CPHA=1 Transmission Format





#### Figure 19-7 Baud rate generation

Baud rate: fscl=fbclk/(SCK\_LOW+1+SCK\_HIGH+1), fbclk is the APB bus clock frequency.

## 19.7 Master mode fault detect

MODEF is set if the CS pin has been driven to low before SPI master initial a transmission. Then master mode fault detect function is valid only when *MSTR=1*, *MODFEN=1*, *CSOE=1*.

The SCK is different from normal case if enable master mode fault detect function with *CPOL=0*. The SCK is high when IDLE state, and change to low then only if no mode fault error occurs. SCK keep high after transmission finishes.





#### Figure 19-8 SCK output timing with mode fault detect enable

This mode fault detect function may can't detect the mode fault by master 1 with some special cases. If master 2 drive CS low during (1) period in Figure 19-9, master 1 will not set *MODEF*. Only master 2 drive CS low before (1) period that master 1 can set *MODEF*.



Figure 19-9 Limitation of mode fault detect

## 19.8 Slave low power wakeup

SPI slave in stop mode can generate an asynchronous interrupt to wake the CPU from the low power mode when receives a transmission.

To ensure SPI module low power wakeup function correct, system must follow some regulations. Before CPU enters low power mode, system must confirm that SPI module is in IDLE state. Software can check STATUS[8] IDLEF bit state. For master mode, tx buffers are empty, rx buffers are empty, and internal hardware is idle, IDLEF can be '1'. For slave mode, tx buffers are empty, rx buffers are empty, and CS is deassert(CS is high), IDLEF can be '1'. SPI module can't ensure data valid or wakeup function correct if CPU enter low power mode when SPI module is busy.

The slave generates asynchronous wakeup interrupt only when all of the following conditions apply:

- a. SPI module is slave mode.
- b. SPI slave is IDLE states.
- c. WUEN bit is '1'.
- d. The single-byte wakeup sequence transmission end.

CS high to low initial the wakeup phase, and slave generates the asynchronous wakeup request after the numbers SCK cycle that *FRMSIZE* specified. SPI slave can receive the data of wakeup phase byte. The RXFF flag will be set after chip wakeup finish (clock recover), and read data register will return the data master sent in wakeup phase byte. Only one byte can be transmitted during wakeup

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 261 of 360



phase. During the wakeup phase, a continuous transmission from a master would destroy the data received, and may lead to RXFF flag can't be set rightly.



Figure 19-10 Wakeup sequence

## **19.9 Interrupt**

The SPI has a total of five interrupts.

#### Table 19-1 Interrupt summary

| Flag  | Local enable |
|-------|--------------|
| TXEF  | TXEIE        |
| RXFF  | RXFIE        |
| TXUF  | TXUIE        |
| RXOF  | RXOIE        |
| MODFF | MODFIE       |





#### Figure 19-11 CS continuous mode

#### CS continuous output

- 1. Configure CFG0: CS\_SETUP, CS\_HOLD, SCK\_LOW, SCK\_HIGH.
- 2. Configure CFG1: CS\_IDLE

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 262 of 360

- 3. Configure FRMSIZE, CPHA, CPOL.RMSBF, TMSBF etc.
- 4. Configure CSOE, CONT\_CS, MSTR
- 5. SPIEN=1

**NutoChips** 

- 6. TXEF=1, write data to DATA
- 7. RXFF=1, read data from DATA
- 8. Write CSRLS "1", release CS, then hardware goes to idle.

## 19.11 Master CS discontinuous output

- 1. Configure CFG0: CS\_SETUP, CS\_HOLD, SCK\_LOW, SCK\_HIGH.
- 2. Configure CFG1: CS\_IDLE.
- 3. Configure FRMSIZE, CPHA, CPOL.RMSBF, TMSBF etc.
- 4. Configure CSOE, CONT\_CS, MSTR.
- 5. SPIEN=1
- 6. TXEF=1, write data to DATA.
- 7. RXFF=1, read data from DATA.

CS change to low or high by hardware when CS discontinuous mode. So software does not care the *CSRLS*.

## 19.12 Slave mode

- 1. Configure FRMSIZE, CPHA, CPOL.RMSBF, TMSBF etc.
- 2. Configure MSTR.
- 3. SPIEN=1.
- 4. *TXEF*=1, write data to *DATA*.
- 5. RXFF=1, read data from DATA.

## 19.13 DMA mode

TXEF=1 will generate the DMA TX request. RXFF=1 will generate the DMA RX request.

- 1. Initialize DMA.
- 2. Initialize SPI module, and enable DMATXEN, DMARXEN.
- 3. Wait DMA finish.
- 4. Other options similar to CS continuous or discontinuous mode.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 263 of 360

**19.14 Register definition** 

**NutoChips** 

#### Table 19-2 SPI register map

## SPI1 Base address: 0x4000c000

### SPI2 Base address: 0x4000d000

| ADDRESS    | TITLE  | DESCRIPTION                  |
|------------|--------|------------------------------|
| SPIx+0x000 | CFG0   | SPI CONFIGURATION 0 REGISTER |
| SPIx+0x004 | CFG1   | SPI CONFIGURATION 1 REGISTER |
| SPIx+0x008 | CMD    | SPI COMMAND REGISTER         |
| SPIx+0x00c | STATUS | SPI STATUS REGISTER          |
| SPIx+0x010 | DATA   | SPI DATA REGISTER            |
| SPIx+0x014 | CFG2   | SPI CONFIGURATION 2 REGISTER |

#### SPIx+0x000 CFG0 SPI Configuration Register 0

| Bit   | 31  | 30       | 29 | 28   | 27  | 26 | 25 | 24 | 23       | 22  | 21      | 20  | 19 | 18 | 17 | 16 |  |  |
|-------|-----|----------|----|------|-----|----|----|----|----------|-----|---------|-----|----|----|----|----|--|--|
| Name  |     | CS_SETUP |    |      |     |    |    |    |          |     | CS_HOLD |     |    |    |    |    |  |  |
| Туре  | R/W |          |    |      |     |    |    |    |          |     |         | R/V | V  |    |    |    |  |  |
| Reset | 0   | 0        | 0  | 0    | 0   | 1  | 0  | 1  | 0        | 0   | 0       | 0   | 0  | 1  | 0  | 1  |  |  |
| Bit   | 15  | 14       | 13 | 12   | 11  | 10 | 9  | 8  | 7        | 6   | 5       | 4   | 3  | 2  | 1  | 0  |  |  |
| Name  |     |          |    | SCK_ | LOW |    |    |    | SCK_HIGH |     |         |     |    |    |    |    |  |  |
| Туре  |     | R/W      |    |      |     |    |    |    |          | R/W |         |     |    |    |    |    |  |  |
| Reset | 0   | 0        | 0  | 0    | 0   | 1  | 0  | 1  | 0        | 0   | 0       | 0   | 0  | 1  | 0  | 1  |  |  |

| Bit   | Name     | Description                                               |
|-------|----------|-----------------------------------------------------------|
| 31:24 | CS_SETUP | CS Setup Time                                             |
|       |          | The chip select setup time =                              |
|       |          | (CS_SETUP_COUNT+1)*CLK_PERIOD, where CLK_PERIOD is the    |
|       |          | cycle time of the clock the SPI engine adopts.            |
| 23:16 | CS_HOLD  | CS Hold Time                                              |
|       |          | The chip select hold time = (CS_HOLD_COUNT+1)*CLK_PERIOD. |
| 15:8  | SCK_LOW  | SCK low Time                                              |
|       |          | The SCK clock low time = (SCK_LOW_COUNT+1)*CLK_PERIOD.    |
| 7:0   | SCK_HIGH | SCK high Time                                             |
|       |          | The SCK clock high time = (SCK_HIGH_COUNT+1)*CLK_PERIOD.  |

| SPIx+0x004 | CFG1 | SPI configuration Register 1 |
|------------|------|------------------------------|
|------------|------|------------------------------|

| Bit       | 31          | 30          | 29         | 28          | 27        | 26         | 25        | 24        | 2<br>3          | 2<br>2 | 2<br>1 | 2<br>0 | 19        | 18        | 17       | 16       |
|-----------|-------------|-------------|------------|-------------|-----------|------------|-----------|-----------|-----------------|--------|--------|--------|-----------|-----------|----------|----------|
| Na<br>me  |             | WKUE<br>N   |            | CONT<br>_CS |           | MOD<br>FEN | CS<br>OE  |           | FRMSIZE         |        |        |        | RMS<br>BF | TMS<br>BF | CP<br>HA | CP<br>OL |
| Тур<br>е  |             | R/W         |            | R/W         |           | R/W        | R/W       |           | R/W R/W R/W R/W |        |        |        |           | R/<br>W   |          |          |
| Re<br>set |             | 0           |            | 0           |           | 0          | 1         |           | 0               | 1      | 1      | 1      | 1         | 1         | 0        | 0        |
| Bit       | 15          | 14          | 13         | 12          | 11        | 10         | 9         | 8         | 7               | 6      | 5      | 4      | 3         | 2         | 1        | 0        |
| Na<br>me  | DMAR<br>XEN | DMAT<br>XEN | MOD<br>FIE | MSTR        | RX<br>OIE | TXUI<br>E  | RX<br>FIE | TX<br>EIE |                 |        |        |        | CS_ID     | LE        |          |          |
| Тур<br>е  | R/W         | R/W         | R/W        | R/W         | R/W       | R/W        | R/W       | R/<br>W   | R/W             |        |        |        |           |           |          |          |
| Re<br>set | 0           | 0           | 0          | 0           | 0         | 0          | 0         | 0         | 0               | 0      | 0      | 0      | 0         | 1         | 0        | 1        |

| Bit       | Name         | Description                                                  |               |
|-----------|--------------|--------------------------------------------------------------|---------------|
| 31        |              | ·                                                            |               |
| 30        | WKUEN        | Slave Wakeup Function enable                                 |               |
|           |              | 1: slave wake up function enable                             |               |
|           |              | 0: slave wake up function disable                            |               |
| 29        |              |                                                              |               |
| 28        | CONT_CS      | CS Continuous Output Enable                                  |               |
|           |              | 1: CS output continuous                                      |               |
|           |              | 0: CS output non-continuous                                  |               |
| 27        |              |                                                              |               |
| 26        | MODFEN       | Master Mode Fault Detect Enable                              |               |
|           |              | <ol> <li>enable the multi-master detect function</li> </ol>  |               |
|           |              | 0: disable the multi-master detect function                  |               |
| 25        | CSOE         | CS Hardware Output Enable                                    |               |
|           |              | 1: enable the CS hardware output                             |               |
|           |              | 0: disable the CS hardware output                            |               |
| 24        |              |                                                              |               |
| 23:20     | FRMSIZE      | Frame Size                                                   |               |
|           |              | 1111: 16bit                                                  |               |
|           |              | 1110: 15bit                                                  |               |
|           |              | 0011: 4bit                                                   |               |
|           |              | 0010: 4bit                                                   |               |
|           |              | 0001: 4bit                                                   |               |
|           |              | 0000: 4bit                                                   |               |
| 19        | RMSBF        | RX MSB First                                                 |               |
|           |              | 1: the first bit of shifter shift in is the MSB of the input |               |
|           |              | 0: the first bit of shifter shift in is the LSB of the input | data          |
| 18        | MSBF         | TX MSB First                                                 |               |
|           |              | 1: TX MSB first(MSB first shift out)                         |               |
|           | 0.511.4      | 0: TX LSB first(LSB first shift out)                         |               |
| 17        | СРНА         | Clock Phase                                                  |               |
|           |              | 1: the first SCK transition edge is the data capture ed      |               |
|           |              | 0: the first SCK transition edge is the data shift out ed    | dge           |
| 16        | CPOL         | Clock Polarity                                               |               |
|           |              | 1: SCK is 1 when idle                                        |               |
|           | DMADYEN      | 0: SCK is 0 when idle                                        |               |
| 15        | DMARXEN      | DMA RX Request Enable                                        |               |
|           |              | 1: enable the DMA RX request                                 |               |
|           |              | 0: disable                                                   |               |
| 14        | DMATXEN      | DMA TX channel enable                                        |               |
| AutoChips | Confidential | © 2013 - 2021 AutoChips Inc.                                 | Page 265 of 3 |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 265 of 360

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit | Name    | Description                                            |
|-----|---------|--------------------------------------------------------|
|     |         | 1: enable the DMA RX request                           |
|     |         | 0:disable                                              |
| 13  | MODFIE  | Mode Fault Interrupt Enable                            |
|     |         | 1: enable                                              |
|     |         | 0: disable                                             |
| 12  | MSTR    | Master or Slave Mode Selection                         |
|     |         | 1: master mode                                         |
|     |         | 0: slave mode                                          |
| 11  | RXOIE   | RX Buffer Overflow Interrupt Enable                    |
|     |         | 1: enable                                              |
|     |         | 0: disable                                             |
| 10  | TXUIE   | TX Buffer Underflow Interrupt Enable                   |
|     |         | 1: enable                                              |
|     |         | 0: disable                                             |
| 9   | RXFIE   | RX Buffer Full Interrupt Enable                        |
|     |         | 1: enable                                              |
|     |         | 0: disable                                             |
|     |         | Note: RX buffers Not Empty will generate an interrupt. |
| 8   | TXEIE   | TX Buffer Empty Interrupt Enable                       |
|     |         | 1: enable                                              |
|     |         | 0: disable                                             |
|     |         | Note: TX buffers Not Full will generate an interrupt.  |
| 7:0 | CS_IDLE | CS Idle Time                                           |
|     |         | CS IDLE time = (CS_IDLEA_COUNT+1)*CLK_PERIOD           |

#### SPIx+0x008 CMD SPI Command Register

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22         | 21        | 20        | 19 | 18 | 17 | 16        |
|-------|----|----|----|----|----|----|----|----|----|------------|-----------|-----------|----|----|----|-----------|
| Name  |    |    |    |    |    |    |    |    |    |            |           |           |    |    |    |           |
| Туре  |    |    |    |    |    |    |    |    |    |            |           |           |    |    |    |           |
| Reset |    |    |    |    |    |    |    |    |    |            |           |           |    |    |    |           |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6          | 5         | 4         | 3  | 2  | 1  | 0         |
| Name  |    |    |    |    |    |    |    |    |    | RO<br>TRIG | CS<br>RLS | SW<br>RST |    |    |    | SPI<br>EN |
| Туре  |    |    |    |    |    |    |    |    |    | R/W        | R/W       | R/W       |    |    |    | R/W       |
| Reset |    |    |    |    |    |    |    |    |    | 0          | 0         | 0         |    |    |    | 0         |

| Bit       | Name   | Description                                          |                           |
|-----------|--------|------------------------------------------------------|---------------------------|
| 31:6      |        | ·                                                    |                           |
| 6         | ROTRIG | Master RX only mode trig                             |                           |
|           |        | Note: write this bit '1' will trigger a sequence o   | f read, while ROEN=1      |
|           |        | in CFG2. Read this bit will return '0' always.       |                           |
| 5         | CSRLS  | CS Release                                           |                           |
|           |        | 1: release CS                                        |                           |
|           |        | 0: no effect                                         |                           |
|           |        | Software write this bit '1', then CS will go to high | gh. Read this bit always  |
|           |        | return "0". This bit valid for CS continuous out     | out (CONT_CS=1,           |
|           |        | CSOE=1).                                             |                           |
| 4         | SWRST  | Software reset                                       |                           |
|           |        | 1: reset                                             |                           |
|           |        | 0: no effect                                         |                           |
|           |        | Note: this reset only reset master engine/buffe      | er/flag logic, slave      |
|           |        | buffer/flag logic. CFG0/CFG1/CFG2/CMD con            | trol bits will not reset. |
| 0         | SPIEN  | SPI Enable                                           |                           |
|           |        | 1: enable                                            |                           |
|           |        | 0: disable                                           |                           |
| AutoChing |        | @ 2012 2021 AutoChina Inc                            | Page 266 of 30            |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

## AC781x Reference Manual General

# **VutoChips**

| SPIx+0x00C | STATUS | SPI Status Register |
|------------|--------|---------------------|
|------------|--------|---------------------|

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23   | 22 | 21 | 20        | 19       | 18       | 17       | 16       |
|-------|----|----|----|----|----|----|----|-------|------|----|----|-----------|----------|----------|----------|----------|
| Name  |    |    |    |    |    |    |    |       |      |    |    |           |          |          |          |          |
| Туре  |    |    |    |    |    |    |    |       |      |    |    |           |          |          |          |          |
| Reset |    |    |    |    |    |    |    |       |      |    |    |           |          |          |          |          |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7    | 6  | 5  | 4         | 3        | 2        | 1        | 0        |
| Name  |    |    |    |    |    |    |    | IDLEF | MEBY |    |    | MOD<br>EF | RX<br>OF | TX<br>UF | RX<br>FF | TX<br>EF |
| Туре  |    |    |    |    |    |    |    | R/W   | R/W  |    |    | R/W       | R/W      | R/W      | R/W      | R/W      |
| Reset |    |    |    |    |    |    |    | 1     | 0    |    |    | 0         | 0        | 0        | 0        | 1        |

| Bit  | Name  | Description                                                                      |
|------|-------|----------------------------------------------------------------------------------|
| 31:8 |       |                                                                                  |
| 8    | IDLEF | SPI IDLE Flag                                                                    |
|      |       | 1: SPI module hardware IDLE                                                      |
|      |       | 0: SPI module hardware not IDLE                                                  |
|      |       | Note: for master, TX buffer empty, RX buffer empty, and internal                 |
|      |       | hardware idle, this bit can be '1'. For slave, TX buffer empty, RX               |
|      |       | buffer empty, and CS deassert(not be selected) , this bit can be '1'.            |
| 7    | MEBY  | SPI Master Engine Busy Flag                                                      |
|      |       | 1: SPI master hardware's one byte transmission not finish                        |
|      |       | 0: SPI master hardware's one byte transmission finish                            |
| 4    | MODEF | Mode Fault Error Flag                                                            |
|      |       | 1: master mode error detected                                                    |
|      |       | 0: no multi-master error detected                                                |
|      |       | When SPI configured as a master, it will detect the CS line state                |
|      |       | before drive CS low. If CS have been low, indicating another master              |
|      |       | have initial a transmission. CS pin act as a multi-master error detect           |
|      |       | input only when CSOE=1,MODEEN=1.                                                 |
| 3    | RXOF  | RX Buffer Overflow Flag                                                          |
|      |       | 1: RX buffer overflow                                                            |
|      |       | 0: no overflow                                                                   |
|      |       | write "1" clear this bit.                                                        |
|      |       | <b>Note:</b> if overflow, then only 1 byte valid data in DATA register can       |
|      |       | read out.                                                                        |
| 2    | TXUF  | TX Buffer Underflow Flag                                                         |
|      |       | 1: TX buffer underflow                                                           |
|      |       | 0: not underflow                                                                 |
|      |       | <b>Note</b> : write "1" clear this bit.                                          |
| 1    | RXFF  | RX Buffer Full Flag                                                              |
|      |       | 1: full                                                                          |
|      |       | 0: not full                                                                      |
|      |       | <b>Note:</b> as long as rx buffers have valid data received(1 byte or 2          |
|      |       | bytes), this bit will be '1'. So this bit '1' does not indicate that 2 bytes     |
|      |       | data received in rx buffers. Read DATA register will clear this bit              |
|      |       | hardware auto.                                                                   |
|      |       | <b>Note:</b> this bit named RX Buffers Not Empty is more reasonable              |
|      |       | maybe.                                                                           |
| 0    | TXFF  | TX Buffer Not Full Flag                                                          |
|      |       | 1: empty                                                                         |
|      |       | 0: not empty                                                                     |
|      |       | <b>Note:</b> as long as tx buffers not full(2 bytes data), this bit will be '1'. |
|      |       | Write DATA register will clear this bit hardware auto.                           |
|      |       | <b>Note:</b> this bit named TX buffers Not Full is more reasonable maybe.        |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 267 of 360

#### SPIx+0x010 DATA SPI DATA Register

| Bit   | 31 | 30 | 29   | 28 | 27 | 26                  | 25     | 24     | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|------|----|----|---------------------|--------|--------|-------|----|----|----|----|----|----|----|
| Name  |    |    |      |    |    |                     |        |        |       |    |    |    |    |    |    |    |
| Туре  |    |    |      |    |    |                     |        |        |       |    |    |    |    |    |    |    |
| Reset |    |    |      |    |    |                     |        |        |       |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13   | 12 | 11 | 10                  | 9      | 8      | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |      |    |    |                     |        | D      | ATA   |    |    |    |    |    |    |    |
| Туре  |    |    |      |    |    |                     |        | R      | /W    |    |    |    |    |    |    |    |
| Reset |    |    |      |    |    |                     |        |        | 0     |    |    |    |    |    |    |    |
| Bit   | -  | Ν  | lame |    |    | Desci               | riptio | n      |       |    |    |    |    |    |    |    |
| 31:16 |    |    |      |    |    |                     |        |        |       |    |    |    |    |    |    |    |
| 15:0  |    |    | DATA |    |    | SPI Da              | ata Po | rt Reg | ister |    |    |    |    |    |    |    |
|       |    |    |      |    |    | read: r<br>write: v |        |        |       |    |    |    |    |    |    |    |

#### SPIx+0x014 CFG2 SPI CFG2 Register

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18   | 17   | 16  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|-----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |     |
| Туре  |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |     |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3    | 2    | 1    | 0   |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    | ROEN | TOEN | MNDC | RSV |
| Туре  |    |    |    |    |    |    |    |    |    |    |    |    | R/W  | R/W  | R/W  | R/W |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    | 0    | 0    | 0    | 0   |

| Bit  | Name | Description                                                        |
|------|------|--------------------------------------------------------------------|
| 31:4 |      |                                                                    |
| 3    | ROEN | RX Only Mode Enable                                                |
|      |      | 1: enable                                                          |
|      |      | 0: disable                                                         |
|      |      | Note: RX only mode, TXEF will keep 0. Not trigger RXEF IRQ even    |
|      |      | TXEIE=1.                                                           |
| 2    | TOEN | TX Only Mode Enable                                                |
|      |      | 1: enable                                                          |
|      |      | 0: disable                                                         |
|      |      | Note: TX only mode, RXFF not set after one byte transfer finished. |
|      |      | Not trigger RXFF IRQ even RXFIE=1.                                 |
| 1    | MNOV | Master No Overflow Mode                                            |
|      |      | 1: enable                                                          |
|      |      | 0: disable                                                         |
|      |      | If rxbuff is full, then write to txbuff will not trigger new send. |
| 0    | RSV  | Reserved                                                           |
|      |      | Note: not change this bit.                                         |

## AC781x Reference Manual General

## 20 DMA

## 20.1 Introduction

**NutoChips** 

The Direct Memory Access controller (DMA) is used to speed up memory transmission between peripherals-to-memory or memory-to-memory. Without CPU operations, DMA can move data fast and improve microcontroller's performance.

There are 12 dedicated channels for different kinds peripherals, such as UART, I2C, SPI, ADC, etc. It has a round-robin arbiter for handling priorities between each channel.

## 20.2 Features

- 12 independently configurable channels (requests).
- Each of the 12 channels is connected to dedicated hardware DMA requests, software trigger is also supported on each channel (memory to memory). This configuration is done by software.
- Priorities between requests from channels of one DMA are software programmable (4 levels consisting of very high, high, medium, low) or hardware in case of equality (channel 0 has the highest priority and channel 15 has the lowest priority, etc.)
- Independent source and destination transfer size (byte, half word, word). Source/destination addresses must be aligned on the data size.
- Support for circular buffer management.
- 3 event flags (DMA Half Transfer, DMA Transfer complete and DMA Transfer Error) logically ORed together in a single interrupt request for each channel.
- Memory-to-memory transfer.
- Peripheral-to-memory and memory-to-peripheral transfers.
- Access to SRAM, APB peripherals as source and destination.
- Programmable number of data to be transferred: up to 32767.

## 20.3 Block diagram



#### Figure 20-1 DMA block diagram

## **20.4 Mode of operations**

The DMA module does not support in either Stop or Standby mode. Before entering either Stop or Standby mode, all DMA channels must be disabled, that is, the CHAN\_ENABLE bit of the CHANNELx\_CHAN\_ENABLE register configured to 0 for all DMA channels.

## 20.5 Function description

## 20.5.1 DMA request mapping

Table 20-1 DMA request mapping

| Peripherals | Channel 1 | Channel 2 | Channel 3 | Channel 4  | Channel 5  | Channel 6  |
|-------------|-----------|-----------|-----------|------------|------------|------------|
| ADC         | ADC       |           |           |            |            |            |
| SPI         |           | SPI1_RX   | SPI1_TX   | SPI2_RX    | SPI12_TX   |            |
| UART        | UART6_RX  | UART3_TX  | UART3_RX  | UART1_TX   | UART1_RX   | UART2_TX   |
| I2C         |           |           |           |            |            |            |
| Peripherals | Channel 7 | Channel 8 | Channel 9 | Channel 10 | Channel 11 | Channel 12 |
| ADC         |           |           |           |            |            |            |
| SPI         |           |           |           |            |            |            |
| UART        | UART2_RX  | UART4_TX  | UART4_RX  | UART5_TX   | UART5_RX   | UART6_TX   |
| 12C         |           |           | I2C2_TX   | 12C2_RX    | I2C1_TX    | I2C1_RX    |

## 20.5.2 DMA arbiter

The arbiter manages the channel requests based on their priority and launches the peripheral/memory access sequences.

The priorities are managed in two stages:

- Software: each channel priority can be configured in the CHANNELx\_CONFIG register. There are four levels:
  - Very high priority.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 270 of 360

• High priority.

**NutoChips** 

- Medium priority.
- Low priority.
- When software priorities are equal, priority is determined based on the hardware channel number. For example, channel 0 has the highest priority, channel 15 has the lowest priority, and so on.

### 20.5.3 Configuration guide

ALL registers except **CHANNELx\_CHAN\_ENABLE** register should be programmed before user configures **CHANNELx\_CHAN\_ENABLE** register. Because parameters take effect after CHAN\_ENABLE's pose edge. And when CHAN\_ENABLE is High, please don't modify parameters.



#### Figure 20-2 DMA configuration guide

#### 20.5.3.1 Soft reset and hard reset

Soft reset and hard reset exist in DMA global control and each DMA engine. When soft reset is set, the engine will be reset after the current transaction is finished, and therefore the soft reset will not cause any bus hang. Conversely, when hard reset is set, the engine will be reset immediately, and therefore the bus may go down due to unfinished (and will never finish) transaction.

The mechanism of global soft reset is described as follows. When the software would like to re-start all engines or re-clear all engines in DMA, it can set the global soft resetter to 1. Then HW set WARM\_RST back to 0 to finish the global soft reset.

The mechanism of global hard reset is described as follows. When the software would like to re-start all engines or re-clear all engines in DMA without waiting for any period of time, it can set the global HARD\_RST to 1 and then set to 0 to complete the global hard reset. Note that this may break the bus protocol and result in system hang.

### 20.5.3.2 Pause and Resume

**NutoChips** 

There are pause and resume functions available for DMA. The mechanism is as follows:

- 1. Start DMA. (Program necessary settings, then set CHAN\_ENABLE = 1.)
- 2. Pause DMA. (Set STOP = 1.)
- 3. Resume DMA. (Set STOP = 0.)
- 4. Wait for DMA to finish. (CHAN\_ENABLE will become 0, and interrupt flag will be set to 1.)

The software can repeat step 2 and 3 many times when DMA is running. DMA will not pause immediately and will wait for the last transaction to be finished.

#### 20.5.3.3 Channel circular

Circular mode is available to handle circular buffers and continuous data flows (e.g. ADC scan mode). This feature can be enabled using the CHAN\_CIRCULAR bit in the **CHANNELx\_CONFIG register**. When circular mode is activated, the number of data to be transferred is automatically reloaded with the initial value programmed during the channel configuration phase, and the DMA requests continue to be served.

It should be noted that after read or write MEM\_END\_ADDR-0x01, the DMA master will return to MEM\_START\_ADDR to continue handling.



Figure 20-3 DMA channel circular

#### 20.5.3.4 I2C using DMA

When the number of data transfers which has been programmed for the corresponding DMA stream is reached, the DMA controller sends an End of Transfer EOT-1 signal to the I2C interface. I2C hard engine has received the signal and decide whether to send ACK/NACK.



### 20.5.3.5 Programmable data width, data alignment

#### Table 20-2 Programmable data width & data alignment

| MSIZE | PSIZE | Length | MEM_BYTE_MODE | Source         | Direction | Destination   |   |   |               |    |               |
|-------|-------|--------|---------------|----------------|-----------|---------------|---|---|---------------|----|---------------|
|       |       |        |               | 0x00 03020100  |           | 0x00 03020100 |   |   |               |    |               |
| 32    | 32    | 4      | 00            | 0x04 07060504  | 1(TX)     | 0x04 07060504 |   |   |               |    |               |
| 52    | 52    | -      | 00            | 0x08 0B0A0908  | (17)      | 0x08 0B0A0908 |   |   |               |    |               |
|       |       |        |               | 0x0C 0F0E0D0C  |           | 0x0C 0F0E0D0C |   |   |               |    |               |
|       |       |        |               | 0x00 03020100  |           | 0x00 00000100 |   |   |               |    |               |
| 32    | 32    | 4      | 01            | 0x04 07060504  | 1(TX)     | 0x04 00000302 |   |   |               |    |               |
| 52    | 52    | -      | 01            | 0,04 07 000304 | (17)      | 0x08 00000504 |   |   |               |    |               |
|       |       |        |               |                |           | 0x0C 00000706 |   |   |               |    |               |
|       |       |        |               | 0x00 03020100  |           | 0x00 00000200 |   |   |               |    |               |
| 32    | 32    | 4      | 10            | 0x04 07060504  | 1(TX)     | 0x04 00000301 |   |   |               |    |               |
| 52    | 52    | 4      | 10            | 0,04 07 000304 | (17)      | 0x08 00000604 |   |   |               |    |               |
|       |       |        |               |                |           | 0x0C 00000705 |   |   |               |    |               |
|       |       |        |               |                |           | 0x00 0000000  |   |   |               |    |               |
| 32    | 32    | 4      | 11            | 0x00 03020100  | 1(TX)     | 0x04 00000001 |   |   |               |    |               |
| 52    | 52    | -      |               | 0,00 03020100  |           | 0x08 00000002 |   |   |               |    |               |
|       |       |        |               |                |           | 0x0C 00000003 |   |   |               |    |               |
|       |       | Λ      | 4             | 1              | Л         | Л             | 4 |   | 0x00 03020100 |    | 0x00 03020100 |
| 32    | 32    |        |               |                |           |               |   | 4 | 4             | 00 | 0x04 07060504 |
| 52    | 52    | 4      | 00            | 0x08 0B0A0908  | 0(11)     | 0x08 0B0A0908 |   |   |               |    |               |
|       |       |        |               | 0x0C 0F0E0D0C  |           | 0x0C 0F0E0D0C |   |   |               |    |               |
|       |       |        |               | 0x00 03020100  |           |               |   |   |               |    |               |
| 32    | 32    | 4      | 01            | 0x04 07060504  | 0(RX)     | 0x00 05040100 |   |   |               |    |               |
| 52    | 32    | 4      | UT            | 0x08 0B0A0908  |           | 0x04 0D0C0908 |   |   |               |    |               |
|       |       |        |               | 0x0C 0F0E0D0C  |           |               |   |   |               |    |               |
|       |       |        |               | 0x00 03020100  |           |               |   |   |               |    |               |
| 32    | 32    | 4      | 10            | 0x04 07060504  | 0(RX)     | 0x00 05010400 |   |   |               |    |               |
| 52    | 32    | 4      | 10            | 0x08 0B0A0908  |           | 0x04 0D090C08 |   |   |               |    |               |
|       |       |        |               | 0x0C 0F0E0D0C  |           |               |   |   |               |    |               |
|       |       |        |               | 0x00 03020100  |           |               |   |   |               |    |               |
| 32    | 32    | 4      | 11            | 0x04 07060504  | 0(RX)     | 0x00 0c080400 |   |   |               |    |               |
| 32    | 32    | 4      |               | 0x08 0B0A0908  |           |               |   |   |               |    |               |
|       |       |        |               | 0x0C 0F0E0D0C  |           |               |   |   |               |    |               |

## 20.6 Memory map and register descriptions

#### Table 20-3 DMA register map

#### DMA Base address: 0x40012000

| ADDRESS  | TITLE           | DESCRIPTION        |
|----------|-----------------|--------------------|
| DMA+0x00 | DMA_TOP_RST     | General DMA reset  |
| DMA+0x40 | CHANNELx_STATUS | flag               |
| DMA+0x44 | CHANNELx_INTEN  | Interrupt enable   |
| DMA+0x48 | CHANNELx_RST    | Channel reset      |
| DMA+0x4C | CHANNELx_STOP   | DMA channel stop   |
| DMA+0x50 | CHANNELx_CONFIG | DMA channel config |
|          |                 | •                  |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 273 of 360

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.



| ADDRESS  | TITLE                             | DESCRIPTION                |
|----------|-----------------------------------|----------------------------|
| DMA+0x54 | CHANNELx_CHAN_LENGTH              | DMA channel length         |
| DMA+0x58 | CHANNELx_MEM_START_ADDR           | Memory start address       |
| DMA+0x5C | CHANNELx_MEM_END_ADDR             | Memory end address         |
| DMA+0x60 | CHANNELx_PERIPH_ADDR              | Channel peripheral address |
| DMA+0x64 | CHANNELx_CHAN_ENABLE              | Channel enable             |
| DMA+0x68 | CHANNELx_DATA_TRANS_NUM           | Data transfer number       |
| DMA+0x6C | CHANNELx_INTER_FIFO_DATA_LEFT_NUM | data left in inter fifo    |

DMA\_TOP\_RST register

OFFSET ADDR = 12'h00

| -     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |          |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17       | 16       |
| R     |    |    |    |    |    |    |    |    |    | 0  |    |    |    |    |          |          |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |          |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0        |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1        | 0        |
| R     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | HARD_RST | WARM_RST |
| w     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |          |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0        |

| Bit(s) | Name     | Description                                                          |
|--------|----------|----------------------------------------------------------------------|
|        |          | General DMA hard reset (reset regardless of the current transaction) |
|        |          | SW sets ' HARD_RST ' to 1 then sets ' HARD_RST ' back to 0, and the  |
| 1      | HARD_RST | reset mechanism is finished.                                         |
|        |          | 0: Disable                                                           |
|        |          | 1: Enable                                                            |
|        |          | General DMA soft reset (reset after the current transaction)         |
|        |          | SW sets ' WARM_RST ' to 1 and HW clears ' WARM_RST ' back to 0, and  |
| 0      | WARM_RST | the reset mechanism is finished.                                     |
|        |          | 0: Disable                                                           |
|        |          | 1: Enable                                                            |

| CHAN      | NEL | x_S | ΓΑΤ | JS re | egist | er     |        | OF     | FSE    | T AD   | DDR    | = 12   | 'h40   | )               |                 |            |
|-----------|-----|-----|-----|-------|-------|--------|--------|--------|--------|--------|--------|--------|--------|-----------------|-----------------|------------|
| Bit       | 31  | 30  | 29  | 28    | 27    | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 18              | 17              | 16         |
| R         |     |     |     |       |       |        |        |        |        |        | 0      |        |        |                 |                 |            |
| W         |     |     |     |       |       |        |        |        |        |        |        |        |        |                 |                 |            |
| Rese<br>t | 0   | 0   | 0   | 0     | 0     | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0               | 0               | 0          |
| Bit       | 15  | 14  | 13  | 12    | 11    | 1<br>0 | 9      | 8      | 7      | 6      | 5      | 4      | 3      | 2               | 1               | 0          |
| R         |     |     |     |       |       |        | 0      |        |        |        |        |        |        | TRANS_ERRO<br>R | HALF_FINIS<br>H | FINIS<br>H |
| W         |     |     |     |       |       |        |        |        |        |        |        |        |        | W0C             | W0C             | W0C        |
| Rese<br>t | 0   | 0   | 0   | 0     | 0     | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0               | 0               | 0          |

| Bit(s) | Name        | Description                                                                                                                        |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
|        |             | Transfer Error Flag                                                                                                                |
| 2      | TRANS_ERROR | Indicate when channel n reading or writing, whether or not error flag occurred .write "0"to this bit, clear status.                |
|        |             | 0: Error not happened                                                                                                              |
|        |             | 1: Error happened                                                                                                                  |
|        | HALF_FINISH | Half Finish Flag                                                                                                                   |
| 1      |             | Indicate when channel n reading or writing, whether or not half Number of Data transferred. write "0"to this bit, clear status.    |
|        |             | 0: Half of data not finished                                                                                                       |
|        |             | 1: Half of data finished                                                                                                           |
|        |             | Finish Flag                                                                                                                        |
| 0      | FINISH      | Indicate when channel n reading or writing, whether or not DMA channel finished data transfer. write "0"to this bit, clear status. |
|        |             | 0: Data transfer not finished                                                                                                      |
|        |             | 1: Data transfer finished                                                                                                          |

| CHAN      | NEL    | x_IN   | ITEN   | l reg  | jiste  | r      |        | OF     | FSE    | ET A   | DDR    | 2 = 1  | 2'h4   | 4                     |                       |                      |
|-----------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|-----------------------|-----------------------|----------------------|
| Bit       | 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 18                    | 17                    | 16                   |
| R         |        |        |        |        |        |        |        |        |        |        |        |        |        |                       |                       |                      |
| W         |        |        |        |        |        |        |        |        |        |        |        |        |        |                       |                       |                      |
| Rese<br>t | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0                     | 0                     | 0                    |
| Bit       | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 11     | 1<br>0 | 9      | 8      | 7      | 6      | 5      | 4      | 3      | 2                     | 1                     | 0                    |
| R         |        |        |        |        |        |        | 0      |        |        |        |        |        |        | TRANS_ERRO            | HALF_FINIS            | FINISH               |
| w         |        |        |        |        |        |        |        |        |        |        |        |        |        | R interrupt<br>enable | H interrupt<br>enable | interrup<br>t enable |
| Rese<br>t | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0                     | 0                     | 0                    |

## CHANNELY STATUS register

AutoChips Confidential (

© 2013 - 2021 AutoChips Inc.

Page 275 of 360

| Bit(s) | Name             | Description                              |
|--------|------------------|------------------------------------------|
|        |                  | TRANS_ERROR interrupt enable             |
| 2      | TRANS_ERROR      | This bit is set and cleared by software. |
| 2      | interrupt enable | 0: interrupt disabled                    |
|        |                  | 1: interrupt enabled                     |
|        |                  | HALF_FINISH interrupt enable             |
| 1      | HALF_FINISH      | This bit is set and cleared by software. |
| 1      | interrupt enable | 0: interrupt disabled                    |
|        |                  | 1: interrupt enabled                     |
|        |                  | FINISH interrupt enable                  |
| 0      | FINISH interrupt | This bit is set and cleared by software. |
| 0      | enable           | 0: interrupt disabled                    |
|        |                  | 1: interrupt enabled                     |

#### CHANNELx\_RST register

#### OFFSET ADDR = 12'h48

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18      | 17       | 16       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----------|----------|
| R     |    |    |    |    |    |    |    |    |    | (  | 0  |    |    |         |          |          |
| w     |    |    |    |    |    |    |    |    |    |    |    |    |    |         |          |          |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0        | 0        |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2       | 1        | 0        |
| R     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | FLUSH   | HARD_RST | WARM_RST |
| w     |    |    |    |    |    |    |    |    |    |    |    |    |    | 1 20011 |          |          |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0        | 0        |

| Bit(s) | Name     | Description                                                                                                                                       |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------|
|        |          | DMA channel flush                                                                                                                                 |
|        |          | Setting FLUSH = 1 will stop DMA and allow DMA to flush its internal buffer residual data to the memory. After the flush is finished, DMA will set |
| 2      | FLUSH    | channel enable to 0 and stop DMA.                                                                                                                 |
|        |          | SW sets $FLUSH = 1$ and waits for HW to be clear to 0.                                                                                            |
|        |          | 0: Disable                                                                                                                                        |
|        |          | 1: Enable                                                                                                                                         |
|        |          | DMA channel hard reset (reset regardless of the current transaction)                                                                              |
| 1      | HARD_RST | SW sets 'HARD_RST' to 1 then sets 'HARD_RST' back to 0, and the reset mechanism is finished.                                                      |
|        |          | 0: Disable                                                                                                                                        |
|        |          | 1: Enable                                                                                                                                         |
|        |          | DMA channel soft reset (reset after the current transaction)                                                                                      |
| 0      | WARM_RST | SW sets 'WARM_RST' to 1 then HW sets 'WARM_RST' back to 0, and the reset mechanism is finished.                                                   |
|        |          | 0: Disable                                                                                                                                        |
|        |          | 1: Enable                                                                                                                                         |

© 2013 - 2021 AutoChips Inc.

#### CHANNELx\_STOP register

OFFSET ADDR = 12'h4C

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|
| R     |    |    |    |    |    |    |    |    |    | 0  |    |    |    |    |    |      |
| w     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
| R     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | STOP |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0101 |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |

| Bit(s) | Name | Description                                                                                                             |
|--------|------|-------------------------------------------------------------------------------------------------------------------------|
|        |      | DMA channel stop (stop after the current transaction)                                                                   |
| 0      | STOP | SW sets ' STOP ' to 1 then after current transaction, transfer paused, SW sets ' STOP ' to 0 then resume data transfer. |
|        |      | 0: Not stop channel transfer<br>1: STOP channel transfer                                                                |

| СН       | ANN    | IEL    | x_C    | ONFI | G regi      | ister    | OF | FSET ADDF |                   |                 |        |        |        |             |             |          |
|----------|--------|--------|--------|------|-------------|----------|----|-----------|-------------------|-----------------|--------|--------|--------|-------------|-------------|----------|
| Bit      | 3<br>1 | 3<br>0 | 2<br>9 | 28   | 27          | 26       | 25 | 24        | 23                | 22              | 2<br>1 | 2<br>0 | 1<br>9 | 18          | 17          | 16       |
| R        | 0      | 0      | 0      | 0    | 0           | 0        | 0  | 0         | 0                 | 0               | 0      | 0      | 0      | 0           | 0           | 0        |
| W        | 0      | 0      | 0      | 0    | 0           | 0        | 0  | 0         | 0                 | 0               | 0      | 0      | 0      | 0           | 0           | 0        |
| Re<br>se | 0      | 0      | 0      | 0    | 0           | 0        | 0  | 0         | 0                 | 0               | 0      | 0      | 0      | 0           | 0           | 0        |
| t        | 0      | 0      | 0      | 0    | 0           | 0        | 0  | 0         | 0                 | 0               | 0      | 0      | 0      | 0           | 0           | 0        |
| Bit      | 1<br>5 | 1<br>4 | 1<br>3 | 12   | 11          | 10       | 9  | 8         | 7                 | 6               | 5      | 4      | 3      | 2           | 1           | 0        |
| R        | 0      | 0      | 0      |      |             | СН       |    |           |                   |                 |        |        |        |             |             | MEM      |
| w        | 0      | 0      | 0      |      | _BYT<br>ODE | _DI<br>R |    |           | MEM_INC<br>REMENT | PERIPH<br>_SIZE |        |        |        | CHAI<br>IOR | N_PR<br>ITY | 2ME<br>M |
| Re       |        |        |        |      |             |          |    |           |                   |                 |        |        |        |             |             |          |

| Name          | Description                             |
|---------------|-----------------------------------------|
|               | Indicate MEM word split transfer number |
|               | 00: 1                                   |
| MEM_BYTE_MODE | 01:2                                    |
|               | 10:2                                    |
|               | 11: 4                                   |
|               | Indicate Data transfer direction        |
| CHAN_DIR      | 0: read from Peripheral                 |
|               |                                         |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

| Bit(s) | Name           | Description                         |
|--------|----------------|-------------------------------------|
|        |                | 1: read from MEM                    |
| 9      | CHAN_CIRCULAR  | 0: Circular mode disable            |
| 5      | ONAN_ONCOLAR   | 1: Circular mode enable             |
| 8      | PERIPH_INCREME | 0: Peripheral address fixed         |
| 0      | NT             | 1: Peripheral address increment     |
| 7      | MEM_INCREMENT  | 0: MEM address fixed                |
| 1      |                | 1: MEM address increment            |
|        |                | 00: 8bit                            |
| 6:5    | PERIPH _SIZE   | 01:16bit                            |
| 0.0    |                | 10:32bit                            |
|        |                | 11: reserve                         |
|        |                | 00: 8bit                            |
| 4:3    | MEM _SIZE      | 01:16bit                            |
| 4.0    |                | 10:32bit                            |
|        |                | 11: reserve                         |
|        |                | 00: low                             |
| 2:1    | CHAN_PRIORITY  | 01: middle                          |
|        |                | 10: high                            |
|        |                | 11: very high                       |
| 0      | MEM2MEM        | 0: transfer between non MEM and MEM |
| U      |                | 1: transfer between MEM and MEM     |

### CHANNELx\_CHAN\_LENGTH register

#### OFFSET ADDR = 12'h54

|       |    |    |    |    |    | ·  |    |    |       |    |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| R     |    |    |    |    |    |    |    |    | 0     |    |    |    |    |    |    |    |
| w     |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     |    |    |    |    |    |    |    | CL | IAN_L |    | 4  |    |    |    |    |    |
| w     |    |    |    |    |    |    |    |    |       |    | •  |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
|       |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |

| Bit(s) | Name        | Description                 |
|--------|-------------|-----------------------------|
|        |             | DMA channel Transfer length |
| 15:0   | CHAN_LENGTH | 0~32767                     |
|        |             | [15]bit should be 0         |

AutoChips Confidential

#### CHANNELx\_MEM\_START\_ADDR register

OFFSET ADDR = 12'h58

| Bit   | 31 | 30                    | 29 | 28 | 27 | 26 | 25 | 24    | 23   | 22 | 21     | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----------------------|----|----|----|----|----|-------|------|----|--------|----|----|----|----|----|
| R     |    | MEM_START_ADDR[31:16] |    |    |    |    |    |       |      |    |        |    |    |    |    |    |
| w     |    |                       |    |    |    |    |    |       |      |    |        |    |    |    |    |    |
| Reset | 0  | 0                     | 0  | 0  | 0  | 0  | 0  | 0     | 0    | 0  | 0      | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14                    | 13 | 12 | 11 | 10 | 9  | 8     | 7    | 6  | 5      | 4  | 3  | 2  | 1  | 0  |
| R     |    |                       |    |    |    |    | м  | IFM S | TART |    | [15:0] |    |    |    |    |    |
| W     |    |                       |    |    |    |    |    | 0     |      |    | [13.0] |    |    |    |    |    |
| Reset | 0  | 0                     | 0  | 0  | 0  | 0  | 0  | 0     | 0    | 0  | 0      | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name          | Description             |
|--------|---------------|-------------------------|
| 31:0   | MEM_START_ADD | MEM_START_ADDR          |
| 31.0   | R             | Memory initial address. |

#### CHANNELx\_MEM\_END\_ADDR register

OFFSET ADDR = 12'h5C

| Bit   | 31 | 30                  | 29 | 28 | 27 | 26 | 25 | 24        | 23     | 22     | 21    | 20 | 19 | 18 | 17 | 16 |
|-------|----|---------------------|----|----|----|----|----|-----------|--------|--------|-------|----|----|----|----|----|
| R     |    | MEM_END_ADDR[31:16] |    |    |    |    |    |           |        |        |       |    |    |    |    |    |
| W     |    |                     |    |    |    |    |    | VI LIVI_L | -110_7 | נואשש  | ,     |    |    |    |    |    |
| Reset | 0  | 0                   | 0  | 0  | 0  | 0  | 0  | 0         | 0      | 0      | 0     | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14                  | 13 | 12 | 11 | 10 | 9  | 8         | 7      | 6      | 5     | 4  | 3  | 2  | 1  | 0  |
| R     |    |                     |    |    |    |    |    | мем і     |        | ז פחח. | 15-01 |    |    |    |    |    |
| w     |    | MEM_END_ADDR [15:0] |    |    |    |    |    |           |        |        |       |    |    |    |    |    |
| Reset | 0  | 0                   | 0  | 0  | 0  | 0  | 0  | 0         | 0      | 0      | 0     | 0  | 0  | 0  | 0  | 0  |
|       |    |                     |    |    |    |    |    |           |        |        |       |    |    |    |    |    |

| Bit(s) | Name         | Description                                                    |
|--------|--------------|----------------------------------------------------------------|
|        |              | MEM_END_ADDR                                                   |
| 31:0   | MEM_END_ADDR | After read or write MEM_END_ADDR -1, the DMA master returns to |
|        |              | MEM_START_ADDR address to continue handling.                   |

#### CHANNELx\_PERIPH\_ADDR register OFFSET ADDR = 12'h60

| Bit   | 31 | 30                 | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22     | 21   | 20 | 19 | 18 | 17 | 16 |
|-------|----|--------------------|----|----|----|----|----|------|-------|--------|------|----|----|----|----|----|
| R     |    | PERIPH_ADDR[31:16] |    |    |    |    |    |      |       |        |      |    |    |    |    |    |
| w     |    | PERIFI ADDR[31.10] |    |    |    |    |    |      |       |        |      |    |    |    |    |    |
| Reset | 0  | 0                  | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0      | 0    | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14                 | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6      | 5    | 4  | 3  | 2  | 1  | 0  |
| R     |    |                    |    |    |    |    |    | PERI | рн аг | יוזאטנ | 5-01 |    |    |    |    |    |
| W     |    | PERIPH_ADDR[15:0]  |    |    |    |    |    |      |       |        |      |    |    |    |    |    |
| Reset | 0  | 0                  | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0      | 0    | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name        | Description |
|--------|-------------|-------------|
| 31:0   | PERIPH_ADDR | PERIPH_ADDR |

© 2013 - 2021 AutoChips Inc.

Page 279 of 360

| CH    | CHANNELx_CHAN_ENABLE register |    |    |    |    |    |    |    |    | FSET |    | )R = ′ | 12'h6 | 4  |    |             |
|-------|-------------------------------|----|----|----|----|----|----|----|----|------|----|--------|-------|----|----|-------------|
| Bit   | 31                            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21 | 20     | 19    | 18 | 17 | 16          |
| R     |                               |    |    |    |    |    |    |    |    | 0    |    |        |       |    |    |             |
| w     |                               |    |    |    |    |    |    |    |    |      |    |        |       |    |    |             |
| Reset | 0                             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0      | 0     | 0  | 0  | 0           |
| Bit   | 15                            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6    | 5  | 4      | 3     | 2  | 1  | 0           |
| R     | 0                             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0      | 0     | 0  | 0  | CHAN ENABLE |
| w     |                               |    |    |    |    |    |    |    |    |      |    |        |       |    |    | CHAN_ENABLE |
| Reset | 0                             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0      | 0     | 0  | 0  | 0           |
|       |                               |    |    |    |    |    |    |    |    |      |    |        |       |    |    |             |

| Bit(s) | Name        | Description                                                                                                                                                                                                                 |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |             | Channel enable                                                                                                                                                                                                              |
|        |             | In non-channel circular mode, SW set CHAN_ENABLE to 1, and when<br>transfer finish, HW clear CHAN_ENABLE to 0;                                                                                                              |
| 0      | CHAN_ENABLE | In channel circular mode, SW set CHAN_ENABLE to 1, when transfer finish, HW restart new transfer with the same configuration; If you need to disable the DMA channel, you must disable the DMA channel circular mode first. |
|        |             | 0: disable channel                                                                                                                                                                                                          |
|        |             | 1: enable channel                                                                                                                                                                                                           |

#### CHANNELx\_DATA\_TRANS\_NUM register OFFSET ADDR = 12'h68

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|-------|-------|----|----|----|----|----|----|----|
| R     |    |    |    |    |    |    |    | (     | )     |    |    |    |    |    |    |    |
| w     |    |    |    |    |    |    |    |       |       |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     |    |    |    |    |    |    | DA | TA_TR | ANS_N | UM |    |    |    |    |    |    |
| w     |    |    |    |    |    |    |    |       |       |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name           | Description                                   |
|--------|----------------|-----------------------------------------------|
| 15:0   | DATA TRANS NUM | DATA_TRANS_NUM                                |
| 15.0   |                | Indicated how many data have been transferred |

| <br>_ | —                  | _            |                   |                             |                                  |                                                                                                                                                               |                                                                                                                                                                                                                        |                                                                                                                                                               |                                                                                                                                                                            |                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|--------------------|--------------|-------------------|-----------------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | 30                 | 29           | 28                | 27                          | 26                               | 25                                                                                                                                                            | 24                                                                                                                                                                                                                     | 23                                                                                                                                                            | 22                                                                                                                                                                         | 21                                                                                                                                                                                                  | 20                                                                                                                                                                                                                                                                                            | 19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 18                                                                                                                                                                                                                                                                                     | 17                                                                                                                                                                                                                                                                                                                                                                                                                      | 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |                    |              |                   |                             |                                  | 0                                                                                                                                                             |                                                                                                                                                                                                                        |                                                                                                                                                               |                                                                                                                                                                            |                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       |                    |              |                   |                             |                                  |                                                                                                                                                               |                                                                                                                                                                                                                        |                                                                                                                                                               |                                                                                                                                                                            |                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0     | 0                  | 0            | 0                 | 0                           | 0                                | 0                                                                                                                                                             | 0                                                                                                                                                                                                                      | 0                                                                                                                                                             | 0                                                                                                                                                                          | 0                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15    | 14                 | 13           | 12                | 11                          | 10                               | 9                                                                                                                                                             | 8                                                                                                                                                                                                                      | 7                                                                                                                                                             | 6                                                                                                                                                                          | 5                                                                                                                                                                                                   | 4                                                                                                                                                                                                                                                                                             | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 2                                                                                                                                                                                                                                                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       |                    |              | 0                 |                             |                                  |                                                                                                                                                               |                                                                                                                                                                                                                        |                                                                                                                                                               |                                                                                                                                                                            | INT                                                                                                                                                                                                 | ER_FI                                                                                                                                                                                                                                                                                         | FO_DA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ATA_LE                                                                                                                                                                                                                                                                                 | EFT_N                                                                                                                                                                                                                                                                                                                                                                                                                   | UM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |                    |              |                   |                             |                                  |                                                                                                                                                               |                                                                                                                                                                                                                        |                                                                                                                                                               |                                                                                                                                                                            |                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0     | 0                  | 0            | 0                 | 0                           | 0                                | 0                                                                                                                                                             | 0                                                                                                                                                                                                                      | 0                                                                                                                                                             | 0                                                                                                                                                                          | 0                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       | 31<br>0<br>15<br>0 | 0 0<br>15 14 | 0 0 0<br>15 14 13 | 0 0 0 0<br>15 14 13 12<br>0 | 0 0 0 0 0<br>15 14 13 12 11<br>0 | 31     30     29     28     27     26       0     0     0     0     0     0       15     14     13     12     11     10       0     0     0     0     0     0 | 31     30     29     28     27     26     25       0     0     0     0     0     0       0     0     0     0     0     0       15     14     13     12     11     10     9       0     0     0     0     0     0     0 | 31     30     29     28     27     26     25     24       0     0     0     0     0     0     0     0       15     14     13     12     11     10     9     8 | 31     30     29     28     27     26     25     24     23       0     0     0     0     0     0     0     0       15     14     13     12     11     10     9     8     7 | 31     30     29     28     27     26     25     24     23     22       0     0     0     0     0     0     0     0     0     0       15     14     13     12     11     10     9     8     7     6 | 31     30     29     28     27     26     25     24     23     22     21       0     0     0     0     0     0     0     0     0     0     0       15     14     13     12     11     10     9     8     7     6     5       0     0     0     0     0     0     0     10     9     10     10 | 31       30       29       28       27       26       25       24       23       22       21       20         0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0 | 31     30     29     28     27     26     25     24     23     22     21     20     19       0     0     0     0     0     0     0     0     0     0     0     0       15     14     13     12     11     10     9     8     7     6     5     4     3       0     U     INTER_FIFO_DA | 31     30     29     28     27     26     25     24     23     22     21     20     19     18       0     0     0     0     0     0     0     0     0     0     0     0       0     0     0     0     0     0     0     0     0     0     0     0       15     14     13     12     11     10     9     8     7     6     5     4     3     2       0     0     0     0     9     8     7     6     5     4     3     2 | 31       30       29       28       27       26       25       24       23       22       21       20       19       18       17         0       0       0       0       0       0       0       0       0       19       18       17         0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       10       11       10       9       8       7       6       5       4       3       2       1       1       11       10       9       8       7       6 <td< th=""></td<> |

| Bit(s) | Name            | Description                                                                                                |
|--------|-----------------|------------------------------------------------------------------------------------------------------------|
| 5.0    | INTER_FIFO_DATA | INTER_FIFO_DATA_LEFT_NUM<br>Indicated how many byte data left in inter fifo. usually used it together with |
| 5:0    | _LEFT_NUM       | FLUSH. When Time out, and INTER_FIFO_DATA_LEFT_NUM not equal to 0,then SW can start flush process.         |

## **//utoChips**

## 21 WDT

## 21.1 Introduction

The Watchdog Timer (WDOG) module is an independent timer that is available for system use. It provides a safety feature to ensure that software is executing as planned and that the CPU is not stuck in an infinite loop or executing unintended code. If the WDOG module is not serviced (refreshed) within a certain period, it resets the MCU.

## 21.2 Features

- Configurable clock source inputs independent from the bus clock.
  - Internal 32 kHz RC oscillator.
  - Internal 8 MHz RC oscillator.
  - External XOSC clock source.
- Programmable timeout period.
  - Programmable 32-bit timeout value.
  - o Optional fixed 256 clock prescaler when longer timeout periods are needed.
- Robust write sequence for counter refresh
  - Refresh sequence of writing 0x02A602A6 and then 0x80B480B4.
- Window mode option for the refresh mechanism
  - Programmable 32-bit window value.
  - Provides robust check that program flow is faster than expected.
  - Early refresh attempts trigger a reset.
- Optional timeout interrupt to allow post-processing diagnostics
  - o Interrupt request to CPU with interrupt vector for an interrupt service routine.
  - Forced reset occurs 128 bus clocks after the interrupt vector fetch.
- Configuration bits are write-once-after-reset to ensure watchdog configuration cannot be mistakenly altered.
- Robust write sequence for unlocking write-once configuration bits.
  - Unlock sequence of writing 0x20C520C5 and then 0x28D928D9 for allowing updates to write-once configuration bits.
  - Software must make updates within 128 bus clocks after unlocking and before WDOG closing unlock window.



## 21.3 Block diagram





## 21.4 Mode of operation

WDG is always running with Internal 32 kHz RC oscillator even if microcontroller has entered STOP mode. Therefore, the user should make sure disabled WDG if doesn't feed WDG during STOP mode to avoid unexpected system reset.

## 21.5 Memory map and register descriptions

#### Table 21-1 WDG register map

|   | ADDRESS               | TITLE   | DESCRIPTION             |                 |
|---|-----------------------|---------|-------------------------|-----------------|
|   | WDG+0x00              | WDT_CS1 | Watchdog Status         |                 |
| ł | AutoChips Confidentia | l © 201 | 3 - 2021 AutoChips Inc. | Page 283 of 360 |

### WDG Base address: 0x4000b000

© 2013 - 2021 AutoChips Inc.

Page 283 of 360



| ADDRESS  | TITLE     | DESCRIPTION            |
|----------|-----------|------------------------|
| WDG+0x04 | WDT_CS2   | Watchdog Status        |
| WDG+0x08 | WDT_CNT   | Watchdog Counter       |
| WDG+0x0C | WDT_TOVAL | Watchdog Timeout Value |
| WDG+0x10 | WDT_WIN   | Watchdog Window        |

| WDT_  | CS1 r | egist     | er |    |    | OFFSET ADDR = 12'h00 |    |    |    |     |        |    |    |    |    |    |  |
|-------|-------|-----------|----|----|----|----------------------|----|----|----|-----|--------|----|----|----|----|----|--|
| Bit   | 31    | 30        | 29 | 28 | 27 | 26                   | 25 | 24 | 23 | 22  | 21     | 20 | 19 | 18 | 17 | 16 |  |
| R     |       |           |    |    |    |                      |    |    |    | 0   |        |    |    |    |    |    |  |
| w     |       |           |    |    |    |                      |    |    |    |     |        |    |    |    |    |    |  |
| Reset | 0     | 0         | 0  | 0  | 0  | 0                    | 0  | 0  | 0  | 0   | 0      | 0  | 0  | 0  | 0  | 0  |  |
| Bit   | 15    | 14        | 13 | 12 | 11 | 10                   | 9  | 8  | 7  | 6   | 5      | 4  | 3  | 2  | 1  | 0  |  |
| R     |       |           |    | (  | )  |                      |    |    | EN | INT | UPDATE |    | 0  |    | (  | )  |  |
| w     |       |           |    |    |    |                      |    |    |    |     |        |    |    |    |    |    |  |
| Reset | 0     | 0 0 0 0 0 |    |    | 0  | 0                    | 0  | 0  | 1  | 0   | 1      | 0  | 0  | 0  | 0  | 0  |  |

| Bit(s) | Name   | Description                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|        |        | Watchdog Enable                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| 7      | EN     | This write-once bit enables the watchdog counter to start counting.                                                                                                                                                                                                  |  |  |  |  |  |  |
|        |        | 0 Watchdog disabled.                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|        |        | 1 Watchdog enabled.                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|        |        | Watchdog Interrupt                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| 6      | INT    | This write-once bit configures the watchdog to generate an interrupt request upon a reset-triggering event (timeout or illegal write to the watchdog), prior to forcing a reset. After the interrupt vector fetch, the reset occurs after a delay of 128 bus clocks. |  |  |  |  |  |  |
|        |        | 0 Watchdog interrupts are disabled. Watchdog resets are not delayed.                                                                                                                                                                                                 |  |  |  |  |  |  |
|        |        | 1 Watchdog interrupts are enabled. Watchdog resets are delayed by 128 bus clocks.                                                                                                                                                                                    |  |  |  |  |  |  |
|        |        | Allow updates                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|        |        | This write-once bit allows software to reconfigure the watchdog without a reset.                                                                                                                                                                                     |  |  |  |  |  |  |
| 5      | UPDATE | 0 Updates not allowed. After the initial configuration, the watchdog cannot be later modified without forcing a reset.                                                                                                                                               |  |  |  |  |  |  |
|        |        | 1 Updates allowed. Software can modify the watchdog configuration registers within 128 bus clocks after performing the unlock write seque                                                                                                                            |  |  |  |  |  |  |

| WDT_  | CS2 r           | egist | ter |    | 0  | FFSE | et ac | DR = | = 12'h0 |     |    |      |    |    |    |     |
|-------|-----------------|-------|-----|----|----|------|-------|------|---------|-----|----|------|----|----|----|-----|
| Bit   | 31              | 30    | 29  | 28 | 27 | 26   | 25    | 24   | 23      | 22  | 21 | 20   | 19 | 18 | 17 | 16  |
| R     |                 |       |     |    |    |      |       |      | (       | )   |    |      |    |    |    |     |
| W     |                 |       |     |    |    |      |       |      |         |     |    |      |    |    |    |     |
| Reset | 0               | 0     | 0   | 0  | 0  | 0    | 0     | 0    | 0       | 0   | 0  | 0    | 0  | 0  | 0  | 0   |
| Bit   | 15              | 14    | 13  | 12 | 11 | 10   | 9     | 8    | 7       | 6   | 5  | 4    | 3  | 2  | 1  | 0   |
| R     |                 |       |     | (  | )  |      |       |      | WIN     | FLG | 0  | PRES |    | 0  | CI | к   |
| W     |                 |       |     |    |    |      |       |      |         | w1c |    |      |    |    |    | -13 |
| Reset | 0 0 0 0 0 0 0 0 |       |     |    |    |      | 0     | 0    | 0       | 0   | 0  | 0    | 0  | 0  | 0  |     |

| Bit(s) | Name  | Description                                                              |
|--------|-------|--------------------------------------------------------------------------|
|        |       | Watchdog Window                                                          |
| 7      | WIN   | This write-once bit enables window mode.                                 |
| 7      | VVIIN | 0 Window mode disabled.                                                  |
|        |       | 1 Window mode enabled.                                                   |
|        |       | Watchdog Interrupt Flag                                                  |
|        |       | This bit is an interrupt indicator when INT is set in control and status |
| 6      | FLG   | register 1. Write 1 to clear it.                                         |
|        |       | 0 No interrupt occurred.                                                 |
|        |       | 1 An interrupt occurred.                                                 |
|        |       | Watchdog Prescalar                                                       |
|        |       | This write-once bit enables a fixed 256 pre-scaling of watchdog counter  |
| 4      | PRES  | reference clock. (The block diagram shows this clock divider option.)    |
|        |       | 0 256 prescalar disabled.                                                |
|        |       | 1 256 prescalar enabled.                                                 |
|        |       | Watchdog Clock                                                           |
|        |       | This write-once field indicates the clock source that feeds the watchdog |
|        |       | counter.                                                                 |
| 1:0    | CLK   | 00 Bus clock.                                                            |
|        |       | 01 32 kHz internal low-power oscillator (LPOSC).                         |
|        |       | 10 8 MHz internal oscillator (LFOSC).                                    |
|        |       | 11 External clock source(XOSC).                                          |

#### WDT\_CNT register

OFFSET ADDR = 12'h08

|       |                           | icgi | 3101 |    |    | U  |    |    |      |             |    |    |    |    |    |    |
|-------|---------------------------|------|------|----|----|----|----|----|------|-------------|----|----|----|----|----|----|
| Bit   | 31                        | 30   | 29   | 28 | 27 | 26 | 25 | 24 | 23   | 22          | 21 | 20 | 19 | 18 | 17 | 16 |
| R     |                           |      |      |    | -  |    |    |    | WDT_ | CNT[31:16]  | -  | -  |    | -  | -  |    |
| W     |                           |      |      |    |    |    |    |    |      |             |    |    |    |    |    |    |
| Reset | 0                         | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0    | 0           | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | t 15 14 13 12 11 10 9 8 7 |      | 7    | 6  | 5  | 4  | 3  | 2  | 1    | 0           |    |    |    |    |    |    |
| R     |                           |      |      |    |    |    |    |    | WDT_ | _CNT [15:0] |    |    |    |    |    |    |
| W     |                           |      |      |    |    |    |    |    |      |             |    |    |    |    |    |    |
| Reset | 0                         | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0    | 0           | 0  | 0  | 0  | 0  | 0  | 0  |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 285 of 360

## **NutoChips**

| Bit(s) | Name           | Description                                                                                                                                                                                                                                                                                                                                    |
|--------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |                | Watchdog Counter Register                                                                                                                                                                                                                                                                                                                      |
| 31:0   | WDT_CNT [31:0] | The watchdog counter registers provide access to the value of the free<br>running watchdog counter. Software can read the counter registers at any<br>time. Software cannot write directly to the watchdog counter; however, two<br>write sequences to these registers have special functions: The refresh<br>sequence and The unlock sequence |

| WDT_  | ۹L re | giste            | ər |    | 0  | OFFSET ADDR = 12'h0C |    |    |    |            |    |    |    |    |    |    |
|-------|-------|------------------|----|----|----|----------------------|----|----|----|------------|----|----|----|----|----|----|
| Bit   | 31    | 30               | 29 | 28 | 27 | 26                   | 25 | 24 | 23 | 22         | 21 | 20 | 19 | 18 | 17 | 16 |
| R     |       | WDT_TOVAL[31:16] |    |    |    |                      |    |    |    |            |    |    |    |    |    |    |
| W     |       |                  |    |    |    |                      |    |    |    |            |    |    |    |    |    |    |
| Reset | 0     | 0                | 0  | 0  | 0  | 0                    | 0  | 0  | 0  | 0          | 1  | 1  | 1  | 1  | 1  | 1  |
| Bit   | 15    | 14               | 13 | 12 | 11 | 10                   | 9  | 8  | 7  | 6          | 5  | 4  | 3  | 2  | 1  | 0  |
| R     |       |                  |    |    |    |                      |    |    |    | /AL [15:0] |    |    |    |    |    |    |
| W     |       |                  |    |    |    |                      |    |    |    |            |    |    |    |    |    |    |
| Reset | 0     | 0                | 0  | 0  | 0  | 0                    | 0  | 0  | 0  | 0          | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name             | Description                                                                                                                                                                                                               |
|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |                  | Watchdog Timeout Value Register                                                                                                                                                                                           |
| 31:0   | WDT_TOVAL [31:0] | The watchdog counter is continuously compared with the timeout value . If<br>the counter reaches the timeout value, the watchdog forces a reset.<br>Counter length equivalent to WDT_TOVAL+1<br>Default value is 0x3f0000 |

| WDT_ | WIN | regis | ster |    |    | OFI | FSET |    | DR = 12'h | n10 |
|------|-----|-------|------|----|----|-----|------|----|-----------|-----|
| Bit  | 31  | 30    | 29   | 28 | 27 | 26  | 25   | 24 | 23        | 22  |

| Bit   | 31 | 30             | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22         | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----------------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|
| R     |    | WDT_WIN[31:16] |    |    |    |    |    |    |    |            |    |    |    |    |    |    |
| w     |    |                |    |    |    |    |    |    |    |            |    |    |    |    |    |    |
| Reset | 0  | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14             | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6          | 5  | 4  | 3  | 2  | 1  | 0  |
| R     |    | WDT_WIN [15:0] |    |    |    |    |    |    |    |            |    |    |    |    |    |    |
| w     |    |                |    |    |    |    |    |    |    | ina [15.0] |    |    |    |    |    |    |
| Reset | 0  | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name           | Description                                                                                                                                                                                |
|--------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | WDT_WIN [31:0] | Watchdog Window Register                                                                                                                                                                   |
|        |                | This section describes the watchdog window registers: When window mode is enabled (WDOG_CS2[WIN] is set),WDOG_WIN determine the earliest time that a refresh sequence is considered valid. |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 286 of 360

## 21.6 Functional description

## 21.6.1 Watchdog refresh mechanism

The watchdog resets the MCU if the watchdog counter is not refreshed. A robust refresh mechanism makes it very unlikely that the watchdog can be refreshed by runaway code. To refresh the watchdog counter, software must execute a refresh write sequence before the timeout period expires. In addition, if window mode is used, software must not start the refresh sequence until after the time value set in the WDOG\_WIN registers.

When Window mode is enabled, the watchdog must be refreshed after the counter has reached a minimum expected time value. Otherwise, the watchdog resets the MCU. The minimum expected time value is specified in the WDOG\_WIN registers. Setting CS2[WIN] enables Window mode.

**The refresh write sequence** is a write of 0x02A602A6 followed by a write of 0x80B480B4 to the WDOG\_CNT registers. The write of the 0x80B480B4 must occur after the write of 0x02A602A6. Otherwise, the watchdog resets the MCU.

### Note: timeout = ( PRES \* (WDT\_CNT+1) )/ CLK

## 21.6.2 Configuring the Watchdog

All watchdog control bits, timeout value, and window value are write-once after reset. This means that after a write has occurred they cannot be changed unless a reset occurs. This provides a robust mechanism to configure the watchdog and ensure that a runaway condition cannot mistakenly disable or modify the watchdog configuration after configured.

This is guaranteed by the user configuring the window and timeout value first, followed by the other control bits, and ensuring that CS1[UPDATE] is also set to 0. The new configuration takes effect only after all registers except WDOG\_CNT are written once after reset. Otherwise, the WDOG uses the reset values by default. If window mode is not used (CS2[WIN] is 0), writing to WDOG\_WIN is not required to make the new configuration take effect.

In some cases (such as when supporting a bootloader function), users may want to reconfigure or disable the watchdog without forcing a reset first. By setting CS1[UPDATE] to 1 on the initial configuration of the watchdog after a reset, users can reconfigure the watchdog at any time by executing an unlock sequence. (Conversely, if CS1[UPDATE] remains 0, the only way to reconfigure the watchdog is by initiating a reset.) The unlock sequence is similar to the refresh sequence but uses different values.

**The unlock sequence** is a write to the WDOG\_CNT registers of 0x20C520C5 followed by 0x28D928D9 at any time after the watchdog has been configured. After completing the unlock sequence, the user must reconfigure the watchdog within 128 bus clocks.

## 21.6.3 Using interrupts to delay watchdog reset

When interrupts are enabled (**WDT\_CS1 reister**[INT] = 1), the watchdog first generates an interrupt request upon a reset triggering event (such as a counter timeout or invalid refresh attempt). The watchdog delays forcing a reset for 128 bus clocks to allow the interrupt service routine (ISR) to perform tasks, such as analyzing the stack to debug code. When interrupts are disabled (**WDT\_CS1 reister** [INT] = 0), the watchdog does not delay forcing a reset.

### 21.6.4 Backup reset

The LPOSC clock must be used as the reference clock for the counter. Otherwise, the backup reset function is not available. The backup reset function is a safeguard feature that independently generates a reset in case the main WDOG logic loses its clock (the bus clock) and can no longer monitor the counter. If the watchdog counter overflows twice in succession (without an intervening reset), the backup reset function takes effect and generates a reset.

© 2013 - 2021 AutoChips Inc.

## **//utoChips**

## 22 RTC

## 22.1 Introduction

The Real-Time Counter (RTC) consists of one 32-bit counter, one 32-bit comparator, several binarybased and decimal-based prescaler dividers, four clock sources, one programmable periodic interrupt, and one programmable external toggle pulse output. This module can be used for time-of-day, calendar or any task scheduling functions. It can also serve as a cyclic wake-up from low-power modes, Stop and Wait without the need of external components.

### 22.2 Features

Features of the RTC module include:

- 32-bit up-counter
  - 32-bit modulo match limit.
  - Software controllable periodic interrupt on match.
- Software selectable clock sources for input to prescaler with programmable 20 bit prescaler.
  - o Bus clock
  - o LPOSC (32 kHz)
  - o External XOSC clock
  - Internal LFOSC clock (8 MHz)
- Tamper detection
  - 1 tamper event on edge detection.
  - o 2 backup registers (8 bytes).

## 22.3 Block diagram



#### Figure 22-1 RTC block diagram

### 22.4 Mode of operation

RTC is running even if microcontroller has entered STOP mode when using LPOSC(32 kHz) as clock source. If user enables RTC interrupt, when RTC times out, it will trigger an interrupt and wake up MCU from STOP mode.

### 22.5 Memory map and register descriptions

#### Table 22-1 RTC register map

#### RTC Base address: 0x40008400

| ADDRESS       | TITLE                 | DESCRIPTION                    |
|---------------|-----------------------|--------------------------------|
| RTC+0x00      | RTC_SC                | Watchdog Status                |
| RTC+0x04      | RTC_MOD               | RTC Modulo                     |
| RTC+0x08      | RTC_Counter           | RTC Count                      |
| RTC+0x0C      | RTC Clock Prescaler   | RTC Clock Prescaler            |
| RTC+0x10      | RTC_Prescaler Counter | RTC Prescaler Counter          |
| RTC+0x20      | BKP_CR                | TAMPER pin active level/enable |
| RTC+0x24      | BKP_CSR               | TAMPER interrupt               |
| RTC+0x28,0x2c | BKP_DRx               | Backup Data                    |

AutoChips Confidential



#### RTC\_SC register

#### OFFSET ADDR = 12'h00

| Bit       | 31  | 30                 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22   | 21 | 20   | 19 | 18 | 17       | 16       |
|-----------|-----|--------------------|----|----|----|----|----|----|------|------|----|------|----|----|----------|----------|
| R         |     | 0 Pcl k_e clk_ sel |    |    |    |    |    |    |      |      |    |      |    |    | RPI<br>F | RPI<br>E |
| W         |     |                    |    |    |    |    |    |    |      |      |    |      |    |    |          |          |
| Res<br>et | 0   | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0  | 0    | 0  | 0  | 0        | 0        |
| Bit       | 15  | 14                 | 13 | 12 | 11 | 10 | 9  | 8  | 7    | 6    | 5  | 4    | 3  | 2  | 1        | 0        |
| R         | RTC |                    | (  | )  |    | (  | )  |    | RTIF | RTIE | 0  | RTCO |    | (  | )        |          |
| W         |     |                    |    |    |    |    |    |    |      |      |    |      |    |    |          |          |
| Res<br>et | 0   | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0  | 0    | 0  | 0  | 0        | 0        |

| Bit(s)      | Name         | Description                                                                                   |  |  |  |  |  |  |  |
|-------------|--------------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|             |              | CLK_CHG_OK: Clock change Ok flag                                                              |  |  |  |  |  |  |  |
| 18          | CLK_CHG_OK   | This status bit indicates the RTC counter clock change state and read only.                   |  |  |  |  |  |  |  |
| 10          |              | 0: RTC counter clock has changed success.                                                     |  |  |  |  |  |  |  |
|             |              | 1: RTC counter clock is changing.                                                             |  |  |  |  |  |  |  |
|             |              | RPIF: Real-Time Prescaler Interrupt Flag                                                      |  |  |  |  |  |  |  |
|             |              | This status bit indicates the RTC Prescaler counter register reached the                      |  |  |  |  |  |  |  |
|             |              | value in the RTC prescaler divider register. Writing a logic 0 has no effect.                 |  |  |  |  |  |  |  |
| 17          | RPIF         | Writing a logic 1 clears the bit and the real-time interrupt request. Reset clears RPIF to 0. |  |  |  |  |  |  |  |
|             |              | 0: RTC Prescaler counter has not reached the value in the RTC prescaler divider register.     |  |  |  |  |  |  |  |
|             |              | 1: RTC Prescaler counter has reached the value in the RTC prescaler divider register.         |  |  |  |  |  |  |  |
|             |              | RPIE: Real-Time Prescaler Interrupt Enable                                                    |  |  |  |  |  |  |  |
|             |              | This read/write bit enables real-time prescaler interrupts. If RPIE is set,                   |  |  |  |  |  |  |  |
| 16          | RPIE         | then an interrupt is generated when RPIF is set. Reset clears RPIE to 0.                      |  |  |  |  |  |  |  |
| 10          | RPIE         | 0: Real-time prescaler interrupt requests are disabled. Use software                          |  |  |  |  |  |  |  |
|             |              | polling.                                                                                      |  |  |  |  |  |  |  |
|             |              | 1: Real-time prescaler interrupt requests are enabled.                                        |  |  |  |  |  |  |  |
|             |              | RTCLKS: Real-Time Clock Source Select                                                         |  |  |  |  |  |  |  |
|             |              | This read/write field selects the clock source input to the RTC prescaler.                    |  |  |  |  |  |  |  |
|             |              | Changing the clock source clears the prescaler and RTCCNT counters.                           |  |  |  |  |  |  |  |
| 15:14       | RTCLKS       | Reset clears RTCLKS to 00. Freq = RTCLKS / ( ( MOD +1) * (RTCPS+1) )                          |  |  |  |  |  |  |  |
| 10.11       |              | 00: Bus clock.                                                                                |  |  |  |  |  |  |  |
|             |              | 01: Internal 32 kHz oscillator (LPOCLK).                                                      |  |  |  |  |  |  |  |
|             |              | 10: External oscillator (XOSC).                                                               |  |  |  |  |  |  |  |
|             |              | 11: Internal 8 MHz oscillator (LFOSC).                                                        |  |  |  |  |  |  |  |
| 7           | RTIF         | RTIF: Real-Time Interrupt Flag                                                                |  |  |  |  |  |  |  |
|             |              | This status bit indicates the RTC counter register reached the value in the                   |  |  |  |  |  |  |  |
| AutoChips ( | Confidential | © 2013 - 2021 AutoChips Inc. Page 291 of 36                                                   |  |  |  |  |  |  |  |

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit(s) | Name | Description                                                                                                                                         |
|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|        |      | RTC modulo register. Writing a logic 0 has no effect. Writing a logic 1 clears the bit and the real-time interrupt request. Reset clears RTIF to 0. |
|        |      | 0: RTC counter has not reached the value in the RTC modulo register.                                                                                |
|        |      | 1: RTC counter has reached the value in the RTC modulo register.                                                                                    |
|        |      | RTIE: Real-Time Interrupt Enable                                                                                                                    |
| 6      | RTIE | This read/write bit enables real-time interrupts. If RTIE is set, then an interrupt is generated when RTIF is set. Reset clears RTIE to 0.          |
|        |      | 0: Real-time interrupt requests are disabled. Use software polling.                                                                                 |
|        |      | 1: Real-time interrupt requests are enabled.                                                                                                        |
|        |      | RTCO: Real-Time Counter Output                                                                                                                      |
| 4      | RTCO | The read/write bit enables real-time to toggle output on pinout. If this bit is set, the RTCO pinout will be toggled when RTC counter overflows.    |
|        |      | 0: Real-time counter output disabled.                                                                                                               |
|        |      | 1: Real-time counter output enabled.                                                                                                                |

#### **RTC\_MOD** register OFFSET ADDR = 12'h04 Bit R MOD[31:16] W Reset Bit R MOD[15:0] W Reset

| Bit(s) | Name      | Description                                                                |
|--------|-----------|----------------------------------------------------------------------------|
|        |           | RTC Modulo                                                                 |
| 31:0   | MOD[31:0] | This read/write field contains the modulo value used to reset the count to |
| 0.110  |           | 0x0 upon a compare match and set SC[RTIF] status field. In normal use,     |
|        |           | MOD should not be equal to 0x0.Reset sets the modulo to 0x0.               |

### RTC\_Counter register

#### OFFSET ADDR = 12'h08

| Bit   | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|
| R     | CNT[31:16] |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |
| w     |            |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |
| Reset | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |
| R     |            |    |    |    |    |    |    |    | CI | NT[15:0] |    |    |    |    |    |    |
| w     |            |    |    |    |    |    |    |    |    |          |    |    |    |    |    |    |
| Reset | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0  | 0  | 0  | 0  |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 292 of 360

| Bit(s) | Name      | Description                                                                   |
|--------|-----------|-------------------------------------------------------------------------------|
|        |           | RTC Count                                                                     |
| 31:0   | CNT[31:0] | This read-only field contains the current value of the 32-bit counter. Writes |
| 0110   | []        | have no effect to this register. Reset or writing different values to         |
|        |           | SC[RTCLKS] and [RTCPS] clear the count to 0x0.                                |

#### **RTC Clock Prescaler**

OFFSET ADDR = 12'h0C

| Bit   | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23       | 22 | 21 | 20 | 19 | 18 | 17    | 16           |  |  |  |  |  |
|-------|-------------|----|----|----|----|----|----|----|----------|----|----|----|----|----|-------|--------------|--|--|--|--|--|
| R     | -           | 0  |    |    |    |    |    |    |          |    |    |    |    |    |       | RTCPS[19:16] |  |  |  |  |  |
| W     |             |    |    |    |    |    |    |    |          |    |    |    |    |    | 13.10 | 1            |  |  |  |  |  |
| Reset | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0  | 0  | 0  | 0     | 0            |  |  |  |  |  |
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7        | 6  | 5  | 4  | 3  | 2  | 1     | 0            |  |  |  |  |  |
| R     |             | -  |    |    |    |    |    | PT | CDS[15.( | 1  | -  |    | -  | _  |       |              |  |  |  |  |  |
| w     | RTCPS[15:0] |    |    |    |    |    |    |    |          |    |    |    |    |    |       |              |  |  |  |  |  |
| Reset | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0  | 0  | 0  | 0     | 0            |  |  |  |  |  |

| Bit(s) | Name  | Description                                                                                           |
|--------|-------|-------------------------------------------------------------------------------------------------------|
|        |       | RTCPS: Real-Time Clock Prescaler Select                                                               |
| 10-0   | RTCPS | This read/write field selects binary-based or decimal-based divide-by values for the clock source.    |
| 19:0   | RICFS | Changing the prescaler value clears the prescaler and RTCCNT counters.<br>Reset clears RTCPS to 0000. |
|        |       | When RTCPS equal 0000, RTC counter Off.                                                               |

#### **RTC\_Prescaler Counter register**

OFFSET ADDR = 12'h10

| Bit   | 31 | 30 | 29 | 28 | 27           | 26 | 25 | 24 | 23   | 22      | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|--------------|----|----|----|------|---------|----|----|----|----|----|----|
| R     |    |    |    |    | PSCNT[19:16] |    |    |    |      |         |    |    |    |    |    |    |
| w     |    |    |    |    |              |    |    |    |      |         |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0            | 0  | 0  | 0  | 0    | 0       | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11           | 10 | 9  | 8  | 7    | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
| R     |    |    |    |    | -            | -  | -  |    | PSCN | T[15:0] | -  | -  |    | -  | -  |    |
| w     |    |    |    |    |              |    |    |    |      |         |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0            | 0  | 0  | 0  | 0    | 0       | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name        | Description                                                                                                                                                                                        |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |             | RTC PSCount                                                                                                                                                                                        |
| 19:0   | PSCNT[31:0] | This read-only field contains the current value of the 20-bit counter. Writes have no effect to this register. Reset or writing different values to SC[RTCLKS] and [RTCPS] clear the count to 0x0. |

| BKP_(                  | CR re | giste | er |    |    |    |    |    |       |    |    |    |    | OF | FSET ADDF | R = 12'h20   |
|------------------------|-------|-------|----|----|----|----|----|----|-------|----|----|----|----|----|-----------|--------------|
| Bit                    | 31    | 30    | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18 | 17        | 16           |
| AutoChips Confidential |       |       |    |    |    |    |    |    | 004 / |    |    |    |    |    | Dea       | - 202 of 260 |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 293 of 360

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-----|
| R     |    | 0  |    |    |    |    |    |    |    |    |    |    |    |    |      |     |
| w     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1    | 0   |
| R     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | TPAL | TPE |
| w     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0   |

| Bit(s) | Name | Description                                                                                                                                                                                                                                        |
|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | TPAL | <ul> <li>TPAL: TAMPER pin active level</li> <li>0: A high level on the TAMPER pin resets all data backup registers (if TPE bit is set).</li> <li>1: A low level on the TAMPER pin resets all data backup registers (if TPE bit is set).</li> </ul> |
| 0      | TPE  | <b>TPE: TAMPER pin enable</b><br>0: The TAMPER pin is free for general purpose I/O<br>1: Tamper alternate I/O function is activated.                                                                                                               |

#### **BKP\_CSR** register

#### OFFSET ADDR = 12'h24

|       |    | •        |        |      |    |    |     |     |          |    |    |    |    |      |     |    |
|-------|----|----------|--------|------|----|----|-----|-----|----------|----|----|----|----|------|-----|----|
| Bit   | 31 | 30       | 29     | 28   | 27 | 26 | 25  | 24  | 23       | 22 | 21 | 20 | 19 | 18   | 17  | 16 |
| R     |    | RESERVED |        |      |    |    |     |     |          |    |    |    |    |      |     |    |
| W     |    | RESERVED |        |      |    |    |     |     |          |    |    |    |    |      |     |    |
| Reset | 0  | 0        | 0      | 0    | 0  | 0  | 0   | 0   | 0        | 0  | 0  | 0  | 0  | 0    | 0   | 0  |
| Bit   | 15 | 14       | 13     | 12   | 11 | 10 | 9   | 8   | 7        | 6  | 5  | 4  | 3  | 2    | 1   | 0  |
| R     |    | -        | PESE   | RVED | _  |    | TIF | TEF |          | PE |    |    |    | TPIE | 0   | 0  |
| W     |    |          | INL OL |      | ·  |    |     |     | RESERVED |    |    |    |    | СТІ  | CTE |    |
| Reset | 0  | 0        | 0      | 0    | 0  | 0  | 0   | 0   | 0        | 0  | 0  | 0  | 0  | 0    | 0   | 0  |

| Bit(s) | Name | Description                                                                                                                                                                                              |  |  |  |  |
|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|        |      | TIF: Tamper interrupt flag                                                                                                                                                                               |  |  |  |  |
| 9      | TIF  | This bit is set by hardware when a Tamper event is detected and the TPIE bit is set. It is cleared by writing 1 to the CTI bit (also clears the interrupt). It is also cleared if the TPIE bit is reset. |  |  |  |  |
|        |      | 0: No Tamper interrupt                                                                                                                                                                                   |  |  |  |  |
|        |      | 1: A Tamper interrupt occurred                                                                                                                                                                           |  |  |  |  |
|        |      | TEF: Tamper event flag                                                                                                                                                                                   |  |  |  |  |
| 8      | TEF  | This bit is set by hardware when a Tamper event is detected. It is cleared by writing 1 to the CTE bit.                                                                                                  |  |  |  |  |
|        |      | 0: No Tamper event                                                                                                                                                                                       |  |  |  |  |
|        |      | 1: A Tamper event occurred                                                                                                                                                                               |  |  |  |  |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

| Bit(s) | Name | Description                                                                      |
|--------|------|----------------------------------------------------------------------------------|
|        |      | TPIE: TAMPER pin interrupt enable                                                |
| 2      | TPIE | 0: Tamper interrupt disabled                                                     |
| 2      |      | 1: Tamper interrupt enabled (the TPE bit must also be set in the BKP_CR register |
|        |      | CTI: Clear tamper interrupt                                                      |
| 1      | СТІ  | This bit is write only, and is always read as 0.                                 |
| I      | CII  | 0: No effect                                                                     |
|        |      | 1: Clear the Tamper interrupt and the TIF Tamper interrupt flag.                 |
|        |      | CTE: Clear tamper event                                                          |
| 0      | CTE  | This bit is write only, and is always read as 0.                                 |
| 0      | ULL  | 0: No effect                                                                     |
|        |      | 1: Reset the TEF Tamper event flag (and the Tamper detector)                     |

#### **BKP\_DRx** register

#### OFFSET ADDR = 12'h28, 12'h2C

| Bit   | 31 | 30              | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22          | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----------------|----|----|----|----|----|----|-------|-------------|----|----|----|----|----|----|
| R     |    |                 |    |    |    |    |    |    | BKD I | DATA[21.16] | 1  |    |    |    |    |    |
| w     |    | BKP_DATA[31:16] |    |    |    |    |    |    |       |             |    |    |    |    |    |    |
| Reset | 0  | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0           | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14              | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6           | 5  | 4  | 3  | 2  | 1  | 0  |
| R     |    |                 |    |    |    |    |    |    |       |             |    |    |    |    |    |    |
| w     |    | BKP_DATA[15:0]  |    |    |    |    |    |    |       |             |    |    |    |    |    |    |
| Reset | 0  | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0           | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name           | Description                                                                                                                                                                                                  |
|--------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | BKP_DATA[31:0] | Backup data<br>These bits can be written with user data.<br>Note: The BKP_DRx registers are not reset by a System reset or Power<br>reset or when the device wakes up from Standby mode. They are reset by a |
|        |                | Backup Domain reset or by a TAMPER pin event (if the TAMPER pin function is activated).                                                                                                                      |

### 22.6 Functional description

#### 22.6.1 Low power mode operation

The RTC continues to run in low power mode if the RTC is enabled before executing the SLEEP instruction and clock source is LPOSC clock.

As RTC block can work in STOP mode even in Standby mode, therefore, the RTC can be used to bring the MCU out of stop modes with no external components.

### 22.6.2 RTC backup registers

The backup registers (RTC\_BKPDRx) are two 32-bit registers in value line devices for storing 8 bytes of user application data. They are implemented in the VDD domain. They are not reset by system reset or when the device wakes up from Standby mode. They are reset by a power-on reset. A tamper detection event resets all backup registers (RTC\_BKPDx). By setting the TPIE bit in the **BKP\_CSR register**, an interrupt is generated when a tamper detection event occurs.

### 22.6.3 Configuration sequence

All registers should be programmed before RTC\_CLK & RTC\_RTPTS. When RTC block is on normal working, any change of RTC\_CLK & RTC\_RTPTS will clear RTC counter.

## 23 Embedded Flash

**NutoChips** 

### 23.1 Embedded flash function overview

#### 23.1.1 Introduction

This chapter introduces the embedded flash controller, which acts as a bridge between the Cortex-M3 and the flash memory. In practical application, flash boot mode is the main mode and the read-only code will be stored in it. For this module, many application descriptions will be introduced.

### 23.1.2 Feature list

- Flash memory:
  - 64Kwords or 256Kbytes.
  - Endurance: ≥ 10000 cycles.
  - Memory organization: main memory(64Kx32bit) + information memory(2560x32bit).
  - Page capacity: 2048 bytes per page.
- Flash controller:
  - o Operation list:
    - Erase: Page Erase, Mass Erase, Option Page Erase.
    - Program: Option Page Program, Page Program, the minimum programming bit width is 32bit, and the programming address needs to be aligned with 4 bytes.
    - Read: Read.
    - Verify: Page Erase Verify, Mass Erase Verify.
  - Contain pre-fetch buffer.

### 23.1.3 Block diagram



Figure 23-1 Block diagram for flash and flash controller

AutoChips Confidential



### 23.1.4 Data flow & Algorithm



Figure 23-2 Data flow & algorithm for flash and flash controller

### 23.2 Embedded flash memory organization

Before introducing the commands, user should learn about the flash memory organization in Table 23-1. The whole flash memory is composed of two parts: one is main memory and the other is information memory. Every 2 Kbytes is called one page in the flash memory as illustrated in Table 23-1. Main memory is used for storing the user code including code and data, and user can put erase, program, verify and read command operations on main memory. The information memory is divided into 3 parts. The ISP Code section is used for solidify the code of semiconductor producer and user can't erase and program. The first 24 bytes in Option byte section are the writing and reading protection information to the main memory and the reserved bytes in option byte section can be used by user in fact. For option byte section, user can erase, program, verify and read.

| FLASH<br>Memory             | Name     | Address                                 | Size (bytes) | User permission<br>(note) |  |
|-----------------------------|----------|-----------------------------------------|--------------|---------------------------|--|
|                             | Page 0   | 0x0800 0000 ~ 0x0800 07FF               | 2K           |                           |  |
|                             | Page 1   | 0x0800 0800 ~ 0x0800 0FFF               | 2K           |                           |  |
| Main momory                 | Page 2   | 0x0800 1000 ~ 0x0800 17FF               | 2K           |                           |  |
| Main memory<br>(user pages) | Page 3   | 0x0800 1800 ~ 0x0800 1FFF               | 2K           | ]                         |  |
|                             |          |                                         | 2К           | Erase/program/read/verify |  |
|                             | Page 127 | 0x0803 F800 ~ 0x0803 FFFF               | 2K           |                           |  |
|                             | Option   | 0x0804 0000 ~ 0x0804 0014               | 24           |                           |  |
| Information<br>memory       | byte     | 0x0804 0018 ~ 0x0804 07FF<br>(Reserved) | 2024         |                           |  |
|                             | ISP Code | 0x0804 0800 ~ 0x0804 1fff               | 6K           | Read                      |  |

Table 23-1 Flash memory organization

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 298 of 360

Note: user permission when writing/reading protection is invalid.

## 23.3 Embedded flash protect

**NutoChips** 

In option page, the content mainly aims at the read protection, write protection, watch dog enable and so on. Flash memory has writing and reading protection function for the main memory in order to avoid illegal access. The related information is stored in the following option bytes and writing protection information also be loaded to the register **eFLASH\_WPRT\_EN1** to **eFLASH\_WPRT\_EN4**. After programming new data to the flash memory 0x0804 0000 ~ 0x0804 002C, the new data will be loaded into the corresponding registers and validate its corresponding functions until the next reset. Specially, the complement codes, such as nRDP/nWDTEN and so on, are implemented by the hardware automatically.

| Address     | [31:24]           | [23:16]    | [15:8]  | [7:0]     | Default value | Comment        |
|-------------|-------------------|------------|---------|-----------|---------------|----------------|
| 0x0804 0000 | 0xFF              | nRDP       | 0xFF    | RDP       | 0xFF53 FFAC   |                |
| 0x0804 0004 | 0xFF              | nWDTEN     | 0xFF    | WDTEN     | 0xFFFFFFFF    |                |
| 0x0804 0008 | nWPRT_            | EN[15:0]   | WPRT_E  | N[15:0]   | 0xFFFFFFFF    | page 16 ~ 1    |
| 0x0804 000c | nWPRT_I           | EN[31:16]  | WPRT_EI | N[31:16]  | 0xFFFFFFFF    | page 32 ~ 17   |
| 0x0804 0010 | nWPRT_EN[47:32]   |            | WPRT_EI | N[47:32]  | 0xFFFFFFFF    | page 48 ~ 33   |
| 0x0804 0014 | nWPRT_EN[63:48]   |            | WPRT_EI | N[63:48]  | 0xFFFFFFFF    | page 64 ~ 49   |
| 0x0804 0018 | nWPRT_EN[79:64]   |            | WPRT_EI | N[79:64]  | 0xFFFFFFFF    | page 80 ~ 65   |
| 0x0804 001c | nWPRT_I           | EN[95:80]  | WPRT_EI | N[95:80]  | 0xFFFFFFFF    | page 96 ~ 81   |
| 0x0804 0020 | nWPRT_E           | EN[111:96] | WPRT_EN | N[111:96] | 0xFFFFFFFF    | page 112 ~ 97  |
| 0x0804 0024 | nWPRT_EN[127:112] |            | WPRT_EN | [127:112] | 0xFFFFFFFF    | page 128 ~ 113 |
| 0x0804 0028 | nDATA0            |            | DATA0   |           | 0xFFFFFFFF    |                |
| 0x0804 002C | nDA               | TA1        | DATA1   |           | 0xFFFFFFFF    |                |

Table 23-2 The content of the key addresses in option page

### 23.3.1 Read and write protection

For read or write protection, the following tables determine whether the main memory is under the protection.

| Conditions  | RDP    | nRDP            | Read protection status |  |
|-------------|--------|-----------------|------------------------|--|
| Case1       | 0xFF   | 0xFF            | Protected              |  |
| Case2       | 0xAC   | 0x53            | Not protected          |  |
| Other cases | Except | case1 and case2 | Protected              |  |

#### Table 23-3 Read protection description

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

#### Table 23-4 Write protection description

| Conditions  | WPRT_EN[x] | nWPRT_EN[x]   | Write protection<br>status |
|-------------|------------|---------------|----------------------------|
| Case1       | 0          | 1             | Protected                  |
| Other cases | Except c   | Not protected |                            |

#### 23.3.2 Others

For WDT enable setting, WDT must be programmed to 0xCC and the nWDT must be programmed to 0x33. Otherwise, WDT function will be disabled. For DATAx/nDATAx, user can use these two memory unit freely with no special notice.

Table 23-5 Watch dog enable description

| Conditions | WDTEN    | nWDTEN            | Status           |  |  |
|------------|----------|-------------------|------------------|--|--|
| case1      | 0xCC     | 0x33              | enable watch dog |  |  |
| others     | Except t | disable watch dog |                  |  |  |

### 23.4 Program guide

#### 23.4.1 Brief introduction

In this section, the introduction by flow chart will be described about Page erase, Mass erase, Page program, Option page erase, Option page program, Page erase verify and Mass erase verify. All the command operation mainly refers to the following registers: eFLASH\_CTRL1, eFLASH\_CTRL2, eFLASH\_ADR\_CMD, eFIASH\_SR1. For read operation, user can directly read the desired address as illustrated in Table 23-1 in flash memory, so the related description will be ignored in the document.

In particular, the following flow chart just illustrates the single command operation. And it is just significant to do the configuration of unlocking and eFIASH\_CTRL2 once before one or more command operations. For the whole embedded flash memory, there are total 133 pages, which are composed of 1 option page, 3 system pages, 128 user pages.

For the following description, much emphasis will be placed on the page erase, page erase verify and page program, which other command operations can easily refer to.

### 23.4.2 Command operation description

#### 23.4.2.1 Page erase

Page erase operation just acts on main memory in flash memory. Page erase operation can't reach the information memory. In the following paragraphs, detailed descriptions are introduced for page erase and other command operations can refer to it.

- Before configuring the eFIASH\_CTRL1 and eFIASH\_CTRL2, we must check whether they are locked by observing the status of LOCK. If the two registers are in lock state, we must sequentially write 0xac7811 and 0x01234567 to eFIASH\_KEY to unlock. If they are not in lock state, we can go to the next step directly.
- 2. After unlocking, we had better check whether there are some command operations in process by reading out the status of CMD\_BSY. CMD\_BSY equal to 1 represents some command

© 2013 - 2021 AutoChips Inc.

operations is not finished and we must wait until CMD\_BSY is equal to 0. In fact, unlocking process can be done before or after checking CMD\_BSY and Figure 23-3 just illustrates the "before" case.

- 3. When CMD\_BSY turns to 0, we can configure the two registers: eFIASH\_CTRL1 and eFIASH\_CTRL2. For all the erase and program command operations, user must configure 0x78 to eFLASH\_CTRL2 when embedded flash clock works at 100MHz to get a specific clock internally. Particularly, user must adjust the value of eFLASH\_CTRL2 proportionally when embedded flash clock change to other frequency but less than 160MHz certainly.
- 4. Then, user should configure the page erase start address in eFLASH\_ADR\_CMD, which value is the start address of the desired erase page. The start address for different 133 pages is described in registers eFLASH\_ADR\_CMD.
- 5. After the basic configuration above, user can launch the command and trigger it to start by controlling the eFLASH\_CTRL1. User should guarantee that bit CMD\_ST must turn from 0 to 1 after other bits have been configured in eFLASH\_CTRL1 in order to get a valid trigger. In details, EOPIE is configured to 1 to make related status occurs after the incoming command operation will be completed. CMD\_CTL is configured to 0x1 to determine the incoming command operation is page erase. Other bits should be 0 and will be used in other command operations.
- 6. After a valid trigger, the command operation starts. User should check whether the command operation is finished by reading out the bit CMD\_BSY and EOP\_INT. When CMD\_BSY is equal to 0 and EOP\_INT is equal to 1, it represents that the command operation has been finished and user should clear the EOP\_INT by writing 0 to this bit. In fact, it is ok for user to just use CMD\_BSY to indicate whether the operation is finished for all command operations. Then user can read out other status to check whether there are some errors based on user's requirement, such as OPR\_ERR, especially for write protection case, user can not erase the page with write protection character.
- 7. Until now, the page erase command description is finished completely as the following flow chart. To point out, the process of other command operations is similar to the page erase, just with some difference, which will be described later.

**NutoChips** 



#### Figure 23-3 Page erase command operation flow

#### 23.4.2.2 Mass erase

Mass erase can erase the whole user 128 pages memory. The flow is illustrated as Figure 23-4. Compared with page erase, there is no need to specify the erase address in eFLASH\_ADR\_CMD. Specially, when the main memory attribute is changed from read-protect to read-not-protect, a mass erase will be performed automatically in order to protect the user code from illegal reading. For example, when user program the RDP in option page from the default 0XFF to 0xAC, a mass erase performs automatically.



#### Figure 23-4 Mass erase command operation flow

#### 23.4.2.3 Page program

Page program command can reach the whole user 128 pages memory. The flow is illustrated as Figure 23-5.

The page program command flow is also similar to the page erase. But there are two differences: one is CMD\_CTL and the other is PROG\_LENGTH[9:0]. The bits PROG\_LENGTH[9:0] are configured to a specified value to determine the program length by word. For example, if PROG\_LENGTH[9:0] are configured to 150, user should write not more than 150 words. If the user write more than 150 words, such as 180 words, the last 30 words will not be written into flash in fact. Meanwhile, if the user writes less than 150 words, such as 110 words, the write operation will be validated normally, but user should keep in mind that program process will be not finished until the data number equal to length or you should use flush command to force program be terminated.

About page program command, there are some auto pre-check mechanisms to do content protection, such as write protection check, blank content check and address boundary check. So user should check eFLASH\_SR1 register carefully after each program command to confirm whether the write operation is successful.



#### Figure 23-5 Page program command operation flow

#### 23.4.2.4 Page erase verify

Page verify command can reach the whole user 128 pages memory and information memory. This operation is usually executed after erase operation in order to verify whether the erase operation is performed successfully. The flow is illustrated as Figure 23-6. Compared with the page erase command flow, there is just one difference in page erase verify flow: CMD\_CTL.

### AC781x Reference Manual General

## **VutoChips**



#### Figure 23-6 Page erase verify command operation flow

#### 23.4.2.5 Mass erase verify

Mass erase verify command can reach the whole user 128 pages memory. This operation is usually executed after mass erase operation in order to verify whether the mass erase operation is finished successfully. The flow is illustrated as Figure 23-7. Compared with the page erase command flow, there are two differences in page erase verify flow: CMD\_CTL and eFLASH\_ADR\_CMD. Because of reaching the whole 128 pages memory, there is no need to specify the eFLASH\_ADR\_CMD for this command operation.



Figure 23-7 Mass erase verify command operation flow

#### 23.4.2.6 Option page erase

Option page erase command aims at the one Option page. The flow is illustrated as Figure 23-8. Compared with the page erase command flow, there is just one difference in page erase verify flow: CMD\_CTL. The difference is easily described in registers map.

### AC781x Reference Manual General

## **VutoChips**



#### Figure 23-8 Option page erase command operation flow

#### 23.4.2.7 Option page program

Option page erase command aims at the Option page. The flow is illustrated as Figure 23-9. Compared with the page program command flow, there is just one difference in page erase verify flow: CMD\_CTL. The difference is easily described in register map.

User should pay high attention to read protection character change when do option page program, if you change read protect character from protect to un-protection, eflash controller will do mass erase command automatically to erase the content of whole user pages.



#### Figure 23-9 Option page program command operation flow

### 23.5 Register definition

| Table 23-6 Embedded flash register map |
|----------------------------------------|
|----------------------------------------|

| Address                    | Name             | Width | Register function                 |
|----------------------------|------------------|-------|-----------------------------------|
| 0x40002000                 | eFLASH_KEY       | 32    | Unlock sequence register          |
| 0x40002008                 | eFLASH_ADR_CMD   | 32    | Erase start address               |
| 0x4000200c                 | eFLASH_ CTRL1    | 32    | Control register 1                |
| 0x40002010                 | eFLASH_SR1       | 32    | Status register                   |
| 0x40002014                 | eFLASH_ CTRL2    | 32    | Control register 2: clock setting |
| 0x40002018 ~<br>0x40002024 | eFLASH_ WPRT_ENx | 32    | Write Protect enable bit[127:0]   |
| 0x4000202C                 | eFLASH_CHIP_ID1  | 32    | Chip ID information               |
| 0x40002030                 | eFLASH_CHIP_ID2  | 32    | Chip ID information               |
| 0x40002034                 | eFLASH_CHIP_ID3  | 32    | Chip ID information               |
| 0x40002038                 | eFLASH_CHIP_ID4  | 32    | Chip ID information               |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 308 of 360

| 0x00 e | FLAS | H_KE                                  | ΞY |    |    | Ke | ey seo | quenc | e reg | ister |    |    |    | R  | ESE | <b>: 0x0</b> |
|--------|------|---------------------------------------|----|----|----|----|--------|-------|-------|-------|----|----|----|----|-----|--------------|
| BIT    | 31   | 30                                    | 29 | 28 | 27 | 26 | 25     | 24    | 23    | 22    | 21 | 20 | 19 | 18 | 17  | 16           |
| NAME   |      | KEY[31:16]                            |    |    |    |    |        |       |       |       |    |    |    |    |     |              |
| Туре   |      | RW                                    |    |    |    |    |        |       |       |       |    |    |    |    |     |              |
| BIT    | 15   | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |    |    |    |    |        |       |       |       |    |    |    |    |     |              |
| NAME   |      | KEY[15:0]                             |    |    |    |    |        |       |       |       |    |    |    |    |     |              |
| Туре   |      | RW                                    |    |    |    |    |        |       |       |       |    |    |    |    |     |              |

| Bit(s) Mnemonic | Name | Description                                                       |
|-----------------|------|-------------------------------------------------------------------|
| 31:0 <b>KEY</b> | KEY  | Unlock the writing protection of the eflash control registers     |
|                 |      | The eflash control registers are indicated to be not locked when  |
|                 |      | eFLASH _INFO [LOCK] bit is 0 and is locked when eFLASH_INFO       |
|                 |      | [LOCK] bit is 1. Sequential write 0xac7811 & 0x01234567 to unlock |
|                 |      | the protection, then the control registers can be written again.  |

| 80x0 | eFLAS | SH_A                                  | DR_C | MD |    |    | Erase | e/prog | gram s | start | addre | SS |    | F  | RESE | Г: 0х0 |
|------|-------|---------------------------------------|------|----|----|----|-------|--------|--------|-------|-------|----|----|----|------|--------|
| BIT  | 31    | 30                                    | 29   | 28 | 27 | 26 | 25    | 24     | 23     | 22    | 21    | 20 | 19 | 18 | 17   | 16     |
| NAME |       | ADR_CMD[31:16]                        |      |    |    |    |       |        |        |       |       |    |    |    |      |        |
| Туре |       | RW                                    |      |    |    |    |       |        |        |       |       |    |    |    |      |        |
| BIT  | 15    | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |      |    |    |    |       |        |        |       |       |    |    |    |      |        |
| NAME |       | ADR_CMD[15:0]                         |      |    |    |    |       |        |        |       |       |    |    |    |      |        |
| Туре |       | RW                                    |      |    |    |    |       |        |        |       |       |    |    |    |      |        |

| Bit(s) | Mnemonic | Name    | Description                                                                                                                                                                                                                                                        |
|--------|----------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | ADR_CMD  | ADR_CMD | Start address for commands                                                                                                                                                                                                                                         |
|        |          |         | Note: Before erase/program/verify, the start address must be set.<br>ADR_CMD[31:20] must be 12'b0.                                                                                                                                                                 |
|        |          |         | (1) For page erase:                                                                                                                                                                                                                                                |
|        |          |         | ADR_CMD[19:0] is the low 20 bits of the eflash address, which is just among this page. For example, if user want to erase page 127 which range from 0x0803 F000 to 0x0803 F7FF, so, user can configure ADR_CMD[31:0] as any value from 0x0003 F000 to 0x0003 F7FF. |
|        |          |         | (2) For program:                                                                                                                                                                                                                                                   |
|        |          |         | ADR_CMD[19:0] is the program start address, which is the low 20 bits of eflash address. ADR_CMD[19:0] and PROG_LENGTH[9:0] are together to determine the programmable address range.                                                                               |
|        |          |         | (3) For page verify:                                                                                                                                                                                                                                               |
|        |          |         | ADR_CMD[19:0] is the low 20 bits of the first eflash address of this page.                                                                                                                                                                                         |
|        |          |         | (4) For mass erase/verify                                                                                                                                                                                                                                          |
|        |          |         | ADR_CMD[31:0] is not cared.                                                                                                                                                                                                                                        |

| 0>   | κOC e | eFLASH_CTRL1 Control register 1 RESET: 0x0 |    |            |     |        |                  |       |    |     |    | x0     |              |    |     |    |  |
|------|-------|--------------------------------------------|----|------------|-----|--------|------------------|-------|----|-----|----|--------|--------------|----|-----|----|--|
| BIT  | 31    | 30                                         | 29 | 28         | 27  | 26     | 25               | 24    | 23 | 22  | 21 | 20     | 19           | 18 | 17  | 16 |  |
| NAME | HDFEN |                                            |    | RSV        |     |        | PROG_LENGTH[9:0] |       |    |     |    |        |              |    |     |    |  |
| Туре | RW    |                                            |    | R          |     |        | RW               |       |    |     |    |        |              |    |     |    |  |
| BIT  | 15    | 14                                         | 13 | 12         | 11  | 10     | 9                | 8     | 4  | 3   | 2  | 1      | 0            |    |     |    |  |
| NAME | R     | SV                                         |    | OPT_CMD_EN | RSV | WRPTIE | RDRTIE           | EOPIE |    | RSV |    | CMD_ST | CMD_CTL[3:0] |    | :0] |    |  |
| Туре |       | R RW                                       |    |            | R   |        | RW               |       |    | R   |    | RW     |              | R  | W   |    |  |

| Bit(s) | Mnemonic    | Name        | Description                                                     |
|--------|-------------|-------------|-----------------------------------------------------------------|
| 31     | HDFEN       | HDFEN       | Hardfault interrupt enable                                      |
|        |             |             | 0: disable                                                      |
|        |             |             | 1: enable                                                       |
| 25:16  | PROG_LENGTH | PROG_LENGTH | Program length for Program operation                            |
|        |             |             | Note: unit is word,                                             |
|        |             |             | Program length.                                                 |
| 12     | OPT_CMD_EN  | OPT_CMD_EN  | Enable the command operation related with the option bytes zone |
|        |             |             | Note: refer to CMD_CTL                                          |
|        |             |             | 0: disable 4'h6, 4'h7, enable 4'h1, 4'h2, 4'h3                  |
|        |             |             | 1: enable 4'h6, 4'h7, disable 4'h1, 4'h2, 4'h3                  |
| 10     | WRPTIE      | WRPTIE      | Enable the interrupt of write protection error                  |
|        |             |             | 0: disable                                                      |
|        |             |             | 1: enable                                                       |
| 9      | RDRTIE      | RDRTIE      | Enable the interrupt of read protection error                   |
|        |             |             | 0: disable                                                      |
|        |             |             | 1: enable                                                       |
| 8      | EOPIE       | EOPIE       | Enable the status and interrupt of end of operation             |
|        |             |             | 0: disable                                                      |
|        |             |             | 1: enable                                                       |
| 4      | CMD_ST      | CMD_ST      | Control the command operation to start                          |
|        |             |             | Write 1 to trigger the command to start                         |
| 3:0    | CMD_CTL     | CMD_CTL     | Command                                                         |
|        |             |             | 4'h0: Idle                                                      |
|        |             |             | 4'h1: Page Erase                                                |
|        |             |             | 4'h2: Mass Erase                                                |
|        |             |             | 4'h3: Page Program                                              |
|        |             |             | 4'h4: Page Erase Verify                                         |
|        |             |             | 4'h5: Mass Erase Verify                                         |
|        |             |             | 4'h6: Option Page Erase                                         |
|        |             |             | 4'h7: Option Page Program                                       |

AutoChips Confidential

| 0x10 |    | eF | LAS | SH_SR' | 1  |     |       | Sta     | atus reg | gister 1 |        |      | I    | RESE | ET: 0x702 |
|------|----|----|-----|--------|----|-----|-------|---------|----------|----------|--------|------|------|------|-----------|
| BIT  | 31 | 30 | 29  | 28     | 27 | 26  | 25 24 | 23      | 22       | 21       | 20     | 19   | 18   | 17   | 16        |
| NAME |    |    | CI  | MD_BSY | ST | A   |       | INI_RDY | RSV      |          | IRQ    |      |      |      |           |
| Туре | R  |    |     |        |    |     |       |         |          |          |        |      |      |      |           |
| BIT  | 15 | 14 | 13  | 12     | 11 | 10  | 98    | 7       | 6        | 5        | 4      | 3    | 2    | 1    | 0         |
| NAME |    |    |     | FLUSH  |    | ОРТ | ER    | VRER    | ERAER    | PPADRER  | PPERER | RDER | WRER | EOP  | CMD_BSY   |
| Туре |    | R  |     | RW     |    |     |       |         |          | R        |        |      |      |      |           |

| Bit(s) | Mnemonic    | Name          | Description                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24  | CMD_BSY_STA | TCMD_BSY_STAT | Indicate the busy status for each command operation                                                                                                                                                                                                                                                                                                                                                |
|        |             |               | CMD_BSY_STAT[7]: Option page program busy                                                                                                                                                                                                                                                                                                                                                          |
|        |             |               | CMD_BSY_STAT[6]: Option page erase busy                                                                                                                                                                                                                                                                                                                                                            |
|        |             |               | CMD_BSY_STAT[5]: Mass erase verify busy                                                                                                                                                                                                                                                                                                                                                            |
|        |             |               | CMD_BSY_STAT[4]: Page erase verify busy                                                                                                                                                                                                                                                                                                                                                            |
|        |             |               | CMD_BSY_STAT[3]: Page program busy                                                                                                                                                                                                                                                                                                                                                                 |
|        |             |               | CMD_BSY_STAT[2]: Mass erase busy                                                                                                                                                                                                                                                                                                                                                                   |
|        |             |               | CMD_BSY_STAT[1]: Page erase busy                                                                                                                                                                                                                                                                                                                                                                   |
|        |             |               | CMD_BSY_STAT[0]: Recall busy                                                                                                                                                                                                                                                                                                                                                                       |
| 23     | INI_RDY     | INI_RDY       | Indicate the flash controller initialization finished                                                                                                                                                                                                                                                                                                                                              |
|        |             |               | 0: not finished                                                                                                                                                                                                                                                                                                                                                                                    |
|        |             |               | 1: finished                                                                                                                                                                                                                                                                                                                                                                                        |
| 20     | IRQ         | IRQ           | Indicate the flash controller interrupt                                                                                                                                                                                                                                                                                                                                                            |
|        |             |               | Note: There are 3 interrupt sources, which are command operation finish, write protection error and read protection error.                                                                                                                                                                                                                                                                         |
|        |             |               | 0: no interrupt                                                                                                                                                                                                                                                                                                                                                                                    |
|        |             |               | 1: interrupt occur                                                                                                                                                                                                                                                                                                                                                                                 |
| 12     | FLUSH       | FLUSH         | Write 1 to fore the program command operation to be finished                                                                                                                                                                                                                                                                                                                                       |
|        |             |               | <b>Note:</b> This bit will not be used when user perform progracommand operation obeying this application note. But in som cases, the remaining memory doesn't match the value PROG_LENGTH[9:0] or the actual program number of memory less than PROG_LENGTH[9:0], So, the program can't be finished For this condition, write 1 to FLUSH will force the program command operation to be finished. |
| 11:8   | OPT_ER      | OPT_ERR       | Indicate the error status for option byte                                                                                                                                                                                                                                                                                                                                                          |
|        |             |               | OPT_ERR [3]:                                                                                                                                                                                                                                                                                                                                                                                       |
|        |             |               | 0: no error, namely, DATAx=~nDATAx                                                                                                                                                                                                                                                                                                                                                                 |
|        |             |               | 1: exist error, namely, DATAx != ~nDATAx, except DATAx<br>nDATAx=0xff                                                                                                                                                                                                                                                                                                                              |
|        |             |               | OPT_ERR [2]:                                                                                                                                                                                                                                                                                                                                                                                       |
|        |             |               | 0: no error, namely, WPRT_EN[x] = ~nWPRT_EN[x]                                                                                                                                                                                                                                                                                                                                                     |
|        |             |               | 1: exist error, namely, WPRT_EN[x] != ~nWPRT_EN[x], exce<br>WPRT_EN[x] = ~nWPRT_EN[x] = 0x1                                                                                                                                                                                                                                                                                                        |
|        |             |               | OPT_ERR [1]:                                                                                                                                                                                                                                                                                                                                                                                       |
|        |             |               | 0: no error, namely, WDTEN = ~nWDTEN                                                                                                                                                                                                                                                                                                                                                               |
|        |             |               | 1: exist error, namely, WDTEN != ~nWDTEN, except WDTEN<br>nWDTEN=0xff                                                                                                                                                                                                                                                                                                                              |
|        |             |               | OPT_ERR [0]:                                                                                                                                                                                                                                                                                                                                                                                       |
|        |             |               | 0: no error, namely, RDP = ~nRDP                                                                                                                                                                                                                                                                                                                                                                   |
|        |             |               | 1: exist error, namely, RDP != ~nRDP, except RDP = nRDP=0xff                                                                                                                                                                                                                                                                                                                                       |

This document contains information that is proprietary to AutoChips Inc.

Unauthorized reproduction or disclosure of this information in whole or in part is strictly prohibited.

| Bit(s) | Mnemonic | Name    | Description                                                                                                         |  |  |  |  |  |  |  |  |  |
|--------|----------|---------|---------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 7      | VRER     | VRER    | Indicate whether there is error in the verify command oper                                                          |  |  |  |  |  |  |  |  |  |
|        |          |         | 0: data verify is ok                                                                                                |  |  |  |  |  |  |  |  |  |
|        |          |         | 1: data verify is not ok                                                                                            |  |  |  |  |  |  |  |  |  |
| 6      | ERAER    | ERAER   | Indicate whether there is error in the erase command operation                                                      |  |  |  |  |  |  |  |  |  |
|        |          |         | 0: no error                                                                                                         |  |  |  |  |  |  |  |  |  |
|        |          |         | 1: error occurs, because address in eFLASH_ADR_CMD is illegal.                                                      |  |  |  |  |  |  |  |  |  |
| 5      | PPADRER  | PPADRER | Indicate whether there is error in the page program command                                                         |  |  |  |  |  |  |  |  |  |
|        |          |         | operation.                                                                                                          |  |  |  |  |  |  |  |  |  |
|        |          |         | 0: no error                                                                                                         |  |  |  |  |  |  |  |  |  |
|        |          |         | 1: error occurs, because program address is illegal or verify operation before program command operation is not OK. |  |  |  |  |  |  |  |  |  |
| 4      | PPERER   | PPERER  | Indicate permission error of commands operation                                                                     |  |  |  |  |  |  |  |  |  |
|        |          |         | 0: no error                                                                                                         |  |  |  |  |  |  |  |  |  |
|        |          |         | 1: error occurs when page/mass erase or program acts on the                                                         |  |  |  |  |  |  |  |  |  |
|        |          |         | protected main memory                                                                                               |  |  |  |  |  |  |  |  |  |
| 3      | RDER     | RDER    | Indicate the operation violates the read protection rules                                                           |  |  |  |  |  |  |  |  |  |
|        |          |         | <b>Note:</b> User can refer to the section 3.2.1 in details.                                                        |  |  |  |  |  |  |  |  |  |
|        |          |         | Write 1 to clear RDER to 0.                                                                                         |  |  |  |  |  |  |  |  |  |
|        |          |         | 0: no violation for the read protection rules                                                                       |  |  |  |  |  |  |  |  |  |
|        |          |         | 1: violations for the read protection rules                                                                         |  |  |  |  |  |  |  |  |  |
| 2      | WRER     | WRER    | Indicate the operation violates the write protection rules                                                          |  |  |  |  |  |  |  |  |  |
|        |          |         | <b>Note:</b> User can refer to the section 3.2.1 in details.                                                        |  |  |  |  |  |  |  |  |  |
|        |          |         | Write 1 to clear WRER to 0.                                                                                         |  |  |  |  |  |  |  |  |  |
|        |          |         | 0: no violation for the write protection rules                                                                      |  |  |  |  |  |  |  |  |  |
|        |          |         | 1: violations for the write protection rules                                                                        |  |  |  |  |  |  |  |  |  |
| 1      | EOP      | EOP     | Indicate whether command operation is finished                                                                      |  |  |  |  |  |  |  |  |  |
|        |          |         | <b>Note:</b> it is not significant for user.                                                                        |  |  |  |  |  |  |  |  |  |
|        |          |         | Write 1 to clear EOP to 0.                                                                                          |  |  |  |  |  |  |  |  |  |
|        |          |         | 0: not finished                                                                                                     |  |  |  |  |  |  |  |  |  |
|        |          |         | 1: finished                                                                                                         |  |  |  |  |  |  |  |  |  |
| 0      | CMD_BSY  | CMD_BSY | Indicate whether any of the command operations is in process                                                        |  |  |  |  |  |  |  |  |  |
|        |          |         | 0: all operations are not in process                                                                                |  |  |  |  |  |  |  |  |  |
|        |          |         | 1: at least one operation in process                                                                                |  |  |  |  |  |  |  |  |  |

| 0x14 | eFLASH_CTRL2 Control register 2 |    |    |    |    |    |    |            |    |             |    |    |    |  | RESET: 0x9  |            |
|------|---------------------------------|----|----|----|----|----|----|------------|----|-------------|----|----|----|--|-------------|------------|
| BIT  | 31                              | 30 | 29 | 28 | 24 | 23 | 22 | 21         | 20 | 19          | 18 | 17 | 16 |  |             |            |
| NAME |                                 |    |    |    |    |    |    |            |    |             |    |    |    |  | CLK_CHG_BSY | CYC_MANUAL |
| Туре | R R                             |    |    |    |    |    |    |            |    |             |    | R  | RW |  |             |            |
| BIT  | 15                              | 14 | 13 | 12 | 11 | 10 | 9  | 8          | 7  | 6 5 4 3 2 1 |    |    |    |  | 1           | 0          |
| NAME |                                 |    |    |    |    |    |    | CKDIV_LOCK |    | CKDIV[6:0]  |    |    |    |  |             |            |
| Туре | F                               | २  | F  | R  |    | R  |    | RW         | R  | RW          |    |    |    |  |             |            |

AutoChips Confidential

| Bit(s) | Mnemonic    | Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17     | CLK_CHG_BSY | CLK_CHG_BSY | Indicate whether ready to change eflash operation clock<br>frequency to above 72MHz<br>Note: CYC_MANUAL and CLK_CHG_BSY are always used<br>together. After write 1 to CYC_MANUAL, CLK_CHG_BSY changes<br>to 1. And use can change eflash operation clock to above 72MHz<br>until CLK_CHG_BSY goes back to 0.                                                                                                                                 |
| 16     | CYC_MANUAL  | CYC_MANUAL  | Control the maximum operation clock frequency for eflash<br>0: embedded operation clock ≤72MHz<br>1: 72MHz <embedded 120mhz<="" <="" clock="" operation="" th=""></embedded>                                                                                                                                                                                                                                                                 |
| 8      | CKDIV_LOCK  | CKDIV_LOCK  | <ul> <li>Lock the configuration for eFLASH_CTRL2</li> <li>Note: if this bit is written to 1 after power on, this register eFIASH_CTRL2 can't be configured again until the chip is powered down.</li> <li>0: can configure the register</li> <li>1: can't configure the register</li> </ul>                                                                                                                                                  |
| 6:0    | CKDIV       | CKDIV       | <b>Clock divisor for generating 1us pulse</b><br>Must configure to the reasonable value based on the speed of eflash<br>controller to get 1us period before the following operation: Page<br>program, Page erase, Mass erase based on the command operation<br>flow. For example, if eflash controller speed is 96MHz, CKDIV= 96/1<br>= 96= 7'h60, however, it is recommended that this value should be<br>larger than 7'h60, such as 7'h62. |

| 0x18~0 | x24 eFLAS       | H_W            | PRT_ | _ENx |    | Wri | te Pr | otection e | nabl | e reg | jister | X  |    |    | RES | ET |
|--------|-----------------|----------------|------|------|----|-----|-------|------------|------|-------|--------|----|----|----|-----|----|
| BIT    | 31              | 30             | 29   | 28   | 27 | 26  | 25    | 24         | 23   | 22    | 21     | 20 | 19 | 18 | 17  | 16 |
| NAME   | WPRT_ENx[31:16] |                |      |      |    |     |       |            |      |       |        |    |    |    |     |    |
| Туре   |                 | R              |      |      |    |     |       |            |      |       |        |    |    |    |     |    |
| BIT    | 15              | 14             | 13   | 12   | 11 | 10  | 9     | 8          | 7    | 6     | 5      | 4  | 3  | 2  | 1   | 0  |
| NAME   |                 | WPRT_ENx[15:0] |      |      |    |     |       |            |      |       |        |    |    |    |     |    |
| Туре   | R               |                |      |      |    |     |       |            |      |       |        |    |    |    |     |    |

**Note:** *x*=1~4, four eFLASH\_WPRT\_ENx registers compose 128 enable bits, which determine the write protection attribution of each main memory page respectively.

| Bit(s) Mnemonic      | Name     | Description                                                                                |
|----------------------|----------|--------------------------------------------------------------------------------------------|
| 31:0 <b>WPRT_ENx</b> | WPRT_ENx | Indicate whether there exists the write protection for the corresponding main memory page. |
|                      |          | 0: not in protection                                                                       |
|                      |          | 1: in write protection                                                                     |

| 0 | x2c  | eFLAS | H_CH  | HP_IC | 01 |    |       | Chip | DID 1 |       |    |    |    |    |    | RESET |    |  |
|---|------|-------|-------|-------|----|----|-------|------|-------|-------|----|----|----|----|----|-------|----|--|
|   | BIT  | 31    | 30    | 29    | 28 | 27 | 26    | 25   | 24    | 23    | 22 | 21 | 20 | 19 | 18 | 17    | 16 |  |
| Ī | NAME |       | UUID3 |       |    |    |       |      |       | UUID2 |    |    |    |    |    |       |    |  |
| Ī | Туре | )     |       |       |    |    | F     | र    |       |       |    |    |    |    |    |       |    |  |
| ſ | BIT  | 15    | 14    | 13    | 12 | 11 | 10    | 9    | 8     | 7     | 6  | 5  | 4  | 3  | 2  | 1     | 0  |  |
| Ī | NAME |       | UUID1 |       |    |    | UUIDO |      |       |       |    |    |    |    | •  |       |    |  |
| Ī | Туре |       |       |       |    |    |       | F    | R     |       |    |    |    |    |    |       |    |  |

| Bit(s) Mnemonic | Name     | Description                   |
|-----------------|----------|-------------------------------|
| 31:0 CHIP_ID1   | CHIP_ID1 | Chip ID information 1         |
|                 |          | UUID15~UUID0: 128 bit CHIP ID |

| 0x30 | eFLAS | SH_C | HIP_I | D2 | Chip ID 2 |    |    |    |    |    |    |    | RESET |    |    |    |
|------|-------|------|-------|----|-----------|----|----|----|----|----|----|----|-------|----|----|----|
| BIT  | 31    | 30   | 29    | 28 | 27        | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19    | 18 | 17 | 16 |
| NAME |       |      |       | UU | ID7       |    |    |    |    |    |    | UU | ID6   |    |    |    |
| Туре | R     |      |       |    |           |    |    |    |    |    |    |    |       |    |    |    |
| BIT  | 15    | 14   | 13    | 12 | 11        | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3     | 2  | 1  | 0  |
| NAME |       |      |       | UU | ID5       |    |    |    |    |    |    | UU | ID4   |    |    |    |
| Туре | R     |      |       |    |           |    |    |    |    |    |    |    |       |    |    |    |

| Bit(s) Mnemonic | Name     | Description                   |
|-----------------|----------|-------------------------------|
| 31:0 CHIP_ID2   | CHIP_ID2 | Chip ID information 2         |
|                 |          | UUID15~UUID0: 128 bit CHIP ID |

| 0x34 | (34 eFLASH_CHIP_ID3 |                |    |    |    | Chip ID 3 |    |    |        |             |   |   |   | RESET |    |    |
|------|---------------------|----------------|----|----|----|-----------|----|----|--------|-------------|---|---|---|-------|----|----|
| BIT  | 31                  | 31 30 29 28 27 |    |    |    |           | 25 | 24 | 23     | 23 22 21 20 |   |   |   | 18    | 17 | 16 |
| NAME |                     | UUID11         |    |    |    |           |    |    | UUID10 |             |   |   |   |       |    |    |
| Туре |                     | R              |    |    |    |           |    |    |        |             |   |   |   |       |    |    |
| BIT  | 15                  | 14             | 13 | 12 | 11 | 10        | 9  | 8  | 7      | 6           | 5 | 4 | 3 | 2     | 1  | 0  |
| NAME |                     | UUID9          |    |    |    |           |    |    | UUID8  |             |   |   |   |       |    |    |
| Туре | R                   |                |    |    |    |           |    |    |        |             |   |   |   |       |    |    |

| Bit(s) Mnemonic | Name     | Description                   |
|-----------------|----------|-------------------------------|
| 31:0 CHIP_ID3   | CHIP_ID3 | Chip ID information 3         |
|                 |          | UUID15~UUID0: 128 bit CHIP ID |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 314 of 360



| 0x38 | eFLA | SH_C   | HIP_I | D4 | Chip ID 4 |    |    |    |        |    |    |     |     |    | R  | ESET |
|------|------|--------|-------|----|-----------|----|----|----|--------|----|----|-----|-----|----|----|------|
| BIT  | 31   | 30     | 29    | 28 | 27        | 26 | 25 | 24 | 23     | 22 | 21 | 20  | 19  | 18 | 17 | 16   |
| NAME |      | UUID15 |       |    |           |    |    |    | UUID14 |    |    |     |     |    |    |      |
| Туре |      | R      |       |    |           |    |    |    |        |    |    |     |     |    |    |      |
| BIT  | 15   | 14     | 13    | 12 | 11        | 10 | 9  | 8  | 7      | 6  | 5  | 4   | 3   | 2  | 1  | 0    |
| NAME |      | UUID13 |       |    |           |    |    |    |        |    |    | UUI | D12 |    |    |      |
| Туре |      | R      |       |    |           |    |    |    |        |    |    |     |     |    |    |      |

| Bit(s) Mnemonic | Name     | Description                                            |
|-----------------|----------|--------------------------------------------------------|
| 31:0 CHIP_ID4   | CHIP_ID4 | Chip ID information 4<br>UUID15~UUID0: 128 bit CHIP ID |

## 24 Serial Flash

**NutoChips** 

## 24.1 Serial FLASH function overview

#### 24.1.1 Introduction

The sflash\_top module is able to interface with external NOR flash memory. Its purpose is to translate the AHB/APB/RS232 transactions into the appropriate protocol. 32\*32 bits SRAM is used as programming data buffer or read data cache. The timing of the NOR flash pins can be adjusted by programmable delay cells to meet the access timing requirements.

#### 24.1.2 Feature list:

- RISC access serial flash.
- RS232 access serial flash.
- Check sum for serial flash read data.
- System boot up from serial flash.

#### 24.1.3 Block diagram



Figure 24-1 Diagram of module sflash controller

### 24.2 Application note

#### 24.2.1 Clock setting

There are 3 clocks in sflash\_top module: bclk, clk\_flash and clk\_rs232. The default frequency of APB bus clock (bclk) is half of AHB bus clock, equals to 4MHz. Default frequency of another 2 clock is the same 8MHz.

The absolute address of related clock configuration register is 0x40000000, only sflash\_top module related clock is discussed, detail information is shown in the following.

| 0x400  | 00000 <u>rs_reg_00</u> |      | clock | configuration register                                                                                 |  |  |  |  |  |  |
|--------|------------------------|------|-------|--------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Bit(s) | Name                   | Туре | Reset | Description                                                                                            |  |  |  |  |  |  |
|        |                        |      |       | Select different source of clk_flash                                                                   |  |  |  |  |  |  |
| 24     | serial_clk_sel         | RW   | 0     | 0: select clock pllmul_in, frequency is 8MHz<br>1: select clock serial_clk_div, generated by AHB clock |  |  |  |  |  |  |
|        |                        |      |       | Configure different division factor of serial_clk_div                                                  |  |  |  |  |  |  |
|        |                        |      |       | 00: division factor is 1/2                                                                             |  |  |  |  |  |  |
| 3:2    | rg_serial_clk_div      | RW   | 0     | 01: division factor is 1/4(default)                                                                    |  |  |  |  |  |  |
|        |                        |      |       | 10: division factor is 1/6                                                                             |  |  |  |  |  |  |
|        |                        |      |       | 11: division factor is 1/8                                                                             |  |  |  |  |  |  |

#### Table 24-1 Clock configuration register

#### 24.2.2 RISC access NOR flash

**NutoChips** 

Multiple operations can be triggered through RISC method. All the operations are completed by related registers configuration using APB bus. Register base address and offset address is shown in chapter 24.3.

After any operation is triggered, we check the status through register REG\_SF\_INTREN and REG\_SF\_INTRSTUS, if the corresponding interrupt value is valid, writing corresponding bit to 1'b1 is necessary, a program (not page program) command is shown in the following. For more intuitive (specific steps are necessary), we ignore the following steps in the flow chart of different operation.



Figure 24-2 RISC access NOR flash

#### 24.2.3 Read NOR flash id

The read identification (RDID) instruction is for reading the manufacturer ID of 1-byte and followed by Device ID of 2-byte.

The sequence of issuing RDID instruction is: CS# goes low $\rightarrow$  sending RDID instruction code $\rightarrow$ 24-bits ID data out on SO $\rightarrow$  to end RDID operation can drive CS# to high at any time during data out.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 317 of 360

### AC781x Reference Manual General

## **NutoChips**

While Program/Erase operation is in progress, it will not decode the RDID instruction, therefore there's no effect on the cycle of program/erase operation which is currently in progress. When CS# goes high, the device is at standby stage.

The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Write REG\_SF\_PRGDATA5 to 0x9f;
- 4) Write REG\_SF\_ PRGDATA4 to 0x0;
- 5) Write REG\_SF\_ PRGDATA3 to 0x0;
- 6) Write REG\_SF\_ PRGDATA2 to 0x0;
- 7) Write REG\_SF\_CNT to 0x20;
- 8) Write REG\_SF\_CMD to 0x4;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 10) Read REG\_SF\_SHREG2/1/0, we can get manufacturer ID of 1-byte and device ID of 2-byte.



Figure 24-3 Read NOR flash id sequence

### 24.2.4 Write status register (WRSR)

The WRSR instruction is for changing the values of Status Register Bits and Configuration Register Bits. Before sending WRSR instruction, the Write Enable (WREN) instruction must be decoded and executed to set the Write Enable Latch (WEL) bit in advance. The WRSR instruction can change the value of Block Protect bits to define the protected area of memory.

The sequence of issuing WRSR instruction is: CS# goes low $\rightarrow$  sending WRSR instruction code $\rightarrow$  Status Register data on SI $\rightarrow$ CS# goes high.

The CS# must go high exactly at the 16 bits data boundary; otherwise, the instruction will be rejectedand not executed. The self-timed Write Status Register cycle time (tW) is initiated as soon as ChipAutoChips Confidential© 2013 - 2021 AutoChips Inc.Page 319 of 360

## **//utoChips**

Select (CS#) goes high. The Write in Progress (WIP) bit still can be check out during the Write Status Register cycle is in progress. The WIP sets 1 during the tW timing, and sets 0 when Write Status Register Cycle is completed, and the Write Enable Latch (WEL) bit is reset.

For some manufactures, the default value of block write protection bits in software status register is 1'b1, so we should **change the value of block write protection bits in status register to 1'b0 through WRSR command**. The function of each bit in software status register is depending on the type of nor flash.

The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Write REG\_SF\_PRGDATA5 to 0x6;
- 4) Write REG\_SF\_CNT to 0x8;
- 5) Write REG\_SF\_CMD to 0x4;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 7) Write REG\_SF\_CMD to 0x2, trigger RDSR command;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- 9) Read REG\_SF\_RDSR, if WEL = 1, turn to step 3, else continue;

#### 10) Write REG\_SF\_PRGDATA5 to 0x01;

- 11) Write REG\_SF\_PRGDATA4 to 0x02;
- 12) Write REG\_SF\_CNT to 0x10;
- 13) Write REG\_SF\_CMD to 0x4;
- 14) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 15) Write REG\_SF\_CMD to 0x2, trigger RDSR command;
- 16) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- 17) Read REG\_SF\_RDSR (default valid), check the value of block protection bit, if the value is1'b1, turn to step 3.



Figure 24-4 Write status register sequence

Also, **WRSR command can be used to enable Quad Enable(QE) bit**. Notice the method to set Quad Enable (QE) bit is discrepant, step 9 and step 10 in the following flow should be modified depending on the corresponding model.

RDSR command is triggered automatically when WRSR command is completed, which will continue until WIP equals to 1'b0.

The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Write REG\_SF\_PRGDATA5 to 0x6;
- 4) Write REG\_SF\_CNT to 0x8;
- 5) Write REG\_SF\_CMD to 0x4;

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 321 of 360

- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 7) Write REG\_SF\_CMD to 0x2, trigger RDSR command;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- 9) Read REG\_SF\_RDSR, if WEL = 1, turn to step 3, else continue;

#### 10) Write REG\_SF\_PRGDATA5 to 0x01;

- 11) Write REG\_SF\_PRGDATA4 to 0x40;
- 12) Write REG\_SF\_CNT to 0x10;

**NutoChips** 

- 13) Write REG\_SF\_CMD to 0x4;
- 14) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 15) Write REG\_SF\_CMD to 0x2, trigger RDSR command;
- 16) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- 17) Read REG\_SF\_RDSR, check the value of block protection bit, if the value is 1'b1, turn to step

### AC781x Reference Manual General

# **//utoChips**





### 24.2.5 Erase NOR flash (sector/block erase)

The Sector/Block Erase (SE/BE32K/BE) instruction is for erasing the data of the chosen sector to be "1". The instruction is used for any 4K-byte sector and 32K/64K-byte block. A Write Enable (WREN) instruction must execute to set the Write Enable Latch (WEL) bit before sending the SE/BE32K/BE. Any address of the sector is a valid address for SE/BE32K/BE instruction. The CS# must go high exactly at the byte boundary (the least significant bit of the address byte been latched-in). Otherwise, the instruction will be rejected and not executed.

The read mode is 3-byte address. Address bits [Am-A12]/ [Am-A15]/ [Am-A16] (Am is the most significant address) select the sector address.

The sequence of issuing SE instruction is: CS# goes low $\rightarrow$  sending SE instruction code $\rightarrow$  3-byte address on SI $\rightarrow$  CS# goes high.

The self-timed SE/BE32K/BE Cycle time (tSE/tBE32K/tBE) is initiated as soon as Chip Select (CS#) goes high. The Write in Progress (WIP) bit still can be checked while the SE/BE32K/BE cycle is in progress. The WIP sets 1 during the tSE/tBE32K/tBE timing, and clears when SE/BE32K/BE Cycle is AutoChips Confidential © 2013 - 2021 AutoChips Inc. Page 323 of 360

### AC781x Reference Manual General

## completed, and the Write Enable Latch (WEL) bit is cleared. If the Block is protected by BP bits (Block Protect Mode) or SPB/DPB (Advanced Sector Protect Mode), the SE/BE32K/BE instruction will not be executed on the block.

Notice the command of erase may not the same for different manufactures. For some manufactures, only 4K-byte sector and 64K-byte block erase are supported. EQPI mode isn't supported. The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;

**NutoChips** 

- 3) Release block write protection;
- 4) Write REG\_SF\_PRGDATA5 to 0x6;
- 5) Write REG\_SF\_CNT to 0x8;
- 6) Write REG\_SF\_CMD to 0x4;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 8) Write REG\_SF\_CMD to 0x2, trigger RDSR command;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- 10) Read REG\_SF\_RDSR, if WEL = 1, turn to step 4, else continue;
- Write REG\_SF\_PRGDATA5 to 0x20/0x52/0xd8(sector erase/32 KB block erase/64KB block erase);
- 12) Write REG\_SF\_ PRGDATA4 to addr[23:16];
- 13) Write REG\_SF\_ PRGDATA3 to addr[15:8];
- 14) Write REG\_SF\_ PRGDATA2 to addr[7:0];
- 15) Write REG\_SF\_CNT to 0x20;
- 16) Write REG\_SF\_CMD to 0x4;
- 17) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 18) Write REG\_SF\_CMD to 0x2;
- 19) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;

20) Read REG\_SF\_RDSR, if WIP = 0, sector/block Cycle is completed, else repeat step 20 until

WIP = 0.

**NutoChips** 



Figure 24-6 Erase NOR flash(sector/block erase) flow

#### 24.2.6 Erase NOR flash (chip erase)

The Chip Erase (CE) instruction is for erasing the data of the whole chip to be "1". A Write Enable (WREN) instruction must be executed to set the Write Enable Latch (WEL) bit before sending the Chip Erase (CE). The CS# must go high exactly at the byte boundary, otherwise the instruction will be rejected and not executed.

The sequence of issuing CE instruction is: CS# goes low $\rightarrow$ sending CE instruction code $\rightarrow$ CS# goes high.

The self-timed Chip Erase Cycle time is initiated as soon as Chip Select (CS#) goes high. The Write in Progress (WIP) bit still can be checked while the Chip Erase cycle is in progress. The WIP sets during the tCE timing, and clears when Chip Erase Cycle is completed, and the Write Enable Latch (WEL) bit is cleared.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 325 of 360

### **NutoChips**

When the chip is under "Block protect (BP) Mode", the Chip Erase (CE) instruction will not be executed, if one (or more) sector is protected by BP3-BP0 bits. It will be only executed when BP3-BP0 all set to "0".

When the chip is under "Advances Sector Protect Mode", the Chip Erase (CE) instruction will be executed on unprotected block. The protected Block will be skipped. If one (or more) 4K byte sector was protected in top or bottom 64K byte block, the protected block will also skip the chip erase command.

The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Release block write protection;

Solution 1:

- 4) Write REG\_SF\_CMD to 0x8;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x8, then write REG\_SF\_INTRSTUS to 0x8;
- 6) Write REG\_SF\_CMD to 0x2;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- Read REG\_SF\_RDSR, if REG\_SF\_RDSR[0] = 0, Chip Erase Cycle is completed, else repeat step 6 until REG\_SF\_RDSR[0] = 0.



Figure 24-7 Erase NOR flash(chip erase) flow solution 1

Solution2:

- 4) Write REG\_SF\_PRGDATA5 to 0x6;
- 5) Write REG\_SF\_CNT to 0x8;
- 6) Write REG\_SF\_CMD to 0x4;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 8) Write REG\_SF\_CMD to 0x2, trigger RDSR command;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- 10) Read REG\_SF\_RDSR, if WEL = 1, turn to step 4, else continue;
- 11) Write REG\_SF\_PRGDATA5 to 0Xc7;
- 12) Write REG\_SF\_CNT to 0x08;
- 13) Write REG\_SF\_CMD to 0x4;
- 14) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 15) Write REG\_SF\_CMD to 0x2;

© 2013 - 2021 AutoChips Inc.

- 16) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- 17) Read REG\_SF\_RDSR, if WIP = 0, Chip Erase Cycle is completed, else repeat step 17 until WIP = 0.



Figure 24-8 Erase NOR flash(chip erase) flow solution 2

#### 24.2.7 Page Program NOR flash

The Page Program (PP) instruction is for programming the memory to be "0". A Write Enable (WREN) instruction must be executed to set the Write Enable Latch (WEL) bit before sending the Page Program (PP).

AutoChips Confidential

**NutoChips** 

© 2013 - 2021 AutoChips Inc.

Page 328 of 360

#### 24.2.7.1 Buffer enable

A 128-byte buffer can be used in flashif/sf\_prefetch block, program data should be written into buffer 32-bits by 32-bits through register REG\_SF\_ PP\_DW\_DATA, at least two 32-bits, at most 32 32-bits data. 128 data bytes can be sent to NOR flash one time. If the entire 128 data bytes are going to be programmed, address[6:0](The seven least significant address bits) should be set to 0. If address[6:0] are not all zero, transmitted data that exceed page length are programmed from the starting address (24-bit address that last 7 bit are all 0) of currently selected page.

The sequence of issuing PP instruction is: CS# goes low $\rightarrow$  sending PP instruction code $\rightarrow$  3-byte address on SI $\rightarrow$  at least 8-byte and at most 128-byte on data on SI  $\rightarrow$  CS# goes high.

The CS# must be kept to low during the whole Page Program cycle. The CS# must go high exactly at the byte boundary (the latest eighth bit of data being latched in), otherwise the instruction will be rejected and will not be executed.

The self-timed Page Program Cycle time (tPP) is initiated as soon as Chip Select (CS#) goes high. The Write in Progress (WIP) bit still can be checked while the Page Program cycle is in progress. The WIP sets during the tPP timing, and clears when Page Program Cycle is completed, and the Write Enable Latch (WEL) bit is cleared. If the page is protected by BP bits (Block Protect Mode) or SPB/DPB (Advanced Sector Protect Mode), the Page Program (PP) instruction will not be executed. The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Release block write protection;
- 4) Write REG\_SF\_ CFG2 to 0x01;
- Write REG\_SF\_ PP\_DW\_DATA to expected value(32 bits), at least two 32-bits, at most 32
   32-bits data(buffer full);
- 6) Write REG\_SF\_ RADR2 to expected address addr[23:16];
- 7) Write REG\_SF\_ RADR1 to expected address addr[15:8];
- 8) Write REG\_SF\_ RADR0 to expected address addr[7:0];
- 9) Write REG\_SF\_CMD to 0x10;
- 10) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x10, then write REG\_SF\_INTRSTUS to 0x10;
- 11) Write REG\_SF\_CMD to 0x2;
- 12) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2, else turn to step 12;
- 13) Read REG\_SF\_RDSR, if WIP = 0, Page program Cycle is completed, else turn to step 11.

# **NutoChips**



Figure 24-9 Buffer enable flow

#### 24.2.7.2 Buffer disable

The 128-byte buffer isn't used for page program, only 1 data byte can be sent to NOR flash one time. The sequence of issuing PP instruction is: CS# goes low $\rightarrow$  sending PP instruction code $\rightarrow$  3-byte address on SI $\rightarrow$  1-byte on data on SI $\rightarrow$  CS# goes high.

The CS# must be kept to low during the whole Page Program cycle. The CS# must go high exactly at the byte boundary (the latest eighth bit of data being latched in), otherwise the instruction will be rejected and will not be executed.

The self-timed Page Program Cycle time (tPP) is initiated as soon as Chip Select (CS#) goes high. The Write in Progress (WIP) bit still can be checked while the Page Program cycle is in progress. The WIP sets during the tPP timing, and clears when Page Program Cycle is completed, and the Write Enable Latch (WEL) bit is cleared. If the page is protected by BP bits (Block Protect Mode) or SPB/DPB (Advanced Sector Protect Mode), the Page Program (PP) instruction will not be executed. The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Release block write protection;

© 2013 - 2021 AutoChips Inc.

4) Write REG\_SF\_ CFG2 to 0x0;

**NutoChips** 

- 5) Write REG\_SF\_ WDATA to expected value(8 bits);
- 6) Write REG\_SF\_ RADR2 to expected address addr[23:16];
- 7) Write REG\_SF\_ RADR1 to expected address addr[15:8];
- 8) Write REG\_SF\_ RADR0 to expected address addr[7:0];
- 9) Write REG\_SF\_CMD to 0x10;
- 10) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x10, then write REG\_SF\_INTRSTUS to 0x10;
- 11) Write REG\_SF\_CMD to 0x2;
- 12) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2, else turn to step 12;
- 13) Read REG\_SF\_RDSR, if WIP = 0, Page program Cycle is completed, else turn to step 11.



#### Figure 24-10 Buffer disable flow

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 331 of 360

#### 24.2.8 4 x I/O Page Program(4PP)

The Quad Page Program (4PP) instruction is for programming the memory to be "0". A Write Enable (WREN) instruction must be executed to set the Write Enable Latch (WEL) bit and Quad Enable (QE) bit must be set to "1" before sending the Quad Page Program (4PP). The Quad Page Programming take four pins: SIO0, SIO1, SIO2, and SIO3, which raise programmer performance and the effectiveness of application.

#### 24.2.8.1 Buffer enable

The sequence of issuing 4PP instruction is: CS# goes low $\rightarrow$  sending 4PP instruction code $\rightarrow$  3-byte address on SIO[3:0] $\rightarrow$  at least 8-byte and at most 128-byte on data on SIO[3:0] $\rightarrow$  CS# goes high. Notice the method to set Quad Enable(QE) bit is discrepant for different manufactures. EQPI mode isn't supported.

The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Release block write protection and enable Quad Enable(QE) bit;
- 4) Write REG\_QSPI\_CFG to 0x4/0x6;
- 5) Write REG\_SF\_ CFG2 to 0x11;
- 6) Write REG\_SF\_ PRGDATA0 to 0x32/0x38;
- Write REG\_SF\_ PP\_DW\_DATA to expected value(32 bits), at least two 32-bits, at most 32
   32-bits data(buffer full);
- 8) Write REG\_SF\_ RADR2 to expected address addr[23:16];
- 9) Write REG\_SF\_ RADR1 to expected address addr[15:8];
- 10) Write REG\_SF\_ RADR0 to expected address addr[7:0];
- 11) Write REG\_SF\_CMD to 0x10;
- 12) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x10, then write REG\_SF\_INTRSTUS to 0x10;
- 13) Write REG\_SF\_CMD to 0x2;
- 14) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2, else turn to step 12;
- 15) Read REG\_SF\_RDSR, if WIP = 0, Page program Cycle is completed, else turn to step 11.



Figure 24-11 Buffer enable flow

#### 24.2.8.2 Buffer disable

The 128-byte buffer isn't used for page program, only 1 data byte can be sent to NOR flash one time.

The sequence of issuing 4PP instruction is: CS# goes low $\rightarrow$  sending 4PP instruction code $\rightarrow$  3-byte address on SIO[3:0] $\rightarrow$  1-byte data on SIO[3:0] $\rightarrow$  CS# goes high.

Notice the method to set Quad Enable(QE) bit is discrepant for different manufactures. EQPI mode isn't supported.

The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Release block write protection and enable Quad Enable(QE) bit;
- 4) Write REG\_QSPI\_CFG to 0x4/0x6;
- 5) Write REG\_SF\_CFG2 to 0x10;

<sup>6)</sup> Write REG\_SF\_ PRGDATA0 to 0x32/0x38; AutoChips Confidential © 2013 - 202

- 7) Write REG\_SF\_ WDATA to expected value(8 bits);
- 8) Write REG\_SF\_ RADR2 to expected address addr[23:16];
- 9) Write REG\_SF\_ RADR1 to expected address addr[15:8];
- 10) Write REG\_SF\_ RADR0 to expected address addr[7:0];
- 11) Write REG\_SF\_CMD to 0x10;

**NutoChips** 

- 12) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x10, then write REG\_SF\_INTRSTUS to 0x10;
- 13) Write REG\_SF\_CMD to 0x2;
- 14) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2, else turn to step 12;
- 15) Read REG\_SF\_RDSR, if WIP = 0, Page program Cycle is completed, else turn to step 11.



Figure 24-12 Buffer disable flow

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 334 of 360

### 24.2.9 AAI program NOR flash

The AAI program instruction allows multiple bytes of data to be programmed without re-issuing the next sequential address location. This feature decreases total programming time when the multiple bytes or entire memory array is to be programmed. An AAI program instruction pointing to a protected memory area will be ignored. The selected address range must be in the erased state (FFH) when initiating an AAI program instruction.

While within AAI WORD programming sequence, the only valid instructions are AAI WORD program operation, RDSR, WRDI. Software detection by polling the BUSY in the software status register can be used to determine the completion of each AAI WORD program cycle.

Prior to any write operation, the Write Enable (WREN) instruction must be executed. The AAI WORD program instruction is initiated by executing an 8-bit command, ADH (ESMT F25L16PA), followed by address bits [A23 -A0]. Following the addresses, two bytes of data is input sequentially. If the 8-bit command isn't ADH, 2 methods can be used to configure the operation code, refer to the following step 9 for details.

Chip Select (CS#) must be driven high before the AAI WORD program instruction is executed. The user must check the busy status before entering the next valid command. Once the device indicates it is no longer busy, data for next two sequential addresses may be programmed and so on. After entering the last desired byte, use the RDSR instruction to check the busy status and execute the WRDI instruction to terminate the AAI. User must check busy status after WRDI to determine if the device is ready for any command. There is no wrap mode during AAI programming. Once the highest unprotected memory address is reached, the device will exit AAI operation and reset the Write-Enable-Latch bit (WEL = 0) and the AAI bit (AAI=0).

The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Release block write protection;
- 4) Write REG\_SF\_CFG2 to 0x1;
- 5) Write REG\_SF\_ PP\_DW\_DATA to expected value(32 bits), repeat 32 times until buffer is full;
- 6) Write REG\_SF\_ RADR2 to expected address addr[23:16];
- 7) Write REG\_SF\_ RADR1 to expected address addr[15:8];
- 8) Write REG\_SF\_ RADR0 to expected address addr[7:0];
- 9) Select suitable operation code

Solution 1:

Write REG\_SF\_ CFG2 to 0x01, 8-bit command is AFH;

Solution 2:

Write REG\_SF\_ CFG2 to 0x41, 8-bit command is ADH;

Solution 3:

Write REG\_SF\_PRGDATA0 to 0x\*\*;

Write REG\_SF\_ CFG2 to 0x11, 8-bit command is 0x\*\*;

10) Write REG\_SF\_AAICMD to 0x1;

© 2013 - 2021 AutoChips Inc.

Page 335 of 360

- 11) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x40, then write REG\_SF\_INTRSTUS to 0x40;
- 12) Write REG\_SF\_CMD to 0x2;

**NutoChips** 

13) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2, else turn to step 13;

14) Read REG\_SF\_RDSR, if WIP = 0, AAI program Cycle is completed, else repeat step 14.



Figure 24-13 AAI program NOR flash

#### 24.2.10 Read NOR flash

#### 24.2.10.1 Normal read NOR flash

The read instruction is for reading data out. The address is latched on rising edge of SCLK, and data shifts out on the falling edge of SCLK at a maximum frequency fR. The first address byte can be at any location. The address is automatically increased to the next higher address after each byte data is shifted out, so the whole memory can be read out at a single READ instruction. The address counter

Page 336 of 360

rolls over to 0 when the highest address has been reached. Read Cycle is completed when 128-byte buffer is full.

The sequence of issuing READ instruction is: CS# goes low—sending READ instruction code— 3-byte address on SI— data out on SO—to end READ operation can use CS# to high at any time during data out.

The specific steps are as follows:

**NutoChips** 

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Write REG\_SF\_PRGDATA5 to 0x6;
- 4) Write REG\_SF\_CNT to 0x8;
- 5) Write REG\_SF\_CMD to 0x4;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 7) Write REG\_SF\_CMD to 0x2, trigger RDSR command;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- 9) Read REG\_SF\_RDSR, if WEL = 1, turn to step 3, else continue;
- 10) Write REG\_SF\_ RADR2 to expected address addr[23:16];
- 11) Write REG\_SF\_ RADR1 to expected address addr[15:8];
- 12) Write REG\_SF\_ RADR0 to expected address addr[7:0];
- 13) Write REG\_SF\_ CMD to 0x1;
- 14) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x1, then write REG\_SF\_INTRSTUS to 0x1;
- 15) All 128-byte data are saved in buffer, if we want to read out the data, we should write REG\_SF\_ CMD to 0x81, read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x1, then write REG\_SF\_INTRSTUS to 0x1, and then read REG\_SF\_ RDATA, related operation in the above should repeat 128 times.





#### 24.2.10.2 Fast read NOR flash

The FAST READ instruction is used to read data quickly. The address is latched on rising edge of SCLK, and data of each bit shifts out on the falling edge of SCLK at a maximum frequency fC. The first address byte can be at any location. The address is automatically increased to the next higher address after each byte data is shifted out, so the whole memory can be read out at a single FAST\_READ instruction. The address counter rolls over to 0 when the highest address has been reached.

The sequence of issuing FAST\_READ instruction is: CS# goes low $\rightarrow$  sending FAST\_READ instruction code $\rightarrow$ 3-byte address on SI $\rightarrow$  8 dummy cycles (default) $\rightarrow$  data out on SO $\rightarrow$  to end FAST\_READ operation can use CS# to high at any time during data out.

Page 338 of 360

#### AC781x Reference Manual General

While Program/Erase/Write Status Register cycle is in progress, FAST\_READ instruction is rejected without any impact on the Program/Erase/Write Status Register current cycle. The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Write REG\_SF\_PRGDATA5 to 0x6;
- 4) Write REG\_SF\_CNT to 0x8;

**NutoChips** 

- 5) Write REG\_SF\_CMD to 0x4;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 7) Write REG\_SF\_CMD to 0x2, trigger RDSR command;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- 9) Read REG\_SF\_RDSR, if WEL = 1, turn to step 3, else continue;
- 10) Write REG\_SF\_ RADR2 to expected address addr[23:16];
- 11) Write REG\_SF\_ RADR1 to expected address addr[15:8];
- 12) Write REG\_SF\_ RADR0 to expected address addr[7:0];
- 13) Write REG\_SF\_CFG1 to 0x1;
- 14) Write REG\_SF\_ CMD to 0x1;
- 15) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x1, then write REG\_SF\_INTRSTUS to 0x1;
- 16) All 128-byte data are saved in buffer, if we want to read out the data, we should write REG\_SF\_ CMD to 0x81, and then read REG\_SF\_ RDATA, related operation in the above should repeat 128 times.





#### 24.2.10.3 Dual read NOR flash (DREAD)

The DREAD instruction enables double throughput of Serial Flash in read mode. The address is latched on rising edge of SCLK, and data of every two bits (interleave on 2 I/O pins) shift out on the falling edge of SCLK at a maximum frequency fT. The first address byte can be at any location. The address is automatically increased to the next higher address after each byte data is shifted out, so the whole memory can be read out at a single DREAD instruction. The address counter rolls over to 0 when the highest address has been reached. Read Cycle is completed when 128-byte buffer is full.

Page 340 of 360

The sequence of issuing DREAD instruction is: CS# goes low $\rightarrow$ sending DREAD instruction code $\rightarrow$  3-byte address on SI $\rightarrow$  8-bit dummy cycle $\rightarrow$  data out on SO1 & SO0 $\rightarrow$ to end DREAD operation can use CS# to high at any time during data out.

The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Write REG\_SF\_PRGDATA5 to 0x6;
- 4) Write REG\_SF\_CNT to 0x8;
- 5) Write REG\_SF\_CMD to 0x4;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 7) Write REG\_SF\_CMD to 0x2, trigger RDSR command;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- 9) Read REG\_SF\_RDSR, if WEL = 1, turn to step 3, else continue;
- 10) Write REG\_SF\_DUAL to 0x1;
- 11) Write REG\_SF\_PRGDATA3 to 0x3B;
- 12) Write REG\_SF\_ RADR2 to expected address addr[23:16];
- 13) Write REG\_SF\_ RADR1 to expected address addr[15:8];
- 14) Write REG\_SF\_ RADR0 to expected address addr[7:0];
- 15) Write REG\_SF\_ CMD to 0x1;
- 16) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x1, then write REG\_SF\_INTRSTUS to 0x1;
- 17) All 128-byte data are saved in buffer, if we want to read out the data, we should write REG\_SF\_ CMD to 0x81, read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x1, then write REG\_SF\_INTRSTUS to 0x1, and then read REG\_SF\_ RDATA, related operation in the above should repeat 128 times.





### 24.2.10.4 2 x I/O read NOR flash (2READ)

The 2READ instruction enables Double Transfer Rate of Serial Flash in read mode. The address is latched on rising edge of SCLK, and data of every two bits (interleave on 2 I/O pins) shift out on the falling edge of SCLK at a maximum frequency fT. The first address byte can be at any location. The address is automatically increased to the next higher address after each byte data is shifted out, so the whole memory can be read out at a single 2READ instruction. The address counter rolls over to 0 when the highest address has been reached. Read Cycle is completed when 128-byte buffer is full.

The sequence of issuing 2READ instruction is: CS# goes low $\rightarrow$ sending 2READ instruction code $\rightarrow$  3byte address on SIO1 & SIO0  $\rightarrow$  4 dummy cycle(default) on SIO1 & SIO0 $\rightarrow$  data out interleave on SIO1 & SIO0 $\rightarrow$ to end 2READ operation can use CS# to high at any time during data out. The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Write REG\_SF\_PRGDATA5 to 0x6;
- 4) Write REG\_SF\_CNT to 0x8;
- 5) Write REG\_SF\_CMD to 0x4;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 7) Write REG\_SF\_CMD to 0x2, trigger RDSR command;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- 9) Read REG\_SF\_RDSR, if WEL = 1, turn to step 3, else continue;
- 10) Write REG\_SF\_DUAL to 0x3;
- 11) Write REG\_SF\_PRGDATA3 to 0xBB;
- 12) Write REG\_SF\_ RADR2 to expected address addr[23:16];
- 13) Write REG\_SF\_ RADR1 to expected address addr[15:8];
- 14) Write REG\_SF\_ RADR0 to expected address addr[7:0];
- 15) Write REG\_SF\_ CMD to 0x1;
- 16) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x1, then write REG\_SF\_INTRSTUS to 0x1;
- 17) All 128-byte data are saved in buffer, if we want to read out the data, we should write REG\_SF\_ CMD to 0x81, read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x1, then write REG\_SF\_INTRSTUS to 0x1, and then read REG\_SF\_ RDATA, related operation in the above should repeat 128 times.





#### 24.2.10.5 Quad read NOR flash (QREAD)

The QREAD instruction enables quad throughput of serial flash in read mode. The address is latched on rising edge of SCLK, and data of every four bits (interleave on 4 I/O pins) shift out on the falling edge of SCLK at a maximum frequency fQ. The first address byte can be at any location. The address is automatically increased to the next higher address after each byte data is shifted out, so the whole memory can be read out at a single QREAD instruction. The address counter rolls over to 0 when the highest address has been reached. Read Cycle is completed when 128-byte buffer is full.

#### AC781x Reference Manual General

# The sequence of issuing QREAD instruction is: CS# goes low $\rightarrow$ sending QREAD instruction code $\rightarrow$ 3-byte address on SI $\rightarrow$ 8-bit dummy cycle $\rightarrow$ data out interleave on SIO3, SIO2, SIO1 & SIO0 $\rightarrow$ to end READ operation can use CS# to high at any time during data out.

The specific steps are as follows:

**NutoChips** 

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Write REG\_SF\_PRGDATA5 to 0x6;
- 4) Write REG\_SF\_CNT to 0x8;
- 5) Write REG\_SF\_CMD to 0x4;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 7) Write REG\_SF\_CMD to 0x2, trigger RDSR command;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- 9) Read REG\_SF\_RDSR, if WEL = 1, turn to step 3, else continue;
- 10) Release block write protection and enable Quad Enable(QE) bit;
- 11) Write REG\_SF\_DUAL to 0x4;
- 12) Write REG\_SF\_PRGDATA4 to 0x6B;
- 13) Write REG\_SF\_ RADR2 to expected address addr[23:16];
- 14) Write REG\_SF\_ RADR1 to expected address addr[15:8];
- 15) Write REG\_SF\_ RADR0 to expected address addr[7:0];
- 16) Write REG\_SF\_ CMD to 0x1;
- 17) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x1, then write REG\_SF\_INTRSTUS to 0x1;
- 18) All 128-byte data are saved in buffer, if we want to read out the data, we should write REG\_SF\_ CMD to 0x81, read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x1, then write REG\_SF\_INTRSTUS to 0x1, and then read REG\_SF\_ RDATA, related operation in the above should repeat 128 times.



Figure 24-18 Quad read NOR flash flow

#### 24.2.10.6 4 x I/O read NOR flash

The 4READ instruction enables quad throughput of Serial Flash in read mode. A Quad Enable (QE) bit of status register must be set to "1" before sending the 4READ instruction. The address is latched on rising edge of SCLK, and data of every four bits (interleave on 4 I/O pins) shift out on the falling edge of SCLK at a maximum frequency fQ. The first address byte can be at any location. The address is automatically increased to the next higher address after each byte data is shifted out, so the whole

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 346 of 360

#### AC781x Reference Manual General

# **//utoChips**

memory can be read out at a single 4READ instruction. The address counter rolls over to 0 when the highest address has been reached. Read Cycle is completed when 128-byte buffer is full.

The sequence of issuing 4READ instruction is: CS# goes low $\rightarrow$ sending 4READ instruction code $\rightarrow$  3-byte address interleave on SIO3, SIO2, SIO1 & SIO0  $\rightarrow$  **2+4 dummy cycles (default)**  $\rightarrow$  data out interleave on SIO3, SIO2, and SIO1 & SIO0 $\rightarrow$ to end 4READ operation can use CS # to high at any time during data out.

The specific steps are as follows:

- 1) Write REG\_SF\_WEPROT to 0x30;
- 2) Write REG\_SF\_INTREN to 0x7f;
- 3) Write REG\_SF\_PRGDATA5 to 0x6;
- 4) Write REG\_SF\_CNT to 0x8;
- 5) Write REG\_SF\_CMD to 0x4;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x4, then write REG\_SF\_INTRSTUS to 0x4;
- 7) Write REG\_SF\_CMD to 0x2, trigger RDSR command;
- Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x2, then write REG\_SF\_INTRSTUS to 0x2;
- 9) Read REG\_SF\_RDSR, if WEL = 1, turn to step 3, else continue;
- 10) Release block write protection and enable Quad Enable(QE) bit;
- 11) Write REG\_SF\_DUAL to 0xc;
- 12) Write REG\_SF\_PRGDATA4 to 0xEB;
- 13) Write REG\_DUMMY\_CFG to suitable value;
- 14) Write REG\_SF\_ RADR2 to expected address addr[23:16];
- 15) Write REG\_SF\_ RADR1 to expected address addr[15:8];
- 16) Write REG\_SF\_ RADR0 to expected address addr[7:0];
- 17) Write REG\_SF\_ CMD to 0x1;
- 18) Read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x1, then write REG\_SF\_INTRSTUS to 0x1;
- 19) All 128-byte data are saved in buffer, if we want to read out the data, we should write REG\_SF\_ CMD to 0x81, read REG\_SF\_INTRSTUS and REG\_SF\_INTREN, if the value of REG\_SF\_INTRSTUS & REG\_SF\_INTREN is 0x1, then write REG\_SF\_INTRSTUS to 0x1, and then read REG\_SF\_ RDATA, related operation in the above should repeat 128 times.

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 347 of 360



Figure 24-19 4 x I/O read NOR flash flow

### 24.3 System boot from serial flash

When trapping mode is set to serial flash boot mode, system boot from serial flash is selected. Related request signal and address signal (base address is 0x6000\_0000) is valid, then corresponding data can be read out from serial flash.

Page 348 of 360

### 24.4 Register definitions

#### Table 24-2 Flashif related register map

#### Flashif base address: (+40010000h)

| Address | Name              | Width | Register Function                                             |
|---------|-------------------|-------|---------------------------------------------------------------|
| 000     | REG_SF_CMD        | 8     | Serial flash command register                                 |
| 004     | REG_SF_CNT        | 8     | Bit count to transfer by PRG command                          |
| 008     | REG_SF_RDSR       | 8     | Read back Status Register by RDSR command                     |
| 00C     | REG_SF_RDATA      | 8     | Read back Flash Data by RD command                            |
| 010     | REG_SF_RADR0      | 8     | Read or Write address for Read command or Write command       |
| 014     | REG_SF_RADR1      | 8     | Read or Write address for Read command or Write command       |
| 018     | REG_SF_RADR2      | 8     | Read or Write address for Read command or Write command       |
| 01C     | REG_SF_WDATA      | 8     | The serial flash write data used by the Write Command         |
| 020     | REG_SF_PRGDATA0   | 8     | The serial flash program shift data used by the PRG Command.  |
| 024     | REG_SF_PRGDATA1   | 8     | The serial flash program shift data used by the PRG Command.  |
| 028     | REG_SF_PRGDATA2   | 8     | The serial flash program shift data used by the PRG Command.  |
| 02C     | REG_SF_PRGDATA3   | 8     | The serial flash program shift data used by the PRG Command.  |
| 030     | REG_SF_PRGDATA4   | 8     | The serial flash program shift data used by the PRG Command.  |
| 034     | REG_SF_PRGDATA5   | 8     | The serial flash program shift data used by the PRG Command.  |
| 038     | REG_SF_SHREG0     | 8     | The shift register of serial flash interface. For debug only. |
| 03C     | REG_SF_SHREG1     | 8     | The shift register of serial flash interface. For debug only. |
| 040     | REG_SF_SHREG2     | 8     | The shift register of serial flash interface. For debug only. |
| 060     | REG_SF_CFG1       | 8     | module Configure register 1                                   |
| 064     | REG_SF_CFG2       | 8     | module Configure register 2                                   |
| 088     | REG_QSPI_CFG      | 8     | Configuration for QSPI mode                                   |
| 08c     | REG_SF_PRGDATA6   | 8     | The serial flash program shift data used by the PRG Command.  |
| 098     | REG_SF_PP_DW_DATA | 32    | Flash page program data register                              |
| 0A8     | REG_SF_INTRSTUS   | 8     | Interrupt register                                            |
| 0AC     | REG_SF_INTREN     | 8     | Interrupt Enable register                                     |
| 0B4     | REG_SF_CFG3       | 8     | module Configure register 3                                   |
| 0B8     | REG_FL_CHKSUM_CTL | 8     | flash check sum control register                              |
| 0BC     | REG_FL_CHKSUM     | 32    | Check sum output register                                     |
| 0C0     | REG_SF_AAICMD     | 8     | AAI programming command enable register                       |
| 0C4     | REG_SF_WRPROT     | 8     | Write command enable register                                 |
| 0C8     | REG_SF_RADR3      | 8     | Read or Write address for Read command or Write command       |
| 000     | REG_SF_DUAL       | 8     | Serial flash dual mode configure register                     |
| 0E0     | REG_DUMMY_CFG     | 8     | Configuration of dummy cycle for QSPI read command            |
| 0E4     | REG_DUMMY_CFG2    | 8     | Configuration 2 of dummy cycle for QSPI read command          |

### **NutoChips**

| 000           |      | <u>REG</u> | SF_C | MD     | serial | flash                                                                               | com                                                                                                                                                                                                                                                    | mand                        | regis                  | ter             |                   |         |                             |         |         | 00      |  |  |  |  |
|---------------|------|------------|------|--------|--------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|------------------------|-----------------|-------------------|---------|-----------------------------|---------|---------|---------|--|--|--|--|
| Bit           | 15   | 14         | 13   | 12     | 11     | 10                                                                                  | 9                                                                                                                                                                                                                                                      | 8                           | 7                      | 6               | 5                 | 4       | 3                           | 2       | 1       | 0       |  |  |  |  |
| Name          |      |            |      |        |        |                                                                                     |                                                                                                                                                                                                                                                        |                             | AINC                   |                 | WRSR              |         | ERASE                       |         |         |         |  |  |  |  |
| Type<br>Reset |      |            |      |        |        |                                                                                     |                                                                                                                                                                                                                                                        |                             | RW<br>0                |                 | RW<br>0           | RW<br>0 | A0<br>0                     | A0<br>0 | A0<br>0 | A0<br>0 |  |  |  |  |
| Resel         |      |            |      |        |        |                                                                                     |                                                                                                                                                                                                                                                        |                             | 0                      |                 | 0                 | 0       | 0                           | 0       | 0       | 0       |  |  |  |  |
|               | -    |            | -    |        |        | -                                                                                   |                                                                                                                                                                                                                                                        |                             |                        |                 |                   |         |                             |         |         |         |  |  |  |  |
| Bit(s)        |      | nonic      | Nam  |        |        |                                                                                     | script                                                                                                                                                                                                                                                 |                             |                        | -               |                   |         |                             |         |         |         |  |  |  |  |
| 7             | AINC |            | AUTC | )_INCF | १      |                                                                                     | e RAD<br>nmano                                                                                                                                                                                                                                         |                             | auto                   | increa          | ase by            | 1 aft   | er trigg                    | ering   | g RD c  | or WR   |  |  |  |  |
|               |      |            |      |        |        | 0: a                                                                                | ddress                                                                                                                                                                                                                                                 | s not a                     | uto inc                | rease           |                   |         |                             |         |         |         |  |  |  |  |
|               |      |            |      |        |        | 1: a                                                                                | ddress                                                                                                                                                                                                                                                 | auto                        | increas                | e               |                   |         |                             |         |         |         |  |  |  |  |
| 5             | WRSF | ર          | WRSI | R_CMI  | C      |                                                                                     |                                                                                                                                                                                                                                                        |                             |                        |                 |                   |         | works<br>work fo            |         |         | T and   |  |  |  |  |
|               |      |            |      |        |        | 0: n                                                                                | 0: no write serial flash status register command                                                                                                                                                                                                       |                             |                        |                 |                   |         |                             |         |         |         |  |  |  |  |
|               |      |            |      |        |        | 1: w                                                                                | 1: write serial flash status register command                                                                                                                                                                                                          |                             |                        |                 |                   |         |                             |         |         |         |  |  |  |  |
| 4             | WR   |            | WR_( | CMD    |        | pre<br>RAI<br>Thi                                                                   | Write 1 to trigger Single Byte Write. The write data must be<br>prepared at WDATA and the write address must be prepared a<br>RADR before trigger. This bit will be auto-cleared when done<br>This command works for ST, SST and compatible command-se |                             |                        |                 |                   |         |                             |         |         |         |  |  |  |  |
|               |      |            |      |        |        |                                                                                     | flash, but not work for ATMEL.<br>Setting buf2wr, en (CEG2[0]), will enter page programming mode.                                                                                                                                                      |                             |                        |                 |                   |         |                             |         |         |         |  |  |  |  |
|               |      |            |      |        |        |                                                                                     | Setting buf2wr_en (CFG2[0]), will enter page programming mode. this mode, this bit is the trigger bit.                                                                                                                                                 |                             |                        |                 |                   |         |                             |         |         |         |  |  |  |  |
|               |      |            |      |        |        | 0: w                                                                                | 0: write data command is not triggered                                                                                                                                                                                                                 |                             |                        |                 |                   |         |                             |         |         |         |  |  |  |  |
|               |      |            |      |        |        | 1: trigger write data command                                                       |                                                                                                                                                                                                                                                        |                             |                        |                 |                   |         |                             |         |         |         |  |  |  |  |
| 3             | ERAS | E          | ERAS | SE_CM  | ID     | for                                                                                 | This bit will be auto-cleared when done. This command works<br>for ST and compatible command-set flash, but not work for SST<br>and ATMEL.                                                                                                             |                             |                        |                 |                   |         |                             |         |         |         |  |  |  |  |
|               |      |            |      |        |        | 0: b                                                                                | ulk era                                                                                                                                                                                                                                                | ise is r                    | not trig               | gered           |                   |         |                             |         |         |         |  |  |  |  |
|               |      |            |      |        |        | 1: tı                                                                               | rigger b                                                                                                                                                                                                                                               | oulk er                     | ase co                 | mman            | d                 |         |                             |         |         |         |  |  |  |  |
| 2             | PRG  |            | PRG_ | CMD    |        | the<br>trig<br>woi                                                                  | prog<br>ger. T<br>ks for                                                                                                                                                                                                                               | ram d<br>his bit<br>all fla | ata m<br>will b<br>sh. | ust b<br>e auto | e prep<br>o-clear | ared    | ed at R<br>at PRC<br>en don | DAT     | A0~5 k  | before  |  |  |  |  |
|               |      |            |      |        |        | -                                                                                   | -                                                                                                                                                                                                                                                      |                             | is not t<br>ogram      |                 |                   |         |                             |         |         |         |  |  |  |  |
| 1             | RDSR | 1          | RDSF | R_CME  | )      | con                                                                                 |                                                                                                                                                                                                                                                        |                             |                        |                 |                   |         | on RDS<br>Id comp           |         |         |         |  |  |  |  |
|               |      |            |      |        |        | 0: r                                                                                | ead sta                                                                                                                                                                                                                                                | atus re                     | gister i               | s not ti        | riggere           | d       |                             |         |         |         |  |  |  |  |
|               |      |            |      |        |        | 0: read status register is not triggered<br>1: trigger read status register command |                                                                                                                                                                                                                                                        |                             |                        |                 |                   |         |                             |         |         |         |  |  |  |  |
| 0             | RD   |            |      |        |        |                                                                                     | The read address must be prepared at RADR before trigger.<br>Read Data will be shown on RDATA Register. This command<br>works for ST, SST, ATMEL and compatible command-set flash.                                                                     |                             |                        |                 |                   |         |                             |         |         |         |  |  |  |  |
|               |      |            |      |        |        | 0: read data is not triggered                                                       |                                                                                                                                                                                                                                                        |                             |                        |                 |                   |         |                             |         |         |         |  |  |  |  |
|               |      |            |      |        |        | 1: tı                                                                               | 1: trigger read data command                                                                                                                                                                                                                           |                             |                        |                 |                   |         |                             |         |         |         |  |  |  |  |

| - | - | - |
|---|---|---|
| n | n |   |
| U | U | 4 |

<u>REG\_SF\_CNT</u> Bit count to transfer by PRG command

00

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-----|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   | - | - | CNT |   |   |   |
| Туре  |    |    |    |    |    |    |   |   |   |   |   |   | RW  |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   | 0 | 0 | 0 | 0   | 0 | 0 | 0 |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 350 of 360



| Bit(s) | ) Mnemon | ic Name | Description                                           |
|--------|----------|---------|-------------------------------------------------------|
| 6:0    | CNT      | SF_CNT  | bit count to transfer by PRG command. Maximum 48 bits |

| 008   |    | <u>REG</u> | <u>SF_R</u> | DSR | Read | back | Statu | s Reg | ister | by RC | SR c | omma | and  |   |   | 00 |
|-------|----|------------|-------------|-----|------|------|-------|-------|-------|-------|------|------|------|---|---|----|
| Bit   | 15 | 14         | 13          | 12  | 11   | 10   | 9     | 8     | 7     | 6     | 5    | 4    | 3    | 2 | 1 | 0  |
| Name  |    |            |             |     |      |      |       |       |       |       |      | RDS  | RDAT |   |   |    |
| Туре  |    |            |             |     |      |      |       |       |       |       |      | R    | U    |   |   |    |
| Reset |    |            |             |     |      |      |       |       | 0     | 0     | 0    | 0    | 0    | 0 | 0 | 0  |

| Bit(s) | Mnemonic | Name      | Description                               |
|--------|----------|-----------|-------------------------------------------|
| 7:0    | RDSRDAT  | RDSR_DATA | Read back Status Register by RDSR command |

| 00C   |    | REG SF | <u>RDATA</u> | Read back Flash Data by RD command |    |    |   |   |   |   |   |     |     |   |   |   |
|-------|----|--------|--------------|------------------------------------|----|----|---|---|---|---|---|-----|-----|---|---|---|
| Bit   | 15 | 14     | 13           | 12                                 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2 | 1 | 0 |
| Name  |    |        |              |                                    |    |    |   |   |   |   |   | SFR | DAT |   |   |   |
| Туре  |    |        |              |                                    |    |    |   |   |   |   |   | R   | U   |   |   |   |
| Reset |    |        |              |                                    |    |    |   |   | 0 | 0 | 0 | 0   | 0   | 0 | 0 | 0 |

| Bit(s) Mnemonic   | Name     | Description                        |
|-------------------|----------|------------------------------------|
| 7:0 <b>SFRDAT</b> | SF_RDATA | Read back Flash Data by RD command |

| 010 |     | REG_S | SF_RA | DKU | Read<br>comm |     | ite ad | ddres | s for | Read     | d con | nman | d or | Write    | 00       |  |
|-----|-----|-------|-------|-----|--------------|-----|--------|-------|-------|----------|-------|------|------|----------|----------|--|
|     | 4.5 |       | 10    | 4.0 |              | 4.0 | -      | -     | -     | <u> </u> | -     |      |      | <u> </u> | <u> </u> |  |

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 1 | 6 | 5 | 4    | 3    | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|------|------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | SFPA | ADR0 |   |   |   |
| Туре  |    |    |    |    |    |    |   |   |   |   |   | R    | W    |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0    | 0    | 0 | 0 | 0 |

| Bit(s) | Mnemonio | Name     | Description                                             |
|--------|----------|----------|---------------------------------------------------------|
| 7:0    | SFPADR0  | SFP_ADR0 | Read or Write address for Read command or Write command |

### 014 <u>REG SF RADR1</u> Read or Write address for Read command or Write command

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|-------|----|----|----|----|----|----|---|---|---------|---|---|---|---|---|---|---|--|--|
| Name  |    |    |    |    |    |    |   |   | SFPADR1 |   |   |   |   |   |   |   |  |  |
| Туре  |    |    |    |    |    |    |   |   | RW      |   |   |   |   |   |   |   |  |  |
| Reset |    |    |    |    |    |    |   |   | 0       | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |

| Bit(s) | Mnemonio | Name     | Description                                             |
|--------|----------|----------|---------------------------------------------------------|
| 7:0    | SFPADR1  | SFP_ADR1 | Read or Write address for Read command or Write command |

AutoChips Confidential

00

| 018   |    | REG_S | SF_RA | <u>DR2</u> |    | Read or Write address for Read command or Write command |   |   |         |   |   |   |   |   |   |   |  |
|-------|----|-------|-------|------------|----|---------------------------------------------------------|---|---|---------|---|---|---|---|---|---|---|--|
| Bit   | 15 | 14    | 13    | 12         | 11 | 10                                                      | 9 | 8 | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Name  |    |       |       |            |    |                                                         |   |   | SFPADR2 |   |   |   |   |   |   |   |  |
| Туре  |    |       |       |            |    |                                                         |   |   | RW      |   |   |   |   |   |   |   |  |
| Reset |    |       |       |            |    |                                                         |   |   | 0       | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |
|       |    |       |       |            |    |                                                         |   |   |         |   |   |   |   |   |   |   |  |

| Bit(s) Mnemonic    | Name     | Description                                             |
|--------------------|----------|---------------------------------------------------------|
| 7:0 <b>SFPADR2</b> | SFP_ADR2 | Read or Write address for Read command or Write command |

| 01C   |    | REG_ | <u>SF_W</u> | DATA | The s | erial f | lash v | write o | data u  | ised b | y the | Write | Com | manc | 1 | 00 |  |  |
|-------|----|------|-------------|------|-------|---------|--------|---------|---------|--------|-------|-------|-----|------|---|----|--|--|
| Bit   | 15 | 14   | 13          | 12   | 11    | 10      | 9      | 8       | 7       | 6      | 5     | 4     | 3   | 2    | 1 | 0  |  |  |
| Name  |    |      |             |      |       |         |        |         | SFWRDAT |        |       |       |     |      |   |    |  |  |
| Type  |    |      |             |      |       |         |        |         | RW      |        |       |       |     |      |   |    |  |  |
| Reset |    |      |             |      |       |         |        |         | 0       | 0      | 0     | 0     | 0   | 0    | 0 | 0  |  |  |

| Bit(s) | Mnemonic | Name        | Description                                           |
|--------|----------|-------------|-------------------------------------------------------|
| 7:0    | SFWRDAT  | SFP_WR_DATA | The serial flash write data used by the Write Command |

| 020   |    | <u>REG_S</u> | F_PRG | DATA0 | The serial flash program shift data used by the PRG Command. |    |   |   |   |   |   |   |   |   |   |   |
|-------|----|--------------|-------|-------|--------------------------------------------------------------|----|---|---|---|---|---|---|---|---|---|---|
| Bit   | 15 | 14           | 13    | 12    | 11                                                           | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  |    |              |       |       |                                                              |    |   |   |   |   |   |   |   |   |   |   |
| Туре  |    |              |       |       |                                                              |    |   |   |   |   |   | R | W |   |   |   |
| Reset |    |              |       |       |                                                              |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|       |    |              |       |       |                                                              |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) Mnemonic Name             | Description                                                                                                                                                                   |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 <b>PRGDATA0</b> SFP_PRGDATA0 | The serial flash program shift data used by the PRG Command.<br>The PRGDATA6 is shifted first, and the PRGDATA0 is shifted<br>last. In each byte shift, MSB is shifted first. |

| 024 | <b><u>REG_SF_PRGDATA1</u></b> The serial flash program shift data used by the PRG Command. |
|-----|--------------------------------------------------------------------------------------------|
| 024 | PRG Command.                                                                               |

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6 | 5 | 4    | 3     | 2 | 1 | 0 |  |  |
|-------|----|----|----|----|----|----|---|---|----|---|---|------|-------|---|---|---|--|--|
| Name  |    |    |    |    |    |    |   |   |    |   |   | PRGD | DATA1 |   |   |   |  |  |
| Туре  |    |    |    |    |    |    |   |   | RW |   |   |      |       |   |   |   |  |  |
| Reset |    |    |    |    |    |    |   |   | 0  | 0 | 0 | 0    | 0     | 0 | 0 | 0 |  |  |

| Bit(s) Mnemonic Name             | Description                                                                                                                                                                   |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 <b>PRGDATA1</b> SFP_PRGDATA1 | The serial flash program shift data used by the PRG Command.<br>The PRGDATA6 is shifted first, and the PRGDATA0 is shifted<br>last. In each byte shift, MSB is shifted first. |

AutoChips Confidential

**//utoChips** 

© 2013 - 2021 AutoChips Inc.

00

### AC781x Reference Manual General

00

00

| 028   | REG_SF_PRGDATA2<br>PRG Command. |    |    |    |    |    |   |   |   |   |   |     |       |   |   | 00 |
|-------|---------------------------------|----|----|----|----|----|---|---|---|---|---|-----|-------|---|---|----|
| Bit   | 15                              | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3     | 2 | 1 | 0  |
| Name  |                                 |    |    |    |    |    |   |   |   |   |   | PRG | DATA2 |   |   |    |
| Туре  |                                 |    |    |    |    |    |   |   |   |   |   | R   | W     |   |   |    |
| Reset |                                 |    |    |    |    |    |   |   | 0 | 0 | 0 | 0   | 0     | 0 | 0 | 0  |
|       |                                 |    |    |    |    |    |   |   |   |   |   |     |       |   |   |    |

| Bit(s) | Mnemonic | Name         | Description                                                                                                                                                                   |
|--------|----------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | PRGDATA2 | SFP_PRGDATA2 | The serial flash program shift data used by the PRG Command.<br>The PRGDATA6 is shifted first, and the PRGDATA0 is shifted<br>last. In each byte shift, MSB is shifted first. |

### 02C <u>REG\_SF\_PRGDATA3</u> The serial flash program shift data used by the PRG Command.

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3     | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|------|-------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | PRGD | DATA3 |   |   |   |
| Туре  |    |    |    |    |    |    |   |   |   |   |   | R    | W     |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0    | 0     | 0 | 0 | 0 |

| Bit(s) Mnemonic Name             | Description                                                                                                                                                                   |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 <b>PRGDATA3</b> SFP_PRGDATA3 | The serial flash program shift data used by the PRG Command.<br>The PRGDATA6 is shifted first, and the PRGDATA0 is shifted<br>last. In each byte shift, MSB is shifted first. |

#### 030 <u>REG\_SF\_PRGDATA4</u> PRG Command.

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3     | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|------|-------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | PRGD | DATA4 |   |   |   |
| Туре  |    |    |    |    |    |    |   |   |   |   |   | R    | W     |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0    | 0     | 0 | 0 | 0 |

| Bit(s) Mnemonic Name             | Description                                                                                                                                                                   |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 <b>PRGDATA4</b> SFP_PRGDATA4 | The serial flash program shift data used by the PRG Command.<br>The PRGDATA6 is shifted first, and the PRGDATA0 is shifted<br>last. In each byte shift, MSB is shifted first. |

### 034 <u>REG\_SF\_PRGDATA5</u> The serial flash program shift data used by the 00 PRG Command.

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3     | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|------|-------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | PRGD | DATA5 |   |   |   |
| Туре  |    |    |    |    |    |    |   |   |   |   |   | R    | W     |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0    | 0     | 0 | 0 | 0 |

| Bit(s) Mnemonic Name             | Description                                                                                                                                                                   |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 <b>PRGDATA5</b> SFP_PRGDATA5 | The serial flash program shift data used by the PRG Command.<br>The PRGDATA6 is shifted first, and the PRGDATA0 is shifted<br>last. In each byte shift, MSB is shifted first. |

AutoChips Confidential

**NutoChips** 

© 2013 - 2021 AutoChips Inc.

Page 353 of 360



| 038                                                |       | <u>REG_S</u> | F_SHR   |       | The s<br>debug    |                               |                                                | ster                             | of                      | seria                   | al f               | las  | h ir  | nterfa       | ce.   | For   |       | 00      |
|----------------------------------------------------|-------|--------------|---------|-------|-------------------|-------------------------------|------------------------------------------------|----------------------------------|-------------------------|-------------------------|--------------------|------|-------|--------------|-------|-------|-------|---------|
| Bit                                                | 15    | 14           | 13      | 12    | 11                | 10                            | 9                                              | 8                                | 7                       | 6                       | ô                  | 5    |       | 4 3          |       | 2     | 1     | 0       |
| Name<br>Type                                       |       |              |         |       |                   |                               |                                                |                                  |                         |                         |                    |      | ę     | SHREG<br>RU  | 0     |       |       |         |
| Reset                                              |       |              |         |       |                   |                               |                                                |                                  | 0                       | (                       | 0                  | 0    |       |              | )     | 0     | 0     | 0       |
|                                                    |       |              |         |       |                   |                               |                                                |                                  |                         |                         |                    |      |       |              |       |       |       |         |
| Bit(s)                                             | Mnem  | onic Na      | ame     |       | Des               | scrip                         | tion                                           |                                  |                         |                         |                    |      |       |              |       |       |       |         |
| 7:0                                                | SHRE  |              | HIFT RE | 60    |                   |                               |                                                | tor of                           | 601                     | tial fle                | ach                | inte | rfa   | ce. Foi      | dob   |       | nly   |         |
| 7.0                                                | SHILL | 30 01        |         | .00   | THE               | SIIII                         | regis                                          |                                  | 301                     |                         | a311               | mu   |       | . 1 0        | ueb   | uy o  | iiiy. |         |
| 03C                                                |       | REG_S        |         | EGT   | The s<br>debug    | g onl                         | у.                                             |                                  |                         |                         |                    |      |       |              |       |       |       | 00      |
| Bit<br>Name                                        | 15    | 14           | 13      | 12    | 11                | 10                            | 9                                              | 8                                | 7                       | (                       | 6                  | 5    |       | 4 SHREG      | -     | 2     | 1     | 0       |
| Туре                                               |       |              |         |       |                   |                               |                                                |                                  |                         |                         |                    |      |       | RU           |       |       |       |         |
| Reset                                              |       |              |         |       |                   |                               |                                                |                                  | 0                       | (                       | )                  | 0    |       | 0 0          | )     | 0     | 0     | 0       |
|                                                    |       |              |         |       |                   |                               |                                                |                                  |                         |                         |                    |      |       |              |       |       |       |         |
| Bit(s)                                             | Mnem  | onic Na      | ame     |       | Des               | scrip                         | tion                                           |                                  |                         |                         |                    |      |       |              |       |       |       |         |
| 7:0                                                | SHRE  |              | HIFT_RE | G1    |                   |                               |                                                | ter of                           | ser                     | rial fla                | ash                | inte | erfac | ce. Foi      | . dep | oua o | nlv.  |         |
| 040                                                |       | REG_S        |         | EGZ   | The s<br>debug    | g onl                         | у.                                             |                                  |                         |                         |                    |      | h ir  |              |       |       |       | 00      |
| Bit                                                | 15    | 14           | 13      | 12    | 11                | 10                            | 9                                              | 8                                | 7                       | (                       | 6                  | 5    |       | 4 3<br>SHREG |       | 2     | 1     | 0       |
| Name<br>Type                                       |       |              |         |       |                   |                               |                                                |                                  | -                       |                         |                    |      |       | RU           | 2     |       |       |         |
| Reset                                              |       |              |         |       |                   |                               |                                                |                                  | 0                       | (                       | 0                  | 0    |       | 0 0          | )     | 0     | 0     | 0       |
|                                                    |       |              |         |       |                   |                               |                                                |                                  |                         |                         |                    |      |       |              |       |       |       |         |
| Bit(s)                                             | Mnem  | onic Na      | ame     |       | Des               | scrip                         | tion                                           |                                  |                         |                         |                    |      |       |              |       |       |       |         |
| 7:0                                                | SHRE  | <b>32</b> S⊦ | HIFT_RE | G2    | The               | shift                         | reais                                          | ter of                           | ser                     | rial fla                | ash                | inte | erfac | ce. Foi      | . dep | oua o | nlv.  |         |
| 060                                                |       | REG_SF       | CFG1    | mo    | dule (            | Confi                         | gure                                           | regis                            | ster                    | <sup>.</sup> 1          |                    |      |       |              |       |       |       | 00      |
| Bit                                                | 15    | 14 1         | 3 12    | 11    | 10                | 9                             | 8                                              | 7                                |                         | 6                       | 5                  |      | 4     | 3            | 2     | 2     | 1     | 0       |
| Name                                               |       |              |         |       |                   |                               |                                                | FL_N                             |                         | I_SEL                   |                    |      |       |              |       |       |       | FR      |
| Type<br>Reset                                      |       |              |         | -     |                   |                               |                                                | 0                                | RW                      | /                       |                    |      |       | _            | _     |       |       | RW<br>0 |
| Reset                                              |       |              |         |       |                   |                               |                                                | 0                                |                         | 0                       |                    |      |       |              |       |       |       | 0       |
| $\mathbf{D}^{\mathbf{i}}_{\mathbf{i}}(\mathbf{z})$ |       |              | Nama    |       | <b>D</b>          | <b>!</b>                      | 4                                              |                                  |                         |                         |                    |      |       |              |       |       |       |         |
|                                                    | Mnem  |              | Name    |       |                   | scrip                         |                                                |                                  |                         |                         |                    |      |       |              |       |       |       |         |
| 7:6                                                | FL_MC | DN_SEL       | FL_MON  | N_SEL | 00:<br>01:<br>10: | nor fla<br>nor fla<br>nor fla | ash co<br>ash co<br>ash co<br>ash co<br>ash co | ontrolle<br>ontrolle<br>ontrolle | er st<br>er st<br>er st | atus0<br>atus1<br>atus2 | )<br> <br><u>2</u> | nal  | sele  | ection.      |       |       |       |         |
| 0                                                  | FR    |              | FAST_R  | EAD   |                   | <b>t read</b><br>Iorma        | <b>i</b><br>I read                             | comn                             | nan                     | d                       |                    |      |       |              |       |       |       | and 1   |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 354 of 360

| 064   | REG_SF_CFG2 |    |    |    |    | odule | Conf | igure | regis |            |             |             |   |   | 00                   |              |
|-------|-------------|----|----|----|----|-------|------|-------|-------|------------|-------------|-------------|---|---|----------------------|--------------|
| Bit   | 15          | 14 | 13 | 12 | 11 | 10    | 9    | 8     | 7     | 6          | 5           | 4           | 3 | 2 | 1                    | 0            |
| Name  |             |    |    |    |    |       |      |       |       | AAICF<br>G | PRGW<br>RSR | PRGW<br>REN |   |   | RS232<br>WRBU<br>FEN | BUF2<br>WREN |
| Туре  |             |    |    |    |    |       |      |       |       | RW         | RW          | RW          |   |   | RW                   | RW           |
| Reset |             |    |    |    |    |       |      |       |       | 0          | 0           | 0           |   |   | 0                    | 0            |

| Bit(s) | Mnemonic         | Name                   | Description                                                                                                                                                                                                                                             |
|--------|------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6      | AAICFG           | AAI_CFG                | Auto Address Increment command configure<br>0: AAI command is 0xAD<br>1: AAI command is 0xAF                                                                                                                                                            |
| 5      | PRGWRSR          | PRG_WRSR_OPC<br>ODE_EN | <ul><li>Program operation code enable</li><li>0: Using 0x01 as the write status register Command Op Code</li><li>1: Using the PRGDATA6 as the Write status register Command Op Code</li></ul>                                                           |
| 4      | PRGWREN          | PRG_WR_OPCOD<br>E_EN   | <ul><li>Program operation code enable</li><li>0: Using 0x02 as the write Command Op Code</li><li>1: Using the PRGDATA0 as the Write Command Op Code</li></ul>                                                                                           |
| 1      | RS232WRB<br>UFEN | RS232WRBUF_EN          | Internal buffer data input selection<br>0: internal buffer input data from RISC<br>1: internal buffer input data from RS232                                                                                                                             |
| 0      | BUF2WREN         | BUF2WR_EN_SET          | Let the pre-fetch buffer, designed for flash reading, used for<br>Page Program. We promise that the data path is not switched<br>until the pre-fetch buffer is idle.<br>0: pre-fetch buffer use for reading<br>1: pre-fetch buffer use for Page program |

| 088   |    | REG_ | QSPI | _CFG |    | Config | guratio | on reg | gister |   |   |   |                  |                       |                       | 00              |
|-------|----|------|------|------|----|--------|---------|--------|--------|---|---|---|------------------|-----------------------|-----------------------|-----------------|
| Bit   | 15 | 14   | 13   | 12   | 11 | 10     | 9       | 8      | 7      | 6 | 5 | 4 | 3                | 2                     | 1                     | 0               |
| Name  |    |      |      |      |    |        |         |        |        |   |   |   | prg_rd<br>sr_dis | prg_d<br>ata_qu<br>ad | prg_a<br>ddr_q<br>uad | rdsr_b<br>ypass |
| Туре  |    |      |      |      |    |        |         |        |        |   |   |   | R/W              | R/W                   | R/W                   | R/W             |
| Reset |    |      |      |      |    |        |         |        |        |   |   |   | 0                | 0                     | 0                     | 0               |

| Bit(s) | Mnemonic | Name          | Description                                                                                                          |
|--------|----------|---------------|----------------------------------------------------------------------------------------------------------------------|
| 3      | PROGRAM  | prg_rdsr_dis  | <b>Disable rdsr command following page program</b><br>0: No action<br>1: Disable rdsr command following page program |
| 2      | PROGRAM  | prg_data_quad | Enable qspi page program mode.<br>0: No action.<br>1: Qspi page program.                                             |
| 1      | PROGRAM  | prg_addr_quad | Enable qspi page program mode(address).<br>0: No action.<br>1: Qspi page program(address)                            |
| 0      | RDSR     | rdsr_bypass   | Bypass rdsr command following wrsr command.<br>0: No action<br>1: Disable rdsr command following wrsr command        |

AutoChips Confidential

**//utoChips** 

© 2013 - 2021 AutoChips Inc.

Page 355 of 360

### **NutoChips**

| 08C   |    | REG_S | F_PRG | DATA6 | The<br>PRG | seria<br>Com | l flas<br>manc | h pro<br>I. | ogran | n shi | ft da | ta us | ed b  | y the | • | 00 |
|-------|----|-------|-------|-------|------------|--------------|----------------|-------------|-------|-------|-------|-------|-------|-------|---|----|
| Bit   | 15 | 14    | 13    | 12    | 11         | 10           | 9              | 8           | 7     | 6     | 5     | 4     | 3     | 2     | 1 | 0  |
| Name  |    |       |       |       |            |              |                |             |       |       |       | PRG   | DATA6 |       |   |    |
| Туре  |    |       |       |       |            |              |                |             |       |       |       | R     | W     |       |   |    |
| Reset |    |       |       |       |            |              |                |             | 0     | 0     | 0     | 0     | 0     | 0     | 0 | 0  |
|       |    |       |       |       |            |              |                |             |       |       |       |       |       |       |   |    |

| Bit(s) Mnemonic Name             | Description                                                                                                                                                                   |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 <b>PRGDATA5</b> SFP_PRGDATA6 | The serial flash program shift data used by the PRG Command.<br>The PRGDATA6 is shifted first, and the PRGDATA0 is shifted<br>last. In each byte shift, MSB is shifted first. |

| 098   |    | REG_SF | PP_DV | V_DATA | F    | lash  | page | e pro | gram   | n dat | a reg | jister |    |    |    | 0  |
|-------|----|--------|-------|--------|------|-------|------|-------|--------|-------|-------|--------|----|----|----|----|
| Bit   | 31 | 30     | 29    | 28     | 27   | 26    | 25   | 24    | 23     | 22    | 21    | 20     | 19 | 18 | 17 | 16 |
| Name  |    |        |       | R      | EG_S | F_PP  | _DW_ | DATA[ | 31:16  | ]     |       |        |    |    |    |    |
| Туре  |    |        |       |        |      |       | WO   |       |        |       |       |        |    |    |    |    |
| Reset |    |        |       |        |      |       | 0    |       |        |       |       |        |    |    |    |    |
| Bit   | 15 | 14     | 13    | 12     | 11   | 10    | 9    | 8     | 7      | 6     | 5     | 4      | 3  | 2  | 1  | 0  |
| Name  |    |        |       | R      | EG_S | SF_PP | _DW_ | DATA  | [15:0] |       |       |        |    |    |    |    |
| Туре  |    |        |       |        |      |       | WO   |       |        |       |       |        |    |    |    |    |
| Reset |    |        |       |        |      |       | 0    |       |        |       |       |        |    |    |    |    |
|       |    |        |       |        |      |       |      |       |        |       |       |        |    |    |    |    |

| Bit(s) | Mnemonic | Name | Description                      |
|--------|----------|------|----------------------------------|
| 31:0   | PP_DW_DA |      | Flash page program data register |
|        | TA       | DATA |                                  |

| 0A8   |    | <u>REG</u> | SF_IN | <u>rrstus</u> |    | In | terr | up | t re | gister |        |       |        |        |        | 0     |
|-------|----|------------|-------|---------------|----|----|------|----|------|--------|--------|-------|--------|--------|--------|-------|
| Bit   | 15 | 14         | 13    | 12            | 11 | 10 | 9    | 8  | 7    | 6      | 5      | 4     | 3      | 2      | 1      | 0     |
| Name  |    |            |       |               |    |    |      |    |      | AAIINT | WSRINT | WRINT | ERSINT | PRGINT | RSRINT | RDINT |
| Туре  |    |            |       |               |    |    |      |    |      | W1C    | W1C    | W1C   | W1C    | W1C    | W1C    | W1C   |
| Reset |    |            |       |               |    |    |      |    |      | 0      | 0      | 0     | 0      | 0      | 0      | 0     |

| Bit(s) | Mnemonic | Name      | Description                                                                 |
|--------|----------|-----------|-----------------------------------------------------------------------------|
| 6      | AAIINT   | AAI_INT   | Interrupt for AAI programming completion. Cleared when write 1 to it.       |
|        |          |           | 0: no AAI interrupt                                                         |
|        |          |           | 1: AAI interrupt occur                                                      |
| 5      | WSRINT   | WRSR_INT  | Interrupt for Write Status Register completion. Cleared when write 1 to it. |
|        |          |           | 0: no Write status register not interrupt                                   |
|        |          |           | 1: Write status register complete interrupt                                 |
| 4      | WRINT    | WR_INT    | Interrupt for Write/Page Program Completion. Cleared when write 1 to it.    |
|        |          |           | 0: No write/program interrupt                                               |
|        |          |           | 1: Write/program completion interrupt                                       |
| 3      | ERSINT   | ERASE_INT | Interrupt for Bulk Erase. Cleared when write 1 to it                        |
|        |          |           | 0: No Erase interrupt                                                       |
|        |          |           | 1: Erase complete interrupt                                                 |
| 2      | PRGINT   | PRG_INT   | Interrupt for Programmable op-code completion. Cleared when write 1 to it.  |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

| Bit(s) | Mnemonic | Name     | Description                                                          |
|--------|----------|----------|----------------------------------------------------------------------|
|        |          |          | 0: No program op-code completion interrupt                           |
|        |          |          | 1: Programmable op-code completion interrupt.                        |
| 1      | RSRINT   | RDSR_INT | Interrupt for Read Status completion. Cleared when write 1 to it.    |
|        |          |          | 0: No read status completion interrupt                               |
|        |          |          | 1: Read status completion interrupt                                  |
| 0      | RDINT    | RD_INT   | Interrupt for Read Operation Completion. Cleared when write 1 to it. |
|        |          |          | 0: No read operation completion interrupt                            |
|        |          |          | 1: Read operation completion interrupt                               |

| 0AC <u>REG_SF_INTREN</u> |   |    |    |    | h  | nterru | upt E | nable | e reg |   |    |    |    |    | 0            |    |             |
|--------------------------|---|----|----|----|----|--------|-------|-------|-------|---|----|----|----|----|--------------|----|-------------|
| Bit                      |   | 15 | 14 | 13 | 12 | 11     | 10    | 9     | 8     | 7 | 6  | 5  | 4  | 3  | 2            | 1  | 0           |
| Name                     | e |    |    |    |    |        |       |       |       |   |    |    |    |    | PRGI<br>NTEN |    | RDIN<br>TEN |
| Туре                     | • |    |    |    |    |        |       |       |       |   | RW | RW | RW | RW | RW           | RW | RW          |
| Rese                     | t |    |    |    |    |        |       |       |       |   | 0  | 0  | 0  | 0  | 0            | 0  | 0           |

| Bit(s) | Mnemonic | Name         | Description                        |
|--------|----------|--------------|------------------------------------|
| 6      | AAIINTEN | AAI_INTREN   | AAI enable interrupt control bit   |
|        |          |              | 0: AAI interrupt disable           |
|        |          |              | 1: AAI interrupt enable            |
| 5      | WSRINTEN | WRSR_INTREN  | WRSR enable interrupt control bit  |
|        |          |              | 0: WRSR interrupt disable          |
|        |          |              | 1: WRSR interrupt enable           |
| 4      | WRINTEN  | WR_INTREN    | WR enable interrupt control bit    |
|        |          |              | 0: WR interrupt disable            |
|        |          |              | 1: WR interrupt enable             |
| 3      | ERSINTEN | ERASE_INTREN | ERASE enable interrupt control bit |
|        |          |              | 0: ERASE interrupt disable         |
|        |          |              | 1: ERASE interrupt enable          |
| 2      | PRGINTEN | PRG_INTREN   | PRG enable interrupt control bit   |
|        |          |              | 0: PRG interrupt disable           |
|        |          |              | 1: PRG interrupt enable            |
| 1      | RSRINTEN | RDSR_INTREN  | RDSR enable interrupt control bit  |
|        |          |              | 0: RDSR interrupt disable          |
|        |          |              | 1: RDSR interrupt enable           |
| 0      | RDINTEN  | RD_INTREN    | RD enable interrupt control bit    |
|        |          |              | 0: RD interrupt disable            |
|        |          |              | 1: RD interrupt enable             |

| 0B4   |    | REG_ | SF_C | FG3 | m  | nodule | e Con | figure | e regis | ster 3                   |    |    |    |   |    | 0 |  |
|-------|----|------|------|-----|----|--------|-------|--------|---------|--------------------------|----|----|----|---|----|---|--|
| Bit   | 15 | 14   | 13   | 12  | 11 | 10     | 9     | 8      | 7       | 6                        | 5  | 4  | 3  | 2 | 1  | 0 |  |
| Name  |    |      |      |     |    |        |       |        | WRDI    | DI EOPE DYDIS N LUE STUS |    |    |    |   |    | s |  |
| Туре  |    |      |      |     |    |        |       |        | RW      | RW                       | RW | RW | RW |   | RW |   |  |
| Reset |    |      |      |     |    |        |       |        | 0       | 0                        | 0  | 0  | 0  | 0 | 0  | 0 |  |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 357 of 360

| Bit(s) | Mnemonic  | Name            | Description                                                                       |
|--------|-----------|-----------------|-----------------------------------------------------------------------------------|
| 7      | WRDI      | WREN_DIS        | Serial flash write enable control bit                                             |
|        |           |                 | 0: Send write enable command                                                      |
|        |           |                 | 1: Skip the write enable state                                                    |
| 6      | PRGWEOPE  | PRG_WREN_OPC    | Write Enable command op-code configure                                            |
|        | Ν         | ODE_EN          | 0: Using 0x06 as the Write Enable Command Op-code                                 |
|        |           |                 | 1: Using the PRGDATA2 as the Write Enable Command Op-code                         |
| 5      | POLRDYDIS | POL_RDY_BIT_DIS | Disable polling ready bit disable configure bit                                   |
|        |           |                 | 0: Polling status register                                                        |
|        |           |                 | 1: Skip the polling status state                                                  |
| 4      | PRGRDOPE  | PRG_RD_OPCOD    | Configure Read Status Command Op-code                                             |
|        | Ν         | E_EN            | 0: Using 0x05 as the Read Status Command Op-code if flash brand is zero else 0xd7 |
|        |           |                 | 1: Using the PRGDATA1 as the Read Status Command Op-code                          |
| 3      | RDYVLUE   | RDY_VLUE        | Serial flash Output bit value when it is ready                                    |
|        |           |                 | 0: Wait the polled bit until it becomes logic zero                                |
|        |           |                 | 1: Wait the polled bit until it becomes logic one                                 |
| 2:0    | STUSPOS   | STUS_POS        | 7~0 Which bit of status register is polled                                        |
| -      |           |                 |                                                                                   |

| 0B8   |    | flas | flash check sum control register |    |    |    |   |   |   |   |    |            | 0 |   |   |   |
|-------|----|------|----------------------------------|----|----|----|---|---|---|---|----|------------|---|---|---|---|
| Bit   | 15 | 14   | 13                               | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4          | 3 | 2 | 1 | 0 |
| Name  |    |      |                                  |    |    |    |   |   |   |   |    | 2CH<br>KSU |   |   |   |   |
| Туре  |    |      |                                  |    |    |    |   |   |   |   | RW | RW         |   |   |   |   |
| Reset |    |      |                                  |    |    |    |   |   |   |   | 0  | 0          |   |   |   |   |

| Bit(s) | Mnemonic Name          | Description                           |
|--------|------------------------|---------------------------------------|
| 5      | RS232CHKS RS232_CHKSUM | A RS232 check sum configure register  |
|        | UMS START              | 0: RS232 check sum not start          |
|        |                        | 1: RS232 check start                  |
| 4      | RS232CHKS RS232_CHECKS | SU RS232 check sum configure register |
|        | UME M_MODE             | 0: RS232 check sum mode disable       |
|        |                        | 1: RS232 check sum mode enable        |

| 0BC   |                 | REG_FL | <u>CHKSU</u> | M  | Check sum output register |    |    |    |    |    |    |    |    |    |    |    |
|-------|-----------------|--------|--------------|----|---------------------------|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31              | 30     | 29           | 28 | 27                        | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | e CHKSUM[31:16] |        |              |    |                           |    |    |    |    |    |    |    |    |    |    |    |
| Туре  | RU              |        |              |    |                           |    |    |    |    |    |    |    |    |    |    |    |
| Reset |                 |        |              |    |                           |    |    |    |    | 0  | 0  |    |    |    |    |    |
| Bit   | 15              | 14     | 13           | 12 | 11                        | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | e CHKSUM[15:0]  |        |              |    |                           |    |    |    |    |    |    |    |    |    |    |    |
| Туре  |                 |        |              |    |                           |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0               | 0      | 0            | 0  | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
|       |                 |        |              |    |                           |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Mnemonic | Name   | Description            |
|--------|----------|--------|------------------------|
| 31:0   | CHKSUM   | CHKSUM | Check sum output data. |

AutoChips Confidential

© 2013 - 2021 AutoChips Inc.

Page 358 of 360

| 0C0 <u>REG_SF_AAICMD</u> |    |    |    |    | AA | AAI programming command enable register |   |   |   |   |   |   |   |   |   |           |  |
|--------------------------|----|----|----|----|----|-----------------------------------------|---|---|---|---|---|---|---|---|---|-----------|--|
| Bit                      | 15 | 14 | 13 | 12 | 11 | 10                                      | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |  |
| Name                     |    |    |    |    |    |                                         |   |   |   |   |   |   |   |   |   | AAIW<br>R |  |
| Туре                     |    |    |    |    |    |                                         |   |   |   |   |   |   |   |   |   | A0        |  |
| Reset                    |    |    |    |    |    |                                         |   |   |   |   |   |   |   |   |   | 0         |  |

| 0 AAIWR AAIWR CMD W              |                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pr<br>RJ<br>AJ<br>wi<br>pr<br>0: | Vrite 1 to this register will enable AAI (Auto Address Increment)<br>rogram procedure. The write address must be prepared at<br>ADR (RADR3, RADR2, RADR1, RADR0) and set suitable<br>AI_CFG (CFG2[6]) before trigger. This bit will be auto-cleared<br>when done. It must to set buf2wr_en(CFG2[0]) for AAI<br>rogramming.<br>: AAI procedure not start<br>: AAI procedure is triggered |

| 0C4   |    | W  | Write command enable register |    |    |    |   |   |        |   |   |   |   |   |   |   |
|-------|----|----|-------------------------------|----|----|----|---|---|--------|---|---|---|---|---|---|---|
| Bit   | 15 | 14 | 13                            | 12 | 11 | 10 | 9 | 8 | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  |    |    |                               |    |    |    |   |   | WRPROT |   |   |   |   |   |   |   |
| Туре  |    |    |                               |    |    |    |   |   | RW     |   |   |   |   |   |   |   |
| Reset |    |    |                               |    |    |    |   |   | 1      | 0 | 0 | 0 | 0 | 1 | 0 | 1 |

| Bit(s) | Mnemonic | Name          | Description                                                                                     |
|--------|----------|---------------|-------------------------------------------------------------------------------------------------|
| 7:0    | WRPROT   | WRITE_PROTECT | Set this byte to 0x30 will turn off write protection and enable SF commands in CMD and AAI_CMD. |

| 0C8 | REG SF RADR3 | Read or Write address for Read command or Write |
|-----|--------------|-------------------------------------------------|
| 000 | KLO_SI_KADKS | command                                         |

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---------|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   | SFPADR3 |   |   |   |   |   |   |   |
| Туре  |    |    |    |    |    |    |   |   | RW      |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0       | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) Mnemoni     | c Name   | Description                                             |
|--------------------|----------|---------------------------------------------------------|
| 7:0 <b>SFPADR3</b> | SFP_ADR3 | Read or Write address for Read command or Write command |

| ( | 000 | REG_ | SF_D | UAL | Se | rial fla | ash d | ual m | ode c | onfigu | ure re | gister |  | 00 |  |
|---|-----|------|------|-----|----|----------|-------|-------|-------|--------|--------|--------|--|----|--|
|   |     |      |      |     |    |          |       |       |       |        |        |        |  |    |  |

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2            | 1  | 0            |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-------------|--------------|----|--------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | ADRQ<br>UAD | DUAL<br>RDEN |    | DUAL<br>RDEN |
| Туре  |    |    |    |    |    |    |   |   |   |   |   |   | RW          | RW           | RW | RW           |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0           | 0            | 0  | 0            |

| Bit(s) Mnemonic Name | e Description                                                                           |  |
|----------------------|-----------------------------------------------------------------------------------------|--|
| 3 ADRQUAD ADDR       | R_QUAD quad address mode<br>0: quad address mode disable<br>1: quad address mode enable |  |

© 2013 - 2021 AutoChips Inc.

Page 359 of 360

0

| Bit(s) | Mnemonic | Name         | Description                                                                                                                                                           |
|--------|----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2      | DUALRDEN | QUAD_READ_EN | Quad read mode will be enable after previous read operation is finished. The quad read command must be write in PRGDATA4, and the read data can be obtained in RDATA. |
|        |          |              | 0: quad read mode disable<br>1: quad read mode enable                                                                                                                 |
| 1      | ADRDUAL  | ADDR_DUAL    | Dual address mode                                                                                                                                                     |
|        |          |              | 0: dual address mode disable<br>1: dual address mode enable                                                                                                           |
| 0      | DUALRDEN | DUAL_READ_EN | Dual read mode will be enable after previous read operation is finished. The dual read command must be write in PRGDATA3, and the read data can be obtained in RDATA. |
|        |          |              | 0: dual read mode disable<br>1: dual read mode enable                                                                                                                 |

| 0E0   |    | REG [ | DUMM | CFG | Seria | l flas | h dur | nmy | cycle | e con | figur | e reg | ister  |   |   | 00 |
|-------|----|-------|------|-----|-------|--------|-------|-----|-------|-------|-------|-------|--------|---|---|----|
| Bit   | 15 | 14    | 13   | 12  | 11    | 10     | 9     | 8   | 7     | 6     | 5     | 4     | 3      | 2 | 1 | 0  |
| Name  |    |       |      |     |       |        |       |     |       |       | -     | dumm  | ny_cfg |   | = |    |
| Туре  |    |       |      |     |       |        |       |     | RŴ    |       |       |       |        |   |   |    |
| Reset |    |       |      |     |       |        |       |     | 0     |       |       |       |        |   |   |    |

| Bit(s) Mnemonic Name    | Description                              |
|-------------------------|------------------------------------------|
| 7:0 DUMMY_CFG dummy_cfg | Dummy cycle configuration for QSPI read. |

| 0E4   |    | REG_D | UMMY | _CFG2 | Seri | ial fla | sh dı | ummy | / cyc | e cor | nfigui | e regis              | ster | 2    |        | 00 |
|-------|----|-------|------|-------|------|---------|-------|------|-------|-------|--------|----------------------|------|------|--------|----|
| Bit   | 15 | 14    | 13   | 12    | 11   | 10      | 9     | 8    | 7     | 6     | 5      | 4                    | 3    | 2    | 1      | 0  |
| Name  |    |       |      |       |      |         |       |      |       |       |        | dummy<br>_num_e<br>n |      | dumn | ny_nur | n  |
| Туре  |    |       |      |       |      |         |       |      |       |       |        | RW                   | RW   |      |        |    |
| Reset |    |       |      |       |      |         |       |      |       |       |        | 0                    |      |      | 0      |    |

| Bit(s) | Mnemonic    | Name                  | Description                                                                       |
|--------|-------------|-----------------------|-----------------------------------------------------------------------------------|
| 4      | DUMMY_NUM_E | <b>N</b> dummy_num_en | <b>dummy cycle clock cycle number configure enable</b><br>0: disable<br>1: enable |
| 3:0    | DUMMY_NUM   | dummy_num             | The dummy cycle number                                                            |