



# Gowin RISCV N25

## User Guide

IPUG529-1.0E, 1/23/2019

**Copyright©2019 Guangdong Gowin Semiconductor Corporation. All Rights Reserved.**

No part of this document may be reproduced or transmitted in any form or by any denotes, electronic, mechanical, photocopying, recording or otherwise, without the prior written consent of GOWINSEMI.

#### **Disclaimer**

GOWINSEMI®, LittleBee®, Arora™, and the GOWINSEMI logos are trademarks of GOWINSEMI and are registered in China, the U.S. Patent and Trademark Office and other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders, as described at [www.gowinsemi.com.cn](http://www.gowinsemi.com.cn). GOWINSEMI assumes no liability and provides no warranty (either expressed or implied) and is not responsible for any damage incurred to your hardware, software, data, or property resulting from usage of the materials or intellectual property except as outlined in the GOWINSEMI Terms and Conditions of Sale. All information in this document should be treated as preliminary. GOWINSEMI may make changes to this document at any time without prior notice. Anyone relying on this documentation should contact GOWINSEMI for the current documentation and errata.

## **Revision History**

| Date       | Version | Description                |
|------------|---------|----------------------------|
| 01/23/2019 | 1.0E    | Initial version published. |

# Contents

|                                                        |             |
|--------------------------------------------------------|-------------|
| <b>Contents.....</b>                                   | <b>i</b>    |
| <b>List of Figures.....</b>                            | <b>xvii</b> |
| <b>List of Tables.....</b>                             | <b>xx</b>   |
| <b>1 About This Guide .....</b>                        | <b>1</b>    |
| 1.1 Purpose .....                                      | 1           |
| 1.2 Supported Products .....                           | 1           |
| 1.3 Related Documents .....                            | 1           |
| 1.4 Abbreviations and Terminology.....                 | 2           |
| 1.5 Support and Feedback .....                         | 2           |
| <b>2 Overview.....</b>                                 | <b>3</b>    |
| 2.1 Introduction .....                                 | 3           |
| <b>3 Features and Performance .....</b>                | <b>5</b>    |
| 3.1 Performance .....                                  | 5           |
| 3.2 Resources.....                                     | 6           |
| 3.3 The Clock Frequency.....                           | 6           |
| <b>4 CPU Core Overview .....</b>                       | <b>7</b>    |
| 4.1 N25(F) Processor Features .....                    | 7           |
| 4.2 Block Diagram .....                                | 9           |
| 4.3 Major Components .....                             | 9           |
| 4.4 Pipeline Stages and Activities.....                | 10          |
| 4.5 Design Hierarchy .....                             | 11          |
| 4.5.1 AHB Platform .....                               | 11          |
| <b>5 Processor Configuration Options .....</b>         | <b>13</b>   |
| 5.1 Configuration Tool.....                            | 13          |
| 5.1.1 RISC-V Atomic Instruction Extension .....        | 14          |
| 5.1.2 RISC-V Floating-Point Instruction Extension..... | 14          |
| 5.1.3 Privilege Modes .....                            | 14          |
| 5.1.4 Performance Monitors .....                       | 14          |
| 5.1.5 Bus Interface Unit .....                         | 14          |

|                                                         |           |
|---------------------------------------------------------|-----------|
| 5.1.6 Hardware Multiplier.....                          | 15        |
| 5.1.7 Branch Prediction .....                           | 15        |
| 5.1.8 Physical Memory Protection .....                  | 15        |
| 5.1.9 Local Memory Interface .....                      | 15        |
| 5.1.10 Instruction Local Memory .....                   | 15        |
| 5.1.11 Data Local Memory (DLM).....                     | 16        |
| 5.1.12 Slave Port Support.....                          | 16        |
| 5.1.13 Instruction Cache.....                           | 16        |
| 5.1.14 Data Cache.....                                  | 17        |
| 5.1.15 Debug Support.....                               | 17        |
| 5.1.16 Trace Interface.....                             | 17        |
| 5.1.17 Andes Vectored PLIC Extension.....               | 17        |
| 5.1.18 Andes StackSafe Extension .....                  | 17        |
| 5.1.19 Andes PowerBrake Extension .....                 | 17        |
| 5.1.20 Andes Custom Extension .....                     | 18        |
| 5.2 Configuration Parameters.....                       | 18        |
| 5.2.1 Device Regions.....                               | 18        |
| 5.2.2 Write-through Regions.....                        | 18        |
| 5.2.3 DEBUG_VEC.....                                    | 19        |
| <b>6 Signals Descriptions .....</b>                     | <b>20</b> |
| 6.1 General Signals .....                               | 20        |
| 6.2 Interrupt Signals.....                              | 20        |
| 6.3 Debug Signals .....                                 | 21        |
| 6.4 Trace Signals .....                                 | 21        |
| 6.5 AHB Interface Signals.....                          | 21        |
| 6.6 Instruction Local Memory Interface Signals .....    | 22        |
| 6.7 Data Local Memory Interface Signals .....           | 23        |
| 6.8 Instruction Cache Interface Signals.....            | 25        |
| 6.9 Data Cache Interface Signals .....                  | 28        |
| 6.10 AHB Slave Port Signals .....                       | 32        |
| 6.11 BTB Interface Signals .....                        | 32        |
| <b>7 Reset and Clocking Scheme.....</b>                 | <b>34</b> |
| 7.1 Reset .....                                         | 34        |
| 7.2 Clock Domains.....                                  | 34        |
| <b>8 Instruction Set Overview.....</b>                  | <b>36</b> |
| 8.1 Introduction .....                                  | 36        |
| 8.2 Integer Registers .....                             | 36        |
| 8.3 Atomic Instructions.....                            | 37        |
| 8.3.1 Load-Reserved/Store-Conditional Instruction ..... | 37        |
| 8.3.2 Atomic Memory Operation Instruction .....         | 37        |
| 8.4 Misaligned Memory Access .....                      | 37        |

|                                                            |           |
|------------------------------------------------------------|-----------|
| 8.4.1 Limitation .....                                     | 37        |
| 8.5 Floating Point ISA Extension .....                     | 37        |
| 8.5.1 FPU Features .....                                   | 37        |
| <b>9 Physical Memory Attributes.....</b>                   | <b>39</b> |
| 9.1 Introduction .....                                     | 39        |
| 9.2 Device Regions.....                                    | 40        |
| 9.3 Write-through Regions.....                             | 40        |
| <b>10 Local Memory.....</b>                                | <b>41</b> |
| 10.1 Introduction .....                                    | 41        |
| 10.2 Local Memory Spaces .....                             | 41        |
| 10.3 Local Memory Address Range .....                      | 42        |
| 10.4 Local Memory Usage Constraints .....                  | 43        |
| 10.5 Local Memory Interface .....                          | 43        |
| <b>11 Local Memory Slave Port .....</b>                    | <b>45</b> |
| 11.1 Introduction .....                                    | 45        |
| 11.2 Latency of Transfer .....                             | 45        |
| 11.3 Basic Transfer .....                                  | 46        |
| 11.4 Burst Transfer .....                                  | 46        |
| 11.5 Support for Soft Error Protection .....               | 47        |
| 11.6 Local Memory Slave Port Operation under WFI Mode..... | 48        |
| <b>12 Caches.....</b>                                      | <b>49</b> |
| 12.1 Introduction .....                                    | 49        |
| 12.2 Cache Access Latency .....                            | 50        |
| 12.3 I-Cache Fill Operation.....                           | 51        |
| 12.4 D-Cache Fill Operations .....                         | 51        |
| 12.5 D-Cache Eviction Operations .....                     | 51        |
| 12.6 FENCE/FENCE.I Operations.....                         | 51        |
| <b>13 Bus Interface Unit.....</b>                          | <b>53</b> |
| 13.1 Introduction .....                                    | 53        |
| 13.2 BIU Block Diagram .....                               | 53        |
| 13.3 Atomic Operations .....                               | 54        |
| 13.4 Low Latency AHB Access Mode .....                     | 54        |
| <b>14 Trap .....</b>                                       | <b>55</b> |
| 14.1 Introduction .....                                    | 55        |
| 14.2 Interrupt .....                                       | 55        |
| 14.3 Exception .....                                       | 56        |
| 14.4 Trap Handling .....                                   | 56        |
| <b>15 Reset and Non-Maskable Interrupts.....</b>           | <b>58</b> |

|                                                                      |           |
|----------------------------------------------------------------------|-----------|
| 15.1 Reset .....                                                     | 58        |
| 15.2 Non-Maskable Interrupts .....                                   | 58        |
| <b>16 Power Management .....</b>                                     | <b>59</b> |
| 16.1 Wait-For-Interrupt Mode .....                                   | 59        |
| <b>17 Memory Subsystem Error Protection .....</b>                    | <b>60</b> |
| 17.1 Introduction .....                                              | 60        |
| 17.1.1 Memory Subsystem Error Protection Scheme .....                | 60        |
| 17.1.2 Error Protected Memory Subsystem .....                        | 60        |
| 17.1.3 Read-Modify-Write Operations .....                            | 60        |
| 17.2 Parity/ECC Control Mode and Access types .....                  | 61        |
| 17.2.1 Parity/ECC Checking Disabled.....                             | 61        |
| 17.2.2 Generating Exceptions on Uncorrectable Parity/ECC Errors..... | 61        |
| 17.2.3 Generating Exceptions on Parity/ECC Errors .....              | 62        |
| 17.2.4 Error Handling in Caches .....                                | 62        |
| 17.2.5 Error Handling in ILM and DLM .....                           | 63        |
| 17.2.6 Behavior of Parity/ECC-Supported Local Memory Accesses.....   | 63        |
| <b>18 Control and Status Registers .....</b>                         | <b>64</b> |
| 18.1 Introduction .....                                              | 64        |
| 18.1.1 System Register Type.....                                     | 64        |
| 18.1.2 Reset Value .....                                             | 64        |
| 18.1.3 CSR Listing.....                                              | 65        |
| 18.2 Machine Information Registers.....                              | 68        |
| 18.2.1 Machine Vendor ID Register.....                               | 68        |
| 18.2.2 Machine Architecture ID Register .....                        | 69        |
| 18.2.3 Machine Implementation ID Register .....                      | 69        |
| 18.2.4 Hart ID Register.....                                         | 69        |
| 18.3 Machine Trap Related CSRs .....                                 | 70        |
| 18.3.1 Machine Status .....                                          | 70        |
| 18.3.2 Machine ISA Register .....                                    | 72        |
| 18.3.3 Machine Exception Delegation .....                            | 74        |
| 18.3.4 Machine Interrupt Delegation .....                            | 77        |
| 18.3.5 Machine Interrupt Enable .....                                | 78        |
| 18.3.6 Machine Interrupt Pending .....                               | 79        |
| 18.3.7 Machine Trap Vector Base Address .....                        | 81        |
| 18.3.8 Machine Exception Program Counter.....                        | 81        |
| 18.3.9 Machine Cause Register .....                                  | 81        |
| 18.3.10 Machine Trap Value .....                                     | 83        |
| 18.3.11 Machine Scratch Register .....                               | 84        |
| 18.3.12 Machine Extended Status.....                                 | 84        |
| 18.3.13 Machine Detailed Trap Cause .....                            | 85        |
| 18.4 Counter Related CSRs .....                                      | 85        |

---

|                                                             |     |
|-------------------------------------------------------------|-----|
| 18.4.1 Machine Cycle Counter .....                          | 85  |
| 18.4.2 Machine Instruction-Retired Counter.....             | 86  |
| 18.4.3 Machine Performance Monitoring Counter.....          | 86  |
| 18.4.4 Machine Performance Monitoring Event Selector .....  | 86  |
| 18.4.5 Machine Counter Enable .....                         | 88  |
| 18.4.6 Machine Counter Write Enable.....                    | 89  |
| 18.4.7 Machine Counter Interrupt Enable.....                | 89  |
| 18.4.8 Machine Counter Mask for Machine Mode.....           | 89  |
| 18.4.9 Machine Counter Mask for Supervisor Mode .....       | 90  |
| 18.4.10 Machine Counter Mask for User Mode.....             | 90  |
| 18.4.11 Machine Counter Overflow Status .....               | 90  |
| 18.5 Configuration Control & Status Registers.....          | 91  |
| 18.5.1 Instruction Cache/Memory Configuration Register..... | 91  |
| 18.5.2 Data Cache/Memory Configuration Register.....        | 93  |
| 18.5.3 Misc. Configuration Register .....                   | 96  |
| 18.6 Trigger Registers .....                                | 99  |
| 18.6.1 Trigger Select.....                                  | 99  |
| 18.6.2 Trigger Data 1 .....                                 | 100 |
| 18.6.3 Trigger Data 2 .....                                 | 100 |
| 18.6.4 Trigger Data 3 .....                                 | 101 |
| 18.6.5 Trigger Info.....                                    | 101 |
| 18.6.6 Match Control .....                                  | 101 |
| 18.6.7 Instruction Count.....                               | 103 |
| 18.6.8 Interrupt Trigger .....                              | 104 |
| 18.6.9 Exception Trigger.....                               | 105 |
| 18.7 Debug and Trigger Registers.....                       | 106 |
| 18.7.1 Debug Control and Status Register.....               | 106 |
| 18.7.2 Debug Program Counter .....                          | 109 |
| 18.7.3 Debug Scratch Register 0 .....                       | 110 |
| 18.7.4 Debug Scratch Register 1 .....                       | 110 |
| 18.7.5 Exception Redirection Register .....                 | 110 |
| 18.7.6 Debug Detailed Cause .....                           | 114 |
| 18.8 Memory and Miscellaneous Registers.....                | 115 |
| 18.8.1 Instruction Local Memory Base Register.....          | 115 |
| 18.8.2 Data Local Memory Base Register.....                 | 116 |
| 18.8.3 ECC Code Register .....                              | 117 |
| 18.8.4 NMI Vector Base Address Register .....               | 118 |
| 18.8.5 Performance Throttling Control Register .....        | 119 |
| 18.8.6 Cache Control Register .....                         | 119 |
| 18.8.7 Machine Miscellaneous Control Register .....         | 122 |
| 18.8.8 Machine CCTL Begin Address .....                     | 125 |
| 18.8.9 Machine CCTL Command .....                           | 125 |
| 18.8.10 Machine CCTL Data .....                             | 126 |
| 18.8.11 User CCTL Begin Address .....                       | 127 |

|                                                                               |            |
|-------------------------------------------------------------------------------|------------|
| 18.8.12 User CCTL Command .....                                               | 128        |
| 18.9 Hardware Stack Protection and Recording Registers .....                  | 129        |
| 18.9.1 Machine Hardware Stack Protection Control .....                        | 129        |
| 18.9.2 Machine SP Bound Register .....                                        | 131        |
| 18.9.3 Machine SP Base Register.....                                          | 131        |
| 18.10 CoDense Registers.....                                                  | 132        |
| 18.10.1 Instruction Table Base Address Register.....                          | 132        |
| 18.11 Physical Memory Protection Unit Configuration & Address Registers ..... | 132        |
| 18.11.1 PMP Configuration Registers.....                                      | 132        |
| 18.11.2 PMP Address Register.....                                             | 135        |
| <b>19 Instruction Latency.....</b>                                            | <b>136</b> |
| 19.1 ALU Instructions.....                                                    | 136        |
| 19.2 Load Instructions .....                                                  | 136        |
| 19.3 Multiply Instructions .....                                              | 136        |
| 19.4 Divide and Remainder Instructions.....                                   | 137        |
| 19.5 Branch and Jump Instruction.....                                         | 137        |
| 19.6 Trap Return Instruction .....                                            | 137        |
| 19.7 ACE Instructions .....                                                   | 137        |
| 19.8 ACE Instructions .....                                                   | 138        |
| <b>20 N25(F) AHB Platform .....</b>                                           | <b>139</b> |
| 20.1 AE250 Memory Map .....                                                   | 139        |
| 20.2 Interrupt Assignment.....                                                | 140        |
| 20.3 Functional Description .....                                             | 141        |
| 20.3.1 ATCBMC200 – AHB Bus Matrix.....                                        | 141        |
| 20.3.2 ATCAPBBRG100 – AHB-to-APB Bridge.....                                  | 141        |
| 20.3.3 ATCUART100 – UART Controller.....                                      | 142        |
| 20.3.4 ATCSPI200 – SPI Controller.....                                        | 142        |
| 20.3.5 ATCIIC100 – I2C Controller .....                                       | 142        |
| 20.3.6 ATCWDT200 – Watchdog Timer.....                                        | 143        |
| 20.3.7 ATCRTC100 – Real-Time Clock .....                                      | 143        |
| 20.3.8 ATCPIT100 – PIT Controller .....                                       | 143        |
| 20.3.9 ATCGPIO100 – GPIO Controller .....                                     | 144        |
| 20.3.10 ATCRAMBRG200 – RAM Bridge.....                                        | 144        |
| 20.3.11 ATCDMAC100 – DMA Controller .....                                     | 144        |
| 20.4 System Management Unit .....                                             | 145        |
| 20.4.1 Summary of Registers .....                                             | 145        |
| 20.4.2 SYSTEM ID & Revision Register (SYSTEMVER) (0x00).....                  | 146        |
| 20.4.3 Wake-up and Reset Status Register (WRSR) (0x10).....                   | 146        |
| 20.4.4 SMU Command Register (SMUCR) (0x14).....                               | 148        |
| 20.4.5 Wake-up and Reset Mask Register (WRMASK) (0x1c) .....                  | 148        |
| 20.4.6 Clock Enable Register (CER) (0x20).....                                | 149        |
| 20.4.7 Clock Ratio Register (CRR) (0x24) .....                                | 151        |

|                                                                    |            |
|--------------------------------------------------------------------|------------|
| 20.4.8 Scratch Pad Register (SCRATCH) (0x40) .....                 | 151        |
| 20.4.9 Reset Vector (RESET_VECTOR) (0x50) .....                    | 152        |
| <b>21 Platform-Level Interrupt Controller (PLIC) .....</b>         | <b>153</b> |
| 21.1 Introduction .....                                            | 153        |
| 21.2 Support for Preemptive Priority Interrupt.....                | 154        |
| 21.2.1 Interrupt Claims with Preemptive Priority .....             | 155        |
| 21.2.2 Interrupt Completion with Preemptive Priority .....         | 155        |
| 21.3 Vectored Interrupts .....                                     | 155        |
| 21.3.1 Vector Mode Protocol .....                                  | 156        |
| 21.4 PLIC Configuration Options.....                               | 156        |
| 21.4.1 Number of Interrupts.....                                   | 157        |
| 21.4.2 Number of Targets .....                                     | 157        |
| 21.4.3 Maximum Interrupt Priority .....                            | 157        |
| 21.4.4 Edge Trigger .....                                          | 157        |
| 21.4.5 Asynchronous Interrupt Source .....                         | 157        |
| 21.4.6 Address Width of PLIC Bus Interface .....                   | 157        |
| 21.4.7 Data Width of PLIC Bus Interface.....                       | 158        |
| 21.4.8 Support For Vectored PLIC Extension .....                   | 158        |
| 21.4.9 Bus Type of PLIC .....                                      | 158        |
| 21.5 PLIC Registers.....                                           | 158        |
| 21.5.1 Memory Map .....                                            | 158        |
| 21.5.2 Feature Enable Register.....                                | 159        |
| 21.5.3 Interrupt Source Priority.....                              | 160        |
| 21.5.4 Interrupt Pending .....                                     | 160        |
| 21.5.5 Interrupt Trigger Type .....                                | 161        |
| 21.5.6 Number of Interrupt and Target Configuration Register ..... | 161        |
| 21.5.7 Version & Maximum Priority Configuration Register .....     | 161        |
| 21.5.8 Interrupt Enable Bits for Target m .....                    | 162        |
| 21.5.9 Priority Threshold for Target m .....                       | 162        |
| 21.5.10 Claim and Complete Register for Target m .....             | 162        |
| 21.5.11 Preempted Priority Stack Registers for Target m.....       | 163        |
| 21.6 Interrupt Latency.....                                        | 163        |
| 21.7 Interface Signals .....                                       | 164        |
| <b>22 Machine Timer.....</b>                                       | <b>168</b> |
| 22.1 Introduction .....                                            | 168        |
| 22.2 Machine Timer Registers .....                                 | 169        |
| 22.3 Machine Timer Configuration Options .....                     | 169        |
| 22.3.1 Address Width of Machine Timer Interface.....               | 170        |
| 22.3.2 Bus Type of Machine Timer .....                             | 170        |
| 22.4 Interface Signals .....                                       | 170        |
| <b>23 Debug Subsystem .....</b>                                    | <b>174</b> |

|                                                             |            |
|-------------------------------------------------------------|------------|
| 23.1 Overview .....                                         | 174        |
| 23.2 Integration Requirements .....                         | 175        |
| 23.3 NCEPLDM200 .....                                       | 175        |
| 23.3.1 Abstract Data 0–3 (data0–3).....                     | 177        |
| 23.3.2 Debug Module Control (dmcontrol) .....               | 177        |
| 23.3.3 Debug Module Status (dmstatus) .....                 | 178        |
| 23.3.4 Hart Info (hartinfo).....                            | 180        |
| 23.3.5 Halt Summary (haltsum).....                          | 181        |
| 23.3.6 Hart Array Window Select (hawindowsel) .....         | 181        |
| 23.3.7 Hart Array Window (hawindow) .....                   | 181        |
| 23.3.8 Abstract Control and Status (abstractcs) .....       | 181        |
| 23.3.9 Abstract Command .....                               | 182        |
| 23.3.10 Abstract Command Autoexec (abstractauto).....       | 184        |
| 23.3.11 Device Tree Addr 0–3 (devtreeaddr0–3).....          | 184        |
| 23.3.12 Program Buffer 0–15 (progbuf0–15).....              | 184        |
| 23.3.13 Authentication Data (authdata) .....                | 184        |
| 23.3.14 System Bus Access Control and Status (sbcs) .....   | 184        |
| 23.3.15 System Bus Address (sbaddress0–2) .....             | 184        |
| 23.3.16 System Bus Data (sbdata0–3).....                    | 184        |
| 23.4 Interface Signals .....                                | 184        |
| 23.5 NCEJDTM200.....                                        | 190        |
| 23.5.1 BYPASS.....                                          | 190        |
| 23.5.2 IDCODE .....                                         | 190        |
| 23.5.3 DTM Control and Status (dtmcs) .....                 | 190        |
| 23.5.4 Debug Module Interface Access (dmi).....             | 191        |
| <b>24 ATCWDT200 .....</b>                                   | <b>193</b> |
| 24.1 Introduction .....                                     | 193        |
| 24.1.1 Features.....                                        | 193        |
| 24.1.2 Block Diagram .....                                  | 193        |
| 24.1.3 Function Description .....                           | 194        |
| 24.2 Signal Description.....                                | 195        |
| 24.3 Programming Model .....                                | 195        |
| 24.3.1 Summary of Registers .....                           | 196        |
| 24.3.2 Register Description .....                           | 196        |
| 24.3.3 ID and Revision Register (0x00).....                 | 196        |
| 24.3.4 Control Register (0x10) .....                        | 196        |
| 24.3.5 Restart Register (0x14) .....                        | 198        |
| 24.3.6 Write Enable Register (0x18) .....                   | 199        |
| 24.3.7 Status Register (0x1C) .....                         | 199        |
| 24.4 Hardware Configuration Options .....                   | 199        |
| 24.4.1 Magic Number for Write Protection .....              | 199        |
| 24.4.2 Magic Number for Restarting the Watchdog Timer ..... | 199        |
| 24.4.3 Duration of Watchdog Interrupt Timer Interval.....   | 200        |

|                                                                     |            |
|---------------------------------------------------------------------|------------|
| 24.5 Programming Sequence .....                                     | 200        |
| 24.5.1 Setup and Enable the Watchdog Timer:.....                    | 200        |
| 24.5.2 Restart the Watchdog Timer .....                             | 200        |
| 24.5.3 Disable the Watchdog Timer.....                              | 200        |
| <b>25 ATCRTC100 .....</b>                                           | <b>201</b> |
| 25.1 Introduction .....                                             | 201        |
| 25.1.1 Description .....                                            | 201        |
| 25.1.2 Features.....                                                | 201        |
| 25.1.3 Block Diagram .....                                          | 201        |
| 25.2 Signal Description.....                                        | 202        |
| 25.3 Programming Model .....                                        | 204        |
| 25.3.1 Summary of Registers .....                                   | 204        |
| 25.3.2 Register Description .....                                   | 204        |
| 25.3.3 ID and Revision Register (0x00).....                         | 204        |
| 25.3.4 Counter Register (0x10) .....                                | 204        |
| 25.3.5 Alarm Register (0x14) .....                                  | 205        |
| 25.3.6 Control Register (0x18) .....                                | 205        |
| 25.3.7 Status Register (0x1C) .....                                 | 206        |
| 25.3.8 Digital Trimming Register (0x20) .....                       | 207        |
| 25.4 Hardware Configuration Options .....                           | 208        |
| 25.4.1 Day Counter Bits.....                                        | 208        |
| 25.4.2 Half-second Interrupt Support .....                          | 209        |
| 25.5 Programming Sequence.....                                      | 209        |
| 25.5.1 Adjust Time and Interrupts on the Hour .....                 | 209        |
| 25.5.2 Trigger an Alarm Interrupt at a Specific Time .....          | 209        |
| 25.5.3 Trigger an Alarm Wakeup Signal at a Specific Time .....      | 209        |
| 25.5.4 Hardware Digital Trimming .....                              | 209        |
| 25.5.5 Determining Trimming Value by Measuring Frequency.....       | 210        |
| 25.5.6 Determining Trimming Value by Observing Time Deviation ..... | 211        |
| 25.5.7 Trimming Capabilities .....                                  | 212        |
| <b>26 ATCPIT100 .....</b>                                           | <b>213</b> |
| 26.1 Introduction .....                                             | 213        |
| 26.1.1 Features.....                                                | 213        |
| 26.1.2 Block Diagram .....                                          | 213        |
| 26.1.3 Function Description .....                                   | 214        |
| 26.2 Signal Description.....                                        | 214        |
| 26.3 Programming Model .....                                        | 215        |
| 26.3.1 Summary of Registers .....                                   | 215        |
| 26.3.2 Register Description .....                                   | 216        |
| 26.3.3 ID and Revision Register (0x00).....                         | 216        |
| 26.3.4 Configuration Register (0x10).....                           | 217        |
| 26.3.5 Interrupt Enable Register (0x14) .....                       | 218        |

|                                                            |            |
|------------------------------------------------------------|------------|
| 26.3.6 Interrupt Status Register (0x18) .....              | 218        |
| 26.3.7 Channel Enable Register (0x1C) .....                | 219        |
| 26.3.8 Chn Control Register (0x20 + n * 0x10) .....        | 221        |
| 26.3.9 Chn Reload Register (0x24 + n * 0x10).....          | 222        |
| 26.3.10 Chn Counter Register (0x28 + n * 0x10) .....       | 223        |
| 26.4 Hardware Configuration Options .....                  | 224        |
| 26.4.1 Number of PIT Channels .....                        | 224        |
| 26.5 Programming Sequence .....                            | 224        |
| 26.5.1 Generate 2 Periodic Interrupts with Channel 0 ..... | 224        |
| 26.5.2 Generate 2 Aligned PWM Output .....                 | 224        |
| 26.5.3 Changing the PIT Modes .....                        | 225        |
| <b>27 ATCBUSDEC200.....</b>                                | <b>226</b> |
| 27.1 Introduction .....                                    | 226        |
| 27.1.1 Features.....                                       | 226        |
| 27.1.2 Block Diagram .....                                 | 226        |
| 27.1.3 Interconnect Logic .....                            | 227        |
| 27.1.4 Internal Slave .....                                | 227        |
| 27.1.5 Default Slave .....                                 | 227        |
| 27.2 Signal Description.....                               | 228        |
| 27.3 Programming Model .....                               | 229        |
| 27.3.1 Summary of Registers .....                          | 229        |
| 27.3.2 Register Description .....                          | 229        |
| 27.3.3 ID and Revision Register.....                       | 230        |
| 27.3.4 Base/Size Register .....                            | 230        |
| 27.4 Hardware Configuration Options .....                  | 231        |
| 27.4.1 AHB-Lite Bus Address Width .....                    | 231        |
| 27.4.2 AHB-Lite Address Decode Width .....                 | 231        |
| 27.4.3 AHB-Lite Bus Data Width .....                       | 232        |
| 27.4.4 AHB-Lite Slave Ports .....                          | 232        |
| 27.4.5 AHB-Lite Slave Size .....                           | 232        |
| 27.4.6 AHB-Lite Slave Base Address Offset.....             | 232        |
| 27.4.7 AHB-Lite Default Slave Error Response.....          | 233        |
| 27.5 Integration Guideline.....                            | 233        |
| 27.6 Access Latencies .....                                | 233        |
| <b>28 ATCBMC200 .....</b>                                  | <b>235</b> |
| 28.1 Introduction .....                                    | 235        |
| 28.1.1 Features.....                                       | 235        |
| 28.1.2 Block Diagram .....                                 | 235        |
| 28.1.3 Function Description .....                          | 236        |
| 28.1.4 MST Commander .....                                 | 236        |
| 28.1.5 SLV Commander .....                                 | 236        |
| 28.1.6 Bus Matrix.....                                     | 236        |

|                                                                  |            |
|------------------------------------------------------------------|------------|
| 28.1.7 AHB Slave Grouping .....                                  | 237        |
| 28.2 Signal Description .....                                    | 237        |
| 28.3 Programming Model .....                                     | 239        |
| 28.3.1 Summary of Registers .....                                | 239        |
| 28.3.2 Register Description .....                                | 239        |
| 28.3.3 ID and Revision Register (0x00).....                      | 240        |
| 28.3.4 Priority Register (0x10) .....                            | 240        |
| 28.3.5 Control Register (0x14) .....                             | 241        |
| 28.3.6 Interrupt Status Register (0x18) .....                    | 242        |
| 28.3.7 Base/Size Register of AHB Slave 1–10 (0x20–0x44).....     | 244        |
| 28.3.8 Base/Size Register of AHB Slave 11–15 (0x48–0x58).....    | 245        |
| 28.4 Hardware Configuration Options .....                        | 246        |
| 28.4.1 Address Width.....                                        | 246        |
| 28.4.2 Number of AHB Master Ports .....                          | 246        |
| 28.4.3 Number of AHB Slave Ports .....                           | 246        |
| 28.4.4 Master and Slave Ports Connectivity.....                  | 246        |
| 28.4.5 Slave Base Address .....                                  | 246        |
| 28.4.6 Slave Size.....                                           | 247        |
| <b>29 ATCAPBBRG100 .....</b>                                     | <b>248</b> |
| 29.1 Introduction .....                                          | 248        |
| 29.1.1 Features.....                                             | 248        |
| 29.1.2 Block Diagram .....                                       | 248        |
| 29.1.3 Function Description .....                                | 249        |
| 29.2 Signal Description.....                                     | 249        |
| 29.2.1 Clock Enable Signal .....                                 | 252        |
| 29.3 Programming Model .....                                     | 253        |
| 29.3.1 Summary of Registers .....                                | 253        |
| 29.3.2 Register Description .....                                | 253        |
| 29.3.3 ID and Revision Register (0x00).....                      | 253        |
| 29.3.4 Control Register (0x14) .....                             | 254        |
| 29.3.5 Base/Size Register of Slave 1~n (0x20 + (n-1) * 0x4)..... | 254        |
| 29.4 Hardware Configuration Options .....                        | 256        |
| 29.4.1 Address Width.....                                        | 256        |
| 29.4.2 Address Decode Width .....                                | 256        |
| 29.4.3 APB Slave Ports .....                                     | 257        |
| 29.4.4 APB Slave Size.....                                       | 257        |
| 29.4.5 APB Slave Base Address Offset.....                        | 257        |
| 29.5 Access Latencies .....                                      | 257        |
| <b>30 ATCAPBDEC100.....</b>                                      | <b>259</b> |
| 30.1 Introduction .....                                          | 259        |
| 30.1.1 Features.....                                             | 259        |
| 30.1.2 Block Diagram .....                                       | 259        |

|                                                                           |            |
|---------------------------------------------------------------------------|------------|
| 30.1.3 Function Description .....                                         | 260        |
| 30.2 Signal Description.....                                              | 260        |
| 30.3 Programming Model .....                                              | 262        |
| 30.3.1 Summary of Registers .....                                         | 262        |
| 30.3.2 Register Description .....                                         | 262        |
| 30.3.3 ID and Revision Register (0x00).....                               | 262        |
| 30.3.4 Base/Size Register of Slave 1~ n (0x20 + (n-1) * 0x4) .....        | 262        |
| 30.4 Hardware Configuration Options .....                                 | 264        |
| 30.4.1 Hardware Configuration Options .....                               | 264        |
| 30.4.2 Address Decode Width .....                                         | 264        |
| 30.4.3 APB Slave Ports .....                                              | 264        |
| 30.4.4 APB Slave Size.....                                                | 265        |
| 30.4.5 APB Slave Base Address Offset.....                                 | 265        |
| <b>31 ATCDMAC100.....</b>                                                 | <b>266</b> |
| 31.1 Introduction .....                                                   | 266        |
| 31.1.1 Features.....                                                      | 266        |
| 31.1.2 Block Diagram .....                                                | 266        |
| 31.1.3 Function Description .....                                         | 267        |
| 31.1.4 Channel Arbitration .....                                          | 268        |
| 31.1.5 Hardware Handshaking .....                                         | 268        |
| 31.1.6 Chain Transfer .....                                               | 269        |
| 31.1.7 Data Order .....                                                   | 270        |
| 31.2 Signal Description.....                                              | 272        |
| 31.3 Programming Model .....                                              | 274        |
| 31.3.1 Register Summary.....                                              | 274        |
| 31.3.2 Register Description .....                                         | 275        |
| 31.3.3 ID and Revision Register (Offset 0x00) .....                       | 275        |
| 31.3.4 DMAC Configuration Register (Offset 0x10) .....                    | 276        |
| 31.3.5 DMAC Control Register (Offset 0x20) .....                          | 277        |
| 31.3.6 Interrupt Status Register (Offset 0x30) .....                      | 277        |
| 31.3.7 Channel Enable Register (Offset 0x34).....                         | 278        |
| 31.3.8 Channel Abort Register (Offset 0x40).....                          | 278        |
| 31.3.9 Channel n Control Register (Offset 0x44+n*0x14) .....              | 279        |
| 31.3.10 Channel n Source Address Register (Offset 0x48+n*0x14) .....      | 282        |
| 31.3.11 Channel n Destination Address Register (Offset 0x4C+n*0x14) ..... | 282        |
| 31.3.12 Channel n Transfer Size Register (Offset 0x50+n*0x14) .....       | 282        |
| 31.3.13 Channel n Linked List Pointer Register (Offset 0x54+n*0x14) ..... | 283        |
| 31.4 Hardware Configuration Options .....                                 | 283        |
| 31.4.1 Number of DMA Channels.....                                        | 283        |
| 31.4.2 FIFO Size.....                                                     | 283        |
| 31.4.3 DMA Request/Acknowledge Number .....                               | 283        |
| 31.4.4 DMA Request Synchronization Support .....                          | 283        |
| 31.4.5 Chain Transfer Support .....                                       | 283        |

|                                                                       |            |
|-----------------------------------------------------------------------|------------|
| 31.4.6 Address Width.....                                             | 283        |
| 31.5 Programming Sequence .....                                       | 284        |
| 31.5.1 Transfer without Chain Transfer .....                          | 284        |
| 31.5.2 Chain Transfer .....                                           | 285        |
| <b>32 ATCGPIO100.....</b>                                             | <b>288</b> |
| 32.1 Introduction .....                                               | 288        |
| 32.1.1 Description .....                                              | 288        |
| 32.1.2 Features.....                                                  | 288        |
| 32.1.3 Block Diagram .....                                            | 289        |
| 32.1.4 Function Description.....                                      | 289        |
| 32.2 Signal Description.....                                          | 290        |
| 32.3 Programming Model .....                                          | 291        |
| 32.3.1 Summary of Registers .....                                     | 291        |
| 32.3.2 Register Description .....                                     | 293        |
| 32.3.3 ID and Revision Register (Offset 0x00) .....                   | 293        |
| 32.3.4 Configuration Register (Offset 0x10).....                      | 293        |
| 32.3.5 Channel Data-In Register (Offset 0x20) .....                   | 293        |
| 32.3.6 Channel Data-Out Register (Offset 0x24) .....                  | 294        |
| 32.3.7 Channel Direction Register (Offset 0x28).....                  | 294        |
| 32.3.8 Channel Data-Out Clear Register (Offset 0x2C) .....            | 294        |
| 32.3.9 Channel Data-Out Set Register (Offset 0x30).....               | 294        |
| 32.3.10 Pull Enable Register (Offset 0x40) .....                      | 294        |
| 32.3.11 Pull Type Register (Offset 0x44) .....                        | 295        |
| 32.3.12 Interrupt Enable Register (Offset 0x50).....                  | 295        |
| 32.3.13 Interrupt Mode Register (Offset 0x54, 0x58, 0x5C, 0x60):..... | 295        |
| 32.3.14 Channel Interrupt Status Register (Offset 0x64): .....        | 299        |
| 32.4 Hardware Configuration Options .....                             | 300        |
| 32.4.1 GPIO Channel Number .....                                      | 300        |
| 32.4.2 Pull Support .....                                             | 300        |
| 32.4.3 Interrupt .....                                                | 300        |
| 32.4.4 De-bounce .....                                                | 300        |
| 32.5 Programming Sequence.....                                        | 300        |
| 32.5.1 Output Channel Programming.....                                | 300        |
| 32.5.2 Input Channel Programming.....                                 | 300        |
| 32.5.3 Basic Input Channel .....                                      | 300        |
| 32.5.4 Input Channel with Additional Functions .....                  | 300        |
| <b>33 ATCIIC100 .....</b>                                             | <b>302</b> |
| 33.1 Introduction .....                                               | 302        |
| 33.1.1 Features.....                                                  | 302        |
| 33.1.2 Block Diagram .....                                            | 302        |
| 33.1.3 I <sup>2</sup> C Master .....                                  | 303        |
| 33.1.4 I <sup>2</sup> C Slave .....                                   | 303        |

|                                                         |            |
|---------------------------------------------------------|------------|
| 33.1.5 General Call Address.....                        | 303        |
| 33.1.6 Auto Clock Stretch .....                         | 303        |
| 33.1.7 Auto-ACK .....                                   | 303        |
| 33.1.8 Timing Parameter Multiplier .....                | 303        |
| 33.2 Signal Description.....                            | 304        |
| 33.3 Programming Model .....                            | 304        |
| 33.3.1 Summary of Registers .....                       | 304        |
| 33.3.2 ID and Revision Register .....                   | 305        |
| 33.3.3 Configuration Register.....                      | 305        |
| 33.3.4 Interrupt Enable Register.....                   | 306        |
| 33.3.5 Status Register .....                            | 307        |
| 33.3.6 Address Register .....                           | 309        |
| 33.3.7 Data Register.....                               | 310        |
| 33.3.8 Control Register.....                            | 310        |
| 33.3.9 Command Register.....                            | 312        |
| 33.3.10 Setup Register .....                            | 312        |
| 33.3.11 Timing Parameter Multiplier Register.....       | 315        |
| 33.4 RTL Configuration.....                             | 315        |
| 33.4.1 Data FIFO Size .....                             | 315        |
| 33.5 Programming Sequence .....                         | 315        |
| 33.5.1 Timing Setup Guide .....                         | 315        |
| 33.5.2 Spike Suppression Width .....                    | 316        |
| 33.5.3 Data Setup Time .....                            | 316        |
| 33.5.4 Data Hold Time .....                             | 317        |
| 33.5.5 I <sup>2</sup> C-Bus Clock Frequency: .....      | 317        |
| 33.5.6 Timing Parameter Multiplier.....                 | 318        |
| 33.5.7 Master Mode.....                                 | 319        |
| 33.5.8 Data Transmit without DMA.....                   | 319        |
| 33.5.9 Data Receive without DMA.....                    | 320        |
| 33.5.10 Arbitration Lost in the Multi-Master Mode ..... | 321        |
| 33.5.11 Slave Mode .....                                | 322        |
| 33.5.12 Data Transaction without DMA: .....             | 322        |
| 33.5.13 Data transaction with DMA .....                 | 322        |
| <b>34 ATCSPI200 .....</b>                               | <b>324</b> |
| 34.1 Introduction .....                                 | 324        |
| 34.1.1 Features.....                                    | 324        |
| 34.1.2 Block Diagram .....                              | 324        |
| 34.1.3 Master Mode .....                                | 325        |
| 34.1.4 Slave Mode .....                                 | 326        |
| 34.1.5 Dual I/O Mode.....                               | 329        |
| 34.1.6 Quad I/O Mode .....                              | 330        |
| 34.2 Signal Description.....                            | 330        |
| 34.3 Programming Model .....                            | 334        |

|                                                                              |            |
|------------------------------------------------------------------------------|------------|
| 34.3.1 Summary of Registers .....                                            | 334        |
| 34.3.2 Register Description .....                                            | 335        |
| 34.3.3 ID and Revision Register (0x00).....                                  | 335        |
| 34.3.4 SPI Transfer Format Register (0x10).....                              | 336        |
| 34.3.5 SPI Direct IO Control Register (0x14) .....                           | 337        |
| 34.3.6 SPI Transfer Control Register (0x20) .....                            | 338        |
| 34.3.7 SPI Command Register (0x24).....                                      | 342        |
| 34.3.8 SPI Address Register (0x28) .....                                     | 342        |
| 34.3.9 SPI Data Register (0x2C) .....                                        | 342        |
| 34.3.10 SPI Control Register (0x30).....                                     | 344        |
| 34.3.11 SPI Status Register (0x34) .....                                     | 345        |
| 34.3.12 SPI Interrupt Enable Register (0x38).....                            | 346        |
| 34.3.13 SPI Interrupt Status Register (0x3C) .....                           | 347        |
| 34.3.14 SPI Interface Timing Register (0x40).....                            | 347        |
| 34.3.15 SPI Memory Access Control Register (0x50) .....                      | 348        |
| 34.3.16 SPI Slave Status Register (0x60) .....                               | 350        |
| 34.3.17 SPI Slave Data Count Register (0x64) .....                           | 351        |
| 34.3.18 Configuration Register (0x7C) .....                                  | 352        |
| 34.4 Hardware Configuration Options .....                                    | 352        |
| 34.4.1 Address Width.....                                                    | 353        |
| 34.4.2 Dual I/O Mode.....                                                    | 353        |
| 34.4.3 Quad I/O Mode .....                                                   | 353        |
| 34.4.4 TX FIFO Depth .....                                                   | 353        |
| 34.4.5 RX FIFO Depth .....                                                   | 353        |
| 34.4.6 Direct IO Control .....                                               | 353        |
| 34.4.7 Memory-Mapped Access Support .....                                    | 353        |
| 34.4.8 Slave Mode.....                                                       | 354        |
| 34.4.9 AHB Register Port.....                                                | 354        |
| 34.4.10 Memory-Mapped AHB/EILM Read .....                                    | 354        |
| 34.4.11 SPI Interface Timing Parameters.....                                 | 354        |
| 34.5 Programming Sequence .....                                              | 354        |
| 34.5.1 SPI Write with DMA .....                                              | 354        |
| 34.5.2 SPI Read with DMA:.....                                               | 355        |
| 34.5.3 Stopping SPI Activities Initiated by the Memory-Mapped Interface..... | 356        |
| 34.5.4 Receiving Data from SPI Masters .....                                 | 357        |
| 34.5.5 Transmitting Data to SPI Masters.....                                 | 358        |
| 34.6 Integration Guideline.....                                              | 359        |
| 34.6.1 SCLK Frequency .....                                                  | 361        |
| 34.6.2 Time between the Edges of SPI CS to the First Edge of SCLK .....      | 361        |
| 34.6.3 Clock Enable Signal .....                                             | 361        |
| 34.6.4 Clock Gating Cell.....                                                | 362        |
| 34.6.5 DFT Considerations.....                                               | 364        |
| <b>35 ATCUART100.....</b>                                                    | <b>366</b> |

---

|                                                                  |     |
|------------------------------------------------------------------|-----|
| 35.1 Introduction .....                                          | 366 |
| 35.1.1 Features.....                                             | 366 |
| 35.1.2 Block Diagram .....                                       | 366 |
| 35.1.3 Transmitter.....                                          | 367 |
| 35.1.4 Receiver.....                                             | 367 |
| 35.1.5 Baud Rate Generator .....                                 | 368 |
| 35.1.6 Modem Controller .....                                    | 369 |
| 35.1.7 Loopback Mode .....                                       | 369 |
| 35.1.8 DMA Operation .....                                       | 370 |
| 35.2 Signal Description.....                                     | 371 |
| 35.3 Programming Model .....                                     | 373 |
| 35.3.1 Summary of Registers .....                                | 373 |
| 35.3.2 ID and Revision Register (0x00).....                      | 373 |
| 35.3.3 Hardware Configure Register (0x10).....                   | 374 |
| 35.3.4 Over Sample Control Register (0x14) .....                 | 374 |
| 35.3.5 Receiver Buffer Register (when DLAB = 0) (0x20).....      | 374 |
| 35.3.6 Transmitter Holding Register (when DLAB = 0) (0x20) ..... | 375 |
| 35.3.7 Interrupt Enable Register (when DLAB = 0) (0x24).....     | 375 |
| 35.3.8 Divisor Latch LSB (when DLAB = 1) (0x20) .....            | 376 |
| 35.3.9 Divisor Latch MSB (when DLAB = 1) (0x24) .....            | 376 |
| 35.3.10 Interrupt Identification Register (0x28) .....           | 376 |
| 35.3.11 FIFO Control Register (0x28) .....                       | 378 |
| 35.3.12 Line Control Register (0x2C) .....                       | 380 |
| 35.3.13 Modem Control Register (0x30) .....                      | 381 |
| 35.3.14 Line Status Register (0x34) .....                        | 381 |
| 35.3.15 Modem Status Register (0x38).....                        | 384 |
| 35.3.16 Scratch Register (0x3C) .....                            | 385 |
| 35.4 Hardware Configuration Options .....                        | 385 |
| 35.4.1 The Depth of FIFO.....                                    | 385 |
| 35.4.2 The Same Clock Source.....                                | 385 |
| 35.5 Programming Sequence .....                                  | 385 |
| 35.5.1 UART Setup.....                                           | 385 |
| 35.5.2 Data Transfer without DMA .....                           | 386 |
| 35.5.3 Data Transfer with DMA .....                              | 386 |
| 35.5.4 Receiving Data .....                                      | 386 |
| 35.5.5 Data Receive without DMA.....                             | 386 |
| 35.5.6 Data receive with DMA .....                               | 386 |

# List of Figures

|                                                                     |     |
|---------------------------------------------------------------------|-----|
| Figure 4-1 N25 (F) Block Diagram .....                              | 9   |
| Figure 4-2 Pipeline Stages and Activities .....                     | 10  |
| Figure 4-3 Design Hierarchy .....                                   | 12  |
| Figure 5-1 Configuration Tool GUI .....                             | 13  |
| Figure 7-1 Suggested Design for Reset Synchronization.....          | 34  |
| Figure 7-2 BUS_CLK_EN Waveform for N:1 (3:1) Clock Ratio .....      | 35  |
| Figure 11-1 Single Access on the Local Memory Slave Port .....      | 46  |
| Figure 11-2 Burst Read Access on the Local Memory Slave Port.....   | 46  |
| Figure 11-3 Burst Write Access on the Local Memory Slave Port ..... | 47  |
| Figure 11-4 Various Size Write Transfers with ECC .....             | 48  |
| Figure 13-1 BIU Block Diagram .....                                 | 53  |
| Figure 21-1 NCEPLIC100 Block Diagram .....                          | 154 |
| Figure 21-2 NCEPLIC100 Vector Mode Protocol .....                   | 156 |
| Figure 21-3 Minimum Interrupt Latency.....                          | 164 |
| Figure 22-1 NCEPLMT100 Block Diagram.....                           | 169 |
| Figure 23-1 Debug Subsystem Block Diagram.....                      | 174 |
| Figure 24-1 ATCWDT200 Block Diagram .....                           | 194 |
| Figure 24-2 Stages of the Watchdog Timer .....                      | 194 |
| Figure 25-1 ATCRTC100 Block Diagram .....                           | 202 |
| Figure 26-1 ATCPIT100 Block Diagram.....                            | 214 |
| Figure 26-2 PWM Example Waveform .....                              | 224 |
| Figure 27-1 ATCBUSDEC200 Block Diagram .....                        | 227 |
| Figure 27-2 Signal Diagram .....                                    | 228 |
| Figure 27-3 ATCBUSDEC200 Connection Example .....                   | 233 |
| Figure 28-1 ATCBMC200 Block Diagram .....                           | 236 |

|                                                                                                                                                                                       |     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Figure 28-2 ATCBMC200 I/O Signals .....                                                                                                                                               | 237 |
| Figure 29-1 ATCAPBBRG100 Block Diagram .....                                                                                                                                          | 249 |
| Figure 29-2 ATCAPBBRG100 Logic Symbol .....                                                                                                                                           | 250 |
| Figure 29-3 ATCAPBBRG100 Clock Enable Signal for 4:1 AHB-to-APB Clock Ratio.....                                                                                                      | 253 |
| Figure 30-1 ATCPBDEC100 Block Diagram .....                                                                                                                                           | 260 |
| Figure 30-2 ATCPBDEC100 Input/Output Signals .....                                                                                                                                    | 261 |
| Figure 31-1 ATCDMAC100 Block Diagram.....                                                                                                                                             | 267 |
| Figure 31-2 Example of DMA Data Transfers .....                                                                                                                                       | 268 |
| Figure 31-3 Example of Hardware Handshaking.....                                                                                                                                      | 268 |
| Figure 31-4 Linked List Structure for Chain Transfers .....                                                                                                                           | 269 |
| Figure 31-5 Data Order at the Destination when the Source Address Mode is the Increment Mode                                                                                          | 271 |
| Figure 31-6 Data Order at the Destination when the Source Address Mode is the Decrement Mode                                                                                          | 271 |
| Figure 31-7 Data Order at the Destination when the Source Address Mode is the Fixed Mode.....                                                                                         | 272 |
| Figure 31-8 ATCDMAC100 Interfaces .....                                                                                                                                               | 272 |
| Figure 32-1 ATCGPIO100 Block Diagram .....                                                                                                                                            | 289 |
| Figure 32-2 ATCGPIO100 Pin Connection Diagram.....                                                                                                                                    | 290 |
| Figure 33-1 ATCIIC100 Block Diagram.....                                                                                                                                              | 302 |
| Figure 34-1 ATCSPI200 Block Diagram.....                                                                                                                                              | 325 |
| Figure 34-2 SPI Transfer Format .....                                                                                                                                                 | 326 |
| Figure 34-3 Timing Diagram of Status-Reading Commands (MSB First, DataMerge=0) .....                                                                                                  | 327 |
| Figure 34-4 Timing Diagram of Data-Reading Commands (MSB First, Merge Mode).....                                                                                                      | 328 |
| Figure 34-5 Timing Diagram of Data-Writing Commands (MSB First, Merge Mode) .....                                                                                                     | 328 |
| Figure 34-6 Timing Diagram of Data-Reading Commands (MSB First, Data Length = 16 Bits) .....                                                                                          | 329 |
| Figure 34-7 Timing Diagram of Slave User-Defined Command (MSB First, Merge Mode, TransMode = {Dummy,Write}, DualQuad = Quad, DummyCnt = 1, WrTranCnt = 3, Data length = 8 Bits) ..... | 329 |
| Figure 34-8 SPI Dual I/O Transfer (3-byte address) .....                                                                                                                              | 330 |
| Figure 34-9 SPI Quad I/O Mode Transfer (3-byte address) .....                                                                                                                         | 330 |
| Figure 34-10 SCLK I/O Pad .....                                                                                                                                                       | 361 |
| Figure 34-11 Relation Between SCLK Domain and spi_clock Domain .....                                                                                                                  | 361 |
| Figure 34-12 ATCSPI200 Clock Enable Signal for 4:1 AHB-to-APB Clock Ratio .....                                                                                                       | 362 |
| Figure 34-13 Clock Gating Logic for Simulation and Synthesis .....                                                                                                                    | 363 |
| Figure 34-14 Clock Gating Cell Diagram with Waveform .....                                                                                                                            | 364 |

|                                                                         |     |
|-------------------------------------------------------------------------|-----|
| Figure 34-15 ATCSPI200 Design for ATPG Test.....                        | 365 |
| Figure 35-1 ATCUART100 Block Diagram.....                               | 367 |
| Figure 35-2 Relationship between MCR and MSR in the Loopback Mode ..... | 370 |

# List of Tables

|                                                            |    |
|------------------------------------------------------------|----|
| Table 1-1 Abbreviations and Terminology .....              | 2  |
| Table 2-1 Gowin RiscV A/N25.....                           | 4  |
| Table 3-1 Gowin RiscV A/N25 Resources .....                | 6  |
| Table 4-1 Major components.....                            | 9  |
| Table 5-1 Supported Combination of Privilege Modes .....   | 14 |
| Table 6-1 General Signals.....                             | 20 |
| Table 6-2 Interrupt Signals.....                           | 20 |
| Table 6-3 Debug Signals .....                              | 21 |
| Table 6-4 Trace Signals .....                              | 21 |
| Table 6-5 AHB Interface Signals .....                      | 22 |
| Table 6-6 Instruction Local Memory Interface Signals ..... | 23 |
| Table 6-7 Instruction Local Memory Address Bit-Width.....  | 23 |
| Table 6-8 Instruction Local Memory Data Bit-Width.....     | 23 |
| Table 6-9 ILM Byte Write Enable Mapping .....              | 23 |
| Table 6-10 Data Local Memory Interface Signals .....       | 24 |
| Table 6-11 Data Local Memory Address Bit-Width .....       | 25 |
| Table 6-12 Data Local Memory Data Bit-Width.....           | 25 |
| Table 6-13 DLM Byte Write Enable Mapping .....             | 25 |
| Table 6-14 Instruction Cache Interface Signals .....       | 26 |
| Table 6-15 I-Cache Tag Address Bit-Width .....             | 27 |
| Table 6-16 I-Cache Tag Data Bit-Width .....                | 27 |
| Table 6-17 I-Cache Data Address Bit-Width .....            | 28 |
| Table 6-18 Data Cache Interface Signals .....              | 29 |
| Table 6-19D-Cache Tag Address Bit-Width .....              | 30 |
| Table 6-20D-Cache Tag Data Bit-Width.....                  | 30 |

---

|                                                                                 |    |
|---------------------------------------------------------------------------------|----|
| Table 6-21 D-Cache Data Address Bit-Width.....                                  | 31 |
| Table 6-22 D-Cache Data Bit-Width.....                                          | 31 |
| Table 6-23 D-Cache Byte Write Enable Mapping .....                              | 31 |
| Table 6-24 AHB Slave Port Signals.....                                          | 32 |
| Table 6-25 BTB Memory Interface Signals .....                                   | 33 |
| Table 6-26 BTB RAM Address Bit-Width .....                                      | 33 |
| Table 8-1 Integer Registers.....                                                | 36 |
| Table 9-1 Normal Memory Attribute .....                                         | 39 |
| Table 9-2 Memory Access Ordering.....                                           | 40 |
| Table 10-1 Priorities for Instruction Fetches .....                             | 42 |
| Table 10-2 Priorities for Data Accesses .....                                   | 42 |
| Table 10-3 Local Memory Address Range (for ILM and DLM) .....                   | 43 |
| Table 10-4 Possible AHB-Lite Transactions Used by Local Memory Interfaces ..... | 44 |
| Table 10-5 Instruction Local Memory Protection Control Signal.....              | 44 |
| Table 10-6 Data Local Memory Protection Control Signal.....                     | 44 |
| Table 11-1 Local Memory Slave Port Selection .....                              | 45 |
| Table 11-2 Local Memory Slave Port Transfer Latency .....                       | 46 |
| Table 12-1 Configuration Choices for the Instruction Cache .....                | 50 |
| Table 12-2 Configuration Choices for the Data Cache .....                       | 50 |
| Table 12-3 Access Latency of the Instruction Cache .....                        | 50 |
| Table 12-4 Access Latency of the Data Cache .....                               | 50 |
| Table 12-5 Effects of FENCE/FENCE.I Instructions .....                          | 52 |
| Table 13-1 AHB Transactions Used by N25(F) .....                                | 54 |
| Table 13-2 AXI Transactions Used by N25(F).....                                 | 54 |
| Table 17-1 Handling Correctable Errors in Caches .....                          | 62 |
| Table 17-2 Handling Uncorrectable Errors in Caches .....                        | 63 |
| Table 17-3 Local Memory Parity/ECC Error Handling .....                         | 63 |
| Table 17-4 Parity/ECC Behavior for Local Memory Operations .....                | 63 |
| Table 17-5 Types of Parity/ECC Error Exception.....                             | 63 |
| Table 18-1 Machine Information Registers .....                                  | 65 |
| Table 18-2 Machine Trap Related Registers.....                                  | 65 |
| Table 18-3 Counter Related Registers.....                                       | 66 |

|                                                                                          |     |
|------------------------------------------------------------------------------------------|-----|
| Table 18-4 Configuration Control & Status Registers .....                                | 66  |
| Table 18-5 Trigger Registers.....                                                        | 66  |
| Table 18-6 Debug Registers .....                                                         | 67  |
| Table 18-7 Memory and Miscellaneous Registers .....                                      | 67  |
| Table 18-8 Hardware Stack Protection and Recording Registers .....                       | 68  |
| Table 18-9 CoDense Registers .....                                                       | 68  |
| Table 18-10 PMP Registers .....                                                          | 68  |
| Table 18-11 RISC-V Definition of the Extensions Field.....                               | 74  |
| Table 18-12 N25(F) mcause Value after Trap .....                                         | 82  |
| Table 18-13 N25(F) mcause Value after Reset.....                                         | 83  |
| Table 18-14 N25(F) mcause Value after NMI .....                                          | 83  |
| Table 18-15 N25(F) mcause Value after Vector Interrupt .....                             | 83  |
| Table 18-16 Event Selectors .....                                                        | 87  |
| Table 18-17 Virtual Address in DPC upon Debug Mode Entry .....                           | 109 |
| Table 18-18 CCTL Command Definition .....                                                | 126 |
| Table 18-19 CCTL Commands Using the mcctlData Register .....                             | 127 |
| Table 18-20 User CCTL Command Definition.....                                            | 129 |
| Table 18-21 N25(F) NAPOT range encoding in PMP address and configuration registers ..... | 135 |
| Table 19-1 Load Instruction Latency .....                                                | 136 |
| Table 19-2 Multiply Instruction Latency: Radix Multiplier .....                          | 137 |
| Table 19-3 Multiply Instruction Latency: Fast Multiplier .....                           | 137 |
| Table 19-4 FPU Instruction latency .....                                                 | 138 |
| Table 20-1 N25(F) AE250 Memory Map .....                                                 | 139 |
| Table 20-2 N25(F) Interrupt Assignment.....                                              | 141 |
| Table 20-3 PLIC Interrupt Source .....                                                   | 141 |
| Table 20-4 DMA Hardware Handshake ID .....                                               | 145 |
| Table 20-5 SMU Register Summary .....                                                    | 146 |
| Table 21-1 PLIC Configuration Parameters .....                                           | 157 |
| Table 21-2 AndeStar-V5 PLIC Memory Map.....                                              | 159 |
| Table 21-3 Meaning of Trigger Type .....                                                 | 161 |
| Table 21-4 General Signals of NCEPLIC100 .....                                           | 165 |
| Table 21-5 AHB Interface Signals of NCEPLIC100 .....                                     | 165 |

|                                                         |     |
|---------------------------------------------------------|-----|
| Table 21-6 AXI Interface Signals of NCEPLIC100 .....    | 166 |
| Table 21-7 Valid AHB Transactions for NCEPLIC100.....   | 167 |
| Table 21-8 Valid AXI Transactions for NCEPLIC100 .....  | 167 |
| Table 22-1 N25(F) NCEPLMT100 Memory Map.....            | 169 |
| Table 22-2 Machine Timer Configuration Parameters ..... | 170 |
| Table 22-3 General Signals of NCEPLMT100 .....          | 170 |
| Table 22-4 AHB Interface Signals of NCEPLMT100.....     | 171 |
| Table 22-5 AXI Interface Signals of NCEPLMT100 .....    | 172 |
| Table 23-1 System Memory Map of NCEPLDM200 .....        | 177 |
| Table 23-2 DMI Memory Map of NCEPLDM200.....            | 177 |
| Table 23-3 General Signals of NCEPLDM200 .....          | 186 |
| Table 23-4 DMI Interface Signals of NCEPLDM200 .....    | 186 |
| Table 23-5 AHB Interface Signals of NCEPLDM200 .....    | 187 |
| Table 23-6 AXI Interface Signals of NCEPLDM200 .....    | 188 |
| Table 23-7 TAP Instruction NCEJDTM200.....              | 190 |
| Table 24-1 Signal Description of ATCWDT200 .....        | 195 |
| Table 24-2 Summary of registers .....                   | 196 |
| Table 24-3 ID and Revision Register .....               | 196 |
| Table 24-4 Control Register .....                       | 197 |
| Table 24-5 Restart Register .....                       | 198 |
| Table 24-6 Write Enable Register .....                  | 199 |
| Table 24-7 Status Register (0x1C).....                  | 199 |
| Table 25-1 Signal Description of ATCRTC100 .....        | 203 |
| Table 25-2 Summary of Registers.....                    | 204 |
| Table 25-3 ID and Revision Register .....               | 204 |
| Table 25-4 Counter Register .....                       | 205 |
| Table 25-5 Alarm Register.....                          | 205 |
| Table 25-6 Control Register .....                       | 206 |
| Table 25-7 Interrupt Status Register .....              | 207 |
| Table 25-8 Digital Trimming Register .....              | 208 |
| Table 25-9 Trimming Capabilities.....                   | 212 |
| Table 26-1 Effective Devices of Channel Modes .....     | 214 |

|                                                                                                |     |
|------------------------------------------------------------------------------------------------|-----|
| Table 26-2 Signal Description of ATCPIT100 .....                                               | 215 |
| Table 26-3 Summary of registers .....                                                          | 216 |
| Table 26-4 ID and Revision Register .....                                                      | 217 |
| Table 26-5 Configuration Register .....                                                        | 217 |
| Table 26-6 Interrupt Enable Register .....                                                     | 218 |
| Table 26-7 Interrupt Status Register .....                                                     | 218 |
| Table 26-8 Channel Enable Register .....                                                       | 219 |
| Table 26-9 Channel 0~3 Control Register (0x20 + n * 0x10) .....                                | 221 |
| Table 26-10 Reload Register for 32-bit Timer Mode (ChMode=1).....                              | 222 |
| Table 26-11 Reload Register for 16-bit Timers Mode (ChMode=2) .....                            | 222 |
| Table 26-12 Reload Register for 8-bit Timers Mode (ChMode=3) .....                             | 223 |
| Table 26-13 Reload Register for PWM Mode (ChMode=4) .....                                      | 223 |
| Table 26-14 Reload Register for Mixed PWM/16-bit Timer Mode (ChMode=6) .....                   | 223 |
| Table 26-15 Reload Register for Mixed PWM/8-bit Timers Mode (ChMode=7) .....                   | 223 |
| Table 27-1 ATCBUSDEC200 Signal Description .....                                               | 229 |
| Table 27-2 Register Summary .....                                                              | 229 |
| Table 27-3 ID and Revision Register (0x00) .....                                               | 230 |
| Table 27-4 Base/Size Register of Downstream Port 1~n (0x1c + n*0x4) in 24-bit Address Mode ... | 230 |
| Table 27-5 Base/Size Register of Downstream Port 1~n (0x1c + n*0x4) in 32-bit Address Mode ... | 231 |
| Table 27-6 ATCBUSDEC200 Access Latencies .....                                                 | 234 |
| Table 28-1 Programmability of Base Address and Size Registers for AHB Slave 1–15.....          | 237 |
| Table 28-2 ATCBMC200 Signal Definition .....                                                   | 238 |
| Table 28-3 ATCBMC200 Register Summary .....                                                    | 239 |
| Table 28-4 ID and Revision Register .....                                                      | 240 |
| Table 28-5 Priority Register.....                                                              | 241 |
| Table 28-6 Control Register .....                                                              | 241 |
| Table 28-7 Interrupt Status Register .....                                                     | 242 |
| Table 28-8 Base/Size Register of AHB Slave 1–10 in 24-bit Mode .....                           | 244 |
| Table 28-9 Base/Size Register of AHB Slave 1–10 in 32-bit Mode .....                           | 244 |
| Table 28-10 Base/Size Register of AHB Slave 11–15 in 24-bit Mode .....                         | 245 |
| Table 28-11 Base/Size Register of AHB Slave 11–15 in 32-bit Mode.....                          | 245 |
| Table 28-12 Slave Sizes Encoding Table.....                                                    | 247 |

|                                                                             |     |
|-----------------------------------------------------------------------------|-----|
| Table 29-1 ATCAPBBRG100 Signal Definition .....                             | 251 |
| Table 29-2 ATCAPBBRG100 Register Summary .....                              | 253 |
| Table 29-3 ID and Revision Register .....                                   | 254 |
| Table 29-4 Configuration Register .....                                     | 254 |
| Table 29-5 Base/Size Register of Slave 1~n in 24-bit mode .....             | 255 |
| Table 29-6 Base/Size Register of Slave 1~n in 32-bit mode .....             | 256 |
| Table 29-7 ATCAPBBRG100 Access Latencies .....                              | 258 |
| Table 30-1 ATCAPBDEC100 Signal Definition .....                             | 261 |
| Table 30-2 ATCAPBDEC100 Register Summary.....                               | 262 |
| Table 30-3 ID and Revision Register .....                                   | 262 |
| Table 30-4 Base/Size Register of Slave 1~n in the 24-bit Mode .....         | 263 |
| Table 30-5 Base/Size Register of Slave 1~n in the 32-bit Mode .....         | 264 |
| Table 31-1 Format of Linked List Descriptor .....                           | 270 |
| Table 31-2 ATCDMAC100 Signal Definition.....                                | 273 |
| Table 31-3 ATCDMAC100 Register Summary.....                                 | 275 |
| Table 31-4 ID and Revision Register .....                                   | 276 |
| Table 31-5 DMAC Configuration Register.....                                 | 276 |
| Table 31-6 DMAC Control Register.....                                       | 277 |
| Table 31-7 Interrupt Status Register .....                                  | 277 |
| Table 31-8 Channel Enable Register .....                                    | 278 |
| Table 31-9 Channel Abort Register .....                                     | 278 |
| Table 31-10 Channel n Control Register.....                                 | 279 |
| Table 31-11 Channel n Source Address Register .....                         | 282 |
| Table 31-12 Channel n Destination Address Register .....                    | 282 |
| Table 31-13 Channel n Transfer Size Register .....                          | 282 |
| Table 31-14 Channel Linked List Pointer Register.....                       | 283 |
| Table 31-15 Register Setup Sample for Transfer without Chain Transfer ..... | 285 |
| Table 31-16 Register Setup Sample for Transfer with Chain Transfer .....    | 287 |
| Table 32-1 ATCGPIO100 Pin Description .....                                 | 290 |
| Table 32-2 ATCGPIO100 Register Summary .....                                | 292 |
| Table 32-3 and Revision Register .....                                      | 293 |
| Table 32-4 Configuration Register .....                                     | 293 |

|                                                                  |     |
|------------------------------------------------------------------|-----|
| Table 32-5 Channel Data-In Register.....                         | 293 |
| Table 32-6 Channel Data-Out Register.....                        | 294 |
| Table 32-7 Channel Direction Register .....                      | 294 |
| Table 32-8 Channel Data-Out Clear Register .....                 | 294 |
| Table 32-9 Channel Data-Out Set Register .....                   | 294 |
| Table 32-10 Pull Enable Register.....                            | 294 |
| Table 32-11 Pull Type Register .....                             | 295 |
| Table 32-12 Interrupt Enable Register .....                      | 295 |
| Table 32-13 Channel (0~7) Interrupt Mode Register (0x54) .....   | 296 |
| Table 32-14 Channel (8~15) Interrupt Mode Register (0x58) .....  | 297 |
| Table 32-15 Channel (16~23) Interrupt Mode Register (0x5C) ..... | 297 |
| Table 32-16 Channel (24~31) Interrupt Mode Register (0x60) ..... | 298 |
| Table 32-17 Channel Interrupt Status Register.....               | 299 |
| Table 32-18 De-bounce Enable Register .....                      | 299 |
| Table 32-19 De-bounce Control Register .....                     | 299 |
| Table 33-1 ATCIIC100 Signal Description.....                     | 304 |
| Table 33-2 ATCIIC100 Registers Summary .....                     | 305 |
| Table 33-3 ID and Revision Register .....                        | 305 |
| Table 33-4 Configuration Register .....                          | 306 |
| Table 33-5 Interrupt Enable Register .....                       | 306 |
| Table 33-6 Status Register.....                                  | 308 |
| Table 33-7 Address Register.....                                 | 310 |
| Table 33-8 Data Register .....                                   | 310 |
| Table 33-9 Control Register .....                                | 311 |
| Table 33-10 Command Register .....                               | 312 |
| Table 33-11 Controller Setting Register .....                    | 313 |
| Table 33-12 Timing Parameter Multiplier Register.....            | 315 |
| Table 33-13 Timing Parameters for Spike Suppression.....         | 316 |
| Table 33-14 Timing Parameters for the Data Setup Time.....       | 316 |
| Table 33-15 Timing Parameters for the Data Hold Time.....        | 317 |
| Table 33-16 Timing Parameters for the SCL Clock.....             | 317 |
| Table 34-1 Supported Commands under the Slave Mode.....          | 327 |

|                                                                                            |     |
|--------------------------------------------------------------------------------------------|-----|
| Table 34-2 ATCSPI200 Signal Definition.....                                                | 331 |
| Table 34-3 ATCSPI200 Register Summary.....                                                 | 335 |
| Table 34-4 ID and Revision Register .....                                                  | 336 |
| Table 34-5 SPI Transfer Format Register .....                                              | 336 |
| Table 34-6 SPI Direct IO Control Register .....                                            | 338 |
| Table 34-7 SPI Transfer Control Register .....                                             | 339 |
| Table 34-8 SPI Command Register .....                                                      | 342 |
| Table 34-9 SPI Address Register.....                                                       | 342 |
| Table 34-10 SPI Data Register .....                                                        | 343 |
| Table 34-11 SPI Control Register.....                                                      | 344 |
| Table 34-12 SPI Status Register.....                                                       | 345 |
| Table 34-13 SPI Interrupt Enable Register .....                                            | 346 |
| Table 34-14 SPI Interrupt Status Register .....                                            | 347 |
| Table 34-15 SPI Interface Timing Register .....                                            | 348 |
| Table 34-16 SPI Memory Access Control Register.....                                        | 349 |
| Table 34-17 Supported SPI Read Commands for Memory-Mapped AHB/EILM Reads.....              | 349 |
| Table 34-18 Latency of a 4 Bytes Data Transfer through the AHB/EILM Memory Read Port ..... | 350 |
| Table 34-19 SPI Slave Status Register.....                                                 | 350 |
| Table 34-20 SPI Slave Data Count Register.....                                             | 351 |
| Table 34-21 Configuration Register .....                                                   | 352 |
| Table 35-1 Clock Variation Tolerance Factor .....                                          | 369 |
| Table 35-2 Signal Description of ATCUART100.....                                           | 371 |
| Table 35-3 Summary of Registers.....                                                       | 373 |
| Table 35-4 ID and Revision Register .....                                                  | 374 |
| Table 35-5 Hardware Configure Register .....                                               | 374 |
| Table 35-6 Over Sample Control Register .....                                              | 374 |
| Table 35-7 Receiver Buffer Register (when DLAB = 0) .....                                  | 375 |
| Table 35-8 Transmitter Holding Register (when DLAB = 0).....                               | 375 |
| Table 35-9 Interrupt Enable Register (when DLAB = 0) .....                                 | 375 |
| Table 35-10 Divisor Latch LSB (when DLAB = 1).....                                         | 376 |
| Table 35-11 Divisor Latch MSB (when DLAB = 1) .....                                        | 376 |
| Table 35-12 Interrupt Identification Register .....                                        | 376 |

|                                                |     |
|------------------------------------------------|-----|
| Table 35-13 Interrupt Control Table.....       | 377 |
| Table 35-14 FIFO Control Register .....        | 378 |
| Table 35-15 Receive FIFO Trigger Level .....   | 378 |
| Table 35-16 Transmit FIFO Trigger Level .....  | 379 |
| Table 35-17 Line Control Register .....        | 380 |
| Table 35-18 Parity Bit Selection .....         | 380 |
| Table 35-19 Modem Control Register .....       | 381 |
| Table 35-20 Line Status Register.....          | 382 |
| Table 35-21 Modem Status Register (0x38) ..... | 384 |
| Table 35-22 Scratch Register.....              | 385 |

# 1 About This Guide

## 1.1 Purpose

The Gowin Risc V N25 IP user guide is designed to help users to quickly master the features of Gowin Risc V N25. It mainly helps the user quickly understand the features, characteristics, and usages of the Gowin Risc V N25 IP products.

This reference manual targets application developers. It provides complete information on how to use the Gowin RiscV A/N25 ae350/250 microcontroller memory and peripherals.

The ae350/250 is a family of microcontrollers with different memory sizes and peripherals. For ordering information, mechanical and electrical device characteristics please refer to the datasheets.

For information on the RISC V ISA, please refer to the RISC-V Instruction Set Manual.

## 1.2 Supported Products

The information in this guide applies to the following products:

1. GW1N Series
2. GW1NR Series
3. GW2A Series
4. GW2AR Series

## 1.3 Related Documents

The latest user guides are available on GOWINSEMI Website. You can find the related documents at [www.gowinsemi.com](http://www.gowinsemi.com):

1. GW1N series of FPGA Products Data Sheet
2. GW1NR series of FPGA Products Data Sheet
3. GW2A series of FPGA Products Data Sheet
4. GW2AR series of FPGA Products Data Sheet

## 5. Gowin YunYuan Software User Guide

Available from RISCV organization web site [riscv.org](https://riscv.org):

1. The RISC-V Instruction Set Manual Volume I: User-Level ISA
2. The RISC-V Instruction Set Manual Volume II: Privileged Architecture

## 1.4 Abbreviations and Terminology

The abbreviations and terminologies used in this manual are set out in 错误!未找到引用源。 below.

**Table 1-1 Abbreviations and Terminology**

| Abbreviations and Terminology | Name                                |
|-------------------------------|-------------------------------------|
| IPIPE                         | Integer Pipeline                    |
| RF                            | Register File                       |
| CSR                           | Control and Status Register         |
| ALU                           | Arithmetic Logic Unit               |
| MDU                           | Multiplication and Division Unit    |
| FASTMUL                       | Fast Multiplier                     |
| IFU                           | Instruction Fetch Unit              |
| ICU                           | Instruction Cache Unit              |
| LSU                           | Load Store Unit                     |
| DCU                           | Data Cache Unit                     |
| ILM                           | Instruction Local Memory Controller |
| DLM                           | Data Local Memory Controller        |
| BIU                           | Bus Interface Unit                  |
| MMU                           | Memory Manager Unit                 |
| TRIGM                         | Trigger Module                      |
| FPU                           | Floating Point Unit                 |
| ACE                           | Andes Custom Extension              |

## 1.5 Support and Feedback

Gowin Semiconductor provides customers with comprehensive technical support. If you have any questions, comments, or suggestions, please feel free to contact us directly using the information provided below.

Website: [www.gowinsemi.com](http://www.gowinsemi.com)

E-mail: [support@gowinsemi.com](mailto:support@gowinsemi.com)

Tel: +86 755 8262 0391

# 2 Overview

## 2.1 Introduction

AndesCore™ N25/N25F is a 32-bit CPU IP corebased on AndeStar™ V5 architecture which incorporated RISC-V technology, it is capable of delivering high per-MHz performance and operating at high frequencies, at the same time it is small in gate count. N25F also supports single and double precision floating point instructions and half precision load/store. N25/N25F comes with options, including branch prediction for efficient branch execution, Instruction and Data caches, Local Memories for low-latency accesses, ECC for L1 memory soft error protection, and Andes Custom Extension™ (ACE) to add proprietary instructions to accelerate performance/power consumption critical spots.

N25/N25F's 5-stage pipeline is optimized for high operating frequency and small gate count. Features also includes PLIC and vectored interrupts for serving various types of system events, AXI 64-bit or AHB 64/32-bit bus, PowerBrake and WFI mode for low power and power management, and JTAG debug interface for development support.

**Table 2-1 Gowin RiscV A/N25**

| Gowin RiscV A/N25   |                                           |
|---------------------|-------------------------------------------|
| IP Core Application |                                           |
| Device Support      | GW1N、GW1NR、GW2A、GW2AR Series              |
| Logic Resource      | Ref.Table 3-1 Gowin RiscV A/N25 Resources |
| Delivery            |                                           |
| Design Kit          | Verilog (encrypted)                       |
| Reference Design    | Verilog                                   |
| TestBench           | ---                                       |
| Verification        |                                           |
| Synthesis           | Synplify_Pro                              |
| IDE                 | GoWinYunYuan                              |

# 3 Features and Performance

## 3.1 Performance

- AndeStar™ V5 Instruction Set Architecture (ISA), compliant to RISC-V technology
- Floating point extensions (N25F)
- Andes extensions, architected for performance and functionality enhancements
- Separately licensable Andes Custom Extension™ (ACE) for customized acceleration
- 32-bit, 5-stage pipeline CPU architecture 16/32-bit mixable instruction format for compacting code density
- Branch predication to speed up control code
- Return Address Stack (RAS) to speed up procedure returns
- Physical Memory Protection (PMP)
- Flexibly configurable Platform-Level Interrupt Controller (PLIC) for supporting wide range of system event scenarios
- Enhancement of vectored interrupt handling for real-time performance
- Advanced CoDense™ technology to reduce program code size

## 3.2 Resources

RTL code is realized by Verilog language。Performance and resource utilization may vary depending on the density, speed, and grade of devices used.

Take Gowin GW2A-18 series FPGA as an example. The resource utilization is shown in Table 3-1. For application verification on other Gowin FPGA, please pay attention to the information released later.

**Table 3-1 Gowin RiscV A/N25 Resources**

| Device  | Speed Grade | Resources | Usage | Remarks |
|---------|-------------|-----------|-------|---------|
| GW2A-18 | -5          | LUT       | 10K   |         |
|         |             | ALU       | 4K    |         |
|         |             | REG       | 6K    |         |
|         |             | BSRAM     | 0-max |         |

## 3.3 The Clock Frequency

This IP uses no special requirements; 2A18 chip in the default conditions can run at 50MHz.

# 4 CPU Core Overview

## 4.1 N25(F) Processor Features

The N25(F) processor features are:

### CPU Core

- 5-stage in-order execution pipeline
- Hardware multiplier
  - radix-2/radix-4/radix-16/radix-256/fast
- Hardware divider
- Optional branch prediction
  - Static branch prediction, or
    - \* 4-entry return address stack (RAS)
  - Dynamic branch prediction:
    - \* 32/64/128/256-entry branch target buffer (BTB)
    - \* 256-entry branch history table
    - \* 8-bit global branch history
    - \* 4-entry return address stack (RAS)
- Machine mode and optional User mode
- Optional performance monitors
- Misaligned memory access
- RISC-V physical memory protection

### AndeStar V5 ISA

- RISC-V RV32I base integer instruction set
- RISC-V RVC standard extension for compressed instructions
- RISC-V RVM standard extension for integer multiplication and division
- Optional RISC-V RVA standard extension for atomic instructions
- Optional RISC-V F and D single/double precision floating point
- Andes Performance extension
- Andes CoDense™ extension

### AndeStar Custom Extension

- Instruction encoding space up to 25 bits
- Concise Verilog description for RTL design
- Operands from existing GPR and memory

- Operands from ACE registers (ACR) and ACE memories (ACM)
- Single-/multi-cycle instructions
- Vector instructions
- Background instructions
- Custom error status
- Block-level self-checking verification environment with Standard Universal Verification Methodology (UVM)
- Andes half precision load/store extension

### Memory Subsystem

- I & D caches
  - Cache size: 8KiB/16KiB/32KiB/64KiB
  - Cache line size: 32B
  - Set associativity: Direct-mapped/2-way/4-way
  - Custom cache control operation through CSR read/write
- I & D local memories
  - Size: 4KiB to 16MiB
  - Optional local memory slave port
  - Interface: RAM or AHB-Lite
- Memory subsystem soft-error protection
  - Protection scheme: parity-checking or error-checking-and-correction (ECC)
  - Automatic hardware error correction
  - Protected memories:
    - \* I & D cache tag RAM and data RAM
    - \* I & D local memories

### Bus

- Interface Protocol
  - Synchronous AHB (32-bit/64-bit data width), or
  - Synchronous AXI4 (64-bit data width)

### Power Management

- Wait-for-interrupt (WFI) mode

### Debug

- RISC-V External Debug Support Version 0.13
- Configurable number of breakpoints: 2/4/8
- External debug module with AHB interfaces
- External JTAG debug transport module
  - JTAG: IEEE Std 1149.1 style 4-wire JTAG interface

### Trace

- Optional instruction trace

### AndeStar Extension

- StackSafe hardware stack protection extension
- PowerBrake simple power/performance scaling extension
- Custom performance counter events

### Platform-Level Interrupt Controller (PLIC)

- AHB interface

- Configurable number of interrupts: 1–1023
- Configurable number of interrupt priorities: 3/7/15/31/63/127/255
- Configurable number of targets: 1–16
- Andes Vectored Interrupt extension

## 4.2 Block Diagram

Figure 4-1 N25 (F) Block Diagram



## 4.3 Major Components

The following list describes the major components of the N25(F) processor:

Table 4-1 Major Components

|         |                                     |
|---------|-------------------------------------|
| IPIPE   | Integer Pipeline                    |
| RF      | Register File                       |
| CSR     | Control and Status Register         |
| ALU     | Arithmetic Logic Unit               |
| MDU     | Multiplication and Division Unit    |
| FASTMUL | Fast Multiplier                     |
| IFU     | Instruction Fetch Unit              |
| ICU     | Instruction Cache Unit              |
| LSU     | Load Store Unit                     |
| DCU     | Data Cache Unit                     |
| ILM     | Instruction Local Memory Controller |
| DLM     | Data Local Memory Controller        |
| BIU     | Bus Interface Unit                  |

|       |                        |
|-------|------------------------|
| MMU   | Memory Manager Unit    |
| TRIGM | Trigger Module         |
| FPU   | Floating Point Unit    |
| ACE   | Andes Custom Extension |

## 4.4 Pipeline Stages and Activities

N25(F) implements a five-stage pipeline architecture. The following figure shows the pipeline stages of the processor.

Figure 4-2 Pipeline Stages and Activities



The pipeline activities of the corresponding stages are:

IF—Instruction Fetch

- Fetching an instruction word from ILM/Instruction Cache/Bus
- Dynamic branch prediction

II—Instruction Decode and Issue

- 16/32-bit instruction alignment
- Instruction decoding
- Register file read
- Resolving data dependency
- Static branch prediction

EX—Instruction Execution

- ALU instruction execution
- Load/Store address generation

MM—Memory Access

- DLM/Data Cache access
- Division instruction execution
- Multiplication instruction execution
- Branch resolution

WB—Instruction Retire and Result Write-Back

- Interrupt resolution
- Instruction retire
- Register file write back
- ILM access
- Bus access
- ACE instruction execution

FRF—FPU Instruction Decode

- Instruction decoding
- Register file read

### F1~F4 – FPU Instruction Execution

- Float-point arithmetic execution
- Data Exchange between Integer/FPU pipelines

## 4.5 Design Hierarchy

### 4.5.1 AHB Platform

The design hierarchy of N25(F) is illustrated in Figure 4-3 Design Hierarchy. The top of N25(F) processor design is n25\_core. The n25\_core design does not include any SRAM cells. All of the required SRAM cells are expected to be instantiated outside of n25\_core to simplify the integration effort.

The ae250\_chip module is a reference AHB platform that instantiates the N25(F) processor. The ae250\_cpu\_subsystem module is a reference subsystem that instantiates all the required memory modules. These two modules are open for modification to meet system requirements.

To support all bus interface configs of the processor, ae250\_cpu\_subsystem contains several optional adapter modules. The ae250\_cpu\_to\_ahb module converts the AXI interface to the AHB interface. It is only present when the type of the N25(F) bus interface is AXI. The ae250\_cpu\_to\_ahb32 module converts the 64-bit AHB interface to the 32-bit AHB interface. It is an optional module and could be removed when the type of the N25(F) bus interface is 32-bit AHB. The ae250\_slv\_to\_lm module contains glue logics connected to the slave port of N25(F).

When ACE is configured, SRAMs for SRAM-ACMs are expected to be instantiated outside of n25\_core, like the rest of SRAM cells; and AHB-ACMs are expected to connect to the main system bus or secondary buses depending on platform requirements.

The ae250\_debug\_subsystem, nceplmt100, and nceplic100 modules are platform IPs as specified in the RISC-V architecture for proper operation of a RISC-V system. The ae250\_debug\_subsystem module implements the debug functionality. nceplmt100 implements the RISC-V machine timer, and nceplic100 implements the RISC-V platform interrupt controller (PLIC).

The PLIC module is instantiated twice, one (u\_plic) for arbitrating interrupts from peripheral devices, and the other (u\_plic\_sw) for supporting software interrupts. The u\_plic\_sw instantiation only needs to use the programmability of the PLIC registers to generate (software programmable) interrupts, so all its interrupt sources are tied to zero.

The atcbmc200, atcspi200, ae250\_smu, atcrc100, atcapbbrg100, atcwdt200, atciic100, atcpit100, atcuart100, and atcgpio100 modules are pre-integrated Andes platform/peripheral IPs that may be shipped together with the N25(F) package, depending on licensing agreements.

**Figure 4-3 Design Hierarchy**

# 5 Processor Configuration Options

The configuration of the N25 (F) processor is through a config tool and Verilog parameters.

## 5.1 Configuration Tool

Figure 5-1 Configuration Tool GUI



### Note !

The screenshot only serves to show how the tool *looks like* to facilitate the description above. It is not a goal for this figure to show the most updated version of the tool. The actual content of the tool may differ slightly as the tool gets updated with new features added to N25(F).

### 5.1.1 RISC-V Atomic Instruction Extension

Specifying this option to "yes" enables the RISC-V "A" Standard Extension for Atomic Instructions(RVA). RVA includes instructions that atomically read-modify-write memories for synchronization between multiple hardware threads (harts).

### 5.1.2 RISC-V Floating-Point Instruction Extension

This option determines the floating-point extension type.

- none: no floating-point extension
- single precision: "F" standard extension for single precision floating-point instruction
- double+single precision: "F" and "D" standard extension for single and double precision floatingpoint instruction

**Note !**

The floating-point extension is available depending on N25(F) licensing agreements.

### 5.1.3 Privilege Modes

The option determines the number of supported privileges levels. The N25(F) processor supports 1or 2 privilege levels

**Table 5-1 Supported Combination of Privilege Modes**

| Number of Levels | Supported Modes | Intended Usage          |
|------------------|-----------------|-------------------------|
| 1                | Machine         | Simple embedded systems |
| 2                | Machine, User   | Secure embedded systems |

The RISC-V privilege architecture specifies four privilege levels as shown in Table 4. Machine mode (M-mode) has the highest privileges and is the mandatory privilege level for a RISC-V hardware platform. User mode (U-mode) restricts privileges to protect against incorrect or malicious application codes. And Supervisor mode (S-mode) is provided for Unix-like operating systems with address translating and protection requirements.

### 5.1.4 Performance Monitors

Specifying this option to "yes" enables hardware performance monitors, including mcycle and minstret Control and Status Registers (CSR). The mcycle register counts the elapsed clock cycles while the minstret register counts the number of retired instructions.

### 5.1.5 Bus Interface Unit

The bus interface unit (BIU) is responsible for system bus accesses of N25(F).

The Bus Data Width option determines the value of parameter BIU\_DATA\_WIDTH. N25(F) supportsthe following system bus data widths:

- AHB bus protocol with 32-bit data width (BIU\_DATA\_WIDTH = 32)

- AHB bus protocol with 64-bit data width (BIU\_DATA\_WIDTH = 64)

- AXI4 bus protocol with 64-bit data width (BIU\_DATA\_WIDTH = 64)

The Low Access-Latency AHB Bus option reduces the system bus access latency at the expense of maximum frequency (around 70% of configurations without this option). This option is expected to be used under configurations where there are no caches.

## 5.1.6 Hardware Multiplier

This option selects the implementation of the hardware multiplier in N25(F). Valid values and their respective performance are:

- radix2: 1-bit/cycle
- radix4: 2-bit/cycle
- radix16: 4-bit/cycle
- radix256: 8-bit/cycle
- fast: two-stage pipelined.

The radix multiplier options realize the multiplier through serial additions, while the fast multiplier option implements a two-stage pipelined parallel multiplier.

## 5.1.7 Branch Prediction

This option selects the branch prediction scheme. The N25(F) processor supports both static and dynamic branch prediction, and the number of BTB entries is configurable.

The static branch prediction algorithm predicts that all backward branches will be taken and all forward branches will not.

The dynamic branch prediction algorithm uses a 2-way branch target buffer (BTB) and a branch history table to predict the target address and direction (taken/not-taken) of each branch.

## 5.1.8 Physical Memory Protection

The Physical Memory Protection Entries option selects the number of supported PMP entries.

## 5.1.9 Local Memory Interface

N25(F) supports two local memory interfaces:

- ram: for connecting to memory devices without wait states
- ahb-lite: for connecting to AHB-lite slaves.

Please note that local memory soft-error protection and the Slave Port support are only available when the interface type is "ram".

## 5.1.10 Instruction Local Memory

The ILM Size option selects the size of the instruction local memory in KiB. Only power-of-2 sizes are supported. Specifying 0 to the option

unconfigures the instruction local memory.

ILM\_BASE is a Verilog parameter for specifying the base address of the instruction local memory, and it must be aligned to the size of the instruction local memory.

ILM Soft Error Protection option selects the soft-error protection scheme for the instruction local memory:

- none: no protection
- parity: single-error detection
- ecc: single-error correction, and double-error detection

### 5.1.11 Data Local Memory (DLM)

The DLM Size option selects the size of the data local memory in KiB. Only power-of-2 sizes are supported. Specifying 0 to DLM\_SIZE\_KB unconfigures the data local memory.

DLM\_BASE is a Verilog parameter for specifying the base address of the data local memory, and it must be aligned to the size of the data local memory.

DLM Soft Error Protection option selects the soft-error protection scheme for the data local memory:

- none: no protection
- parity: single-error detection
- ecc: single-error correction, and double-error detection

### 5.1.12 Slave Port Support

Specifying this option to "yes" enables the local memory slave port. The local memory slave port enables bus masters to access the local memories of N25(F).

The interface protocol is AHB, and the data width is identical to bus data width. The value of parameter SLAVE\_PORT\_DATA\_WIDTH is identical to the value of parameter BIU\_DATA\_WIDTH.

### 5.1.13 Instruction Cache

The I-Cache Size option selects the size of the instruction cache in KiB. Only power-of-2 sizes are supported. Specifying 0 to the option unconfigures the instruction cache.

The I-Cache Replacement Policy option selects the replacement policy of instruction cache on cache misses.

The I-Cache Associativity option selects the associativity of instruction cache.

The I-Cache Soft Error Protection option selects the soft-error protection scheme for the instruction cache:

- none: no protection
- parity: single-error correction
- ecc: single-error and double-error correction

### 5.1.14 Data Cache

The D-Cache Size option selects the size of the data cache in KiB. Only power-of-2 sizes are supported.

Specifying 0 to the option unconfigures the data cache.

The D-Cache Replacement Policy option selects the replacement policy of data cache when cache miss.

The D-Cache Associativity option selects the associativity of data cache.

The D-Cache Soft Error Protection option selects the soft-error protection scheme for the data cache:

- none: no protection
- parity: single-error detection
- ecc: single-error correction, and double-error detection

### 5.1.15 Debug Support

Specifying this option to "yes" enables debug support. The Number of Trigger option selects the number of hardware breakpoints.

### 5.1.16 Trace Interface

Specifying this option to "instruction" enables instruction trace interface.

### 5.1.17 Andes Vectored PLIC Extension

Specifying this option to "yes" enables the Andes Vectored PLIC extension for reducing interrupt latency.

### 5.1.18 Andes StackSafe Extension

Specifying this option to "yes" enables the StackSafe hardware stack protection extension.

The extension is a hardware mechanism for tracking and guarding against the stack pointer overflows/underflows.

### 5.1.19 Andes PowerBrake Extension

Specifying this option to "yes" enables the PowerBrake power/performance scaling extension.

The PowerBrake extension throttles performance by reducing instruction executing rate instead of slowing down clock frequency. The performance and hence power consumption can be switched to a different level in a couple of instructions. This is an ultra-low latency mechanism for performance & power scaling, as compared to the latencies of frequency scaling through PLL programming.

### 5.1.20 Andes Custom Extension

Specifying this option to "yes" enables the custom instruction extension.

The Andes Custom Extension (ACE) feature provides a simple and flexible interface to extend new instructions. Please see AndeStar Custom Extension Specification (CUM009) and AndeStar Custom Extension User Manual (CUM006) for more information.

## 5.2 Configuration Parameters

### 5.2.1 Device Regions

Device regions are memory locations where accesses to the location may cause side effects. Accesses to device regions are non-cacheable and strong-ordered. Memory operations to these regions will be conservative without the need of excessive FENCE instructions. At most eight device regions could be specified in N25(F). A device region n ( $n = 0\text{--}7$ ) is specified by two parameters:

- DEVICE\_REGIONn\_BASE: the base address of the region,
- DEVICE\_REGIONn\_MASK: the address mask of the region.

An address is inside a region when:

$(\text{address} \& \text{DEVICE\_REGIONn\_MASK}) == \text{DEVICE\_REGIONn\_BASE}$ .

A device region can be disabled by setting DEVICE\_REGIONn\_BASE to all ones and DEVICE\_REGIONn\_MASK to all zeros.

Device regions and ILM/DLM/WRITETHROUGH should not overlap with each other. The behavior is undefined when device regions are overlapped with ILM/DLM/WRITETHROUGH.

Write-through Regions

### 5.2.2 Write-through Regions

Write-through regions are memory locations where memory writes will update both D-Cache and the system memory with write-no-allocate policy.

At most eight write-through regions could be specified. A write-through region n ( $n = 0\text{--}7$ ) is specified by two parameters:

- WRITETHROUGH\_REGIONn\_BASE: the base address of the region,
- WRITETHROUGH\_REGIONn\_MASK: the address mask of the region.

An address is inside a region when:

$(\text{address} \& \text{WRITETHROUGH\_REGIONn\_MASK}) == \text{WRITETHROUGH\_REGIONn\_BASE}$ .

A write-through region can be disabled by setting WRITETHROUGH\_REGIONn\_BASE to all ones and WRITETHROUGH\_REGIONn\_MASK to all zeros.

Write-through regions and ILM/DLM/DEVICE regions should not

overlap with each other. The behavior is undefined when write-through regions are overlapped with ILM/DLM/DEVICE regions.

### 5.2.3 DEBUG\_VEC

DEBUG\_VEC defines the entry point address of the exception handler for servicing debug exceptions in the debug mode. It should be set to the address of the Debug ROM of the NCEPLDM200 debug module, which is also the base address of the module. This address space should be a device region for proper operation of the external debug support. See **NCEPLDM200** for more information.

The AE250 memory map assigns the base address of NCEPLDM200 to 0xe68000000.

# 6 Signals Description

The interface ports of the N25(F) core are described in this section. All signals are Active-High unless otherwise indicated.

## 6.1 General Signals

Table 6-1 General Signals

| Signal Name               | Direction | Description                                                                                                                                                                   |
|---------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>hart_id</b>            | input     | This signal indicates the CPU hart ID. Hart IDs might not necessarily be numbered contiguously in a multiprocessor system, but at least one hart must have a hart ID of zero. |
| <b>core_reset_n</b>       | input     | CPU reset (Active-Low)                                                                                                                                                        |
| <b>core_clk</b>           | input     | CPU clock input                                                                                                                                                               |
| <b>reset_vector[31:0]</b> | input     | Default program counter value upon reset. It should normally be a 4-byte aligned value but 2-byte aligned value is also allowed; bit 0 of this input signal should be zero.   |
| <b>bus_clk_en</b>         | input     | This is a core_clk clock domain signal indicating that the data from the bus clock domain can be sampled at the coming rising edge of core_clk.                               |
| <b>core_wfi_mode</b>      | input     | This signal indicates that the processor is in the wait-for-interrupt mode.                                                                                                   |

## 6.2 Interrupt Signals

Table 6-2 Interrupt Signals

| Signal Name       | Direction | Description                                                          |
|-------------------|-----------|----------------------------------------------------------------------|
| <b>meip</b>       | output    | External interrupt acknowledgment, used in the vector interrupt mode |
| <b>meiid[9:0]</b> | input     | Timer interrupt pending                                              |
| <b>meiack</b>     | input     | Software interrupt pending                                           |
| <b>mtip</b>       | input     | Non-maskable interrupt                                               |

|             |       |                                            |
|-------------|-------|--------------------------------------------|
| <b>msip</b> | input | Supervisor-mode external interrupt pending |
| <b>nmi</b>  | input | Non-maskable interrupt                     |
| <b>seip</b> | input | Supervisor-mode external interrupt pending |

## 6.3 Debug Signals

Table 6-3 Debug Signals

| Signal Name             | Direction | Description                                                                                                                                                              |
|-------------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>debugint</b>         | output    | Debug interrupt                                                                                                                                                          |
| <b>hart_unavail</b>     | input     | This signal indicates that the processor is not available for accesses by the external debugger. The processor could be in the reset or some kind of power-gating state. |
| <b>hart_halted</b>      | input     | This signal indicates that the processor is halted.                                                                                                                      |
| <b>hart_under_reset</b> | input     | This signal indicates that the processor is under reset.                                                                                                                 |
| <b>stoptime</b>         | input     | This signal indicates that the processor is in Debug Mode and timers should stop counting. This signal is controllable by dcsr.STOPTIME.                                 |

## 6.4 Trace Signals

Table 6-4 Trace Signals

| Signal Name             | Direction | Description                                                                   |
|-------------------------|-----------|-------------------------------------------------------------------------------|
| <b>trace_invalid</b>    | output    | This signal indicates that an instruction has retired or trapped (exception). |
| <b>trace_iexception</b> | output    | This signal indicates that an instruction has trapped (exception).            |
| <b>trace_cause</b>      | output    | This signal indicates the cause of an exception                               |
| <b>trace_tval</b>       | output    | This signal indicates the exception data                                      |
| <b>trace_interrupt</b>  | output    | This signal indicates that the processor is under reset.                      |
| <b>trace_iaddr</b>      | output    | This signal indicates the cause of an exception                               |
| <b>trace_instr</b>      | output    | This signal indicates the instruction                                         |
| <b>trace_priv</b>       | output    | This signal indicates the privilege mode during execution                     |

## 6.5 AHB Interface Signals

AHB interface signals provide connectivity to the AHB system bus.

These signals are used only when BIU\_BUS is ahb. Otherwise, they are left unconnected. They are sampled/driven in the core\_clk domain on bus\_clk\_en pulses.

Table 6-5 AHB Interface Signals

| Signal Name                       | Direction | Description        |
|-----------------------------------|-----------|--------------------|
| <b>hgrant</b>                     | input     | Bus grant          |
| <b>hrdata[BIU_DATA_WIDTH-1:0]</b> | input     | Read data bus      |
| <b>hready</b>                     | input     | Transfer done      |
| <b>hresp[1:0]</b>                 | input     | Transfer response  |
| <b>haddr[31:0]</b>                | output    | Address bus        |
| <b>hburst[2:0]</b>                | output    | Burst type         |
| <b>hbusreq</b>                    | output    | Bus request        |
| <b>hlock</b>                      | output    | Locked transfer    |
| <b>hprot[3:0]</b>                 | output    | Protection control |
| <b>hsize[2:0]</b>                 | output    | Transfer size      |
| <b>htrans[1:0]</b>                | output    | Transfer type      |
| <b>hwdata[BIU_DATA_WIDTH-1:0]</b> | output    | Write data bus     |
| <b>hwrite</b>                     | output    | Transfer direction |

## 6.6 Instruction Local Memory Interface Signals

ILM interface signals provide connectivity to the Instruction Local Memory. Two interface types, ram and ahb-lite, could be configured through the Local Memory Interface. If the value of option is ram, SRAM style interface is configured. If the value is ahb-lite, the AHB-Lite interface will be used.

The SRAM style interface signals provide connectivity to the Instruction Local Memory RAM of the processor. These signals are present on the processor interface when ILM is configured and the ram type of Local Memory Interface is selected.

**Table 6-6 Instruction Local Memory Interface Signals**

| <b>Signal Name</b>        | <b>Direction</b> | <b>Description</b> |
|---------------------------|------------------|--------------------|
| ilm_cs                    | output           | Chip select        |
| ilm_byte_we[3:0]          | output           | Write enable       |
| ilm_addr[ILM_RAM_AW-1:0]  | output           | Address            |
| ilm_wdata[ILM_RAM_DW-1:0] | output           | Write data         |
| ilm_rdata[ILM_RAM_DW-1:0] | input            | Read data          |

**Table 6-7 Instruction Local Memory Address Bit-Width**

| <b>Size (KiB)</b> | <b>ILM_RAM_AW</b> |
|-------------------|-------------------|
| 4                 | 10                |
| 8                 | 11                |
| 16                | 12                |
| 32                | 13                |
| 64                | 14                |
| 128               | 15                |
| 256               | 16                |
| 512               | 17                |
| 1024              | 18                |
| 2048              | 19                |
| 4096              | 20                |
| 8192              | 21                |
| 16384             | 22                |

**Table 6-8 Instruction Local Memory Data Bit-Width**

| <b>Protection Scheme</b> | <b>ILM_RAM_DW</b> |
|--------------------------|-------------------|
| none                     | 32                |
| parity                   | 36                |
| ecc                      | 39                |

**Table 6-9 ILM Byte Write Enable Mapping**

| <b>BWE Bit</b> | <b>Protection Scheme: none</b> | <b>Protection Scheme: parity</b> | <b>Protection Scheme: ecc</b> |
|----------------|--------------------------------|----------------------------------|-------------------------------|
| 0              | wdata[7:0]                     | {wdata[32], wdata[7:0]}          | wdata[38:0]                   |
| 1              | wdata[15:8]                    | {wdata[33], wdata[15:8]}         | wdata[38:0]                   |
| 2              | wdata[23:16]                   | {wdata[34], wdata[23:16]}        | wdata[38:0]                   |
| 3              | wdata[31:24]                   | {wdata[35], wdata[31:24]}        | wdata[38:0]                   |

## 6.7 Data Local Memory Interface Signals

DLM interface signals provide connectivity to the DATA Local Memory. Two interface types, ram and ahb-lite, could be configured through the

Local Memory Interface. If the value of option is ram, SRAM style interface is configured. If the value is ahb-lite, the AHB-Lite interface will be used.

The SRAM style interface signals provide connectivity to the Instruction Local Memory RAM of the processor. These signals are present on the processor interface when DLM is configured and the ram type of Local Memory Interface is selected.

**Table 6-10 Data Local Memory Interface Signals**

| Signal Name               | Direction | Description  |
|---------------------------|-----------|--------------|
| dlm_cs                    | output    | Chip select  |
| dlm_byte_we[3:0]          | output    | Write enable |
| dlm_addr[DLM_RAM_AW-1:0]  | output    | Address      |
| dlm_wdata[DLM_RAM_DW-1:0] | output    | Write data   |
| dlm_rdata[DLM_RAM_DW-1:0] | input     | Read data    |

**Table 6-11 Data Local Memory Address Bit-Width**

| <b>Size (KiB)</b> | <b>DLM_RAM_AW</b> |
|-------------------|-------------------|
| 4                 | 10                |
| 8                 | 11                |
| 16                | 12                |
| 32                | 13                |
| 64                | 14                |
| 128               | 15                |
| 256               | 16                |
| 512               | 17                |
| 1024              | 18                |
| 2048              | 19                |
| 4096              | 20                |
| 8192              | 21                |
| 16384             | 22                |

**Table 6-12 Data Local Memory Data Bit-Width**

| <b>Protection Scheme</b> | <b>DLM_RAM_DW</b> |
|--------------------------|-------------------|
| none                     | 32                |
| parity                   | 36                |
| ecc                      | 39                |

**Table 6-13 DLM Byte Write Enable Mapping**

| <b>BWE Bit</b> | <b>Protection Scheme: none</b> | <b>Protection Scheme: parity</b> | <b>Protection Scheme: ecc</b> |
|----------------|--------------------------------|----------------------------------|-------------------------------|
| 0              | wdata[7:0]                     | {wdata[32], wdata[7:0]}          | wdata[38:0]                   |
| 1              | wdata[15:8]                    | {wdata[33], wdata[15:8]}         | wdata[38:0]                   |
| 2              | wdata[23:16]                   | {wdata[34], wdata[23:16]}        | wdata[38:0]                   |
| 3              | wdata[31:24]                   | {wdata[35], wdata[31:24]}        | wdata[38:0]                   |

## 6.8 Instruction Cache Interface Signals

I-Cache interface signals provide connectivity to the I-Cache SRAMs of the processor. These signals are always present on the processor interface but they are used only when I-Cache is configured. Otherwise, they are left unconnected.

**Table 6-14 Instruction Cache Interface Signals**

| <b>Signal Name</b>                         | <b>Direction</b> | <b>Description</b>                                                                                                                                                                                                          |
|--------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| icache_disable_init                        | input            | Disable the initialization of I-Cache RAMs when the processor is out of reset.<br>Assertion of this signal is to speed up the power-gating wake up process when the content of I-Cache SRAM is preserved during power-down. |
| icache_tagN_cs                             | output           | Chip select, $N=0, 1, 2, 3$                                                                                                                                                                                                 |
| icache_tagN_we                             | output           | Write enable                                                                                                                                                                                                                |
| icache_tagN_addr[ICACHE_TAG_RAM_AW-1:0]    | output           | Address                                                                                                                                                                                                                     |
| icache_tagN_wdata[ICACHE_TAG_RAM_DW-1:0]   | output           | Write data                                                                                                                                                                                                                  |
| icache_tagN_rdata[ICACHE_TAG_RAM_DW-1:0]   | input            | Read data                                                                                                                                                                                                                   |
| icache_dataN_cs                            | output           | Chip select, $N=0, 1, 2, 3$                                                                                                                                                                                                 |
| icache_dataN_we                            | output           | Write enable                                                                                                                                                                                                                |
| icache_dataN_addr[ICACHE_DATA_RAM_AW-1:0]  | output           | Address                                                                                                                                                                                                                     |
| icache_dataN_wdata[ICACHE_DATA_RAM_DW-1:0] | output           | Write data                                                                                                                                                                                                                  |
| icache_dataN_rdata[ICACHE_DATA_RAM_DW-1:0] | input            | Read data                                                                                                                                                                                                                   |

**Table 6-15 I-Cache Tag Address Bit-Width**

| <b>Associativity</b> | <b>Size (KiB)</b> | <b>ICACHE_TAG_AW</b> |
|----------------------|-------------------|----------------------|
| 1                    | 8                 | 8                    |
|                      | 16                | 9                    |
|                      | 32                | 10                   |
|                      | 64                | 11                   |
| 2                    | 8                 | 7                    |
|                      | 16                | 8                    |
| 4                    | 32                | 9                    |
|                      | 64                | 10                   |
|                      | 8                 | 6                    |
|                      | 16                | 7                    |
| 8                    | 32                | 8                    |
|                      | 64                | 9                    |

**Table 6-16 I-Cache Tag Data Bit-Width**

| <b>Protection Scheme</b> | <b>Associativity</b> | <b>Size (KiB)</b> | <b>ICACHE_TAG_RAM_DW</b> |
|--------------------------|----------------------|-------------------|--------------------------|
| none                     | 1                    | 8                 | 23                       |
|                          |                      | 16                | 23                       |
|                          |                      | 32                | 23                       |
|                          |                      | 64                | 23                       |
|                          | 2                    | 8                 | 23                       |
|                          |                      | 16                | 23                       |
|                          |                      | 32                | 23                       |
|                          |                      | 64                | 23                       |
|                          | 4                    | 8                 | 24                       |
|                          |                      | 16                | 23                       |
|                          |                      | 32                | 23                       |
|                          |                      | 64                | 23                       |
|                          | parity               | 8                 | 27                       |
|                          |                      | 16                | 27                       |
|                          |                      | 32                | 27                       |
|                          |                      | 64                | 27                       |
|                          | 2                    | 8                 | 27                       |
|                          |                      | 16                | 27                       |
|                          |                      | 32                | 27                       |
|                          |                      | 64                | 27                       |
|                          | 4                    | 8                 | 28                       |
|                          |                      | 16                | 27                       |
|                          |                      | 32                | 27                       |
|                          |                      | 64                | 27                       |



| Protection Scheme | Associativity | Size (KiB) | ICACHE_TAG_RAM_DW |
|-------------------|---------------|------------|-------------------|
| ecc               | 1             | 8          | 30                |
|                   |               | 16         | 30                |
|                   |               | 32         | 30                |
|                   |               | 64         | 30                |
|                   |               | 8          | 30                |
|                   |               | 16         | 30                |
|                   |               | 32         | 30                |
|                   |               | 64         | 30                |
|                   |               | 8          | 31                |
|                   |               | 16         | 30                |
|                   | 4             | 32         | 30                |
|                   |               | 64         | 30                |
|                   |               | 8          | 31                |
|                   |               | 16         | 30                |
|                   | 2             | 32         | 30                |
|                   |               | 64         | 30                |
|                   |               | 8          | 10                |
|                   |               | 16         | 11                |
|                   | 4             | 32         | 12                |
|                   |               | 64         | 13                |
|                   |               | 8          | 9                 |
|                   |               | 16         | 10                |
|                   | 2             | 32         | 11                |
|                   |               | 64         | 12                |

Table 6-17 I-Cache Data Address Bit-Width

| Associativity | Size (KiB) | ICACHE_DATA_AW |
|---------------|------------|----------------|
| 1             | 8          | 11             |
|               | 16         | 12             |
|               | 32         | 13             |
|               | 64         | 14             |
| 2             | 8          | 10             |
|               | 16         | 11             |
|               | 32         | 12             |
|               | 64         | 13             |
| 4             | 8          | 9              |
|               | 16         | 10             |
|               | 32         | 11             |
|               | 64         | 12             |

## 6.9 Data Cache Interface Signals

D-Cache interface signals provide connectivity to D-Cache SRAMs of the processor. These signals are always present on the processor interface but they are used only when D-Cache is configured. Otherwise, they are left unconnected.

**Table 6-18 Data Cache Interface Signals**

| <b>Signal Name</b>                         | <b>Direction</b> | <b>Description</b>                                                                                                                                                                                                       |
|--------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dcache_disable_init                        | input            | Disable the initialization of D-Cache RAMs when the processor is out of reset. Assertion of this signal is to speed up the power-gating wake up process when the content of D-Cache SRAM is preserved during power-down. |
| dcache_tagN_cs                             | output           | Chip select, $N=0, 1, 2, 3$                                                                                                                                                                                              |
| dcache_tagN_we                             | output           | Write enable                                                                                                                                                                                                             |
| dcache_tagN_addr[DCACHE_TAG_RAM_AW-1:0]    | output           | Address                                                                                                                                                                                                                  |
| dcache_tagN_wdata[DCACHE_TAG_RAM_DW-1:0]   | output           | Write data                                                                                                                                                                                                               |
| dcache_tagN_rdata[DCACHE_TAG_RAM_DW-1:0]   | input            | Read data                                                                                                                                                                                                                |
| dcache_dataN_cs                            | output           | Chip select, $N=0, 1, 2, 3$                                                                                                                                                                                              |
| dcache_dataN_we[DCACHE_DATA_RAM_BWEW-1:0]  | output           | Write enable                                                                                                                                                                                                             |
| dcache_dataN_addr[DCACHE_DATA_RAM_AW-1:0]  | output           | Address                                                                                                                                                                                                                  |
| dcache_dataN_wdata[DCACHE_DATA_RAM_DW-1:0] | output           | Write data                                                                                                                                                                                                               |
| dcache_dataN_rdata[DCACHE_DATA_RAM_DW-1:0] | input            | Read data                                                                                                                                                                                                                |

**Table 6-19D-Cache Tag Address Bit-Width**

| <b>Associativity</b> | <b>Size (KiB)</b> | <b>DCACHE_TAG_AW</b> |
|----------------------|-------------------|----------------------|
| 1                    | 8                 | 8                    |
|                      | 16                | 9                    |
|                      | 32                | 10                   |
|                      | 64                | 11                   |
| 2                    | 8                 | 7                    |
|                      | 16                | 8                    |
| 4                    | 32                | 9                    |
|                      | 64                | 10                   |
|                      | 8                 | 6                    |
|                      | 16                | 7                    |
|                      | 32                | 8                    |
|                      | 64                | 9                    |

**Table 6-20D-Cache Tag Data Bit-Width**

| <b>Protection Scheme</b> | <b>Associativity</b> | <b>Size (KiB)</b> | <b>DCACHE_TAG_RAM_DW</b> |
|--------------------------|----------------------|-------------------|--------------------------|
| none                     | 1                    | 8                 | 22                       |
|                          |                      | 16                | 21                       |
|                          |                      | 32                | 20                       |
|                          |                      | 64                | 19                       |
|                          | 2                    | 8                 | 23                       |
|                          |                      | 16                | 22                       |
|                          |                      | 32                | 21                       |
|                          |                      | 64                | 20                       |
|                          | 4                    | 8                 | 24                       |
|                          |                      | 16                | 23                       |
|                          |                      | 32                | 22                       |
|                          |                      | 64                | 21                       |
| parity                   | 1                    | 8                 | 26                       |
|                          |                      | 16                | 25                       |
|                          |                      | 32                | 24                       |
|                          |                      | 64                | 23                       |
|                          | 2                    | 8                 | 27                       |
|                          |                      | 16                | 26                       |
|                          |                      | 32                | 25                       |
|                          |                      | 64                | 24                       |
|                          | 4                    | 8                 | 28                       |
|                          |                      | 16                | 27                       |
|                          |                      | 32                | 26                       |
|                          |                      | 64                | 25                       |

|     |   |    |    |
|-----|---|----|----|
| ecc | 1 | 8  | 29 |
|     |   | 16 | 28 |
|     |   | 32 | 27 |
|     |   | 64 | 26 |
|     |   | 8  | 30 |
|     |   | 16 | 29 |
|     |   | 32 | 28 |
|     |   | 64 | 27 |
|     | 4 | 8  | 31 |
|     |   | 16 | 30 |

**Table 6-21 D-Cache Data Address Bit-Width**

| <b>Associativity</b> | <b>Size (KiB)</b> | <b>DCACHE_DATA_AW</b> |
|----------------------|-------------------|-----------------------|
| 1                    | 8                 | 11                    |
|                      | 16                | 12                    |
|                      | 32                | 13                    |
|                      | 64                | 14                    |
| 2                    | 8                 | 10                    |
|                      | 16                | 11                    |
|                      | 32                | 12                    |
|                      | 64                | 13                    |
| 4                    | 8                 | 9                     |
|                      | 16                | 10                    |
|                      | 32                | 11                    |
|                      | 64                | 12                    |

**Table 6-22 D-Cache Data Bit-Width**

| <b>Protection Scheme</b> | <b>DCACHE_DATA_RAM_DW</b> | <b>DCACHE_DATA_RAM_BWEW</b> |
|--------------------------|---------------------------|-----------------------------|
| none                     | 32                        | 4                           |
| parity                   | 36                        | 4                           |
| ecc                      | 39                        | 4                           |

**Table 6-23 D-Cache Byte Write Enable Mapping**

| <b>BWE Bit</b> | <b>Protection Scheme: none</b> | <b>Protection Scheme: parity</b> | <b>Protection Scheme: ecc</b> |
|----------------|--------------------------------|----------------------------------|-------------------------------|
| 0              | wdata[7:0]                     | {wdata[32], wdata[7:0]}          | wdata[38:0]                   |
| 1              | wdata[15:8]                    | {wdata[33], wdata[15:8]}         | wdata[38:0]                   |
| 2              | wdata[23:16]                   | {wdata[34], wdata[23:16]}        | wdata[38:0]                   |
| 3              | wdata[31:24]                   | {wdata[35], wdata[31:24]}        | wdata[38:0]                   |

## 6.10 AHB Slave Port Signals

The AHB Slave Port signals allows external agents to access the local memories of the processor through the AHB interface protocol. These signals are always present on the processor interface but they are used only when SLAVE\_PORT\_SUPPORT is yes. Otherwise, they are left unconnected. They are sampled/driven in the core\_clk domain on bus\_clk\_en pulses.

**Table 6-24 AHB Slave Port Signals**

| Signal Name                           | Direction | Description                   |
|---------------------------------------|-----------|-------------------------------|
| slv_hsel                              | input     | Bus grant                     |
| slv_huser                             | input     | Select ILM/DLM (0:ILM, 1:DLM) |
| slv_hready                            | input     | Ready in                      |
| slv_hreadyout                         | output    | Ready out                     |
| slv_haddr[31:0]                       | input     | Address bus                   |
| slv_hburst[2:0]                       | input     | Burst type                    |
| slv_hprot[3:0]                        | input     | Protection control            |
| slv_hsize[2:0]                        | input     | Transfer size                 |
| slv_htrans[1:0]                       | input     | Transfer type                 |
| slv_hwrite                            | input     | Transfer direction            |
| slv_hwdata[SLAVE_PORT_DATA_WIDTH-1:0] | input     | Write data bus                |
| slv_hrdata[SLAVE_PORT_DATA_WIDTH-1:0] | output    | Read data bus                 |
| slv_hresp[1:0]                        | output    | Transfer response             |

## 6.11 BTB Interface Signals

BTB interface signals provide connectivity to the BTB SRAMs of the processor. These signals are always present on the process interface but they are used only when BTB is configured. Otherwise, they are left unconnected. BTB in N25(F) is 2-way associative.

**Table 6-25 BTB Memory Interface Signals**

| <b>Signal Name</b>                | <b>Direction</b> | <b>Description</b>                                       |
|-----------------------------------|------------------|----------------------------------------------------------|
| btb0_cs                           | output           | Chip select for BTB memory 0<br>0: disable<br>1: enable  |
| btb0_we                           | output           | Write enable for BTB memory 0<br>0: disable<br>1: enable |
| btb0_addr[BTB_RAM_ADDR_WIDTH-1:0] | output           | Address for BTB memory 0                                 |
| btb0_wdata[37:0]                  | output           | Write data for BTB memory 0                              |
| btb0_rdata[37:0]                  | input            | Read data for BTB memory 0                               |
| btb1_cs                           | output           | Chip select for BTB memory 1<br>0: disable<br>1: enable  |
| btb1_we                           | output           | Write enable for BTB memory 1<br>0: disable<br>1: enable |
| btb1_addr[BTB_RAM_ADDR_WIDTH-1:0] | output           | Address for BTB memory 1                                 |
| btb1_wdata[37:0]                  | output           | Write data for BTB memory 1                              |
| btb1_rdata[37:0]                  | input            | Read data for BTB memory 1                               |

**Table 6-26 BTB RAM Address Bit-Width**

| <b>BTB Size</b> | <b>BTB_RAM_ADDR_WIDTH</b> | <b>RAM Dimension</b> |
|-----------------|---------------------------|----------------------|
| 32              | 4                         | 16 × 38              |
| 64              | 5                         | 32 × 38              |
| 128             | 6                         | 64 × 38              |
| 256             | 7                         | 128 × 38             |

# 7 Reset and Clocking Scheme

## 7.1 Reset

N25(F) only has one reset pin (`core_reset_n`) for resetting its only clock domain (`core_clk`). The reset signal should be synchronized to the `core_clk` clock domain before connecting to N25(F). Regarding the Andes Custom Instruction Extension feature, the ACE Engine is also reset by `core_reset_n` since it also operates in the `core_clk` clock domain.

In addition, to maintain proper reset ordering, the reset signal should only be released after the release of the reset signal to the bus clock domain, even though N25(F) does not take the reset signal to the bus clock domain as its input. Figure 7-1 Suggested Design for Reset Synchronization illustrates a reference design for reset synchronization.

**Figure 7-1 Suggested Design for Reset Synchronization**



## 7.2 Clock Domains

N25(F) has only one clock domain: `core_clk`. However, its bus interface signals may be operating in a separate synchronous bus clock domain. The synchronous bus clock is a virtual clock to the N25(F) design. The clock enable input signal `bus_clk_en` serves as the clock enable signal

for generating the virtual clock. The core\_clk domain signal should be asserted for one core\_clk cycle before the rising edge of the bus clock, as shown in Figure 7-2 BUS\_CLK\_EN Waveform for N:1 (3:1) Clock Ratio. N25(F) uses bus\_clk\_en to determine valid cycles to sample/drive the bus interface signals.

Figure 7-2 BUS\_CLK\_EN Waveform for N:1 (3:1) Clock Ratio



Detailed clock domain constraints can be found in the synthesis script timing\_con.tcl as described latter.

# 8 Instruction Set Overview

## 8.1 Introduction

N25(F) implements The RISC-V Instruction Set Manual, Volume I: User-Level ISA (TD001) V2.2. The following instruction sets are implemented:

- RV32I base integer instruction set
- RISC-V "C" standard extension
- RISC-V "M" standard extension
- RISC-V "A" standard extension
- AndeStar V5 instruction extension

For detailed information, please see The RISC-V Instruction Set Manual, Volume I: User-Level ISA (TD001) V2.2 and AndeStar V5 Instruction Extension Specification (UM165).

## 8.2 Integer Registers

Table 8-1 Integer Registers lists all general purpose integer registers.

**Table 8-1 Integer Registers**

| Register | Signal Name | Description                       |
|----------|-------------|-----------------------------------|
| x0       | zero        | Hard-wired zero                   |
| x1       | ra          | Return address                    |
| x2       | sp          | Stack pointer                     |
| x3       | gp          | Global pointer                    |
| x4       | tp          | Thread pointer                    |
| x5       | t0          | Temporary/alternate link register |
| x6–x7    | t1–t2       | Temporaries                       |
| x8       | s0/fp       | Saved register/frame pointer      |
| x9       | s1          | Saved register                    |
| x10–x11  | a0–a1       | Function arguments/return values  |
| x12–x17  | a2–a7       | Function arguments                |
| x18–x27  | s2–s11      | Saved registers                   |
| x28–x31  | t3–t6       | Temporaries                       |

## 8.3 Atomic Instructions

The RVA extension includes load-reserved/store-conditional and atomic memory operation (AMO) instructions.

### 8.3.1 Load-Reserved/Store-Conditional Instruction

N25(F) tracks at most one physical address location for LR-SC instructions at a time. The reservation made by LR instruction is canceled after any memory operation or exception happens. The address of SC instructions must match the reserved address for SC to succeed.

### 8.3.2 Atomic Memory Operation Instruction

An atomic memory operation is expanded to LR-modify-SC sequences in N25(F). The memory content is first loaded with the LR instruction, then the required operation is performed on the retrieved data, and the final result is written back to the memory by the SC instruction. The sequence will be retried again until it succeeds if the SC instruction fails.

## 8.4 Misaligned Memory Access

N25(F) implements misaligned memory access to support accessing misaligned address without triggering any misaligned exceptions.

By controlling the mmisc\_ctl CSR, the scheme can be enabled or disabled. Please see Machine Miscellaneous Control Register for details.

### 8.4.1 Limitation

In the following cases, N25(F) will still trigger misaligned exceptions even though the misaligned memory access scheme is enabled.

- Accesses to device region
- Accesses across two different memory regions
- Atomic Accesses

## 8.5 Floating Point ISA Extension

N25(F) supports the "F" and "D" Standard Extensions for accelerating the performance of floatingpoint heavy applications. The supported configuration is indicated in the Machine ISA (misa) configuration register.

### 8.5.1 FPU Features

N25(F)F supports the following features:

- Fully pipelined MAC instructions
- Hardware subnormal handling
- All rounding modes
- Support of custom half-precision load/store. (See FLHW and FSHW of

AndeStar V5 Instruction  
Extension Specification (UM165) for more information.

# 9 Physical Memory Attributes

## 9.1 Introduction

The memory space of the N25(F) processor is divided into memory regions. Each region has a memory type, which determines its memory attributes. Two types of memories are provided: Device memory and Normal memory.

Normal memory regions are considered as cacheable regions. The content of these memory regions can be cached in the processor. This attribute is ignored if no caches are configured in a processor implementation.

Normal memory regions can be further divided into write-back regions and write-through regions. Table 9-1 Normal Memory Attribute lists the behavior of these two regions.

**Table 9-1 Normal Memory Attribute**

| Regions       | Write hit        | Write-miss        |
|---------------|------------------|-------------------|
| Write-Back    | Write to D-Cache | Write-allocate    |
| Write-Through | Write-through    | Write-no-allocate |

Device memory regions (a.k.a. “device regions”) are memory locations where an access to these locations may cause side effects. Device regions are non-cacheable and strongly-ordered. Accesses to device regions are guaranteed to be non-speculative and issued in program order. An access to a device region is not issued until all preceding accesses to device regions are finished.

On the other hand, accesses to the normal memory regions could be speculative and the order of accessing normal memory regions is not guaranteed. A load access to a normal memory region might bypass an earlier store access if there is no data dependency. In such a scenario, an explicit fence instruction is required to guarantee order.

Table 9-2 Memory Access Ordering shows ordering of two instructions

A and B, where A < B in program order.

**Table 9-2 Memory Access Ordering**

| A<B in program order |               | B             |        |
|----------------------|---------------|---------------|--------|
| A                    | Normal Memory | Normal Memory | Device |
| Normal Memory        | -             | -             |        |
| Device               | -             | -             | <      |

## 9.2 Device Regions

Device regions are memory locations where accesses to the location may cause side effects. Accesses to device regions are non-cacheable and strongly-ordered.

Device regions and ILM/DLM/WRITETHROUGH should not overlap with each other. The behavior is undefined when device regions are overlapped with ILM/DLM/WRITETHROUGH.

## 9.3 Write-through Regions

Write-through regions are memory locations where memory writes will update both D-Cache and the system memory with write-no-allocate policy.

Write-through regions and ILM/DLM/DEVICE regions should not overlap with each other. The behavior is undefined when write-through regions are overlapped with ILM/DLM/DEVICE regions.

# 10 Local Memory

## 10.1 Introduction

Local memories store data or instructions that might either be accessed frequently or require deterministic access latency, such as interrupt service routines, system calls, video data, real-time systems, etc. N25(F) supports both instruction local memory (ILM) and data local memory (DLM). They are dedicated address spaces that are independent of the memory subsystem. Accesses to them bypass the memory subsystem to achieve minimal latency. The Local Memory Base Address is specified by processor parameters described in Processor Configuration Options.

Local memories are memories and accesses to them are treated the same as to the cacheable memory space. It is not suitable to map device registers in the local memories.

The details of local memory usages are described in the subsequent sections.

## 10.2 Local Memory Spaces

The N25(F) processor supports three address spaces: the instruction local memory, the data local memory and the system bus (AHB/AXI) address spaces. The ILM address space is defined by ILM\_BASE and ILM\_SIZE\_KB configuration parameters, and the DLM address space is defined by DLM\_BASE and DLM\_SIZE\_KB configuration parameters. The base addresses of the Andes local memory should be aligned to its size (a power-of-2 size). See Processor Configuration Options for more information regarding the configuration parameters. Any addresses outside the local memory address spaces belong to the system bus address space.

Instruction fetches may go to the instruction local memory or the system bus while load/store data accesses may access all three regions of spaces. The address spaces for ILM and DLM should not overlap each other for maximum compatibility across Andes processor products. The

exact address space access priorities for the N25(F) processor are defined in Table 10-1 Priorities for Instruction Fetches for instruction fetches and Table 10-2 Priorities for Data Accesses for load/store data accesses.

It is not recommended to set the instruction local memory base address to be the same as the data local memory base address. Otherwise, UNPREDICTABLE behavior might happen.

**Table 10-1 Priorities for Instruction Fetches**

| Address hit the ILM space | Address hit the DLM space | Actual space accessed                                                                 |
|---------------------------|---------------------------|---------------------------------------------------------------------------------------|
| No                        | No                        | AHB/AXI address space                                                                 |
| No                        | Yes                       | AHB/AXI address space<br>(not recommended; the ILM and DLM spaces should not overlap) |
| Yes                       | No                        | ILM                                                                                   |
| Yes                       | Yes                       | ILM<br>(not recommended; the ILM and DLM spaces should not overlap)                   |

**Table 10-2 Priorities for Data Accesses**

| Address hit the ILM space | Address hit the DLM space | Actual space accessed                                               |
|---------------------------|---------------------------|---------------------------------------------------------------------|
| No                        | No                        | AHB/AXI address space                                               |
| No                        | Yes                       | DLM                                                                 |
| Yes                       | No                        | ILM                                                                 |
| Yes                       | Yes                       | DLM<br>(not recommended; the ILM and DLM spaces should not overlap) |

## 10.3 Local Memory Address Range

The local memory address ranges are listed in Table 10-3 Local Memory Address Range (for ILM and DLM). LM\_BASE represents the base address field of the ILM and DLM local memory base address system registers (milmb.IBPA and mdlmb.DBPA).

**Table 10-3 Local Memory Address Range (for ILM and DLM)**

| LM Size  | Start          | End                           |
|----------|----------------|-------------------------------|
| 4KiB     | LM_BASE[63:12] | LM_BASE[63:12] + 0x000000FFF  |
| 8KiB     | LM_BASE[63:13] | LM_BASE[63:13] + 0x000001FFF  |
| 16KiB    | LM_BASE[63:14] | LM_BASE[63:14] + 0x000003FFF  |
| 32KiB    | LM_BASE[63:15] | LM_BASE[63:15] + 0x000007FFF  |
| 64KiB    | LM_BASE[63:16] | LM_BASE[63:16] + 0x00000FFFF  |
| 128KiB   | LM_BASE[63:17] | LM_BASE[63:17] + 0x00001FFFF  |
| 256KiB   | LM_BASE[63:18] | LM_BASE[63:18] + 0x00003FFFF  |
| 512KiB   | LM_BASE[63:19] | LM_BASE[63:19] + 0x00007FFFF  |
| 1024KiB  | LM_BASE[63:20] | LM_BASE[63:20] + 0x0000FFFFFF |
| 2048KiB  | LM_BASE[63:21] | LM_BASE[63:21] + 0x0001FFFFFF |
| 4096KiB  | LM_BASE[63:22] | LM_BASE[63:22] + 0x0003FFFFFF |
| 8192KiB  | LM_BASE[63:23] | LM_BASE[63:23] + 0x0007FFFFFF |
| 16384KiB | LM_BASE[63:24] | LM_BASE[63:24] + 0x000FFFFFFF |

## 10.4 Local Memory Usage Constraints

Local memories are optimized for access latency. As a result, the design imposes the following usage restrictions:

- The virtual address mapping for local memories should maintain consistent address offset mappings for the offset part of the address that indexes into the local memory.
- Accesses to the local memory are speculative. Devices with side effects on reads should not be mapped to this region.

## 10.5 Local Memory Interface

The local memory interface could be SRAM or AHB-Lite. This is configured through the Local Memory Interface option. If the value of option is ram, SRAM style of interface is configured. If the value is ahb-lite, the AHB-Lite interface will be used.

Table 10-4 Possible AHB-Lite Transactions Used by Local Memory Interfaces shows the possible transactions of AHB-Lite interface used by the Local Memory Interfaces.

Table 10-5 Instruction Local Memory Protection Control Signal and Table 10-6 Data Local Memory Protection Control Signal summarize the possible HPROT combinations on AHB-lite interfaces for instruction/data local memories.

**Table 10-4 Possible AHB-Lite Transactions Used by Local Memory Interfaces**

| <b>Request types</b> | <b>Transaction Types</b> |
|----------------------|--------------------------|
| Write transfers      | SINGLE WORD              |
|                      | SINGLE HALFWORD          |
|                      | SINGLE BYTE              |
| Read transfers       | SINGLE WORD              |

**Table 10-5 Instruction Local Memory Protection Control Signal**

| ILM_HPROT[3]<br>Cacheable | ILM_HPROT[2]<br>Bufferable | ILM_HPROT[1]<br>Privileged | ILM_HPROT[0]<br>Data/Instruction | Description                  |
|---------------------------|----------------------------|----------------------------|----------------------------------|------------------------------|
| 1                         | 0                          | 0                          | 0                                | User Instruction Fetch       |
|                           |                            | 0                          | 1                                | User Data Access             |
|                           |                            | 1                          | 0                                | Privileged Instruction Fetch |
|                           |                            | 1                          | 1                                | Privileged Data Access       |

**Table 10-6 Data Local Memory Protection Control Signal**

| DLM_HPROT[3]<br>Cacheable | DLM_HPROT[2]<br>Bufferable | DLM_HPROT[1]<br>Privileged | DLM_HPROT[0]<br>Data/Instruction | Description            |
|---------------------------|----------------------------|----------------------------|----------------------------------|------------------------|
| 1                         | 0                          | 0                          | 1                                | User Data Access       |
|                           |                            | 1                          | 1                                | Privileged Data Access |

# 11 Local Memory Slave Port

## 11.1 Introduction

The local memory slave port enables external bus masters to access the local memories of N25(F). When an address exceeds ILM/DLM size, the higher address bits are ignored by the slave port. The slv\_huser signal of the local memory slave port interface selects which local memory to access:

**Table 11-1 Local Memory Slave Port Selection**

| slv_huser[0] | Selection |
|--------------|-----------|
| 0            | ILM       |
| 1            | DLM       |

Local memory slave port contains a four-entry buffer for burst accesses or write accesses. Therefore, write transfers might temporarily be stored in the buffer. Local memory slave port performs prefetch on burst read transfers to shorten the total wait state of burst transfers.

Slave port accesses have lower priority than load/store operations and instruction fetches. When a slave port access is not granted in 4 cycles, the access is granted the highest priority to avoid starvation.

Note that N25(F) does not include logics to guarantee atomicity of atomic instructions accessing the local memory address space when external masters access the same location through the local memory slave port.

## 11.2 Latency of Transfer

The table below summarizes the minimum latency of transfers accessing LM slave port. For read transfers, the latency will be larger than the listed number if the request of LM slave port is not granted by N25(F) instantly. For write transfers, the latency will be larger than the listed number when the internal 4-entry buffer is full.

**Table 11-2 Local Memory Slave Port Transfer Latency**

| Access Type          | Least latency |
|----------------------|---------------|
| Single Read          | 5             |
| Single Write         | 1             |
| Burst Read(N Beats)  | N+4           |
| Burst Write(N Beats) | N             |

## 11.3 Basic Transfer

The waveform below illustrates the best case of single-read accesses with 4 cycle wait states and single-write accesses with no wait state.

Note that BUS\_CLK is a pseudo-clock, please see Clock Domains for more information.

**Figure 11-1 Single Access on the Local Memory Slave Port**

## 11.4 Burst Transfer

Figure 11-2 Burst Read Access on the Local Memory Slave Port and Figure 11-3 Burst Write Access on the Local Memory Slave Port illustrate a 16-beat incremental burst read access and 16-beat wrapped burst write access. Note that extra wait states may be inserted if the data width of local memory slave port is not equal to the data width of local memory.

**Figure 11-2 Burst Read Access on the Local Memory Slave Port**

**Figure 11-3 Burst Write Access on the Local Memory Slave Port**

## 11.5 Support for Soft Error Protection

The local memory slave port would return bus errors to AHB masters as well as trigger local interrupts

to N25(F) when a 2-bit ECC error or parity error is detected.

The behavior of ECC logic for local memories is controlled by milmb.ECCEN/mdlmb.ECCEN. The encoding for errors encountered through accesses from the local memory slave port is summarized in the table below.

Correctable ECC errors only trigger local interrupts when ECCEN is equal to 3. Uncorrectable ECC errors would trigger local interrupts when ECCEN is equal to 2 or 3. The triggering of local interrupts is controlled by mie.IMECCI and the interrupt status is reported in mip.IMECCI. See Machine Interrupt Enable and Machine Interrupt Pending for detail.

Data returned through the local memory slave port is the ECC corrected version. For uncorrectable ECC errors, bus errors are reported when ECCEN is equal to 2 or 3.

| Value | Local Interrupts                                                   | Data Returned                |
|-------|--------------------------------------------------------------------|------------------------------|
| 0     | Disable parity/ECC.                                                | Uncorrected data             |
| 1     | Reserved.                                                          | Reserved                     |
| 2     | Generate local interrupts only on uncorrectable parity/ECC errors. | Corrected data or bus errors |
| 3     | Generate local interrupts on any type of parity/ECC errors.        | Corrected data or bus errors |

Extra wait state is needed while the size of a write transfer differs to the size of local memory. Figure 11-4 Various Size Write Transfers with ECC demonstrates an example of various size write transfers with ECC.

**Figure 11-4 Various Size Write Transfers with ECC**

## 11.6 Local Memory Slave Port Operation under WFI Mode

The local memory slave port is still accessible in WFI mode if the following conditions are met:

- The clock to N25(F) should resume running while there is a transfer issued from the local memory slave port if core clk is deactivated in WFI mode.
- The clock to N25(F) should only be turned off in the WFI mode when there is no more outstanding transfer on the local memory slave port.

# 12 Caches

## 12.1 Introduction

N25(F) has two caches, the instruction cache and the data cache. Both can be configured to 8KiB, 16KiB, 32KiB and 64KiB in size.

The cache organization information can be collected from the cache/memory configuration registers

micm\_cfg for the instruction cache and mdcm\_cfg for the data cache. The configuration choices are listed below and the format of the configuration registers could be found in Instruction Cache/Memory Configuration Register and Data Cache/Memory Configuration Register.

**Table 12-1 Configuration Choices for the Instruction Cache**

| Items               | Field Name<br>(micm_cfg) | Choices                             |
|---------------------|--------------------------|-------------------------------------|
| Cache lines per way | ISET                     | 64, 128, 256, 512, 1024, 2048, 4096 |
| Ways                | IWAY                     | Direct-mapped, 2-way, 4-way         |
| Line size (bytes)   | ISZ                      | 32                                  |

**Table 12-2 Configuration Choices for the Data Cache**

| Items               | Field Name<br>(mdcm_cfg) | Choices                             |
|---------------------|--------------------------|-------------------------------------|
| Cache lines per way | DSET                     | 64, 128, 256, 512, 1024, 2048, 4096 |
| Ways                | DWAY                     | Direct-mapped, 2-way, 4-way         |
| Line size (bytes)   | DSZ                      | 32                                  |

Total cache size = Cache lines per x way x Ways Line size

The replacement policy for 2-way and 4-way caches can be random or pseudo-LRU. The replacement policy for direct-mapped caches is irrelevant.

## 12.2 Cache Access Latency

The access latency of the instruction cache and the data cache are listed below.

**Table 12-3 Access Latency of the Instruction Cache**

| Instruction               | Throughput (cycles/instruction) | Latency (cycles) |
|---------------------------|---------------------------------|------------------|
| Fetch from I-Cache (hit)  | 1                               | 2                |
| Fetch from I-Cache (miss) | 6                               | 7                |

**Table 12-4 Access Latency of the Data Cache**

| Instruction                            | Throughput (cycles/instruction) | Latency (cycles) |
|----------------------------------------|---------------------------------|------------------|
| Load word from D-Cache (hit)           | 1                               | 2                |
| Load word from D-Cache (miss)          | 5                               | 7                |
| Load byte/halfword from D-Cache (hit)  | 1                               | 3                |
| Load byte/halfword from D-Cache (miss) | 5                               | 7                |

## 12.3 I-Cache Fill Operation

The instruction cache fill operation starts when a cacheable line is not in the I-Cache. A burst read request for the missed cache line is always sent first to the system bus to minimize the miss latency.

The fill operation may be aborted by system bus errors. A precise instruction access fault is triggered for the instruction fetch causing the cache miss operation if the error is on the critical word. If the error occurs on non-critical words, the fill operation will be canceled and the missed line will not be installed into I-Cache. Instruction fetches before the non-critical error word will not be affected since they have received the required data.

In Debug Mode, instruction fetches will not affect I-Cache contents. All I-Cache misses will not cause cache replacements in Debug Mode.

## 12.4 D-Cache Fill Operations

The D-Cache fill operation starts when a cacheable line is not in the D-Cache. A burst read request for the missed cache line is always sent first to the system bus to minimize the miss latency. The read request will be followed by a burst write request if cache eviction is required.

The fill operation may be aborted by system bus errors. A precise load/store access fault is triggered for the load/store instruction causing the cache miss operation if the error is for the critical word. If the error occurs on non-critical words, the fill operation will be canceled and the missed line will not be installed into D-Cache. Load instructions will not be affected by these errors since they have received the required data (the critical words). Store instructions will send a single bus request to write the data directly to the bus.

In Debug Mode, load/store instructions will minimally affect D-Cache contents. All cache misses will not cause cache replacements, and only dirty bits may be affected by accesses to cache lines that are already in D-Cache.

## 12.5 D-Cache Eviction Operations

A burst write request will be sent to the system bus if a dirty line is evicted out of D-Cache. An imprecise bus-write error exception is triggered if the burst write request encounters system bus errors.

## 12.6 FENCE/FENCE.I Operations

FENCE/FENCE.I instructions can be used to write back or invalidate the cache content. The behavior of FENCE/FENCE.I is summarized in Table 12-5 Effects of FENCE/FENCE.I Instructions.

**Table 12-5 Effects of FENCE/FENCE.I Instructions**

| <b>Cache</b> | <b>FENCE</b>                              | <b>FENCE.I</b>             |
|--------------|-------------------------------------------|----------------------------|
| I-Cache      | None                                      | Invalidate all cache lines |
| D-Cache      | Write back and invalidate all cache lines | Write back all cache lines |

# 13 Bus Interface Unit

## 13.1 Introduction

The bus interface unit is responsible for off-CPU accesses which include system memory accesses and memory-mapped register accesses in devices. N25(F) supports both AHB and AXI bus protocols.

## 13.2 BIU Block Diagram

The following figure shows the block diagram of the bus interface unit. Requests for the external bus can come from fetch, load, and store accesses to memory. BIU includes an arbiter, a command FIFO, a write-data FIFO, a response FIFO, and a bus master.

Figure 13-1 BIU Block Diagram



Table 13-1 AHB Transactions Used by N25(F) and Table 13-2 AXI Transactions Used by N25(F) summarize the transactions that N25(F) uses to access the AHB and AXI buses

**Table 13-1 AHB Transactions Used by N25(F)**

| Request types                                   | Transaction Types for 64-bit Data Bus          | Transaction Types for 32-bit Data Bus         |
|-------------------------------------------------|------------------------------------------------|-----------------------------------------------|
| Basic transfers                                 | SINGLE WORD<br>SINGLE HALF WORD<br>SINGLE BYTE | SINGLE WORD<br>SINGLE HALFWORD<br>SINGLE BYTE |
| Additional transfers when caches are configured | WRAP4 DOUBLEWORD                               | WRAP8 WORD                                    |

**Table 13-2 AXI Transactions Used by N25(F)**

| Request types                                   | Transaction Types                              |
|-------------------------------------------------|------------------------------------------------|
| Basic transfers                                 | SINGLE WORD<br>SINGLE HALF WORD<br>SINGLE BYTE |
| Additional transfers when caches are configured | WRAP4 DOUBLEWORD                               |

## 13.3 Atomic Operations

Atomic operations are implemented by locking the bus using the HLOCK signal when AHB is supported. The HLOCK signal is asserted to lock the AHB bus once the LR instruction is executed. N25(F) will hold the lock until it executes the SC instruction or the internal lock is cleared.

The Exclusive access mechanism is used for implementing the atomic operations to the AXI bus: ARLOCK[1:0]==1 for load misses caused by LR instructions and AWLOCK[1:0]==1 for store misses caused by SC instructions.

Please see the usage descriptions for LR and SC instructions in The RISC-V Instruction Set Manual, Volume I: User-Level ISA (TD001) V2.2.

## 13.4 Low Latency AHB Access Mode

The low latency access option is designed to improve the bus access latency under low clock frequency conditions.

This mode comes with a couple restrictions:

1. Only AHB bus are supported.
2. Bus must be synchronous. Although the bus clock could run slower (N:1 clock ratio) to reduce power consumption, the timing constraint must be 1:1 with respect to core\_clk during synthesis.
3. Cycle time is sacrificed in order to shorten the access latency. Bus signals are used directly without flops so internal critical paths will appear in the SoC timing report — 1/2 of the bus cycle time should be reserved for internal paths of N25(F).

# 14 Trap

## 14.1 Introduction

According to RISC-V Privileged Architecture, a trap is a control flow change of normal instruction execution caused by an interrupt or an exception. An interrupt is a control flow change event initiated by an external source. An exception is a control flow change event generated as a by-product of instruction execution. When a trap happens, the processor stops processing the current flow of instructions, disables interrupts, saves enough states for later resumption, and starts executing a trap handler.

## 14.2 Interrupt

N25(F) provides three interrupt inputs: external interrupt, timer interrupt and software interrupt. Timer interrupts and software interrupts are local interrupts in a RISC-V platform, which means each processor in the platform receives its own timer/software interrupts. External interrupts are global interrupts in a RISC-V platform, which means they are shared by all processors in a RISC-V platform. External interrupts are arbitrated and distributed by a platform level interrupt controller (PLIC) to processors in the RISC-V platform. Each external interrupt source can be assigned its own priority, and each interrupt target (e.g., RISC-V processors) could select which external interrupt sources it would handle. PLIC routes the highest priority interrupt source to the target processor. PLIC is described in Platform-Level Interrupt Controller (PLIC).

The mip CSR contains pending bits of these three interrupts, and mie CSR contains enable bits of these interrupts. The processor can selectively enable interrupts by manipulating the mie CSR, or globally disable interrupts by clearing the mstatus.MIE bit.

In addition to external interrupts, N25(F) may generate internal interrupts for the following events:

- Local memory slave port parity/ECC error (See Floating Point ISA Extension and mie.IMECCI and mip.IMECCI)

- Bus-write transaction error (See mie.BWEI and mip.BWEI)
- Performance monitor overflow (See mie.PMOVI and mip.PMOVI)

## 14.3 Exception

- N25(F) implements the following exceptions:
- Instruction address misaligned exceptions
    - Jump to misaligned addresses
  - Instruction access faults
    - Bus errors caused by instruction fetches
    - Uncorrectable ECC errors when fetching trap handlers under the vector PLIC mode
  - Illegal instructions
    - Unsupported instructions
    - Privileged instructions
    - Accessing non-existent CSRs
    - Accessing privileged CSRs
    - Writing to read-only CSRs
    - Executing Andes-specific instructions in the RISC-V compatibility mode (mmisc\_ctl.RVCOMP == 1).
    - ACE instructions with reserved sub-opcode or register index
  - Breakpoint exceptions
  - Load address misaligned exceptions
  - Load access faults
    - Bus errors caused by load instructions
    - ECC errors caused by load instructions
  - Store/AMO address misaligned exceptions
  - Store/AMO access faults
    - ECC errors caused by store instructions
  - Environment calls
  - ACE disabled exceptions
  - Stack overflow/underflow exception with StackSafe supported
    - Executing ACE instructions without enabling ACE context (mmisc\_ctl.ACES == 0).
  - ACE exceptions
    - Bus errors caused by memory accesses
    - Misaligned or out-of-range memory address exceptions
    - Zero length vector exceptions
    - Custom-defined exceptions

## 14.4 Trap Handling

All traps are handled in M-mode. When a trap occurs, the following operations are applied:

- mepc is set to the current program counter.
- mstatus is updated.

- The MPP field is set to the current privilege mode
- The MPIE field is set to mie
- The MIE field is set to 0
- mcause is updated.
- mtval is updated when any of address-misaligned, access-fault, or page-fault exceptions occur.
- The privilege mode is changed to M-mode.
- When mmisc\_ctl.VEC\_PLIC is 0, the program counter is set to the address specified by mtvec.
- When mmisc\_ctl.VEC\_PLIC is 1, the mtvec register will be the base address register of a vector table with 4-byte entries storing addresses pointing to interrupt service routines.
  - mtvec[0] is for exceptions and non-external local interrupts. For these traps, the mcause register records the trap type based on RISC-V definitions.
  - mtvec[N] is for external PLIC interrupt source N. For the external PLIC interrupts, the mcause register records the interrupt source ID. The RISC-V architecture defines a two-level stack of interrupt-enable bits and privilege modes. To support nested traps, the trap handler should backup trap handling CSRs and enable the interrupt-enable bit.

After handling a trap, the MRET instruction can be executed for returning to the privilege mode before the trap. When a MRET instruction is executed, the following operations are applied:

- The program counter is set to mepc
- The privilege mode is set to mstatus.MPP
- mstatus is updated
  - The MPP field is set to U-mode (or M-mode if U-mode is not supported)
  - The MIE field is set to mpie
  - The MPIE field is set to 1

# 15 Reset and Non-Maskable Interrupts

## 15.1 Reset

When the core\_reset\_n input signal is deasserted, the following operations are applied:

- CSRs are set to their reset values
- All integer registers (listed in Table 8-1 Integer Registers) are set to zero
- BTB is initialized
- Program execution starts with the address specified by the reset\_vector input signal

## 15.2 Non-Maskable Interrupts

Non-maskable interrupts (NMIs) are intended for handling hardware error conditions and are assumed to be non-resumable. They are triggered through the nmi input signal. The rising edge of the signal causes an immediate jump to an address stored in the mnvec register and transition of the privilege level to M-mode, regardless of the state of a hart's interrupt enable bit.

The following operations are applied when an NMI is taken:

- The mepc register is written with the address of the next instruction when the NMI was taken.
- The mcause register is set to 1, indicating that NMI is caused by the nmi signal.
- The mstatus.MPP field records the privilege mode before NMI was taken.
- The mstatus.MPIE field is set to the value of mstatus.xIE before NMI was taken. The "x" is active privilege mode before the NMI was taken.
- The mstatus.MIE field is set to 0.

# 16 Power Management

## 16.1 Wait-For-Interrupt Mode

The RISC-V WFI instruction enables N25(F) to enter the wait-for-interrupt (WFI) mode for reducing power consumption and power-gating of N25(F) should only happen when the processor is in the WFI mode.

Upon execution of a WFI instruction, N25(F) stops all activities and asserts the core\_wfi\_mode output signal to indicate that the processor is in WFI mode. The processor enters the WFI mode with mstatus.MIE enabled. In such scenarios, when an interrupt is pending (see the mip register in Machine Interrupt Pending) and the interrupt is enabled (see the mie register in Machine Interrupt Enable), the processor will resume.

In WFI mode, memory transactions started before the execution of WFI are completed, all transient states of memory handling are flushed and no new memory accesses will take place. The core\_clk and bus\_clk\_en input signals can be safely changed in this period for frequency scaling. This is also the safe period to power-gate the processor while making the I/D-Cache SRAMs enter the state retention mode.

Slave port accesses are not disabled in WFI mode, but the processor requires core\_clk to access local memories. When slave port accesses are still needed in WFI mode, core\_clk should not be gated off.

# 17 Memory Subsystem Error Protection

## 17.1 Introduction

N25(F) includes support for soft-error protection for the memory subsystems

### 17.1.1 Memory Subsystem Error Protection Scheme

Two memory subsystem error protection schemes are supported:

- Parity check
  - Memory error detection through even parity check
  - Detecting one bit error per byte
  - Each 8-bit data requires one extra bit to store the parity bit
- ECC
  - Single-Error-Correction, Double-Error-Detection (SEC-DED) ECC
  - Single-bit errors can be detected and recovered
  - Double-bit errors can be detected but may not be recovered
  - Each 32-bit data requires seven extra bits to store the ECC code

### 17.1.2 Error Protected Memory Subsystem

The N25(F) memory subsystems protected by the Parity/ECC scheme include:

- Cache memories
  - Instruction caches (Tag RAM and Data RAM)
  - Data caches (Tag RAM and Data RAM)
- Local memories
  - ILM
  - DLM

### 17.1.3 Read-Modify-Write Operations

For data RAMs, the unit of ECC protection is one 32-bit word (four bytes). The ECC code is computed and written to the data RAMs along

with the data word.

To write narrower data (e.g., a byte or a half word) into these RAMs, the processor must read data from the RAM, merge the read data with the write data, and then generate the ECC code for the merged data before writing back the merged data and the ECC code. This process is referred to as read-modify-write operations and these operations are done by hardware automatically in N25(F).

For parity protected RAMs, the unit of parity protection is one byte. The parity bits could be generated directly for all kinds of partial word (bytes and half-words) writes without the need for the readmodify- write operations.

## 17.2 Parity/ECC Control Mode and Access types

For each protected memory, a Parity/ECC enable control flag is defined with three modes:

- Parity/ECC checking disabled
- Generating exceptions on uncorrectable Parity/ECC errors
- Generating exceptions on Parity/ECC errors

### 17.2.1 Parity/ECC Checking Disabled

The behavior of the Parity/ECC logic when Parity/ECC is disabled is:

- Parity/ECC checking is disabled, but all writes to the RAMs still update/regenerate Parity/ECC codes.
  - No exceptions would be generated.
  - No Parity/ECC related registers will be updated.
- The processor gets data before correction and errors would not be corrected.
- The processor uses read-modify-write operations to store a partial word.

### 17.2.2 Generating Exceptions on Uncorrectable Parity/ECC Errors

The behavior of the Parity/ECC logic under this mode is:

- Parity/ECC checking is enabled and all writes to the RAMs update/regenerate Parity/ECC codes. Generating Exceptions on Parity/ECC Errors
  - The processor gets data after correction.
  - The processor uses read-modify-write operations to store a partial word.
- For accesses by the main pipeline:
  - No exception would be generated for correctable errors.
  - Exceptions would be generated for uncorrectable errors.
  - The related error reporting registers would be updated on all Parity/ECC errors.
- For accesses by the local memory slave port:
  - No exception would be generated for any detected Parity/ECC

errors.

- The standard bus error reporting mechanism is used to report uncorrectable errors for the slave port accesses.
- The slave port triggers local interrupts to signal that uncorrectable errors are detected.

### 17.2.3 Generating Exceptions on Parity/ECC Errors

The behavior of the Parity/ECC logic under this mode is:

- Parity/ECC checking is enabled and all writes to the RAMs update/regenerate Parity/ECC codes.
- The processor gets the data after correction.
- The processor uses read-modify-write operations to store a partial word.
- For accesses by the main pipeline:
  - All detected Parity/ECC errors would generate exceptions.
  - The related error reporting registers would be updated on all Parity/ECC errors.
- For accesses by the local memory slave port:
  - No exception would be generated for any detected Parity/ECC errors.
  - The standard bus error reporting mechanism is used to report uncorrectable errors for the slave port accesses.
  - The slave port triggers local interrupts to signal that uncorrectable errors are detected.

### 17.2.4 Error Handling in Caches

The behavior of the cache ECC logic is controlled by mcache\_ctl.IC\_ECCEN/mcache\_ctl.DC\_ECCEN. See Cache Control Register for more information.

The definitions of correctable and uncorrectable errors and their handling are summarized in Table 17-1 Handling Correctable Errors in Caches and Table 17-2 Handling Uncorrectable Errors in Caches.

**Table 17-1 Handling Correctable Errors in Caches**

| Error Type                                                               | Error Handling Action                                                                                                                                                                                                                                                          |
|--------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| One-bit parity errors or one-bit/two-bit ECC errors in clean cache lines | <ul style="list-style-type: none"> <li>• The clean lines are invalidated and the correct copies from the next-level memory are brought back into the cache.</li> <li>• All lines in I-Cache are considered clean.</li> </ul>                                                   |
| One-bit ECC errors in dirty cache lines                                  | <ul style="list-style-type: none"> <li>• All data in dirty lines are written back to the next-level memory after ECC correction.</li> <li>• The dirty lines are then invalidated and the correct copies from the next-level memory are brought back into the cache.</li> </ul> |

**Table 17-2 Handling Uncorrectable Errors in Caches**

| Error Type                                                       | Error Handling Action                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| One-bit parity errors or two-bit ECC errors in dirty cache lines | <ul style="list-style-type: none"> <li>• All data in the dirty lines are written back to the next-level memory.           <ul style="list-style-type: none"> <li>– Data without ECC errors and with one-bit ECC errors are written back after correction.</li> <li>– Data with one-bit parity error or two-bit ECC errors cannot be recovered and they are written back without correction.</li> </ul> </li> <li>• The dirty lines are then invalidated.</li> </ul> |

## 17.2.5 Error Handling in ILM and DLM

The actions when a Parity/ECC error is detected in ILM/DLM are listed in Table 17-3 Local Memory Parity/ECC Error Handling.

**Table 17-3 Local Memory Parity/ECC Error Handling**

| Error Type           | Error Handling Action                                                        |
|----------------------|------------------------------------------------------------------------------|
| Correctable errors   | The data is corrected and written back to ILM/DLM.                           |
| Uncorrectable errors | The data is not corrected and a <i>Machine Error</i> exception is triggered. |

## 17.2.6 Behavior of Parity/ECC-Supported Local Memory Accesses

The behavior of Local Memory ECC logic is controlled by `milmb.ECCEN`/`mdlmb.ECCEN`. See Introduction and Data Local Memory Base Registerfor more information.

**Table 17-4 Parity/ECC Behavior for Local Memory Operations**

| Operation                                       | Parity/ECC Error Checking                                                                                                                                                                                                                                                                                                           |
|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Instruction fetches and load/store instructions | Controlled by <code>milmb.ECCEN</code> / <code>mdlmb.ECCEN</code> .                                                                                                                                                                                                                                                                 |
| Slave port accesses                             | <ul style="list-style-type: none"> <li>• Controlled by <code>milmb.ECCEN</code>/<code>mdlmb.ECCEN</code>.</li> <li>• No exception would be generated for detected Parity/ECC errors.</li> <li>• Uncorrectable errors would be reported through error response.</li> <li>• Uncorrectable errors trigger local interrupts.</li> </ul> |

**Table 17-5 Types of Parity/ECC Error Exception**

| Access Type             | Target RAM     | Precise/Imprecise |
|-------------------------|----------------|-------------------|
| Instruction Fetches     | Local memories | Precise           |
| Load-type instructions  | Local memories | Precise           |
| Store-type instructions | Local memories | Precise           |

# 18 Control and Status Registers

## 18.1 Introduction

The sections below describe the registers in detail.

### 18.1.1 System Register Type

| Term | Description                                                                                             |
|------|---------------------------------------------------------------------------------------------------------|
| IM   | Implementation dependent/determined.                                                                    |
| RO   | Read-Only register/field. Any software write to RO register/field will be silently ignored by hardware. |
| RW   | Read/Write register/field                                                                               |
| WLRL | Write/Read Only Legal Values                                                                            |

### 18.1.2 Reset Value

| Term | Description                    |
|------|--------------------------------|
| DC   | The reset value is Don't-Care. |

### 18.1.3 CSR Listing

Table 18-1 Machine Information Registers

| Mnemonic Name | CSR Address |
|---------------|-------------|
| mvendorid     | 0xf11       |
| marchid       | 0xf12       |
| mimpid        | 0xf13       |
| mhartid       | 0xf14       |

Table 18-2 Machine Trap Related Registers

| Mnemonic Name | CSR Address |
|---------------|-------------|
| mstatus       | 0x300       |
| misa          | 0x301       |
| medeleg       | 0x302       |
| mdelelg       | 0x303       |
| mie           | 0x304       |
| mtvec         | 0x305       |
| mscratch      | 0x340       |
| mepc          | 0x341       |
| mcause        | 0x342       |
| mtval         | 0x343       |
| mip           | 0x344       |
| mxstatus      | 0x7c4       |
| mdcause       | 0x7c9       |

**Table 18-3 Counter Related Registers**

| <b>Mnemonic Name</b> | <b>CSR Address</b> |
|----------------------|--------------------|
| mcycle               | 0xb00              |
| mcycleh              | 0xb80              |
| minstret             | 0xb02              |
| minstreth            | 0xb82              |
| mhpmcOUNTER3         | 0xb03              |
| mhpmcOUNTER4         | 0xb04              |
| mhpmcOUNTER5         | 0xb05              |
| mhpmcOUNTER6         | 0xb06              |
| mhpmcOUNTER3h        | 0xb83              |
| mhpmcOUNTER4h        | 0xb84              |
| mhpmcOUNTER5h        | 0xb85              |
| mhpmcOUNTER6h        | 0xb86              |
| mcounteren           | 0x306              |
| mhpmevent3           | 0x323              |
| mhpmevent4           | 0x324              |
| mhpmevent5           | 0x325              |
| mhpmevent6           | 0x326              |
| mcounterwen          | 0x7ce              |
| mcounterinten        | 0x7cf              |
| mcountermask_m       | 0x7d1              |
| mcountermask_s       | 0x7d2              |
| mcountermask_u       | 0x7d3              |
| mcounterovf          | 0x7d4              |

**Table 18-4 Configuration Control & Status Registers**

| <b>Mnemonic Name</b> | <b>CSR Address</b> |
|----------------------|--------------------|
| micm_cfg             | 0xfc0              |
| mdcm_cfg             | 0xfc1              |
| mmsc_cfg             | 0xfc2              |

**Table 18-5 Trigger Registers**

| <b>Mnemonic Name</b> | <b>CSR Address</b> |
|----------------------|--------------------|
| tselect              | 0x7a0              |

| Mnemonic Name | CSR Address |
|---------------|-------------|
| tdata1        | 0x7a1       |
| tdata2        | 0x7a2       |
| tdata3        | 0x7a3       |
| tinfo         | 0x7a4       |
| mcontrol      | 0x7a1       |
| icount        | 0x7a1       |
| itrigger      | 0x7a1       |
| etrigger      | 0x7a1       |

Table 18-6 Debug Registers

| Mnemonic Name | CSR Address |
|---------------|-------------|
| dcsr          | 0x7b0       |
| dpc           | 0x7b1       |
| dscratch0     | 0x7b2       |
| dscratch1     | 0x7b3       |
| dexc2dbg      | 0x7e0       |
| ddcause       | 0x7e1       |

Table 18-7 Memory and Miscellaneous Registers

| Mnemonic Name  | CSR Address |
|----------------|-------------|
| milmb          | 0x7c0       |
| mdlmb          | 0x7c1       |
| mecc_code      | 0x7c2       |
| mnvec          | 0x7c3       |
| mpft_ctl       | 0x7c5       |
| mcache_ctl     | 0x7ca       |
| mcctlbeginaddr | 0x7cb       |
| mcctlcommand   | 0x7cc       |
| mcctldata      | 0x7cc       |
| ucctlbeginaddr | 0x80b       |
| ucctlcommand   | 0x80c       |
| mmisc_ctl      | 0x7d0       |

**Table 18-8 Hardware Stack Protection and Recording Registers**

| <b>Mnemonic Name</b> | <b>CSR Address</b> |
|----------------------|--------------------|
| mhsps_ctl            | 0x7c6              |
| msp_bound            | 0x7c7              |
| msp_base             | 0x7c8              |

**Table 18-9 CoDense Registers**

| <b>Mnemonic Name</b> | <b>CSR Address</b> |
|----------------------|--------------------|
| uitb                 | 0x800              |

**Table 18-10 PMP Registers**

| <b>Mnemonic Name</b> | <b>CSR Address</b> |
|----------------------|--------------------|
| pmpcfg0              | 0x3a0              |
| pmpcfg1              | 0x3a1              |
| pmpcfg2              | 0x3a2              |
| pmpcfg3              | 0x3a3              |
| pmpaddr0             | 0x3b0              |
| pmpaddr1             | 0x3b1              |
| pmpaddr2             | 0x3b2              |
| pmpaddr3             | 0x3b3              |
| pmpaddr4             | 0x3b4              |
| pmpaddr5             | 0x3b5              |
| pmpaddr6             | 0x3b6              |
| pmpaddr7             | 0x3b7              |
| pmpaddr8             | 0x3b8              |
| pmpaddr9             | 0x3b9              |
| pmpaddr10            | 0x3b10             |
| pmpaddr11            | 0x3b11             |
| pmpaddr12            | 0x3b12             |
| pmpaddr13            | 0x3b13             |
| pmpaddr14            | 0x3b14             |
| pmpaddr15            | 0x3b15             |

## 18.2 Machine Information Registers

### 18.2.1 Machine Vendor ID Register

**Mnemonic Name:** mvendorid

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0xf11 (standard read only)

|    |           |   |
|----|-----------|---|
| 31 | MVENDORID | 0 |
|----|-----------|---|

This read-only register provides the Andes JEDEC manufacturer ID: 0x0000031e.

| Field Name | Bits   | Description                   | Type | Reset      |
|------------|--------|-------------------------------|------|------------|
| MVENDORID  | [31:0] | The manufacturer ID of Andes. | RO   | 0x0000031e |

## 18.2.2 Machine Architecture ID Register

**Mnemonic Name:** marchid

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0xf12 (standard read only)

|    |    |                  |        |   |
|----|----|------------------|--------|---|
| 31 | 30 | <b>[Release]</b> | CPU_ID | 0 |
|----|----|------------------|--------|---|

This register provides the micro-architecture id of AndesCore processor implementations. For N25(F), marchid.CPU\_ID will be 0x0025. Note that the MSB of this register is 1 for commercial implementations of RISC-V processors.

| Field Name | Bits   | Description   | Type | Reset  |
|------------|--------|---------------|------|--------|
| CPU_ID     | [30:0] | Andes CPU ID. | RO   | 0x0025 |

## 18.2.3 Machine Implementation ID Register

**Mnemonic Name:** mimpid

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0xf13 (standard read only)

|    |                  |       |       |           |
|----|------------------|-------|-------|-----------|
| 31 | <b>[Release]</b> | 8 7   | 4 3   | 0         |
|    |                  | MAJOR | MINOR | EXTENSION |

This register provides the revision number of the N25(F) processor.

Please see AndesCore N25(F) Release Note (RN168) for exact values. It is documented in the release note as MAJOR.MINOR. EXTENSION.

| Field Name | Bits   | Description         | Type | Reset |
|------------|--------|---------------------|------|-------|
| EXTENSION  | [3:0]  | Revision extension. | RO   | IM    |
| MINOR      | [7:4]  | Revision minor.     | RO   | IM    |
| MAJOR      | [31:8] | Revision major.     | RO   | IM    |

## 18.2.4 Hart ID Register

**Mnemonic Name:** mhartid

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0xf14 (standard read only)



This register provides the ID of the hardware thread. It is required that one of the hart IDs must be zero on a RISC-V platform. The value of this register is determined by the HART0\_ID parameter.

| Field Name | Bits   | Description | Type | Reset    |
|------------|--------|-------------|------|----------|
| MHARTID    | [31:0] | Hart ID.    | RO   | HART0_ID |

## 18.3 Machine Trap Related CSRs

### 18.3.1 Machine Status

**Mnemonic Name:** mstatus

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x300 (standard read/write)



| Field Name | Bits     | Description                                                                                                                                                                             | Type  | Reset   |   |          |   |         |  |  |
|------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|----------|---|---------|--|--|
| MIE        | [3]      | M-mode interrupt enable bit.                                                                                                                                                            | RW    | 0       |   |          |   |         |  |  |
|            |          | <table border="1"> <thead> <tr> <th>Value</th> <th>Meaning</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>Disabled</td> </tr> <tr> <td>1</td> <td>Enabled</td> </tr> </tbody> </table> | Value | Meaning | 0 | Disabled | 1 | Enabled |  |  |
| Value      | Meaning  |                                                                                                                                                                                         |       |         |   |          |   |         |  |  |
| 0          | Disabled |                                                                                                                                                                                         |       |         |   |          |   |         |  |  |
| 1          | Enabled  |                                                                                                                                                                                         |       |         |   |          |   |         |  |  |
| MPIE       | [7]      | MPIE holds the value of the MIE bit prior to a trap.                                                                                                                                    | RW    | 0       |   |          |   |         |  |  |
| MPP        | [12:11]  | MPP holds the privilege mode prior to a trap.<br>Encoding is in Table 4. When U-mode is not available, this field is hard-wired to 3.                                                   | WLRL  | 3       |   |          |   |         |  |  |

| Field Name | Bits    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Type  | Reset   |   |     |   |         |   |       |   |       |      |   |
|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-----|---|---------|---|-------|---|-------|------|---|
| FS         | [14:13] | <p>FS holds the status of the architectural states of the floating point unit, including the fcsr CSR and f0–f31 floating-point data registers. The value of this field is zero and read-only if the processor does not have FPU.</p> <p>This field is primarily managed by software. The processor hardware assists the state managements in two regards:</p> <ul style="list-style-type: none"> <li>Illegal instruction exceptions are triggered when FS is Off.</li> <li>FS is updated to the Dirty state with the execution of floating point instructions when FS is not Off.</li> </ul> <p>Changing the setting of this field has no effect on the contents of the floating-point register states. In particular, setting FS to Off does not destroy the states, nor does setting FS to Initial clear the contents.</p> <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Off</td></tr> <tr> <td>1</td><td>Initial</td></tr> <tr> <td>2</td><td>Clean</td></tr> <tr> <td>3</td><td>Dirty</td></tr> </tbody> </table> | Value | Meaning | 0 | Off | 1 | Initial | 2 | Clean | 3 | Dirty | WLRL | 0 |
| Value      | Meaning |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |     |   |         |   |       |   |       |      |   |
| 0          | Off     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |     |   |         |   |       |   |       |      |   |
| 1          | Initial |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |     |   |         |   |       |   |       |      |   |
| 2          | Clean   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |     |   |         |   |       |   |       |      |   |
| 3          | Dirty   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |     |   |         |   |       |   |       |      |   |

| Field Name | Bits    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Type  | Reset   |   |     |   |         |   |       |   |       |    |   |
|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-----|---|---------|---|-------|---|-------|----|---|
| XS         | [16:15] | <p>XS holds the status of the architectural states (ACE registers) of ACE instructions. The value of this field is zero if ACE extension is not configured.</p> <p>This field is primarily managed by software. The processor hardware assists the state managements in two regards:</p> <ul style="list-style-type: none"> <li>Illegal instruction exceptions are triggered when XS is Off.</li> <li>XS is updated to the Dirty state with the execution of ACE instructions when XS is not Off.</li> </ul> <p>Changing the setting of this field has no effect on the contents of ACE states. In particular, setting XS to Off does not destroy the states, nor does setting XS to Initial clear the contents.</p> <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Off</td></tr> <tr> <td>1</td><td>Initial</td></tr> <tr> <td>2</td><td>Clean</td></tr> <tr> <td>3</td><td>Dirty</td></tr> </tbody> </table> | Value | Meaning | 0 | Off | 1 | Initial | 2 | Clean | 3 | Dirty | RO | 0 |
| Value      | Meaning |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |     |   |         |   |       |   |       |    |   |
| 0          | Off     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |     |   |         |   |       |   |       |    |   |
| 1          | Initial |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |     |   |         |   |       |   |       |    |   |
| 2          | Clean   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |     |   |         |   |       |   |       |    |   |
| 3          | Dirty   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |     |   |         |   |       |   |       |    |   |
| MPRV       | [17]    | When the MPRV bit is set, the memory access privilege for load and store are specified by the MPP field.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RW    | 0       |   |     |   |         |   |       |   |       |    |   |
| SD         | [31]    | SD summarizes whether either the FS field or XS field is dirty.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RO    | 0       |   |     |   |         |   |       |   |       |    |   |

### 18.3.2 Machine ISA Register

**Mnemonic Name:** misa

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x301 (standard read/write)



| Field Name                                                                                                                                                                                                                     | Bits     | Description                                                        | Type | Reset |         |   |          |   |    |   |    |   |     |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------------------------------------------------------|------|-------|---------|---|----------|---|----|---|----|---|-----|--|
| Extensions                                                                                                                                                                                                                     | [25:0]   | See Table 71.                                                      | RO   | IM    |         |   |          |   |    |   |    |   |     |  |
| Base                                                                                                                                                                                                                           | [31:30]  | The general purpose register width of the native base integer ISA. | RO   | 1     |         |   |          |   |    |   |    |   |     |  |
| <table border="1"><thead><tr><th>Value</th><th>Meaning</th></tr></thead><tbody><tr><td>0</td><td>Reserved</td></tr><tr><td>1</td><td>32</td></tr><tr><td>2</td><td>64</td></tr><tr><td>3</td><td>128</td></tr></tbody></table> |          |                                                                    |      | Value | Meaning | 0 | Reserved | 1 | 32 | 2 | 64 | 3 | 128 |  |
| Value                                                                                                                                                                                                                          | Meaning  |                                                                    |      |       |         |   |          |   |    |   |    |   |     |  |
| 0                                                                                                                                                                                                                              | Reserved |                                                                    |      |       |         |   |          |   |    |   |    |   |     |  |
| 1                                                                                                                                                                                                                              | 32       |                                                                    |      |       |         |   |          |   |    |   |    |   |     |  |
| 2                                                                                                                                                                                                                              | 64       |                                                                    |      |       |         |   |          |   |    |   |    |   |     |  |
| 3                                                                                                                                                                                                                              | 128      |                                                                    |      |       |         |   |          |   |    |   |    |   |     |  |

**Table 18-11 RISC-V Definition of the Extensions Field**

| Bit   | Extension | Description                                                                |
|-------|-----------|----------------------------------------------------------------------------|
| 0     | A         | Atomic extension                                                           |
| 1     | B         | <i>Tentatively reserved for Bit operations extension</i>                   |
| 2     | C         | Compressed extension                                                       |
| 3     | D         | Double-precision floating-point extension                                  |
| 4     | E         | RV32E base ISA                                                             |
| 5     | F         | Single-precision floating-point extension                                  |
| 6     | G         | Additional standard extensions present                                     |
| 7     | H         | Reserved                                                                   |
| 8     | I         | RV32I/64I/128I base ISA                                                    |
| 9     | J         | <i>Tentatively reserved for Dynamically Translated Languages extension</i> |
| 10    | K         | Reserved                                                                   |
| 11    | L         | <i>Tentatively reserved for Decimal Floating-Point extension</i>           |
| 12    | M         | Integer Multiply/Divide extension                                          |
| <hr/> |           |                                                                            |
| Bit   | Extension | Description                                                                |
| 13    | N         | User-level interrupts supported                                            |
| 14    | O         | Reserved                                                                   |
| 15    | P         | <i>Tentatively reserved for Packed-SIMD extension</i>                      |
| 16    | Q         | Quad-precision floating-point extension                                    |
| 17    | R         | Reserved                                                                   |
| 18    | S         | Supervisor mode implemented                                                |
| 19    | T         | <i>Tentatively reserved for Transactional Memory extension</i>             |
| 20    | U         | User mode implemented                                                      |
| 21    | V         | <i>Tentatively reserved for Vector extension</i>                           |
| 22    | W         | Reserved                                                                   |
| 23    | X         | Non-standard extensions present                                            |
| 24    | Y         | Reserved                                                                   |
| 25    | Z         | Reserved                                                                   |

### 18.3.3 Machine Exception Delegation

**Mnemonic Name:** medeleg

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x302 (standard read/write)



| Field Name | Bits         | Description                                                                                                                                                                            | Type  | Reset   |   |              |   |          |  |  |
|------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|--------------|---|----------|--|--|
| IAM        | [0]          | IAM indicates whether an instruction address misaligned exception will be delegated to S-mode.                                                                                         | RW    | 0       |   |              |   |          |  |  |
|            |              | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | Value | Meaning | 0 | Not delegate | 1 | delegate |  |  |
| Value      | Meaning      |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 0          | Not delegate |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 1          | delegate     |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| IAF        | [1]          | IAF indicates whether an instruction access fault exception will be delegated to S-mode.                                                                                               | RW    | 0       |   |              |   |          |  |  |
|            |              | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | Value | Meaning | 0 | Not delegate | 1 | delegate |  |  |
| Value      | Meaning      |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 0          | Not delegate |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 1          | delegate     |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| II         | [2]          | II indicates whether an illegal instruction exception will be delegated to S-mode.                                                                                                     | RW    | 0       |   |              |   |          |  |  |
|            |              | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | Value | Meaning | 0 | Not delegate | 1 | delegate |  |  |
| Value      | Meaning      |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 0          | Not delegate |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 1          | delegate     |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| B          | [3]          | B indicates whether an exception triggered by breakpoint will be delegated to S-mode.                                                                                                  | RW    | 0       |   |              |   |          |  |  |
|            |              | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | Value | Meaning | 0 | Not delegate | 1 | delegate |  |  |
| Value      | Meaning      |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 0          | Not delegate |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 1          | delegate     |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |

| <b>Field Name</b> | <b>Bits</b>    | <b>Description</b>                                                                                                                                                                                   | <b>Type</b>  | <b>Reset</b>   |   |              |   |          |  |  |
|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------|---|--------------|---|----------|--|--|
| LAM               | [4]            | LAM indicates whether a load address misaligned exception will be delegated to S-mode.                                                                                                               | RW           | 0              |   |              |   |          |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Not delegate | 1 | delegate |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| 0                 | Not delegate   |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| 1                 | delegate       |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| LAF               | [5]            | LAF indicates whether a load access fault exception will be delegated to S-mode.                                                                                                                     | RW           | 0              |   |              |   |          |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Not delegate | 1 | delegate |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| 0                 | Not delegate   |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| 1                 | delegate       |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| SAM               | [6]            | SAM indicates whether a store/AMO address misaligned exception will be delegated to S-mode.                                                                                                          | RW           | 0              |   |              |   |          |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Not delegate | 1 | delegate |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| 0                 | Not delegate   |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| 1                 | delegate       |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| SAF               | [7]            | SAF indicates whether a store/AMO access fault exception will be delegated to S-mode.                                                                                                                | RW           | 0              |   |              |   |          |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Not delegate | 1 | delegate |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| 0                 | Not delegate   |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| 1                 | delegate       |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| UEC               | [8]            | UEC indicates whether an exception triggered by environment call from U-mode will be delegated to S-mode.                                                                                            | RW           | 0              |   |              |   |          |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Not delegate | 1 | delegate |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| 0                 | Not delegate   |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |
| 1                 | delegate       |                                                                                                                                                                                                      |              |                |   |              |   |          |  |  |

| Field Name | Bits         | Description                                                                                                                                                                            | Type  | Reset   |   |              |   |          |  |  |
|------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|--------------|---|----------|--|--|
| SEC        | [9]          | SEC indicates whether an instruction exception triggered by environment call from S-mode will be delegated to S-mode.                                                                  | RW    | 0       |   |              |   |          |  |  |
|            |              | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | Value | Meaning | 0 | Not delegate | 1 | delegate |  |  |
| Value      | Meaning      |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 0          | Not delegate |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 1          | delegate     |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| IPF        | [12]         | IPF indicates whether an instruction page fault exception will be delegated to S-mode.                                                                                                 | RW    | 0       |   |              |   |          |  |  |
|            |              | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | Value | Meaning | 0 | Not delegate | 1 | delegate |  |  |
| Value      | Meaning      |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 0          | Not delegate |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 1          | delegate     |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| LPF        | [13]         | LPF indicates whether a load page fault exception will be delegated to S-mode.                                                                                                         | RW    | 0       |   |              |   |          |  |  |
|            |              | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | Value | Meaning | 0 | Not delegate | 1 | delegate |  |  |
| Value      | Meaning      |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 0          | Not delegate |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 1          | delegate     |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| SPF        | [15]         | SPF indicates whether a store/AMO page fault exception will be delegated to S-mode.                                                                                                    | RW    | 0       |   |              |   |          |  |  |
|            |              | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | Value | Meaning | 0 | Not delegate | 1 | delegate |  |  |
| Value      | Meaning      |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 0          | Not delegate |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 1          | delegate     |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |

When supervisor mode is not supported, all bits in medeleg are hard-wired to zero.

### 18.3.4 Machine Interrupt Delegation

**Mnemonic Name:** mideleg

**IM Requirement:** Required

**Access Mode:** Supervisor

**CSR Address:** 0x303 (standard read/write)



| Field Name | Bits         | Description                                                                                                                                                                            | Type  | Reset   |   |              |   |          |  |  |
|------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|--------------|---|----------|--|--|
| SSI        | [1]          | SSI indicates whether an S-mode software interrupt will be delegated to S-mode.                                                                                                        | RW    | 0       |   |              |   |          |  |  |
|            |              | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | Value | Meaning | 0 | Not delegate | 1 | delegate |  |  |
| Value      | Meaning      |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 0          | Not delegate |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 1          | delegate     |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| STI        | [5]          | STI indicates whether an S-mode timer interrupt will be delegated to S-mode.                                                                                                           | RW    | 0       |   |              |   |          |  |  |
|            |              | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | Value | Meaning | 0 | Not delegate | 1 | delegate |  |  |
| Value      | Meaning      |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 0          | Not delegate |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 1          | delegate     |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| SEI        | [9]          | SEI indicates whether an S-mode external interrupt will be delegated to S-mode.                                                                                                        | RW    | 0       |   |              |   |          |  |  |
|            |              | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not delegate</td></tr> <tr> <td>1</td><td>delegate</td></tr> </tbody> </table> | Value | Meaning | 0 | Not delegate | 1 | delegate |  |  |
| Value      | Meaning      |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 0          | Not delegate |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |
| 1          | delegate     |                                                                                                                                                                                        |       |         |   |              |   |          |  |  |

When supervisor mode is not supported, all bits in sideleg are hard-wired to zero.

### 18.3.5 Machine Interrupt Enable

Mnemonic Name: mie

IM Requirement: Required

Access Mode: Machine

CSR Address: 0x304 (standard read/write)

| 31 | 19    | 18   | 17     | 16 | 15   | 12 | 11   | 10 | 8    | 7 | 6 | 4 | 3 | 2 | 0 |
|----|-------|------|--------|----|------|----|------|----|------|---|---|---|---|---|---|
| 0  | PMOVI | BWEI | IMECCI | 0  | MEIE | 0  | MTIE | 0  | MSIE | 0 |   |   |   |   |   |

| Field Name | Bits     | Description                                                                                                                                                                       | Type  | Reset   |   |          |   |         |  |  |
|------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|----------|---|---------|--|--|
| MSIE       | [3]      | M-mode software interrupt enable bit.                                                                                                                                             | RW    | 0       |   |          |   |         |  |  |
|            |          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disabled</td></tr> <tr> <td>1</td><td>Enabled</td></tr> </tbody> </table> | Value | Meaning | 0 | Disabled | 1 | Enabled |  |  |
| Value      | Meaning  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 0          | Disabled |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 1          | Enabled  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| MTIE       | [7]      | M-mode timer interrupt enable bit.                                                                                                                                                | RW    | 0       |   |          |   |         |  |  |
|            |          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disabled</td></tr> <tr> <td>1</td><td>Enabled</td></tr> </tbody> </table> | Value | Meaning | 0 | Disabled | 1 | Enabled |  |  |
| Value      | Meaning  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 0          | Disabled |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 1          | Enabled  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| MEIE       | [11]     | M-mode external interrupt enable bit.                                                                                                                                             | RW    | 0       |   |          |   |         |  |  |
|            |          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disabled</td></tr> <tr> <td>1</td><td>Enabled</td></tr> </tbody> </table> | Value | Meaning | 0 | Disabled | 1 | Enabled |  |  |
| Value      | Meaning  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 0          | Disabled |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 1          | Enabled  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| IMECCI     | [16]     | Imprecise ECC error local interrupt enable bit.<br>The processor may receive imprecise ECC error on slave port accesses or cache writebacks.                                      | RW    | 0       |   |          |   |         |  |  |
|            |          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disabled</td></tr> <tr> <td>1</td><td>Enabled</td></tr> </tbody> </table> | Value | Meaning | 0 | Disabled | 1 | Enabled |  |  |
| Value      | Meaning  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 0          | Disabled |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 1          | Enabled  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| Field Name | Bits     | Description                                                                                                                                                                       | Type  | Reset   |   |          |   |         |  |  |
| BWEI       | [17]     | Bus-write transaction error local interrupt enable bit. The processor may receive bus-write errors on store instructions or cache writebacks.                                     | RW    | 0       |   |          |   |         |  |  |
|            |          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disabled</td></tr> <tr> <td>1</td><td>Enabled</td></tr> </tbody> </table> | Value | Meaning | 0 | Disabled | 1 | Enabled |  |  |
| Value      | Meaning  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 0          | Disabled |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 1          | Enabled  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| PMOVI      | [18]     | Performance monitor overflow local interrupt enable bit.                                                                                                                          | RW    | 0       |   |          |   |         |  |  |
|            |          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disabled</td></tr> <tr> <td>1</td><td>Enabled</td></tr> </tbody> </table> | Value | Meaning | 0 | Disabled | 1 | Enabled |  |  |
| Value      | Meaning  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 0          | Disabled |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 1          | Enabled  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |

Each local interrupt can be configured with a local interrupt number. Bit location of interrupts are the same as their interrupt numbers. Register fields above show the default bit location.

### 18.3.6 Machine Interrupt Pending

**Mnemonic Name:** mip

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x344 (standard read/write)

| 31 | 19 | 18    | 17   | 16     | 15 | 12   | 11 | 10   | 8 | 7    | 6 | 4 | 3 | 2 | 0 |
|----|----|-------|------|--------|----|------|----|------|---|------|---|---|---|---|---|
| 0  |    | PMOVI | BWEI | IMECCI | 0  | MEIP | 0  | MTIP | 0 | MSIP | 0 |   |   |   |   |

| Field Name | Bits        | Description                                                                                                                                                                          | Type  | Reset   |   |             |   |         |  |  |
|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-------------|---|---------|--|--|
| MSIP       | [3]         | M-mode software interrupt pending bit.                                                                                                                                               | RO    | 0       |   |             |   |         |  |  |
|            |             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not pending</td></tr> <tr> <td>1</td><td>Pending</td></tr> </tbody> </table> | Value | Meaning | 0 | Not pending | 1 | Pending |  |  |
| Value      | Meaning     |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| 0          | Not pending |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| 1          | Pending     |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| MTIP       | [7]         | M-mode timer interrupt pending bit.                                                                                                                                                  | RO    | 0       |   |             |   |         |  |  |
|            |             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not pending</td></tr> <tr> <td>1</td><td>Pending</td></tr> </tbody> </table> | Value | Meaning | 0 | Not pending | 1 | Pending |  |  |
| Value      | Meaning     |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| 0          | Not pending |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| 1          | Pending     |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| MEIP       | [11]        | M-mode external interrupt pending bit.                                                                                                                                               | RO    | 0       |   |             |   |         |  |  |
|            |             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not pending</td></tr> <tr> <td>1</td><td>Pending</td></tr> </tbody> </table> | Value | Meaning | 0 | Not pending | 1 | Pending |  |  |
| Value      | Meaning     |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| 0          | Not pending |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| 1          | Pending     |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| IMECCI     | [16]        | Imprecise ECC error local interrupt enable bit.<br>The processor may receive imprecise ECC error on slave port accesses or cache writebacks.                                         | RO    | 0       |   |             |   |         |  |  |
|            |             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not pending</td></tr> <tr> <td>1</td><td>Pending</td></tr> </tbody> </table> | Value | Meaning | 0 | Not pending | 1 | Pending |  |  |
| Value      | Meaning     |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| 0          | Not pending |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| 1          | Pending     |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| Field Name | Bits        | Description                                                                                                                                                                          | Type  | Reset   |   |             |   |         |  |  |
| BWEI       | [17]        | Bus-write transaction error local interrupt pending bit. The processor may receive bus-write errors on store instructions or cache writebacks.                                       | RO    | 0       |   |             |   |         |  |  |
|            |             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not pending</td></tr> <tr> <td>1</td><td>Pending</td></tr> </tbody> </table> | Value | Meaning | 0 | Not pending | 1 | Pending |  |  |
| Value      | Meaning     |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| 0          | Not pending |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| 1          | Pending     |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| PMOVI      | [18]        | Performance monitor overflow local interrupt pending bit.                                                                                                                            | RO    | 0       |   |             |   |         |  |  |
|            |             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not pending</td></tr> <tr> <td>1</td><td>Pending</td></tr> </tbody> </table> | Value | Meaning | 0 | Not pending | 1 | Pending |  |  |
| Value      | Meaning     |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| 0          | Not pending |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |
| 1          | Pending     |                                                                                                                                                                                      |       |         |   |             |   |         |  |  |

Each local interrupt can be configured with a local interrupt number. Bit location of interrupts are the same as their interrupt numbers. Register fields above show the default bit location.

### 18.3.7 Machine Trap Vector Base Address

**Mnemonic Name:** mtvec

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x305 (standard read/write)



This register determines the base address of the trap vector. The least significant 2 bits are hard-wired to zeros. When the configured address width is less than 32, the upper bits are hard-wired to zeros.

When mmisc\_ctl.VEC\_PLIC is 0 (PLIC is not in the vector mode), this register indicates the entry points for the trap handler and it may point to any 4-byte aligned location in the memory space.

On the other hand, when mmisc\_ctl.VEC\_PLIC is 1 (PLIC is in the vector mode), this register will be the base address of a vector table with 4-byte entries storing addresses pointing to interrupt service routines. And this register should be aligned to  $2^{\text{ceiling}(\log_2(N))+2}$ -byte boundary for PLIC with N interrupt sources. For example, if N is 1023, the minimum alignment requirement is 4096 bytes (4KiB).

| Field Name | Bits   | Description                                                                                                                          | Type | Reset |
|------------|--------|--------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| BASE[31:2] | [31:2] | Base address for interrupt and exception handlers. See description above for alignment requirements when PLIC is in the vector mode. | RW   | 0     |

### 18.3.8 Machine Exception Program Counter

**Mnemonic Name:** mepc

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x341 (standard read/write)



This register is written with the virtual address of the instruction that encountered traps and/or NMIs when these events occurred.

| Field Name | Bits   | Description                | Type | Reset |
|------------|--------|----------------------------|------|-------|
| EPC        | [31:1] | Exception program counter. | RW   | 0     |

### 18.3.9 Machine Cause Register

**Mnemonic Name:** mcause

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x342 (standard read/write)



This register indicates the cause of trap, reset, NMI or the interrupt source ID of vector interrupt. This register is updated when trap, reset, NMI or vector interrupt occurs.

| Field Name     | Bits  | Description     | Type | Reset |
|----------------|-------|-----------------|------|-------|
| EXCEPTION_CODE | [9:0] | Exception Code. | RW   | 0     |
| INTERRUPT      | [31]  | Interrupt.      | RW   | 0     |

Each local interrupt can be configured with a local interrupt number. Cause number of interrupts are the same as their interrupt numbers for M-mode local interrupts. Cause numbers below show the default cause numbers of local interrupts.

Table 18-12 N25(F) mcause Value after Trap

| Interrupt | Exception Code | Description                                                                                                   |
|-----------|----------------|---------------------------------------------------------------------------------------------------------------|
| 1         | 3              | Machine software interrupt                                                                                    |
| 1         | 7              | Machine timer interrupt                                                                                       |
| 1         | 11             | Machine external interrupt                                                                                    |
| 1         | 16             | Slave port ECC error interrupt (M-mode)                                                                       |
| 1         | 17             | Bus write transaction error interrupt (M-mode)                                                                |
| 1         | 18             | Performance monitor overflow interrupt(M-mode)                                                                |
| 0         | 0              | Instruction address misaligned                                                                                |
| 0         | 1              | Instruction access fault                                                                                      |
| 0         | 2              | Illegal instruction                                                                                           |
| 0         | 3              | Breakpoint                                                                                                    |
| 0         | 4              | Load address misaligned                                                                                       |
| 0         | 5              | Load access fault                                                                                             |
| 0         | 6              | Store/AMO address misaligned                                                                                  |
| 0         | 7              | Store/AMO access fault                                                                                        |
| 0         | 8              | Environment call from U-mode                                                                                  |
| 0         | 9              | Environment call from S-mode                                                                                  |
| 0         | 10             | Reserved                                                                                                      |
| 0         | 11             | Environment call from M-mode                                                                                  |
| 0         | 12             | Instruction page fault                                                                                        |
| 0         | 13             | Load page fault                                                                                               |
| 0         | 14             | Reserved                                                                                                      |
| 0         | 15             | Store/AMO page fault                                                                                          |
| 0         | 32             | Stack overflow exception                                                                                      |
| 0         | 33             | Stack underflow exception                                                                                     |
| 0         | 40-47          | Andes Custom Extension exception (see <i>AndeStar Custom Extension Specification CUM009</i> for more details) |

**Table 18-13 N25(F) mcause Value after Reset**

| Interrupt | Exception Code | Description           |
|-----------|----------------|-----------------------|
| 0         | 0              | Reset by core_reset_n |

**Table 18-14 N25(F) mcause Value after NMI**

| Interrupt | Exception Code | Description   |
|-----------|----------------|---------------|
| 0         | 1              | NMI triggered |

**Table 18-15 N25(F) mcause Value after Vector Interrupt**

| mcause              | Description                                      |
|---------------------|--------------------------------------------------|
| Interrupt source ID | Interrupt source ID when vector interrupt occurs |

### 18.3.10 Machine Trap Value

**Mnemonic Name:** mtval

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x343 (standard read/write)



This register is updated when a trap is taken to M-mode. The updated value is dependent on the cause of traps:

- For hardware breakpoint exceptions, address-misaligned exceptions, access-fault exceptions, or page-fault exceptions, it is the effective faulting addresses.
- For illegal instruction exceptions, the updated value is the faulting instruction. If the length of the instruction is less than XLEN bits long, the upper bits of mtval are cleared to zero.
- For other exceptions, mtval is set to zero.

For instruction-fetch access faults, this register will be updated with the address pointing to the portion of the instruction that caused the fault, while the mepc register will be updated with the address pointing to the beginning of the instruction.

When the configured address width is less than 32, the upper bits are hard-wired to zeros.

| Field Name | Bits   | Description                                                | Type | Reset |
|------------|--------|------------------------------------------------------------|------|-------|
| MTVAL      | [31:0] | Exception-specific information for software trap handling. | RW   | 0     |

### 18.3.11 Machine Scratch Register

**Mnemonic Name:** mscratch

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x340 (standard read/write)



This is a scratch register for temporary data storage, which is typically used by the M-mode trap handler.

| Field Name | Bits   | Description               | Type | Reset |
|------------|--------|---------------------------|------|-------|
| MSCRATCH   | [31:0] | Scratch register storage. | RW   | 0     |

### 18.3.12 Machine Extended Status

**Mnemonic Name:** mxstatus

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x7c4 (non-standard read/write)



| Field Name | Bits | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Type | Reset |
|------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| PFT_EN     | [0]  | Enable performance throttling. When throttling is enabled, the processor executes instructions at the performance level specified in mpft_ctl.T_LEVEL. On entering a trap: <ul style="list-style-type: none"><li>• PPFT_EN ← PFT_EN;</li><li>• PFT_EN ← (mpft_ctl.FAST_INT) ? 0 : PFT_EN;</li></ul> On executing a MRET instruction: <ul style="list-style-type: none"><li>• PFT_EN ← PPFT_EN;</li></ul> This field is hard-wired to 0 if the PowerBrake feature is not supported. | RW   | 0     |
| PPFT_EN    | [1]  | For saving previous PFT_EN state on entering a trap. This field is hard-wired to 0 if the PowerBrake feature is not supported.                                                                                                                                                                                                                                                                                                                                                     | RW   | 0     |
| IME        | [2]  | Instruction Machine Error flag. It indicates an exception occurred at the instruction cache or instruction local memory (ILM).                                                                                                                                                                                                                                                                                                                                                     | RW   | 0     |
| PIME       | [3]  | For saving previous IME state on entering a trap. This field is hard-wired to 0 if cache and local memory are not supported.                                                                                                                                                                                                                                                                                                                                                       | RW   | 0     |
| DME        | [4]  | Data Machine Error flag. It indicates an exception occurred at the data cache or data local memory (DLM).                                                                                                                                                                                                                                                                                                                                                                          | RW   | 0     |
| PDME       | [5]  | For saving previous DME state on entering a trap. This field is hard-wired to 0 if cache and local memory are not supported.                                                                                                                                                                                                                                                                                                                                                       | RW   | 0     |

### 18.3.13 Machine Detailed Trap Cause

**Mnemonic Name:** mdcause

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x7c9 (non-standard read/write)

| Field Name                                                                                                                                                                                                                                                                                      | Bits                             | Description                                                                          | Type | Reset |         |   |                        |   |                       |   |                                  |   |           |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--------------------------------------------------------------------------------------|------|-------|---------|---|------------------------|---|-----------------------|---|----------------------------------|---|-----------|--|
| MDCAUSE                                                                                                                                                                                                                                                                                         | [1:0]                            | This register further disambiguates causes of traps recorded in the mcause register: | RW   | 0     |         |   |                        |   |                       |   |                                  |   |           |  |
| <ul style="list-style-type: none"> <li>When mcause == 1 (Instruction access fault)</li> </ul>                                                                                                                                                                                                   |                                  |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Reserved</td></tr> <tr> <td>1</td><td>ECC/Parity error</td></tr> <tr> <td>2</td><td>PMP instruction access violation</td></tr> <tr> <td>3</td><td>Bus error</td></tr> </tbody> </table> |                                  |                                                                                      |      | Value | Meaning | 0 | Reserved               | 1 | ECC/Parity error      | 2 | PMP instruction access violation | 3 | Bus error |  |
| Value                                                                                                                                                                                                                                                                                           | Meaning                          |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 0                                                                                                                                                                                                                                                                                               | Reserved                         |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 1                                                                                                                                                                                                                                                                                               | ECC/Parity error                 |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 2                                                                                                                                                                                                                                                                                               | PMP instruction access violation |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 3                                                                                                                                                                                                                                                                                               | Bus error                        |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| <ul style="list-style-type: none"> <li>When mcause == 2 (Illegal instruction)</li> </ul>                                                                                                                                                                                                        |                                  |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Please parse mtval CSR</td></tr> <tr> <td>1</td><td>FP disabled exception</td></tr> <tr> <td>2</td><td>ACE disabled exception</td></tr> </tbody> </table>                               |                                  |                                                                                      |      | Value | Meaning | 0 | Please parse mtval CSR | 1 | FP disabled exception | 2 | ACE disabled exception           |   |           |  |
| Value                                                                                                                                                                                                                                                                                           | Meaning                          |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 0                                                                                                                                                                                                                                                                                               | Please parse mtval CSR           |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 1                                                                                                                                                                                                                                                                                               | FP disabled exception            |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 2                                                                                                                                                                                                                                                                                               | ACE disabled exception           |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| <ul style="list-style-type: none"> <li>When mcause == 5 (Load access fault)</li> </ul>                                                                                                                                                                                                          |                                  |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Reserved</td></tr> <tr> <td>1</td><td>ECC/Parity error</td></tr> <tr> <td>2</td><td>PMP load access violation</td></tr> <tr> <td>3</td><td>Bus error</td></tr> </tbody> </table>        |                                  |                                                                                      |      | Value | Meaning | 0 | Reserved               | 1 | ECC/Parity error      | 2 | PMP load access violation        | 3 | Bus error |  |
| Value                                                                                                                                                                                                                                                                                           | Meaning                          |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 0                                                                                                                                                                                                                                                                                               | Reserved                         |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 1                                                                                                                                                                                                                                                                                               | ECC/Parity error                 |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 2                                                                                                                                                                                                                                                                                               | PMP load access violation        |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 3                                                                                                                                                                                                                                                                                               | Bus error                        |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| <ul style="list-style-type: none"> <li>When mcause == 7 (Store access fault)</li> </ul>                                                                                                                                                                                                         |                                  |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Reserved</td></tr> <tr> <td>1</td><td>ECC/Parity error</td></tr> <tr> <td>2</td><td>PMP store access violation</td></tr> <tr> <td>3</td><td>Bus error</td></tr> </tbody> </table>       |                                  |                                                                                      |      | Value | Meaning | 0 | Reserved               | 1 | ECC/Parity error      | 2 | PMP store access violation       | 3 | Bus error |  |
| Value                                                                                                                                                                                                                                                                                           | Meaning                          |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 0                                                                                                                                                                                                                                                                                               | Reserved                         |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 1                                                                                                                                                                                                                                                                                               | ECC/Parity error                 |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 2                                                                                                                                                                                                                                                                                               | PMP store access violation       |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| 3                                                                                                                                                                                                                                                                                               | Bus error                        |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |
| <ul style="list-style-type: none"> <li>For other exceptions and interrupts, this register will not be updated.</li> </ul>                                                                                                                                                                       |                                  |                                                                                      |      |       |         |   |                        |   |                       |   |                                  |   |           |  |

## 18.4 Counter Related CSRs

### 18.4.1 Machine Cycle Counter

**Mnemonic Name:** mcycle and mcycleh

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0xb00 and 0xb80 (standard read/write)

The mcycle CSR counts the number of cycles that the hart has executed since some arbitrary time in the past. The mcycle register has 64-bit precision. For RV32 processors like N25(F), reads of the mcycle CSR return the lower 32 bits, while reads of the mcycleh CSR return bits 63–32 of the mcycle CSR.

### 18.4.2 Machine Instruction-Retired Counter

**Mnemonic Name:** minstret and minstreth

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0xb02 and 0xb82 (standard read/write)

The minstret CSR counts the number of instructions that the hart has retired since some arbitrary time in the past. The minstret register has 64-bit precision. For RV32 processors like N25(F), reads of the minstret CSR return the low 32 bits, while reads of the minstreth CSR return bits 63–32 of the minstret CSR.

### 18.4.3 Machine Performance Monitoring Counter

**Mnemonic Name:** mhpcounter3–mhpcounter6 and mhpcounter3h–mhpcounter6h

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0xb03 to 0xb06 and 0xb83 to 0xb86 (standard read/write)

The mhpcounter3–mhpcounter6 and mhpcounter3h–mhpcounter6h CSRs count the number of selected events, which are selected by mhpmevent3–mhpmevent6.

### 18.4.4 Machine Performance Monitoring Event Selector

**Mnemonic Name:** mhpmevent3–mhpmevent6

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x323 to 0x326 (standard read/write)

The event selectors are defined in Table 18-16 Event Selectors.

Micro-architectural events are mostly speculative in nature. The counted events could include events caused by speculative actions, unless they are defined to be non-speculative in the comment section. In particular, retired instruction counts are non-speculative counts.

**Table 18-16 Event Selectors**

| TYPE | SEL | Event Name                                 | Comment                                                                                                                                                                     |
|------|-----|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 1   | Cycle count                                | Number of elapsed processor clock cycles.                                                                                                                                   |
| 0    | 2   | Retired instruction count                  | Number of retired instructions.                                                                                                                                             |
| 0    | 3   | Integer load instruction count             | Number of retired load instructions (including LR).                                                                                                                         |
| 0    | 4   | Integer store instruction count            | Number of retired store instructions (including SC).                                                                                                                        |
| 0    | 5   | Atomic instruction count                   | Number of retired atomic instructions (LR and SC not included).                                                                                                             |
| 0    | 6   | System instruction count                   | Number of retired SYSTEM instructions (instructions with major opcode equal to 0b1110011).                                                                                  |
| 0    | 7   | Integer computational instruction count    | Number of retired integer computational instructions.                                                                                                                       |
| 0    | 8   | Conditional branch instruction count       | Number of retired conditional branch instructions.                                                                                                                          |
| 0    | 9   | Taken conditional branch instruction count | Number of retired conditional branch instructions that are taken.                                                                                                           |
| 0    | 10  | JAL instruction count                      | Number of retired JAL instructions.                                                                                                                                         |
| 0    | 11  | JALR instruction count                     | Number of retired JALR instructions.<br>This event selector also counts the events monitored by the <i>return instruction count</i> event selector defined in the next row. |

| TYPE | SEL | Event Name                                               | Comment                                                                                                                                                                                                                                                                   |
|------|-----|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 12  | Return instruction count                                 | Number of retired return instructions. Return instructions are JALR instructions with the following operands:<br><ul style="list-style-type: none"> <li>• (rd != x1/x5) and (rs1 == x1/x5)</li> <li>• rd == x1 and rs1 == x5</li> <li>• rd == x5 and rs1 == x1</li> </ul> |
| 0    | 13  | Control transfer instruction count                       | Number of retired unconditional jumps (JAL and JALR) and conditional branch instructions.                                                                                                                                                                                 |
| 0    | 14  | EXEC.IT instruction count                                | Number of retired EXEC.IT instructions.                                                                                                                                                                                                                                   |
| 0    | 15  | Integer multiplication instruction count                 | Number of retired integer multiplication instructions.                                                                                                                                                                                                                    |
| 0    | 16  | Integer division instruction count                       | Number of retired integer division/remainder instructions.                                                                                                                                                                                                                |
| 0    | 17  | Floating-point load instruction count                    | Number of retired floating-point load instructions.                                                                                                                                                                                                                       |
| 0    | 18  | Floating-point store instruction count                   | Number of retired floating-point store instructions.                                                                                                                                                                                                                      |
| 0    | 19  | Floating-point addition instruction count                | Number of retired floating-point addition/subtraction instructions.                                                                                                                                                                                                       |
| 0    | 20  | Floating-point multiplication instruction count          | Number of retired floating-point multiplication instructions.                                                                                                                                                                                                             |
| 0    | 21  | Floating-point fused multiply-add instruction count      | Number of retired floating-point fused multiply-add/subtraction instructions (FMADD, FMSUB, FNMSUB, FNMMADD).                                                                                                                                                             |
| 0    | 22  | Floating-point division or square-root instruction count | Number of retired floating-point division/square-root instructions.                                                                                                                                                                                                       |
| 0    | 23  | Other floating-point instruction count                   | Number of retired floating-point instructions not counted by the previous floating-point instruction event selectors.                                                                                                                                                     |

### 18.4.5 Machine Counter Enable

**Mnemonic Name:** mcounteren

**IM Requirement:** Required if User mode is implemented

**Access Mode:** Machine

**CSR Address:** 0x306 (standard read/write)



The machine counter-enable register controls the availability of the hardware performance monitoring counters to the next-lowest privileged mode.

When CY, TM, IR, HPM3, HPM4, HPM5, or HPM6 in the mcounteren register is clear, attempts to read the cycle, time, instret, hpmcounter3, hpmcounter4, hpmcounter5, or hpmcounter6 registers while executing in

U-mode (M/U configuration) or S-mode (M/S/U configuration) will cause an illegal instruction exception. When one of these bits is set, accessing to the corresponding register is permitted in the next implemented privilege mode.

The default value of this register is 0.

#### 18.4.6 Machine Counter Write Enable

**Mnemonic Name:** mcounterwen

**IM Requirement:** mmsc\_cfg.PMNDS == 1 and misa[20] == 1

**Access Mode:** Machine

**CSR Address:** 0x7CE (non-standard read/write)

|    |                |  |  |  |  |  |  |                                         |
|----|----------------|--|--|--|--|--|--|-----------------------------------------|
| 31 |                |  |  |  |  |  |  | 7    6    5    4    3    2    1    0    |
|    | <b>Release</b> |  |  |  |  |  |  | HPM6   HPM5   HPM4   HPM3   IR   0   CY |

The machine counter write enable register controls the permission of writing the hardware performance monitoring counters in the next-lowest privileged mode and M-mode itself.

When CY, IR, HPM3, HPM4, HPM5, or HPM6 in the mcounterwen register is clear, attempts to write the cycle, time, instret, hpmcounter3, hpmcounter4, hpmcounter5, or hpmcounter6 registers while executing in U-mode (M/U configuration) or S-mode (M/S/U configuration) will cause an illegal instruction exception. When one of these bits is set, writing to the corresponding register is permitted in the next implemented privilege mode.

The default value of this register is 0.

#### 18.4.7 Machine Counter Interrupt Enable

**Mnemonic Name:** mcounterinten

**IM Requirement:** mmsc\_cfg.PMNDS == 1

**Access Mode:** Machine

**CSR Address:** 0x7CF (non-standard read/write)

|    |                |  |  |  |  |  |  |                                         |
|----|----------------|--|--|--|--|--|--|-----------------------------------------|
| 31 |                |  |  |  |  |  |  | 7    6    5    4    3    2    1    0    |
|    | <b>Release</b> |  |  |  |  |  |  | HPM6   HPM5   HPM4   HPM3   IR   0   CY |

The machine counter interrupt enable register controls whether a counter overflow interrupt is generated or not.

When CY, IR, HPM3, HPM4, HPM5, or HPM6 in the mcounterinten register is clear, no overflow interrupt is generated for the corresponding counter. When one of these bits is set, an interrupt will be generated when the corresponding counter overflows (the counter value wraps around back to 0).

The default value of this register is 0.

#### 18.4.8 Machine Counter Mask for Machine Mode

**Mnemonic Name:** mcountermask\_m

**IM Requirement:** mmsc\_cfg.PMNDS == 1 and misa[20] == 1

**Access Mode:** Machine

**CSR Address:** 0x7D1 (non-standard read/write)

| 31 | 7    | 6    | 5    | 4    | 3  | 2 | 1  | 0 |
|----|------|------|------|------|----|---|----|---|
| 0  | HPM6 | HPM5 | HPM4 | HPM3 | IR | 0 | CY |   |

The machine counter mask for M-mode register controls the performance counter behavior in Mmode.

When CY, IR, HPM3, HPM4, HPM5, or HPM6 in the mcountermask\_m register is set, the specific counter will not be incremented in M-mode.

The setting in this register also controls the privileged mode of the overflow local interrupt when the corresponding counter overflows for the M/S/U configuration: For any bit in this register, if the corresponding counter overflows, an M-mode interrupt is triggered if the bit is zero and an S-mode interrupt is triggered if the bit is one.

On the other hand, a counter overflow will always generate an M-mode interrupt for the M/U configuration, regardless of the settings in this register.

The default value of this register is 0.

#### 18.4.9 Machine Counter Mask for Supervisor Mode

**Mnemonic Name:** mcountermask\_s

**IM Requirement:** mmsc\_cfg.PMNDS == 1 and misa[18] == 1

**Access Mode:** Machine

**CSR Address:** 0x7D2 (non-standard read/write)

| 31 | 7    | 6    | 5    | 4    | 3  | 2 | 1  | 0 |
|----|------|------|------|------|----|---|----|---|
| 0  | HPM6 | HPM5 | HPM4 | HPM3 | IR | 0 | CY |   |

The machine counter mask for S-mode register controls the performance counter behavior in S-mode. The default value of this register is 0.

#### 18.4.10 Machine Counter Mask for User Mode

**Mnemonic Name:** mcountermask\_u

**IM Requirement:** mmsc\_cfg.PMNDS == 1 and misa[20] == 1

**Access Mode:** Machine

**CSR Address:** 0x7D3 (non-standard read/write)

| 31 | 7    | 6    | 5    | 4    | 3  | 2 | 1  | 0 |
|----|------|------|------|------|----|---|----|---|
| 0  | HPM6 | HPM5 | HPM4 | HPM3 | IR | 0 | CY |   |

The machine counter mask for U-mode register controls the performance counter behavior in U-mode. The default value of this register is 0.

#### 18.4.11 Machine Counter Overflow Status

**Mnemonic Name:** mcounterovf

**IM Requirement:** mmsc\_cfg.PMNDS == 1

**Access Mode:** Machine

**CSR Address:** 0x7D4 (non-standard read/write)



The machine counter overflow status register records the overflow status of performance counters. When a bit is set, it indicates that an overflow has happened to the corresponding counter. Write 1 to each bit will clear the overflow state for the corresponding counter.

## 18.5 Configuration Control & Status Registers

### 18.5.1 Instruction Cache/Memory Configuration Register

**Mnemonic Name:** micm\_cfg

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0xfc0 (non-standard read only)



This register provides information about configurations of instruction cache and instruction memory.

| Field Name | Bits          | Description                                                                                                                                                                                                                                                                                                                                                                                    | Type  | Reset   |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
|------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|---------------|---|-------|---|-------|---|-------|---|-------|---|-------|---|-------|---|----------|--|--|
| ISET       | [2:0]         | I-Cache sets (# of cache lines per way):                                                                                                                                                                                                                                                                                                                                                       | RO    | IM      |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
|            |               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>64</td></tr> <tr><td>1</td><td>128</td></tr> <tr><td>2</td><td>256</td></tr> <tr><td>3</td><td>512</td></tr> <tr><td>4</td><td>1024</td></tr> <tr><td>5</td><td>2048</td></tr> <tr><td>6</td><td>4096</td></tr> <tr><td>7</td><td>Reserved</td></tr> </tbody> </table>                  | Value | Meaning | 0 | 64            | 1 | 128   | 2 | 256   | 3 | 512   | 4 | 1024  | 5 | 2048  | 6 | 4096  | 7 | Reserved |  |  |
| Value      | Meaning       |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 0          | 64            |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 1          | 128           |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 2          | 256           |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 3          | 512           |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 4          | 1024          |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 5          | 2048          |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 6          | 4096          |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 7          | Reserved      |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| IWAY       | [5:3]         | Associativity of I-Cache:                                                                                                                                                                                                                                                                                                                                                                      | RO    | IM      |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
|            |               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>Direct-mapped</td></tr> <tr><td>1</td><td>2-way</td></tr> <tr><td>2</td><td>3-way</td></tr> <tr><td>3</td><td>4-way</td></tr> <tr><td>4</td><td>5-way</td></tr> <tr><td>5</td><td>6-way</td></tr> <tr><td>6</td><td>7-way</td></tr> <tr><td>7</td><td>8-way</td></tr> </tbody> </table> | Value | Meaning | 0 | Direct-mapped | 1 | 2-way | 2 | 3-way | 3 | 4-way | 4 | 5-way | 5 | 6-way | 6 | 7-way | 7 | 8-way    |  |  |
| Value      | Meaning       |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 0          | Direct-mapped |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 1          | 2-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 2          | 3-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 3          | 4-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 4          | 5-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 5          | 6-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 6          | 7-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 7          | 8-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |

| Field Name | Bits                          | Description                                                                                                                                                                                                                                                                                                                                                                   | Type  | Reset   |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
|------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------------------------|---|-------------------------------|-----|----------|---|----------|---|----------|---|-----------|-----|----------|--|
| ISZ        | [8:6]                         | I-Cache block (line) size:                                                                                                                                                                                                                                                                                                                                                    | RO    | IM      |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
|            |                               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>No I-Cache</td></tr> <tr><td>1</td><td>8 bytes</td></tr> <tr><td>2</td><td>16 bytes</td></tr> <tr><td>3</td><td>32 bytes</td></tr> <tr><td>4</td><td>64 bytes</td></tr> <tr><td>5</td><td>128 bytes</td></tr> <tr><td>6,7</td><td>Reserved</td></tr> </tbody> </table> | Value | Meaning | 0 | No I-Cache                   | 1 | 8 bytes                       | 2   | 16 bytes | 3 | 32 bytes | 4 | 64 bytes | 5 | 128 bytes | 6,7 | Reserved |  |
| Value      | Meaning                       |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 0          | No I-Cache                    |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 1          | 8 bytes                       |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 2          | 16 bytes                      |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 3          | 32 bytes                      |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 4          | 64 bytes                      |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 5          | 128 bytes                     |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 6,7        | Reserved                      |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| ILCK       | [9]                           | I-Cache locking support:                                                                                                                                                                                                                                                                                                                                                      | RO    | IM      |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
|            |                               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>No locking support</td></tr> <tr><td>1</td><td>With locking support</td></tr> </tbody> </table>                                                                                                                                                                        | Value | Meaning | 0 | No locking support           | 1 | With locking support          |     |          |   |          |   |          |   |           |     |          |  |
| Value      | Meaning                       |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 0          | No locking support            |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 1          | With locking support          |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| IC_ECC     | [11:10]                       | I-Cache soft-error protection scheme:                                                                                                                                                                                                                                                                                                                                         | RO    | IM      |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
|            |                               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>No parity/ECC</td></tr> <tr><td>1</td><td>Parity</td></tr> <tr><td>2</td><td>ECC</td></tr> <tr><td>3</td><td>Reserved</td></tr> </tbody> </table>                                                                                                                      | Value | Meaning | 0 | No parity/ECC                | 1 | Parity                        | 2   | ECC      | 3 | Reserved |   |          |   |           |     |          |  |
| Value      | Meaning                       |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 0          | No parity/ECC                 |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 1          | Parity                        |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 2          | ECC                           |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 3          | Reserved                      |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| ILMB       | [14:12]                       | Number of ILM base registers present:                                                                                                                                                                                                                                                                                                                                         | RO    | IM      |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
|            |                               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>No ILM base register present</td></tr> <tr><td>1</td><td>One ILM base register present</td></tr> <tr><td>2-7</td><td>Reserved</td></tr> </tbody> </table>                                                                                                              | Value | Meaning | 0 | No ILM base register present | 1 | One ILM base register present | 2-7 | Reserved |   |          |   |          |   |           |     |          |  |
| Value      | Meaning                       |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 0          | No ILM base register present  |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 1          | One ILM base register present |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |
| 2-7        | Reserved                      |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |          |   |          |   |          |   |           |     |          |  |

| Field Name | Bits          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Type  | Reset   |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
|------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|---------------|---|--------|---|-------|---|----------|---|-------|---|--------|---|--------|---|--------|---|---------|---|---------|----|---------|----|-------|----|-------|----|-------|----|-------|----|--------|-------|----------|--|--|
| ILMSZ      | [19:15]       | ILM Size:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RO    | IM      |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
|            |               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>0 Byte</td></tr> <tr><td>1</td><td>1 KiB</td></tr> <tr><td>2</td><td>2 KiB</td></tr> <tr><td>3</td><td>4 KiB</td></tr> <tr><td>4</td><td>8 KiB</td></tr> <tr><td>5</td><td>16 KiB</td></tr> <tr><td>6</td><td>32 KiB</td></tr> <tr><td>7</td><td>64 KiB</td></tr> <tr><td>8</td><td>128 KiB</td></tr> <tr><td>9</td><td>256 KiB</td></tr> <tr><td>10</td><td>512 KiB</td></tr> <tr><td>11</td><td>1 MiB</td></tr> <tr><td>12</td><td>2 MiB</td></tr> <tr><td>13</td><td>4 MiB</td></tr> <tr><td>14</td><td>8 MiB</td></tr> <tr><td>15</td><td>16 MiB</td></tr> <tr><td>16-31</td><td>Reserved</td></tr> </tbody> </table> | Value | Meaning | 0 | 0 Byte        | 1 | 1 KiB  | 2 | 2 KiB | 3 | 4 KiB    | 4 | 8 KiB | 5 | 16 KiB | 6 | 32 KiB | 7 | 64 KiB | 8 | 128 KiB | 9 | 256 KiB | 10 | 512 KiB | 11 | 1 MiB | 12 | 2 MiB | 13 | 4 MiB | 14 | 8 MiB | 15 | 16 MiB | 16-31 | Reserved |  |  |
| Value      | Meaning       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 0          | 0 Byte        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 1          | 1 KiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 2          | 2 KiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 3          | 4 KiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 4          | 8 KiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 5          | 16 KiB        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 6          | 32 KiB        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 7          | 64 KiB        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 8          | 128 KiB       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 9          | 256 KiB       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 10         | 512 KiB       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 11         | 1 MiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 12         | 2 MiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 13         | 4 MiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 14         | 8 MiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 15         | 16 MiB        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 16-31      | Reserved      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| ILM_ECC    | [22:21]       | ILM soft-error protection scheme:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RO    | IM      |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
|            |               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>No parity/ECC</td></tr> <tr><td>1</td><td>Parity</td></tr> <tr><td>2</td><td>ECC</td></tr> <tr><td>3</td><td>Reserved</td></tr> </tbody> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Value | Meaning | 0 | No parity/ECC | 1 | Parity | 2 | ECC   | 3 | Reserved |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| Value      | Meaning       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 0          | No parity/ECC |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 1          | Parity        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 2          | ECC           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |
| 3          | Reserved      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |               |   |        |   |       |   |          |   |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |  |  |

## 18.5.2 Data Cache/Memory Configuration Register

**Mnemonic Name:** mdcm\_cfg

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0xfc1 (non-standard read only)



This register provides information about the configurations of data cache and data memory.

| Field Name | Bits          | Description                                                                                                                                                                                                                                                                                                                                                                                    | Type  | Reset   |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
|------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|---------------|---|-------|---|-------|---|-------|---|-------|---|-------|---|-------|---|----------|--|--|
| DSET       | [2:0]         | D-Cache sets (# of cache lines per way):                                                                                                                                                                                                                                                                                                                                                       | RO    | IM      |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
|            |               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>64</td></tr> <tr><td>1</td><td>128</td></tr> <tr><td>2</td><td>256</td></tr> <tr><td>3</td><td>512</td></tr> <tr><td>4</td><td>1024</td></tr> <tr><td>5</td><td>2048</td></tr> <tr><td>6</td><td>4096</td></tr> <tr><td>7</td><td>Reserved</td></tr> </tbody> </table>                  | Value | Meaning | 0 | 64            | 1 | 128   | 2 | 256   | 3 | 512   | 4 | 1024  | 5 | 2048  | 6 | 4096  | 7 | Reserved |  |  |
| Value      | Meaning       |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 0          | 64            |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 1          | 128           |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 2          | 256           |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 3          | 512           |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 4          | 1024          |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 5          | 2048          |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 6          | 4096          |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 7          | Reserved      |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| DWAY       | [5:3]         | Associativity of D-Cache:                                                                                                                                                                                                                                                                                                                                                                      | RO    | IM      |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
|            |               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>Direct-mapped</td></tr> <tr><td>1</td><td>2-way</td></tr> <tr><td>2</td><td>3-way</td></tr> <tr><td>3</td><td>4-way</td></tr> <tr><td>4</td><td>5-way</td></tr> <tr><td>5</td><td>6-way</td></tr> <tr><td>6</td><td>7-way</td></tr> <tr><td>7</td><td>8-way</td></tr> </tbody> </table> | Value | Meaning | 0 | Direct-mapped | 1 | 2-way | 2 | 3-way | 3 | 4-way | 4 | 5-way | 5 | 6-way | 6 | 7-way | 7 | 8-way    |  |  |
| Value      | Meaning       |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 0          | Direct-mapped |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 1          | 2-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 2          | 3-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 3          | 4-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 4          | 5-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 5          | 6-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 6          | 7-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |
| 7          | 8-way         |                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |               |   |       |   |       |   |       |   |       |   |       |   |       |   |          |  |  |

| Field Name | Bits                          | Description                                                                                                                                                                                                                                                                                                                                                                   | Type  | Reset   |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
|------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------------------------|---|-------------------------------|-----|-----------------|---|----------|---|----------|---|-----------|-----|----------|--|
| DSZ        | [8:6]                         | D-Cache block (line) size:                                                                                                                                                                                                                                                                                                                                                    | RO    | IM      |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
|            |                               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>No D-Cache</td></tr> <tr><td>1</td><td>8 bytes</td></tr> <tr><td>2</td><td>16 bytes</td></tr> <tr><td>3</td><td>32 bytes</td></tr> <tr><td>4</td><td>64 bytes</td></tr> <tr><td>5</td><td>128 bytes</td></tr> <tr><td>6,7</td><td>Reserved</td></tr> </tbody> </table> | Value | Meaning | 0 | No D-Cache                   | 1 | 8 bytes                       | 2   | 16 bytes        | 3 | 32 bytes | 4 | 64 bytes | 5 | 128 bytes | 6,7 | Reserved |  |
| Value      | Meaning                       |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 0          | No D-Cache                    |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 1          | 8 bytes                       |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 2          | 16 bytes                      |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 3          | 32 bytes                      |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 4          | 64 bytes                      |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 5          | 128 bytes                     |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 6,7        | Reserved                      |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| DLCK       | [9]                           | D-Cache locking support:                                                                                                                                                                                                                                                                                                                                                      | RO    | IM      |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
|            |                               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>No locking support</td></tr> <tr><td>1</td><td>With locking support</td></tr> </tbody> </table>                                                                                                                                                                        | Value | Meaning | 0 | No locking support           | 1 | With locking support          |     |                 |   |          |   |          |   |           |     |          |  |
| Value      | Meaning                       |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 0          | No locking support            |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 1          | With locking support          |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| DC_ECC     | [11:10]                       | D-Cache soft-error protection scheme:                                                                                                                                                                                                                                                                                                                                         | RO    | IM      |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
|            |                               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>No parity/ECC support</td></tr> <tr><td>1</td><td>Has parity support</td></tr> <tr><td>2</td><td>Has ECC support</td></tr> <tr><td>3</td><td>Reserved</td></tr> </tbody> </table>                                                                                      | Value | Meaning | 0 | No parity/ECC support        | 1 | Has parity support            | 2   | Has ECC support | 3 | Reserved |   |          |   |           |     |          |  |
| Value      | Meaning                       |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 0          | No parity/ECC support         |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 1          | Has parity support            |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 2          | Has ECC support               |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 3          | Reserved                      |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| DLMB       | [14:12]                       | Number of DLM base registers present:                                                                                                                                                                                                                                                                                                                                         | RO    | IM      |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
|            |                               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>No DLM base register present</td></tr> <tr><td>1</td><td>One DLM base register present</td></tr> <tr><td>2-7</td><td>Reserved</td></tr> </tbody> </table>                                                                                                              | Value | Meaning | 0 | No DLM base register present | 1 | One DLM base register present | 2-7 | Reserved        |   |          |   |          |   |           |     |          |  |
| Value      | Meaning                       |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 0          | No DLM base register present  |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 1          | One DLM base register present |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |
| 2-7        | Reserved                      |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                              |   |                               |     |                 |   |          |   |          |   |           |     |          |  |

| Field Name | Bits          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Type  | Reset   |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
|------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|---------------|---|--------|---|-------|---|----------|----|-------|---|--------|---|--------|---|--------|---|---------|---|---------|----|---------|----|-------|----|-------|----|-------|----|-------|----|--------|-------|----------|----|----|
| DLMSZ      | [19:15]       | DLM Size:<br><br><br><br><table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>0 Byte</td></tr> <tr><td>1</td><td>1 KiB</td></tr> <tr><td>2</td><td>2 KiB</td></tr> <tr><td>3</td><td>4 KiB</td></tr> <tr><td>4</td><td>8 KiB</td></tr> <tr><td>5</td><td>16 KiB</td></tr> <tr><td>6</td><td>32 KiB</td></tr> <tr><td>7</td><td>64 KiB</td></tr> <tr><td>8</td><td>128 KiB</td></tr> <tr><td>9</td><td>256 KiB</td></tr> <tr><td>10</td><td>512 KiB</td></tr> <tr><td>11</td><td>1 MiB</td></tr> <tr><td>12</td><td>2 MiB</td></tr> <tr><td>13</td><td>4 MiB</td></tr> <tr><td>14</td><td>8 MiB</td></tr> <tr><td>15</td><td>16 MiB</td></tr> <tr><td>16-31</td><td>Reserved</td></tr> </tbody> </table> | Value | Meaning | 0 | 0 Byte        | 1 | 1 KiB  | 2 | 2 KiB | 3 | 4 KiB    | 4  | 8 KiB | 5 | 16 KiB | 6 | 32 KiB | 7 | 64 KiB | 8 | 128 KiB | 9 | 256 KiB | 10 | 512 KiB | 11 | 1 MiB | 12 | 2 MiB | 13 | 4 MiB | 14 | 8 MiB | 15 | 16 MiB | 16-31 | Reserved | RO | IM |
| Value      | Meaning       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 0          | 0 Byte        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 1          | 1 KiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 2          | 2 KiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 3          | 4 KiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 4          | 8 KiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 5          | 16 KiB        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 6          | 32 KiB        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 7          | 64 KiB        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 8          | 128 KiB       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 9          | 256 KiB       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 10         | 512 KiB       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 11         | 1 MiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 12         | 2 MiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 13         | 4 MiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 14         | 8 MiB         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 15         | 16 MiB        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 16-31      | Reserved      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| DLM_ECC    | [22:21]       | DLM soft-error protection scheme:<br><br><br><br><table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>No parity/ECC</td></tr> <tr><td>1</td><td>Parity</td></tr> <tr><td>2</td><td>ECC</td></tr> <tr><td>3</td><td>Reserved</td></tr> </tbody> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                               | Value | Meaning | 0 | No parity/ECC | 1 | Parity | 2 | ECC   | 3 | Reserved | RO | IM    |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| Value      | Meaning       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 0          | No parity/ECC |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 1          | Parity        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 2          | ECC           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |
| 3          | Reserved      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |               |   |        |   |       |   |          |    |       |   |        |   |        |   |        |   |         |   |         |    |         |    |       |    |       |    |       |    |       |    |        |       |          |    |    |

### 18.5.3 Misc. Configuration Register

**Mnemonic Name:** mmsc\_cfg

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0xfc2 (non-standard read only)



This register provides information regarding miscellaneous processor configurations.

| Field Name | Bits                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Type  | Reset   |   |                        |   |                     |    |                  |   |           |  |  |
|------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------------------|---|---------------------|----|------------------|---|-----------|--|--|
| ECC        | [0]                    | <p>Indicates whether the parity/ECC soft-error protection is implemented or not.</p> <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not implemented.</td></tr> <tr> <td>1</td><td>Implemented.</td></tr> </tbody> </table> <p>The specific parity/ECC scheme used for each protected RAM is specified by the control bits in the following list.</p> <ul style="list-style-type: none"> <li>• micm_cfg.IC_ECC</li> <li>• micm_cfg.ILM_ECC</li> <li>• mdcm_cfg.DC_ECC</li> <li>• mdcm_cfg.DLM_ECC</li> <li>• mmse_cfg.TLB_ECC</li> </ul> | Value | Meaning | 0 | Not implemented.       | 1 | Implemented.        | RO | IM               |   |           |  |  |
| Value      | Meaning                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                        |   |                     |    |                  |   |           |  |  |
| 0          | Not implemented.       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                        |   |                     |    |                  |   |           |  |  |
| 1          | Implemented.           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                        |   |                     |    |                  |   |           |  |  |
| TLB_ECC    | [2:1]                  | TLB parity/ECC support configuration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RO    | IM      |   |                        |   |                     |    |                  |   |           |  |  |
|            |                        | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>No parity/ECC support.</td></tr> <tr> <td>1</td><td>Has parity support.</td></tr> <tr> <td>2</td><td>Has ECC support.</td></tr> <tr> <td>3</td><td>Reserved.</td></tr> </tbody> </table>                                                                                                                                                                                                                                                                                                 | Value | Meaning | 0 | No parity/ECC support. | 1 | Has parity support. | 2  | Has ECC support. | 3 | Reserved. |  |  |
| Value      | Meaning                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                        |   |                     |    |                  |   |           |  |  |
| 0          | No parity/ECC support. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                        |   |                     |    |                  |   |           |  |  |
| 1          | Has parity support.    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                        |   |                     |    |                  |   |           |  |  |
| 2          | Has ECC support.       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                        |   |                     |    |                  |   |           |  |  |
| 3          | Reserved.              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                        |   |                     |    |                  |   |           |  |  |
| ECD        | [3]                    | <p>Indicates whether the Andes CoDense Extension is implemented or not.</p> <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not implemented.</td></tr> <tr> <td>1</td><td>Implemented.</td></tr> </tbody> </table>                                                                                                                                                                                                                                                                                                                       | Value | Meaning | 0 | Not implemented.       | 1 | Implemented.        | RO | IM               |   |           |  |  |
| Value      | Meaning                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                        |   |                     |    |                  |   |           |  |  |
| 0          | Not implemented.       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                        |   |                     |    |                  |   |           |  |  |
| 1          | Implemented.           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                        |   |                     |    |                  |   |           |  |  |

| Field Name | Bits             | Description                                                                                                                                                                                    | Type  | Reset   |   |                  |   |              |  |  |
|------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------------|---|--------------|--|--|
| PFT        | [4]              | Indicates whether the Andes PowerBrake (Performance Throttling) power/performance scaling extension is implemented or not.                                                                     | RO    | IM      |   |                  |   |              |  |  |
|            |                  | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not implemented.</td></tr> <tr> <td>1</td><td>Implemented.</td></tr> </tbody> </table> | Value | Meaning | 0 | Not implemented. | 1 | Implemented. |  |  |
| Value      | Meaning          |                                                                                                                                                                                                |       |         |   |                  |   |              |  |  |
| 0          | Not implemented. |                                                                                                                                                                                                |       |         |   |                  |   |              |  |  |
| 1          | Implemented.     |                                                                                                                                                                                                |       |         |   |                  |   |              |  |  |
| HSP        | [5]              | Indicates whether the Andes StackSafe hardware stack protection extension is implemented or not.                                                                                               | RO    | IM      |   |                  |   |              |  |  |
|            |                  | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not implemented.</td></tr> <tr> <td>1</td><td>Implemented.</td></tr> </tbody> </table> | Value | Meaning | 0 | Not implemented. | 1 | Implemented. |  |  |
| Value      | Meaning          |                                                                                                                                                                                                |       |         |   |                  |   |              |  |  |
| 0          | Not implemented. |                                                                                                                                                                                                |       |         |   |                  |   |              |  |  |
| 1          | Implemented.     |                                                                                                                                                                                                |       |         |   |                  |   |              |  |  |
| ACE        | [6]              | Indicates whether the Andes Custom Extension is implemented or not.                                                                                                                            | RO    | IM      |   |                  |   |              |  |  |
|            |                  | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not implemented.</td></tr> <tr> <td>1</td><td>Implemented.</td></tr> </tbody> </table> | Value | Meaning | 0 | Not implemented. | 1 | Implemented. |  |  |
| Value      | Meaning          |                                                                                                                                                                                                |       |         |   |                  |   |              |  |  |
| 0          | Not implemented. |                                                                                                                                                                                                |       |         |   |                  |   |              |  |  |
| 1          | Implemented.     |                                                                                                                                                                                                |       |         |   |                  |   |              |  |  |
| VPLIC      | [12]             | Indicates whether the Andes Vectored PLIC Extension is implemented or not.                                                                                                                     | RO    | IM      |   |                  |   |              |  |  |
|            |                  | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Not implemented.</td></tr> <tr> <td>1</td><td>Implemented.</td></tr> </tbody> </table> | Value | Meaning | 0 | Not implemented. | 1 | Implemented. |  |  |
| Value      | Meaning          |                                                                                                                                                                                                |       |         |   |                  |   |              |  |  |
| 0          | Not implemented. |                                                                                                                                                                                                |       |         |   |                  |   |              |  |  |
| 1          | Implemented.     |                                                                                                                                                                                                |       |         |   |                  |   |              |  |  |
| EV5PE      | [13]             | Indicates whether AndeStar V5 Performance Extension is implemented or not. N25(F) always implements AndeStar V5 Performance Extension.                                                         | RO    | 1       |   |                  |   |              |  |  |

| <b>Field Name</b> | <b>Bits</b>                                                     | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                    | <b>Type</b>  | <b>Reset</b>   |   |                                                                 |   |                                                             |  |  |
|-------------------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------|---|-----------------------------------------------------------------|---|-------------------------------------------------------------|--|--|
| LMSLVP            | [14]                                                            | Indicates if local memory slave port is present or not.                                                                                                                                                                                                                                                                                                                                                                                               | RO           | IM             |   |                                                                 |   |                                                             |  |  |
|                   |                                                                 | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Local memory slave port is not present.</td></tr> <tr> <td>1</td><td>Local memory slave port is implemented.</td></tr> </tbody> </table> <p>Note that atomicity of atomic instructions accessing local memory address space is not guaranteed if external masters modify the same data through the local memory slave port.</p> | <b>Value</b> | <b>Meaning</b> | 0 | Local memory slave port is not present.                         | 1 | Local memory slave port is implemented.                     |  |  |
| <b>Value</b>      | <b>Meaning</b>                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                |   |                                                                 |   |                                                             |  |  |
| 0                 | Local memory slave port is not present.                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                |   |                                                                 |   |                                                             |  |  |
| 1                 | Local memory slave port is implemented.                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                |   |                                                                 |   |                                                             |  |  |
| PMNDS             | [15]                                                            | Indicate if Andes-enhanced performance monitoring feature is present or not.                                                                                                                                                                                                                                                                                                                                                                          | RO           | IM             |   |                                                                 |   |                                                             |  |  |
|                   |                                                                 | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Andes-enhanced performance monitoring feature is not supported.</td></tr> <tr> <td>1</td><td>Andes-enhanced performance monitoring feature is supported.</td></tr> </tbody> </table>                                                                                                                                            | <b>Value</b> | <b>Meaning</b> | 0 | Andes-enhanced performance monitoring feature is not supported. | 1 | Andes-enhanced performance monitoring feature is supported. |  |  |
| <b>Value</b>      | <b>Meaning</b>                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                |   |                                                                 |   |                                                             |  |  |
| 0                 | Andes-enhanced performance monitoring feature is not supported. |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                |   |                                                                 |   |                                                             |  |  |
| 1                 | Andes-enhanced performance monitoring feature is supported.     |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                |   |                                                                 |   |                                                             |  |  |
| CCTLCSR           | [16]                                                            | Indicate the presence of CSRs for CCTL operations.                                                                                                                                                                                                                                                                                                                                                                                                    | RO           | IM             |   |                                                                 |   |                                                             |  |  |
|                   |                                                                 | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Feature of CSRs for CCTL operations is not supported.</td></tr> <tr> <td>1</td><td>Feature of CSRs for CCTL operations is supported.</td></tr> </tbody> </table>                                                                                                                                                                | <b>Value</b> | <b>Meaning</b> | 0 | Feature of CSRs for CCTL operations is not supported.           | 1 | Feature of CSRs for CCTL operations is supported.           |  |  |
| <b>Value</b>      | <b>Meaning</b>                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                |   |                                                                 |   |                                                             |  |  |
| 0                 | Feature of CSRs for CCTL operations is not supported.           |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                |   |                                                                 |   |                                                             |  |  |
| 1                 | Feature of CSRs for CCTL operations is supported.               |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                |   |                                                                 |   |                                                             |  |  |
| EFHW              | [17]                                                            | Indicate the support of FLHW and FSHW instructions.                                                                                                                                                                                                                                                                                                                                                                                                   | RO           | IM             |   |                                                                 |   |                                                             |  |  |
|                   |                                                                 | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>FLHW and FSHW instructions are not supported.</td></tr> <tr> <td>1</td><td>FLHW and FSHW instructions are supported.</td></tr> </tbody> </table>                                                                                                                                                                                | <b>Value</b> | <b>Meaning</b> | 0 | FLHW and FSHW instructions are not supported.                   | 1 | FLHW and FSHW instructions are supported.                   |  |  |
| <b>Value</b>      | <b>Meaning</b>                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                |   |                                                                 |   |                                                             |  |  |
| 0                 | FLHW and FSHW instructions are not supported.                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                |   |                                                                 |   |                                                             |  |  |
| 1                 | FLHW and FSHW instructions are supported.                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                |   |                                                                 |   |                                                             |  |  |

## 18.6 Trigger Registers

### 18.6.1 Trigger Select

**Mnemonic Name:** tselect

**IM Requirement:** DEBUG\_SUPPORT

**Access Mode:** Debug and Machine

**CSR Address:** 0x7a0 (standard read/write)



This register determines which trigger is accessible through other trigger registers. The set of accessible triggers must start at 0, and be contiguous. Writes of values greater than or equal to the number of supported triggers might result in a different value in this register than what was written. Debuggers should read back the value to confirm that what they wrote was a valid index.

Since triggers can be used both by Halt mode and Machine mode, the debugger must restore this register after the modification.

## 18.6.2 Trigger Data 1

**Mnemonic Name:** tdata1

## **IM Requirement: DEBUG\_SUPPORT**

## **Access Mode:** Debug and Machine

**CSR Address:** 0x7a1 (standard read/write)



This register provides access to the tdata1 register of the currently selected trigger registers selected by the tselect register.

| Field Name | Bits                                                                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Type  | Reset   |   |                                                                                |   |                                                                                                          |   |                                                       |   |                                               |   |                                               |  |  |
|------------|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|--------------------------------------------------------------------------------|---|----------------------------------------------------------------------------------------------------------|---|-------------------------------------------------------|---|-----------------------------------------------|---|-----------------------------------------------|--|--|
| DATA       | [26:0]                                                                                                   | Trigger-specific data                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW    | 0       |   |                                                                                |   |                                                                                                          |   |                                                       |   |                                               |   |                                               |  |  |
| DMODE      | [27]                                                                                                     | Setting this field to indicate the trigger is used by Debug Mode.                                                                                                                                                                                                                                                                                                                                                                                                                                 | RW    | 0       |   |                                                                                |   |                                                                                                          |   |                                                       |   |                                               |   |                                               |  |  |
|            |                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Both Debug-mode and M-mode can write the currently selected trigger registers.</td></tr> <tr> <td>1</td><td>Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored.</td></tr> </tbody> </table>                                                                                                                                          | Value | Meaning | 0 | Both Debug-mode and M-mode can write the currently selected trigger registers. | 1 | Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored. |   |                                                       |   |                                               |   |                                               |  |  |
| Value      | Meaning                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                |   |                                                                                                          |   |                                                       |   |                                               |   |                                               |  |  |
| 0          | Both Debug-mode and M-mode can write the currently selected trigger registers.                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                |   |                                                                                                          |   |                                                       |   |                                               |   |                                               |  |  |
| 1          | Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                |   |                                                                                                          |   |                                                       |   |                                               |   |                                               |  |  |
| TYPE       | [31:28]                                                                                                  | Indicating the trigger type.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RW    | 2       |   |                                                                                |   |                                                                                                          |   |                                                       |   |                                               |   |                                               |  |  |
|            |                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The selected trigger is invalid.</td></tr> <tr> <td>2</td><td>The selected trigger is an address/data match trigger.</td></tr> <tr> <td>3</td><td>The selected trigger is an instruction count trigger.</td></tr> <tr> <td>4</td><td>The selected trigger is an interrupt trigger.</td></tr> <tr> <td>5</td><td>The selected trigger is an exception trigger.</td></tr> </tbody> </table> | Value | Meaning | 0 | The selected trigger is invalid.                                               | 2 | The selected trigger is an address/data match trigger.                                                   | 3 | The selected trigger is an instruction count trigger. | 4 | The selected trigger is an interrupt trigger. | 5 | The selected trigger is an exception trigger. |  |  |
| Value      | Meaning                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                |   |                                                                                                          |   |                                                       |   |                                               |   |                                               |  |  |
| 0          | The selected trigger is invalid.                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                |   |                                                                                                          |   |                                                       |   |                                               |   |                                               |  |  |
| 2          | The selected trigger is an address/data match trigger.                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                |   |                                                                                                          |   |                                                       |   |                                               |   |                                               |  |  |
| 3          | The selected trigger is an instruction count trigger.                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                |   |                                                                                                          |   |                                                       |   |                                               |   |                                               |  |  |
| 4          | The selected trigger is an interrupt trigger.                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                |   |                                                                                                          |   |                                                       |   |                                               |   |                                               |  |  |
| 5          | The selected trigger is an exception trigger.                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                |   |                                                                                                          |   |                                                       |   |                                               |   |                                               |  |  |

### 18.6.3 Trigger Data 2

## Mnemonic Name: tdata2

## **IM Requirement: DEBUG\_SUPPORT**

## **Access Mode: Debug and Machine**

**CSR Address:** 0x7a2 (standard read/write)

This register provides access to the tdata2 register of the currently selected trigger registers selected by the tselect register, and it holds trigger-specific data.

#### 18.6.4 Trigger Data 3

**Mnemonic Name:** tdata3

**IM Requirement:** DEBUG\_SUPPORT

**Access Mode:** Debug and Machine

**CSR Address:** 0x7a3 (standard read/write)

This register is hard-wired to zeros.

#### 18.6.5 Trigger Info

**Mnemonic Name:** tinfo

**IM Requirement:** DEBUG\_SUPPORT

**Access Mode:** Debug and Machine

**CSR Address:** 0x7a4 (standard read/write)



This register provides access to the tinfo register of the currently selected trigger registers selected by the tselect register, and it indicates the supported trigger types of the currently selected trigger.

| Field Name | Bits   | Description                                                                                                                                                                                                                       | Type | Reset |
|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| INFO       | [15:0] | One bit for each possible TYPE in tdata1. Bit N corresponds to type N. If the bit is set, then that type is supported by the currently selected trigger. If the currently selected trigger does not exist, this field contains 1. | RW   | 0     |

#### 18.6.6 Match Control

**Mnemonic Name:** mcontrol

**IM Requirement:** DEBUG\_SUPPORT

**Access Mode:** Debug and Machine

**CSR Address:** 0x7a1 (standard read/write)

This register is accessible as tdata1 when type is 0 or 2.



| Field Name | Bits                                                                                                                                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Type  | Reset   |   |                                      |   |                                                                                                                                                       |   |                                                                       |   |                                                        |  |  |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|--------------------------------------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------|---|-----------------------------------------------------------------------|---|--------------------------------------------------------|--|--|
| LOAD       | [0]                                                                                                                                                   | Setting this field to enable this trigger to compare virtual address of a load                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                      |   |                                                                                                                                                       |   |                                                                       |   |                                                        |  |  |
| STORE      | [1]                                                                                                                                                   | Setting this field to enable this trigger to compare virtual address of a store                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RW    | 0       |   |                                      |   |                                                                                                                                                       |   |                                                                       |   |                                                        |  |  |
| EXECUTE    | [2]                                                                                                                                                   | Setting this field to enable this trigger to compare virtual address of an instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW    | 0       |   |                                      |   |                                                                                                                                                       |   |                                                                       |   |                                                        |  |  |
| U          | [3]                                                                                                                                                   | Setting this field to enable this trigger in U-mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW    | 0       |   |                                      |   |                                                                                                                                                       |   |                                                                       |   |                                                        |  |  |
| S          | [4]                                                                                                                                                   | Setting this field to enable this trigger in S-mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW    | 0       |   |                                      |   |                                                                                                                                                       |   |                                                                       |   |                                                        |  |  |
| M          | [6]                                                                                                                                                   | Setting this field to enable this trigger in M-mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW    | 0       |   |                                      |   |                                                                                                                                                       |   |                                                                       |   |                                                        |  |  |
| MATCH      | [10:7]                                                                                                                                                | Setting this field to select matching scheme.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RW    | 0       |   |                                      |   |                                                                                                                                                       |   |                                                                       |   |                                                        |  |  |
|            |                                                                                                                                                       | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Matches when the value equals tdata2</td></tr> <tr> <td>1</td><td>Matches when the top M bits of the value match the top M bits of tdata2. M is 31 minus the index of the least-significant bit containing 0 in tdata2.</td></tr> <tr> <td>2</td><td>Matches when the value is greater than (unsigned) or equal to tdata2.</td></tr> <tr> <td>3</td><td>Matches when the value is less than (unsigned) tdata2.</td></tr> </tbody> </table> | Value | Meaning | 0 | Matches when the value equals tdata2 | 1 | Matches when the top M bits of the value match the top M bits of tdata2. M is 31 minus the index of the least-significant bit containing 0 in tdata2. | 2 | Matches when the value is greater than (unsigned) or equal to tdata2. | 3 | Matches when the value is less than (unsigned) tdata2. |  |  |
| Value      | Meaning                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |         |   |                                      |   |                                                                                                                                                       |   |                                                                       |   |                                                        |  |  |
| 0          | Matches when the value equals tdata2                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |         |   |                                      |   |                                                                                                                                                       |   |                                                                       |   |                                                        |  |  |
| 1          | Matches when the top M bits of the value match the top M bits of tdata2. M is 31 minus the index of the least-significant bit containing 0 in tdata2. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |         |   |                                      |   |                                                                                                                                                       |   |                                                                       |   |                                                        |  |  |
| 2          | Matches when the value is greater than (unsigned) or equal to tdata2.                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |         |   |                                      |   |                                                                                                                                                       |   |                                                                       |   |                                                        |  |  |
| 3          | Matches when the value is less than (unsigned) tdata2.                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |         |   |                                      |   |                                                                                                                                                       |   |                                                                       |   |                                                        |  |  |

| Field Name | Bits                                                                                                     | Description                                                                                                                                                                                                                                                                                                                                              | Type  | Reset   |   |                                                                                |   |                                                                                                          |  |  |
|------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|--------------------------------------------------------------------------------|---|----------------------------------------------------------------------------------------------------------|--|--|
| CHAIN      | [11]                                                                                                     | Setting this field to enable trigger chain.                                                                                                                                                                                                                                                                                                              | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
|            |                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>When this trigger matches, the configured action is taken.</td></tr> <tr> <td>1</td><td>While this trigger does not match, it prevents the trigger with the next index from matching.</td></tr> </tbody> </table>                                | Value | Meaning | 0 | When this trigger matches, the configured action is taken.                     | 1 | While this trigger does not match, it prevents the trigger with the next index from matching.            |  |  |
| Value      | Meaning                                                                                                  |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 0          | When this trigger matches, the configured action is taken.                                               |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 1          | While this trigger does not match, it prevents the trigger with the next index from matching.            |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| ACTION     | [17:12]                                                                                                  | Setting this field to select what happens when this trigger matches.                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
|            |                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Raise a breakpoint exception.</td></tr> <tr> <td>1</td><td>Enter Debug Mode. (Only supported when DMODE is 1.)</td></tr> </tbody> </table>                                                                                                       | Value | Meaning | 0 | Raise a breakpoint exception.                                                  | 1 | Enter Debug Mode. (Only supported when DMODE is 1.)                                                      |  |  |
| Value      | Meaning                                                                                                  |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 0          | Raise a breakpoint exception.                                                                            |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 1          | Enter Debug Mode. (Only supported when DMODE is 1.)                                                      |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| MASKMAX    | [26:21]                                                                                                  | Indicating the largest naturally aligned range supported by the hardware is $2^{12}$ bytes.                                                                                                                                                                                                                                                              | RO    | 12      |   |                                                                                |   |                                                                                                          |  |  |
| DMODE      | [27]                                                                                                     | Setting this field to indicate the trigger is used by Debug Mode.                                                                                                                                                                                                                                                                                        | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
|            |                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Both Debug-mode and M-mode can write the currently selected trigger registers.</td></tr> <tr> <td>1</td><td>Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored.</td></tr> </tbody> </table> | Value | Meaning | 0 | Both Debug-mode and M-mode can write the currently selected trigger registers. | 1 | Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored. |  |  |
| Value      | Meaning                                                                                                  |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 0          | Both Debug-mode and M-mode can write the currently selected trigger registers.                           |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 1          | Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored. |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| TYPE       | [31:28]                                                                                                  | Indicating the trigger type.                                                                                                                                                                                                                                                                                                                             | RW    | 2       |   |                                                                                |   |                                                                                                          |  |  |
|            |                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The selected trigger is invalid.</td></tr> <tr> <td>2</td><td>The selected trigger is an address/data match trigger.</td></tr> </tbody> </table>                                                                                                 | Value | Meaning | 0 | The selected trigger is invalid.                                               | 2 | The selected trigger is an address/data match trigger.                                                   |  |  |
| Value      | Meaning                                                                                                  |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 0          | The selected trigger is invalid.                                                                         |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 2          | The selected trigger is an address/data match trigger.                                                   |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |

## 18.6.7 Instruction Count

**Mnemonic Name:** icount

**IM Requirement:** DEBUG\_SUPPORT

**Access Mode:** Debug and Machine

**CSR Address:** 0x7a1 (standard read/write)

This register is accessible as tdata1 when type is 3.

This register exists just for single-stepping support so COUNT is hard-wired to 1. After this trigger fires, the mode bits (M, S, U bits) will be cleared instead of decrementing the COUNT bits.

| 31   | 28    | 27 | 26 | 11 | 10    | 9 | 8 | 7 | 6 | 5      | 0 |
|------|-------|----|----|----|-------|---|---|---|---|--------|---|
| TYPE | DMODE | 0  |    |    | COUNT | M | 0 | S | U | ACTION |   |
|      |       |    |    |    |       |   |   |   |   |        |   |

| Field Name | Bits                                                                                                     | Description                                                                                                                                                                                                                                                                                                                                              | Type  | Reset   |   |                                                                                |   |                                                                                                          |  |  |
|------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|--------------------------------------------------------------------------------|---|----------------------------------------------------------------------------------------------------------|--|--|
| ACTION     | [5:0]                                                                                                    | Setting this field to select what happens when this trigger matches.                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
|            |                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Raise a breakpoint exception.</td></tr> <tr> <td>1</td><td>Enter Debug Mode. (Only supported when DMODE is 1.)</td></tr> </tbody> </table>                                                                                                       | Value | Meaning | 0 | Raise a breakpoint exception.                                                  | 1 | Enter Debug Mode. (Only supported when DMODE is 1.)                                                      |  |  |
| Value      | Meaning                                                                                                  |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 0          | Raise a breakpoint exception.                                                                            |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 1          | Enter Debug Mode. (Only supported when DMODE is 1.)                                                      |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| U          | [6]                                                                                                      | Setting this field to enable this trigger in U-mode.                                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
| S          | [7]                                                                                                      | Setting this field to enable this trigger in S-mode.                                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
| M          | [9]                                                                                                      | Setting this field to enable this trigger in M-mode.                                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
| COUNT      | [10]                                                                                                     | This field is hard-wired to 1 for single-stepping support                                                                                                                                                                                                                                                                                                | RO    | 1       |   |                                                                                |   |                                                                                                          |  |  |
| DMODE      | [27]                                                                                                     | Setting this field to indicate the trigger is used by Debug Mode.                                                                                                                                                                                                                                                                                        | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
|            |                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Both Debug-mode and M-mode can write the currently selected trigger registers.</td></tr> <tr> <td>1</td><td>Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored.</td></tr> </tbody> </table> | Value | Meaning | 0 | Both Debug-mode and M-mode can write the currently selected trigger registers. | 1 | Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored. |  |  |
| Value      | Meaning                                                                                                  |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 0          | Both Debug-mode and M-mode can write the currently selected trigger registers.                           |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 1          | Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored. |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| TYPE       | [31:28]                                                                                                  | The selected trigger is an instruction count trigger.                                                                                                                                                                                                                                                                                                    | RW    | 3       |   |                                                                                |   |                                                                                                          |  |  |

## 18.6.8 Interrupt Trigger

**Mnemonic Name:** itrigger

**IM Requirement:** DEBUG\_SUPPORT

**Access Mode:** Debug and Machine

**CSR Address:** 0x7a1 (standard read/write)

This register is accessible as tdata1 when TYPE is 4.

This trigger may fire on any of the interrupts configurable in mie. The interrupts to fire on are configured by setting the same bit in tdata2 as would be set in mie to enable the interrupt.

| 31   | 28    | 27 | 26 |   | 10 | 9 | 8 | 7 | 6 | 5 | 0      |
|------|-------|----|----|---|----|---|---|---|---|---|--------|
| TYPE | DMODE |    |    | 0 |    | M | 0 | S | U |   | ACTION |

| Field Name | Bits                                                                                                     | Description                                                                                                                                                                                                                                                                                                                                              | Type  | Reset   |   |                                                                                |   |                                                                                                          |  |  |
|------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|--------------------------------------------------------------------------------|---|----------------------------------------------------------------------------------------------------------|--|--|
| ACTION     | [5:0]                                                                                                    | Setting this field to select what happens when this trigger matches.                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
|            |                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Raise a breakpoint exception.</td></tr> <tr> <td>1</td><td>Enter Debug Mode. (Only supported when DMODE is 1.)</td></tr> </tbody> </table>                                                                                                       | Value | Meaning | 0 | Raise a breakpoint exception.                                                  | 1 | Enter Debug Mode. (Only supported when DMODE is 1.)                                                      |  |  |
| Value      | Meaning                                                                                                  |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 0          | Raise a breakpoint exception.                                                                            |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 1          | Enter Debug Mode. (Only supported when DMODE is 1.)                                                      |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| U          | [6]                                                                                                      | Setting this field to enable this trigger in U-mode.                                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
| S          | [7]                                                                                                      | Setting this field to enable this trigger in S-mode.                                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
| M          | [9]                                                                                                      | Setting this field to enable this trigger in M-mode.                                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
| DMODE      | [27]                                                                                                     | Setting this field to indicate the trigger is used by Debug Mode.                                                                                                                                                                                                                                                                                        | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
|            |                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Both Debug-mode and M-mode can write the currently selected trigger registers.</td></tr> <tr> <td>1</td><td>Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored.</td></tr> </tbody> </table> | Value | Meaning | 0 | Both Debug-mode and M-mode can write the currently selected trigger registers. | 1 | Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored. |  |  |
| Value      | Meaning                                                                                                  |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 0          | Both Debug-mode and M-mode can write the currently selected trigger registers.                           |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 1          | Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored. |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| TYPE       | [31:28]                                                                                                  | The selected trigger is an interrupt trigger.                                                                                                                                                                                                                                                                                                            | RW    | 4       |   |                                                                                |   |                                                                                                          |  |  |

## 18.6.9 Exception Trigger

**Mnemonic Name:** etrigger

**IM Requirement:** DEBUG\_SUPPORT

**Access Mode:** Debug and Machine

**CSR Address:** 0x7a1 (standard read/write)

This register is accessible as tdata1 when TYPE is 5.

This trigger may fire on up to XLEN of the Exception Codes defined in mcause (with Interrupt=0). Those causes are configured by writing the corresponding bit in tdata2.

| 31   | 28    | 27 | 26 | 10 | 9 | 8 | 7 | 6 | 5 | 0      |
|------|-------|----|----|----|---|---|---|---|---|--------|
| TYPE | DMODE | 0  |    |    |   | M | 0 | S | U | ACTION |

| Field Name | Bits                                                                                                     | Description                                                                                                                                                                                                                                                                                                                                              | Type  | Reset   |   |                                                                                |   |                                                                                                          |  |  |
|------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|--------------------------------------------------------------------------------|---|----------------------------------------------------------------------------------------------------------|--|--|
| ACTION     | [5:0]                                                                                                    | Setting this field to select what happens when this trigger matches.                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
|            |                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Raise a breakpoint exception.</td></tr> <tr> <td>1</td><td>Enter Debug Mode. (Only supported when DMODE is 1.)</td></tr> </tbody> </table>                                                                                                       | Value | Meaning | 0 | Raise a breakpoint exception.                                                  | 1 | Enter Debug Mode. (Only supported when DMODE is 1.)                                                      |  |  |
| Value      | Meaning                                                                                                  |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 0          | Raise a breakpoint exception.                                                                            |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 1          | Enter Debug Mode. (Only supported when DMODE is 1.)                                                      |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| U          | [6]                                                                                                      | Setting this field to enable this trigger in U-mode.                                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
| S          | [7]                                                                                                      | Setting this field to enable this trigger in S-mode.                                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
| M          | [9]                                                                                                      | Setting this field to enable this trigger in M-mode.                                                                                                                                                                                                                                                                                                     | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
| DMODE      | [27]                                                                                                     | Setting this field to indicate the trigger is used by Debug Mode.                                                                                                                                                                                                                                                                                        | RW    | 0       |   |                                                                                |   |                                                                                                          |  |  |
|            |                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Both Debug-mode and M-mode can write the currently selected trigger registers.</td></tr> <tr> <td>1</td><td>Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored.</td></tr> </tbody> </table> | Value | Meaning | 0 | Both Debug-mode and M-mode can write the currently selected trigger registers. | 1 | Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored. |  |  |
| Value      | Meaning                                                                                                  |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 0          | Both Debug-mode and M-mode can write the currently selected trigger registers.                           |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| 1          | Only Debug Mode can write the currently selected trigger registers. Writes from other modes are ignored. |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                |   |                                                                                                          |  |  |
| TYPE       | [31:28]                                                                                                  | The selected trigger is an exception trigger.                                                                                                                                                                                                                                                                                                            | RW    | 5       |   |                                                                                |   |                                                                                                          |  |  |

## 18.7 Debug and Trigger Registers

### 18.7.1 Debug Control and Status Register

**Mnemonic Name:** dcsr

**IM Requirement:** DEBUG\_SUPPORT

**Access Mode:** Debug

**CSR Address:** 0x7b0 (debug-mode-only)

|           |    |         |    |           |          |       |   |      |     |   |   |   |   |  |
|-----------|----|---------|----|-----------|----------|-------|---|------|-----|---|---|---|---|--|
| 15        | 14 | 13      | 12 | 11        | 10       | 9     | 8 | 6    | 5   | 3 | 2 | 1 | 0 |  |
| EBREAKM   | 0  | EBREAKU | 0  | STOPCOUNT | STOPTIME | CAUSE | 0 | STEP | PRV |   |   |   |   |  |
| 31        | 28 | 27      | 16 |           |          |       |   |      |     |   |   |   |   |  |
| XDEBUGVER | 0  |         |    |           |          |       |   |      |     |   |   |   |   |  |

| Field Name | Bits                    | Description                                                                                                                                                                                                                                                                                                                                                 | Type  | Reset   |   |                         |   |                        |   |          |   |         |  |  |
|------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-------------------------|---|------------------------|---|----------|---|---------|--|--|
| PRV        | [1:0]                   | The privilege level that the hart was operating in when Debug Mode was entered. The external debugger can modify this value to change the hart's privilege level when exiting Debug Mode.                                                                                                                                                                   | RW    | 0       |   |                         |   |                        |   |          |   |         |  |  |
|            |                         | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>User/Application</td></tr> <tr> <td>1</td><td>Reserved</td></tr> <tr> <td>2</td><td>Reserved</td></tr> <tr> <td>3</td><td>Machine</td></tr> </tbody> </table>                                                                                       | Value | Meaning | 0 | User/Application        | 1 | Reserved               | 2 | Reserved | 3 | Machine |  |  |
| Value      | Meaning                 |                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                         |   |                        |   |          |   |         |  |  |
| 0          | User/Application        |                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                         |   |                        |   |          |   |         |  |  |
| 1          | Reserved                |                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                         |   |                        |   |          |   |         |  |  |
| 2          | Reserved                |                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                         |   |                        |   |          |   |         |  |  |
| 3          | Machine                 |                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                         |   |                        |   |          |   |         |  |  |
| STEP       | [2]                     | This bit controls whether non-Debug Mode instruction execution is in the single step mode. When set, the hart returns to Debug Mode after a single instruction execution. If the instruction does not complete due to an exception, the hart will immediately enter Debug Mode before executing the trap handler, with appropriate exception registers set. | RW    | 0       |   |                         |   |                        |   |          |   |         |  |  |
|            |                         | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Single Step Mode is off</td></tr> <tr> <td>1</td><td>Single Step Mode is on</td></tr> </tbody> </table>                                                                                                                                             | Value | Meaning | 0 | Single Step Mode is off | 1 | Single Step Mode is on |   |          |   |         |  |  |
| Value      | Meaning                 |                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                         |   |                        |   |          |   |         |  |  |
| 0          | Single Step Mode is off |                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                         |   |                        |   |          |   |         |  |  |
| 1          | Single Step Mode is on  |                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                         |   |                        |   |          |   |         |  |  |

| Field Name | Bits                               | Description                                                                                                                                                                                                                                                                                                                                       | Type  | Reset   |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
|------------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------------------------------|---|-----------------------------|---|----------------|---|--------------|---|-------------|-----|----------|--|--|
| CAUSE      | [8:6]                              | Reason why Debug Mode was entered. When there are multiple reasons to enter Debug Mode, the priority to determine the CAUSE value will be: single step > halt request > ebreak > trigger module. Halt requests are requests issued by the external debugger.                                                                                      | RO    | 0       |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
|            |                                    | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>Reserved</td></tr> <tr><td>1</td><td>ebreak</td></tr> <tr><td>2</td><td>Trigger module</td></tr> <tr><td>3</td><td>Halt request</td></tr> <tr><td>4</td><td>Single step</td></tr> <tr><td>5–7</td><td>Reserved</td></tr> </tbody> </table> | Value | Meaning | 0 | Reserved                           | 1 | ebreak                      | 2 | Trigger module | 3 | Halt request | 4 | Single step | 5–7 | Reserved |  |  |
| Value      | Meaning                            |                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
| 0          | Reserved                           |                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
| 1          | ebreak                             |                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
| 2          | Trigger module                     |                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
| 3          | Halt request                       |                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
| 4          | Single step                        |                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
| 5–7        | Reserved                           |                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
| STOPTIME   | [9]                                | This bit controls whether timers are stopped in Debug Mode. The processor only drives its <code>stoptime</code> output pin to 1 if it is in Debug Mode and this bit is set. Integration effort is required to make timers in the platform observe this pin to really stop them.                                                                   | RW    | 1       |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
|            |                                    | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>Do not stop timers in Debug Mode</td></tr> <tr><td>1</td><td>Stop timers in Debug Mode</td></tr> </tbody> </table>                                                                                                                         | Value | Meaning | 0 | Do not stop timers in Debug Mode   | 1 | Stop timers in Debug Mode   |   |                |   |              |   |             |     |          |  |  |
| Value      | Meaning                            |                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
| 0          | Do not stop timers in Debug Mode   |                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
| 1          | Stop timers in Debug Mode          |                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
| STOPCOUNT  | [10]                               | This bit controls whether performance counters are stopped in Debug Mode.                                                                                                                                                                                                                                                                         | RW    | 1       |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
|            |                                    | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>Do not stop counters in Debug Mode</td></tr> <tr><td>1</td><td>Stop counters in Debug Mode</td></tr> </tbody> </table>                                                                                                                     | Value | Meaning | 0 | Do not stop counters in Debug Mode | 1 | Stop counters in Debug Mode |   |                |   |              |   |             |     |          |  |  |
| Value      | Meaning                            |                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
| 0          | Do not stop counters in Debug Mode |                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |
| 1          | Stop counters in Debug Mode        |                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                    |   |                             |   |                |   |              |   |             |     |          |  |  |

| Field Name | Bits                                    | Description                                                                                                                                                                                                               | Type  | Reset   |   |                                         |   |                  |  |  |
|------------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-----------------------------------------|---|------------------|--|--|
| EBREAKU    | [12]                                    | This bit controls the behavior of ebreak instructions in User/Application Mode.                                                                                                                                           | RW    | 0       |   |                                         |   |                  |  |  |
|            |                                         | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Generate a regular breakpoint exception</td></tr> <tr> <td>1</td><td>Enter Debug Mode</td></tr> </tbody> </table> | Value | Meaning | 0 | Generate a regular breakpoint exception | 1 | Enter Debug Mode |  |  |
| Value      | Meaning                                 |                                                                                                                                                                                                                           |       |         |   |                                         |   |                  |  |  |
| 0          | Generate a regular breakpoint exception |                                                                                                                                                                                                                           |       |         |   |                                         |   |                  |  |  |
| 1          | Enter Debug Mode                        |                                                                                                                                                                                                                           |       |         |   |                                         |   |                  |  |  |
| EBREAKM    | [15]                                    | This bit controls the behavior of ebreak instructions in Machine Mode.                                                                                                                                                    | RW    | 0       |   |                                         |   |                  |  |  |
|            |                                         | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Generate a regular breakpoint exception</td></tr> <tr> <td>1</td><td>Enter Debug Mode</td></tr> </tbody> </table> | Value | Meaning | 0 | Generate a regular breakpoint exception | 1 | Enter Debug Mode |  |  |
| Value      | Meaning                                 |                                                                                                                                                                                                                           |       |         |   |                                         |   |                  |  |  |
| 0          | Generate a regular breakpoint exception |                                                                                                                                                                                                                           |       |         |   |                                         |   |                  |  |  |
| 1          | Enter Debug Mode                        |                                                                                                                                                                                                                           |       |         |   |                                         |   |                  |  |  |
| XDEBUGVER  | [31:28]                                 | Version of the external debugger. 0 indicates that no external debugger exists and 4 indicates that the external debugger confirms to the <i>RISC-V External Debug Support (TD003) V0.13</i> .                            | RO    | 4       |   |                                         |   |                  |  |  |

## 18.7.2 Debug Program Counter

**Mnemonic Name:** dpc

**IM Requirement:** DEBUG\_SUPPORT

**Access Mode:** Debug

**CSR Address:** 0x7b1 (debug-mode-only)



When entering Debug Mode, dpc is updated with the virtual address of the next instruction to be executed. The behavior is described in more detail in Table 18-17 Virtual Address in DPC upon Debug Mode Entry. When leaving Debug Mode, the hart's PC is updated to the value stored in this register. The external debugger may write this register to change where the hart resumes.

| Field Name | Bits   | Description                                      | Type | Reset |
|------------|--------|--------------------------------------------------|------|-------|
| DPC        | [31:0] | Debug Program Counter. Bit 0 is hard-wired to 0. | RW   | 0     |

Table 18-17 Virtual Address in DPC upon Debug Mode Entry

| Cause          | Virtual Address in DPC                                                                 |
|----------------|----------------------------------------------------------------------------------------|
| ebreak         | Address of the ebreak instruction                                                      |
| single step    | Address of the instruction that would be executed next if no debugging was going on.   |
| trigger module | Address of the instruction which caused the trigger module to fire.                    |
| halt request   | Address of the next instruction to be executed at the time that Debug Mode was entered |

### 18.7.3 Debug Scratch Register 0

**Mnemonic Name:** dscratch0

**IM Requirement:** DEBUG\_SUPPORT

**Access Mode:** Debug

**CSR Address:** 0x7b2 (debug-mode-only)



A scratch register that is reserved for use by Debug Module.

### 18.7.4 Debug Scratch Register 1

**Mnemonic Name:** dscratch1

**IM Requirement:** DEBUG\_SUPPORT

**Access Mode:** Debug

**CSR Address:** 0x7b3 (debug-mode-only)



A scratch register that is reserved for use by Debug Module.

### 18.7.5 Exception Redirection Register

**Mnemonic Name:** dexc2dbg

**IM Requirement:** DEBUG\_SUPPORT

**Access Mode:** Debug

**CSR Address:** 0x7e0 (non-standard read/write)



This register redirects selected exceptions to cause the hart to enter Debug Mode instead of performing the standard trap handling.

When an exception is redirected to enter Debug Mode, the dpc CSR will be updated with the virtual address of the instruction causing the exception. The dcsr.CAUSE field will be updated with a value of 1 (ebreak). The actual cause of the exception is saved to the ddcause CSR. The required updates to mepc, mcause, mtval, mstatus, and mxstatus CSRs for exceptions will not be affected by the redirection and these CSRs continue to provide information associated with the corresponding exceptions.

| Field Name | Bits            | Description                                                                                                                                                                               | Type  | Reset   |   |                 |   |          |  |  |
|------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-----------------|---|----------|--|--|
| IAM        | [0]             | Indicating whether Instruction Access Misaligned exceptions are redirected to enter Debug Mode.                                                                                           | RW    | 0       |   |                 |   |          |  |  |
|            |                 | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | Value | Meaning | 0 | Do not redirect | 1 | Redirect |  |  |
| Value      | Meaning         |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 0          | Do not redirect |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 1          | Redirect        |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| IAF        | [1]             | Indicating whether Instruction Access Fault exceptions are redirected to enter Debug Mode.                                                                                                | RW    | 0       |   |                 |   |          |  |  |
|            |                 | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | Value | Meaning | 0 | Do not redirect | 1 | Redirect |  |  |
| Value      | Meaning         |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 0          | Do not redirect |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 1          | Redirect        |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| II         | [2]             | Indicating whether Illegal Instruction exceptions are redirected to enter Debug Mode.                                                                                                     | RW    | 0       |   |                 |   |          |  |  |
|            |                 | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | Value | Meaning | 0 | Do not redirect | 1 | Redirect |  |  |
| Value      | Meaning         |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 0          | Do not redirect |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 1          | Redirect        |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |

| <b>Field Name</b> | <b>Bits</b>     | <b>Description</b>                                                                                                                                                                                      | <b>Type</b>  | <b>Reset</b>   |   |                 |   |          |  |  |
|-------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------|---|-----------------|---|----------|--|--|
| NMI               | [3]             | Indicating whether Non-Maskable Interrupt exceptions are redirected to enter Debug Mode.                                                                                                                | RW           | 0              |   |                 |   |          |  |  |
|                   |                 | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Do not redirect | 1 | Redirect |  |  |
| <b>Value</b>      | <b>Meaning</b>  |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| 0                 | Do not redirect |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| 1                 | Redirect        |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| LAM               | [4]             | Indicating whether Load Access Misaligned exceptions are redirected to enter Debug Mode.                                                                                                                | RW           | 0              |   |                 |   |          |  |  |
|                   |                 | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Do not redirect | 1 | Redirect |  |  |
| <b>Value</b>      | <b>Meaning</b>  |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| 0                 | Do not redirect |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| 1                 | Redirect        |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| LAF               | [5]             | Indicating whether Load Access Fault exceptions are redirected to enter Debug Mode.                                                                                                                     | RW           | 0              |   |                 |   |          |  |  |
|                   |                 | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Do not redirect | 1 | Redirect |  |  |
| <b>Value</b>      | <b>Meaning</b>  |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| 0                 | Do not redirect |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| 1                 | Redirect        |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| SAM               | [6]             | Indicating whether Store Access Misaligned exceptions are redirected to enter Debug Mode.                                                                                                               | RW           | 0              |   |                 |   |          |  |  |
|                   |                 | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Do not redirect | 1 | Redirect |  |  |
| <b>Value</b>      | <b>Meaning</b>  |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| 0                 | Do not redirect |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| 1                 | Redirect        |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| SAF               | [7]             | Indicating whether Store Access Fault exceptions are redirected to enter Debug Mode.                                                                                                                    | RW           | 0              |   |                 |   |          |  |  |
|                   |                 | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Do not redirect | 1 | Redirect |  |  |
| <b>Value</b>      | <b>Meaning</b>  |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| 0                 | Do not redirect |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| 1                 | Redirect        |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| UEC               | [8]             | Indicating whether U-mode Environment Call exceptions are redirected to enter Debug Mode.                                                                                                               | RW           | 0              |   |                 |   |          |  |  |
|                   |                 | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Do not redirect | 1 | Redirect |  |  |
| <b>Value</b>      | <b>Meaning</b>  |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| 0                 | Do not redirect |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |
| 1                 | Redirect        |                                                                                                                                                                                                         |              |                |   |                 |   |          |  |  |

| Field Name | Bits            | Description                                                                                                                                                                               | Type  | Reset   |   |                 |   |          |  |  |
|------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-----------------|---|----------|--|--|
| SEC        | [9]             | Indicating whether S-mode Environment Call exceptions are redirected to enter Debug Mode.                                                                                                 | RW    | 0       |   |                 |   |          |  |  |
|            |                 | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | Value | Meaning | 0 | Do not redirect | 1 | Redirect |  |  |
| Value      | Meaning         |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 0          | Do not redirect |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 1          | Redirect        |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| Reserved   | [10]            | Reserved                                                                                                                                                                                  | RO    | 0       |   |                 |   |          |  |  |
| MEC        | [11]            | Indicating whether M-mode Environment Call exceptions are redirected to enter Debug Mode.                                                                                                 | RW    | 0       |   |                 |   |          |  |  |
|            |                 | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | Value | Meaning | 0 | Do not redirect | 1 | Redirect |  |  |
| Value      | Meaning         |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 0          | Do not redirect |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 1          | Redirect        |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| HSP        | [12]            | Indicating whether Stack Protection exceptions are redirected to enter Debug Mode. This bit is present only when mmSC_cfg.HSP is set.                                                     | RW    | 0       |   |                 |   |          |  |  |
|            |                 | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | Value | Meaning | 0 | Do not redirect | 1 | Redirect |  |  |
| Value      | Meaning         |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 0          | Do not redirect |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 1          | Redirect        |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| ACE        | [13]            | Indicating whether ACE-related exceptions are redirected to enter Debug Mode. This bit is present only when mmSC_cfg.ACE is set.                                                          | RW    | 0       |   |                 |   |          |  |  |
|            |                 | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | Value | Meaning | 0 | Do not redirect | 1 | Redirect |  |  |
| Value      | Meaning         |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 0          | Do not redirect |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 1          | Redirect        |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| IMECC      | [14]            | Indicating whether Imprecise ECC Error local interrupts are redirected to enter Debug Mode.                                                                                               | RW    | 0       |   |                 |   |          |  |  |
|            |                 | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | Value | Meaning | 0 | Do not redirect | 1 | Redirect |  |  |
| Value      | Meaning         |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 0          | Do not redirect |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 1          | Redirect        |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |

| Field Name | Bits            | Description                                                                                                                                                                               | Type  | Reset   |   |                 |   |          |  |  |
|------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-----------------|---|----------|--|--|
| BWE        | [15]            | Indicating whether Bus-write Transaction Error local interrupts are redirected to enter Debug Mode.                                                                                       | RW    | 0       |   |                 |   |          |  |  |
|            |                 | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | Value | Meaning | 0 | Do not redirect | 1 | Redirect |  |  |
| Value      | Meaning         |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 0          | Do not redirect |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 1          | Redirect        |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| IPF        | [16]            | Indicating whether instruction page fault exceptions are redirected to enter Debug Mode.                                                                                                  | RW    | 0       |   |                 |   |          |  |  |
|            |                 | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | Value | Meaning | 0 | Do not redirect | 1 | Redirect |  |  |
| Value      | Meaning         |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 0          | Do not redirect |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 1          | Redirect        |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| LPF        | [17]            | Indicating whether load fault exceptions are redirected to enter Debug Mode.                                                                                                              | RW    | 0       |   |                 |   |          |  |  |
|            |                 | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | Value | Meaning | 0 | Do not redirect | 1 | Redirect |  |  |
| Value      | Meaning         |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 0          | Do not redirect |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 1          | Redirect        |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| SPF        | [18]            | Indicating whether store page fault exceptions are redirected to enter Debug Mode.                                                                                                        | RW    | 0       |   |                 |   |          |  |  |
|            |                 | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | Value | Meaning | 0 | Do not redirect | 1 | Redirect |  |  |
| Value      | Meaning         |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 0          | Do not redirect |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 1          | Redirect        |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| PMOV       | [19]            | Indicating whether performance counter overflow interrupts are redirected to enter Debug Mode.                                                                                            | RW    | 0       |   |                 |   |          |  |  |
|            |                 | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not redirect</td></tr> <tr> <td>1</td><td>Redirect</td></tr> </tbody> </table> | Value | Meaning | 0 | Do not redirect | 1 | Redirect |  |  |
| Value      | Meaning         |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 0          | Do not redirect |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |
| 1          | Redirect        |                                                                                                                                                                                           |       |         |   |                 |   |          |  |  |

## 18.7.6 Debug Detailed Cause

**Mnemonic Name:** ddcause

**IM Requirement:** DEBUG\_SUPPORT

**Access Mode:** Debug

**CSR Address:** 0x7e1 (non-standard read/write)



| Field Name | Bits                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type  | Reset   |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
|------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------------------------|---|-------------------------------------|---|--------------------------------|---|--------------------------|---|------------------------------|---|------------------------------|---|-------------------------|---|-------------------------------|---|--------------------------|---|-------------------------------|----|-------------------------------|----|----------|----|-------------------------------|----|-----------------|----|----------|----|----------------------|----|---------------------|----|-----------------------------|----|------------------------------|-------|----------|----|--------------------------|----|---------------------------|----|------------------------|-------|----------|-------|---------------|-----|----------|--|--|
| CAUSE      | [7:0]                               | Cause for redirection to Debug Mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RO    | 0       |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
|            |                                     | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr><td>0</td><td>Software Breakpoint (EBREAK)</td></tr> <tr><td>1</td><td>Instruction Access Misaligned (IAM)</td></tr> <tr><td>2</td><td>Instruction Access Fault (IAF)</td></tr> <tr><td>3</td><td>Illegal Instruction (II)</td></tr> <tr><td>4</td><td>Non-Maskable Interrupt (NMI)</td></tr> <tr><td>5</td><td>Load Access Misaligned (LAM)</td></tr> <tr><td>6</td><td>Load Access Fault (LAF)</td></tr> <tr><td>7</td><td>Store Access Misaligned (SAM)</td></tr> <tr><td>8</td><td>Store Access Fault (SAF)</td></tr> <tr><td>9</td><td>U-mode Environment Call (UEC)</td></tr> <tr><td>10</td><td>S-mode Environment Call (SEC)</td></tr> <tr><td>11</td><td>Reserved</td></tr> <tr><td>12</td><td>M-mode Environment Call (MEC)</td></tr> <tr><td>13</td><td>Load page fault</td></tr> <tr><td>14</td><td>Reserved</td></tr> <tr><td>15</td><td>Store/AMO page fault</td></tr> <tr><td>16</td><td>Imprecise ECC error</td></tr> <tr><td>17</td><td>Bus write transaction error</td></tr> <tr><td>18</td><td>Performance Counter overflow</td></tr> <tr><td>19–31</td><td>Reserved</td></tr> <tr><td>32</td><td>Stack overflow exception</td></tr> <tr><td>33</td><td>Stack underflow exception</td></tr> <tr><td>34</td><td>ACE disabled exception</td></tr> <tr><td>35–39</td><td>Reserved</td></tr> <tr><td>40–47</td><td>ACE exception</td></tr> <tr><td>≥48</td><td>Reserved</td></tr> </tbody> </table> | Value | Meaning | 0 | Software Breakpoint (EBREAK) | 1 | Instruction Access Misaligned (IAM) | 2 | Instruction Access Fault (IAF) | 3 | Illegal Instruction (II) | 4 | Non-Maskable Interrupt (NMI) | 5 | Load Access Misaligned (LAM) | 6 | Load Access Fault (LAF) | 7 | Store Access Misaligned (SAM) | 8 | Store Access Fault (SAF) | 9 | U-mode Environment Call (UEC) | 10 | S-mode Environment Call (SEC) | 11 | Reserved | 12 | M-mode Environment Call (MEC) | 13 | Load page fault | 14 | Reserved | 15 | Store/AMO page fault | 16 | Imprecise ECC error | 17 | Bus write transaction error | 18 | Performance Counter overflow | 19–31 | Reserved | 32 | Stack overflow exception | 33 | Stack underflow exception | 34 | ACE disabled exception | 35–39 | Reserved | 40–47 | ACE exception | ≥48 | Reserved |  |  |
| Value      | Meaning                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 0          | Software Breakpoint (EBREAK)        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 1          | Instruction Access Misaligned (IAM) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 2          | Instruction Access Fault (IAF)      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 3          | Illegal Instruction (II)            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 4          | Non-Maskable Interrupt (NMI)        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 5          | Load Access Misaligned (LAM)        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 6          | Load Access Fault (LAF)             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 7          | Store Access Misaligned (SAM)       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 8          | Store Access Fault (SAF)            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 9          | U-mode Environment Call (UEC)       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 10         | S-mode Environment Call (SEC)       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 11         | Reserved                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 12         | M-mode Environment Call (MEC)       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 13         | Load page fault                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 14         | Reserved                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 15         | Store/AMO page fault                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 16         | Imprecise ECC error                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 17         | Bus write transaction error         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 18         | Performance Counter overflow        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 19–31      | Reserved                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 32         | Stack overflow exception            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 33         | Stack underflow exception           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 34         | ACE disabled exception              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 35–39      | Reserved                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| 40–47      | ACE exception                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |
| ≥48        | Reserved                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                              |   |                                     |   |                                |   |                          |   |                              |   |                              |   |                         |   |                               |   |                          |   |                               |    |                               |    |          |    |                               |    |                 |    |          |    |                      |    |                     |    |                             |    |                              |       |          |    |                          |    |                           |    |                        |       |          |       |               |     |          |  |  |

## 18.8 Memory and Miscellaneous Registers

### 18.8.1 Instruction Local Memory Base Register

**Mnemonic Name:** milmb

**IM Requirement: ILM SIZE KB > 0**

### **Access Mode: Machine**

**CSR Address:** 0x7c0 (non-standard read/write)

|      |    |       |       |     |   |   |   |
|------|----|-------|-------|-----|---|---|---|
| 31   | 10 | 9     | 4     | 3   | 2 | 1 | 0 |
| IBPA | 0  | RWECC | ECCEN | IEN |   |   |   |

This register controls instruction local memory.

| Field Name | Bits                                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Type  | Reset           |   |                                          |   |                                         |    |                                                             |   |                                                      |    |   |
|------------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------|---|------------------------------------------|---|-----------------------------------------|----|-------------------------------------------------------------|---|------------------------------------------------------|----|---|
| IEN        | [0]                                                         | ILM enable control:<br><br><table border="1" style="margin-left: 20px;"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>ILM is disabled</td></tr> <tr> <td>1</td><td>ILM is enabled</td></tr> </tbody> </table>                                                                                                                                                                                                                  | Value | Meaning         | 0 | ILM is disabled                          | 1 | ILM is enabled                          | RO | 1                                                           |   |                                                      |    |   |
| Value      | Meaning                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                 |   |                                          |   |                                         |    |                                                             |   |                                                      |    |   |
| 0          | ILM is disabled                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                 |   |                                          |   |                                         |    |                                                             |   |                                                      |    |   |
| 1          | ILM is enabled                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                 |   |                                          |   |                                         |    |                                                             |   |                                                      |    |   |
| ECCEN      | [2:1]                                                       | Parity/ECC enable control:<br><br><table border="1" style="margin-left: 20px;"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable parity/ECC</td></tr> <tr> <td>1</td><td>Reserved</td></tr> <tr> <td>2</td><td>Generate exceptions only on uncorrectable parity/ECC errors</td></tr> <tr> <td>3</td><td>Generate exceptions on any type of parity/ECC errors</td></tr> </tbody> </table>                                   | Value | Meaning         | 0 | Disable parity/ECC                       | 1 | Reserved                                | 2  | Generate exceptions only on uncorrectable parity/ECC errors | 3 | Generate exceptions on any type of parity/ECC errors | RW | 0 |
| Value      | Meaning                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                 |   |                                          |   |                                         |    |                                                             |   |                                                      |    |   |
| 0          | Disable parity/ECC                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                 |   |                                          |   |                                         |    |                                                             |   |                                                      |    |   |
| 1          | Reserved                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                 |   |                                          |   |                                         |    |                                                             |   |                                                      |    |   |
| 2          | Generate exceptions only on uncorrectable parity/ECC errors |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                 |   |                                          |   |                                         |    |                                                             |   |                                                      |    |   |
| 3          | Generate exceptions on any type of parity/ECC errors        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                 |   |                                          |   |                                         |    |                                                             |   |                                                      |    |   |
| RWECC      | [3]                                                         | Controls diagnostic accesses of ECC codes of the ILM rams through the <code>mecc_code</code> register. This bit can be turned on for injecting ECC errors to test the ECC handler.<br><br><table border="1" style="margin-left: 20px;"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable diagnostic accesses of ECC codes</td></tr> <tr> <td>1</td><td>Enable diagnostic accesses of ECC codes</td></tr> </tbody> </table> | Value | Meaning         | 0 | Disable diagnostic accesses of ECC codes | 1 | Enable diagnostic accesses of ECC codes | RW | 0                                                           |   |                                                      |    |   |
| Value      | Meaning                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                 |   |                                          |   |                                         |    |                                                             |   |                                                      |    |   |
| 0          | Disable diagnostic accesses of ECC codes                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                 |   |                                          |   |                                         |    |                                                             |   |                                                      |    |   |
| 1          | Enable diagnostic accesses of ECC codes                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                 |   |                                          |   |                                         |    |                                                             |   |                                                      |    |   |
| IBPA       | [31:10]                                                     | The base physical address of ILM. It has to be an integer multiple of the ILM size.                                                                                                                                                                                                                                                                                                                                                                                    | RO    | ILM_BASE[31:10] |   |                                          |   |                                         |    |                                                             |   |                                                      |    |   |

## 18.8.2 Data Local Memory Base Register

**Mnemonic Name:** mdlmb

**IM Requirement:** DLM\_SIZE\_KB > 0

**Access Mode:** Machine

**CSR Address:** 0x7c1 (non-standard read/write)



| Field Name | Bits                                                        | Description                                                                                                                                                                                                                                                                                                                                                             | Type  | Reset           |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
|------------|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------|---|------------------------------------------|---|-----------------------------------------|---|-------------------------------------------------------------|---|------------------------------------------------------|--|--|
| DEN        | [0]                                                         | DLM enable control:                                                                                                                                                                                                                                                                                                                                                     | RO    | 1               |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
|            |                                                             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>DLM is disabled</td></tr> <tr> <td>1</td><td>DLM is enabled</td></tr> </tbody> </table>                                                                                                                                                                         | Value | Meaning         | 0 | DLM is disabled                          | 1 | DLM is enabled                          |   |                                                             |   |                                                      |  |  |
| Value      | Meaning                                                     |                                                                                                                                                                                                                                                                                                                                                                         |       |                 |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 0          | DLM is disabled                                             |                                                                                                                                                                                                                                                                                                                                                                         |       |                 |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 1          | DLM is enabled                                              |                                                                                                                                                                                                                                                                                                                                                                         |       |                 |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| ECCEN      | [2:1]                                                       | Parity/ECC enable control:                                                                                                                                                                                                                                                                                                                                              | RW    | 0               |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
|            |                                                             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable parity/ECC</td></tr> <tr> <td>1</td><td>Reserved</td></tr> <tr> <td>2</td><td>Generate exceptions only on uncorrectable parity/ECC errors</td></tr> <tr> <td>3</td><td>Generate exceptions on any type of parity/ECC errors</td></tr> </tbody> </table> | Value | Meaning         | 0 | Disable parity/ECC                       | 1 | Reserved                                | 2 | Generate exceptions only on uncorrectable parity/ECC errors | 3 | Generate exceptions on any type of parity/ECC errors |  |  |
| Value      | Meaning                                                     |                                                                                                                                                                                                                                                                                                                                                                         |       |                 |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 0          | Disable parity/ECC                                          |                                                                                                                                                                                                                                                                                                                                                                         |       |                 |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 1          | Reserved                                                    |                                                                                                                                                                                                                                                                                                                                                                         |       |                 |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 2          | Generate exceptions only on uncorrectable parity/ECC errors |                                                                                                                                                                                                                                                                                                                                                                         |       |                 |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 3          | Generate exceptions on any type of parity/ECC errors        |                                                                                                                                                                                                                                                                                                                                                                         |       |                 |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| RWECC      | [3]                                                         | Controls diagnostic accesses of ECC codes of the DLM rams through the <code>mecc_code</code> register. This bit can be turned on for injecting ECC errors to test the ECC handler.                                                                                                                                                                                      | RW    | 0               |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
|            |                                                             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable diagnostic accesses of ECC codes</td></tr> <tr> <td>1</td><td>Enable diagnostic accesses of ECC codes</td></tr> </tbody> </table>                                                                                                                       | Value | Meaning         | 0 | Disable diagnostic accesses of ECC codes | 1 | Enable diagnostic accesses of ECC codes |   |                                                             |   |                                                      |  |  |
| Value      | Meaning                                                     |                                                                                                                                                                                                                                                                                                                                                                         |       |                 |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 0          | Disable diagnostic accesses of ECC codes                    |                                                                                                                                                                                                                                                                                                                                                                         |       |                 |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 1          | Enable diagnostic accesses of ECC codes                     |                                                                                                                                                                                                                                                                                                                                                                         |       |                 |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| DBPA       | [31:10]                                                     | The base physical address of DLM. It has to be an integer multiple of the DLM size.                                                                                                                                                                                                                                                                                     | RO    | DLM_BASE[31:10] |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |

### 18.8.3 ECC Code Register

**Mnemonic Name:** `mecc_code`

**IM Requirement:** `mmsc_cfg.ECC == 1`

**Access Mode:** Machine

**CSR Address:** `0x7c2` (non-standard read/write)



This register is used for accessing ECC array of ILM and DLM.

| Field Name | Bits    | Description                                                                                                                                                                                      | Type | Reset |
|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| CODE       | [6:0]   | This field records the ECC value on ECC error exceptions. This field is also used to read/write the ECC codes when diagnostic access of ECC codes are enabled (milmb.RWECC or md1mb.RWECC is 1). | RW   | 1     |
| C          | [16]    | Correctable error. This bit is updated on parity/ECC error exceptions.                                                                                                                           | RO   | 0     |
| P          | [17]    | Precise error. This bit is updated on parity/ECC error exceptions.                                                                                                                               | RO   | 0     |
| RAMID      | [21:18] | The ID of RAM that caused parity/ECC errors. This bit is updated on parity/ECC error exceptions.                                                                                                 | RO   | 0     |
| INSN       | [22]    | Indicates if the parity/ECC error is caused by instruction fetch or data access.                                                                                                                 | RO   | 0     |

### 18.8.4 NMI Vector Base Address Register

**Mnemonic Name:** mnvec

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x7c3 (non-standard read/write)



This register indicates the entry point when an NMI occurs.

| Field Name | Bits   | Description                                                                                                                       | Type | Reset          |
|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------|------|----------------|
| NMVEC      | [31:0] | Handler base address for NMI. Its value is the zero extended value of the <code>reset_vector[31:0]</code> input signal to N25(F). | RO   | Pin Configured |

## 18.8.5 Performance Throttling Control Register

**Mnemonic Name:** mpft\_ctl

**IM Requirement:** POWERBRAKE\_SUPPORT = "yes"

**Access Mode:** Machine

**CSR Address:** 0x7c5 (non-standard read/write)



| Field Name | Bits  | Description                                                                                                                                  | Type | Reset |
|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| T_LEVEL    | [7:4] | Throttling Level. The processor has the highest performance at throttling level 0 and the lowest performance at throttling level 15.         | RW   | 0     |
| FAST_INT   | [8]   | Fast interrupt response. If this field is set, MXSTATUS.PFT_EN will be automatically cleared when the processor enters an interrupt handler. | RW   | 0     |

## 18.8.6 Cache Control Register

**Mnemonic Name:** mcache\_ctl

**IM Requirement:** Cache optional (micm\_cfg.ISZ != 0 or mdcm\_cfg.DSZ != 0)

**Access Mode:** Machine

**CSR Address:** 0x7ca (non-standard read/write)



| <b>Field Name</b> | <b>Bits</b>                                                 | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                      | <b>Type</b> | <b>Reset</b> |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
|-------------------|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|---|---------------------|---|--------------------|---|-------------------------------------------------------------|---|------------------------------------------------------|--|--|
| IC_EN             | [0]                                                         | Controls if the instruction cache is enabled or not.                                                                                                                                                                                                                                                                                                                    | RW          | 0            |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
|                   |                                                             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>I-Cache is disabled</td></tr> <tr> <td>1</td><td>I-Cache is enabled</td></tr> </tbody> </table>                                                                                                                                                                 | Value       | Meaning      | 0 | I-Cache is disabled | 1 | I-Cache is enabled |   |                                                             |   |                                                      |  |  |
| Value             | Meaning                                                     |                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
| 0                 | I-Cache is disabled                                         |                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
| 1                 | I-Cache is enabled                                          |                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
| DC_EN             | [1]                                                         | Controls if the data cache is enabled or not.                                                                                                                                                                                                                                                                                                                           | RW          | 0            |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
|                   |                                                             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>D-Cache is disabled</td></tr> <tr> <td>1</td><td>D-Cache is enabled</td></tr> </tbody> </table>                                                                                                                                                                 | Value       | Meaning      | 0 | D-Cache is disabled | 1 | D-Cache is enabled |   |                                                             |   |                                                      |  |  |
| Value             | Meaning                                                     |                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
| 0                 | D-Cache is disabled                                         |                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
| 1                 | D-Cache is enabled                                          |                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
| IC_ECCEN          | [3:2]                                                       | Parity/ECC error checking enable control for the instruction cache.                                                                                                                                                                                                                                                                                                     | RW          | 0            |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
|                   |                                                             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable parity/ECC</td></tr> <tr> <td>1</td><td>Reserved</td></tr> <tr> <td>2</td><td>Generate exceptions only on uncorrectable parity/ECC errors</td></tr> <tr> <td>3</td><td>Generate exceptions on any type of parity/ECC errors</td></tr> </tbody> </table> | Value       | Meaning      | 0 | Disable parity/ECC  | 1 | Reserved           | 2 | Generate exceptions only on uncorrectable parity/ECC errors | 3 | Generate exceptions on any type of parity/ECC errors |  |  |
| Value             | Meaning                                                     |                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
| 0                 | Disable parity/ECC                                          |                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
| 1                 | Reserved                                                    |                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
| 2                 | Generate exceptions only on uncorrectable parity/ECC errors |                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                     |   |                    |   |                                                             |   |                                                      |  |  |
| 3                 | Generate exceptions on any type of parity/ECC errors        |                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                     |   |                    |   |                                                             |   |                                                      |  |  |

| Field Name | Bits                                                        | Description                                                                                                                                                                                                                                                                                                                                                             | Type  | Reset   |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
|------------|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------------------------------------|---|-----------------------------------------|---|-------------------------------------------------------------|---|------------------------------------------------------|--|--|
| DC_ECCEN   | [5:4]                                                       | Parity/ECC error checking enable control for the data cache.                                                                                                                                                                                                                                                                                                            | RW    | 0       |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
|            |                                                             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable parity/ECC</td></tr> <tr> <td>1</td><td>Reserved</td></tr> <tr> <td>2</td><td>Generate exceptions only on uncorrectable parity/ECC errors</td></tr> <tr> <td>3</td><td>Generate exceptions on any type of parity/ECC errors</td></tr> </tbody> </table> | Value | Meaning | 0 | Disable parity/ECC                       | 1 | Reserved                                | 2 | Generate exceptions only on uncorrectable parity/ECC errors | 3 | Generate exceptions on any type of parity/ECC errors |  |  |
| Value      | Meaning                                                     |                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 0          | Disable parity/ECC                                          |                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 1          | Reserved                                                    |                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 2          | Generate exceptions only on uncorrectable parity/ECC errors |                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 3          | Generate exceptions on any type of parity/ECC errors        |                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| IC_RWECC   | [6]                                                         | Controls diagnostic accesses of ECC codes of the instruction cache rams through the <code>meccc_code</code> register. This bit can be turned on for injecting ECC errors to test the ECC handler.                                                                                                                                                                       | RW    | 0       |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
|            |                                                             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable diagnostic accesses of ECC codes</td></tr> <tr> <td>1</td><td>Enable diagnostic accesses of ECC codes</td></tr> </tbody> </table>                                                                                                                       | Value | Meaning | 0 | Disable diagnostic accesses of ECC codes | 1 | Enable diagnostic accesses of ECC codes |   |                                                             |   |                                                      |  |  |
| Value      | Meaning                                                     |                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 0          | Disable diagnostic accesses of ECC codes                    |                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 1          | Enable diagnostic accesses of ECC codes                     |                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| DC_RWECC   | [7]                                                         | Controls diagnostic accesses of ECC codes of the data cache rams through the <code>meccc_code</code> register. This bit can be turned on for injecting ECC errors to test the ECC handler.                                                                                                                                                                              | RW    | 0       |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
|            |                                                             | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable diagnostic accesses of ECC codes</td></tr> <tr> <td>1</td><td>Enable diagnostic accesses of ECC codes</td></tr> </tbody> </table>                                                                                                                       | Value | Meaning | 0 | Disable diagnostic accesses of ECC codes | 1 | Enable diagnostic accesses of ECC codes |   |                                                             |   |                                                      |  |  |
| Value      | Meaning                                                     |                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 0          | Disable diagnostic accesses of ECC codes                    |                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |
| 1          | Enable diagnostic accesses of ECC codes                     |                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                          |   |                                         |   |                                                             |   |                                                      |  |  |

| Field Name              | Bits                                                                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Type | Reset |       |         |   |                                                                           |   |                                                                          |
|-------------------------|---------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|-------|---------|---|---------------------------------------------------------------------------|---|--------------------------------------------------------------------------|
| CCTL_SUEN               | [8]                                                                       | Enable bit for supervisor and user modes to access ucctlbeginaddr, ucctlcommand, and scctlidata CSRs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RW   | 0     |       |         |   |                                                                           |   |                                                                          |
| <b>Official Release</b> |                                                                           | <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th style="text-align: left; padding: 2px;">Value</th><th style="text-align: left; padding: 2px;">Meaning</th></tr> </thead> <tbody> <tr> <td style="text-align: center; padding: 2px;">0</td><td style="text-align: left; padding: 2px;">Disable ucctlbeginaddr, ucctlcommand, and scctlidata accesses in S/U mode</td></tr> <tr> <td style="text-align: center; padding: 2px;">1</td><td style="text-align: left; padding: 2px;">Enable ucctlbeginaddr, ucctlcommand, and scctlidata accesses in S/U mode</td></tr> </tbody> </table> |      |       | Value | Meaning | 0 | Disable ucctlbeginaddr, ucctlcommand, and scctlidata accesses in S/U mode | 1 | Enable ucctlbeginaddr, ucctlcommand, and scctlidata accesses in S/U mode |
| Value                   | Meaning                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |       |       |         |   |                                                                           |   |                                                                          |
| 0                       | Disable ucctlbeginaddr, ucctlcommand, and scctlidata accesses in S/U mode |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |       |       |         |   |                                                                           |   |                                                                          |
| 1                       | Enable ucctlbeginaddr, ucctlcommand, and scctlidata accesses in S/U mode  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |       |       |         |   |                                                                           |   |                                                                          |

## 18.8.7 Machine Miscellaneous Control Register

**Mnemonic Name:** mmisc\_ctl

**IM Requirement:** Required

**Access Mode:** Machine

**CSR Address:** 0x7d0 (non-standard read/write)



| Field Name | Bits         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Type  | Reset   |   |              |   |             |    |   |
|------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|--------------|---|-------------|----|---|
| VEC_PLIC   | [1]          | Selects the operation mode of PLIC:<br><br><table border="1" style="margin-left: 20px;"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Regular mode</td></tr> <tr> <td>1</td><td>Vector mode</td></tr> </tbody> </table><br>Please note that both this bit and the vector mode enable bit (VECTORED) of the Feature Enable Register in NCEPLIC100 should be turned on for the vectored interrupt support to work correctly. See Section 19.5.2 for the definition of the VECTORED bit.<br>This bit is hard-wired to 0 if the vectored PLIC feature is not supported. | Value | Meaning | 0 | Regular mode | 1 | Vector mode | RW | 0 |
| Value      | Meaning      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |              |   |             |    |   |
| 0          | Regular mode |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |              |   |             |    |   |
| 1          | Vector mode  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |              |   |             |    |   |
| RVCOMPMM   | [2]          | RISC-V compatibility mode enable bit. If the compatibility mode is turned on, all Andes-specific instructions become reserved instructions.<br><br><table border="1" style="margin-left: 20px;"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disabled</td></tr> <tr> <td>1</td><td>Enabled</td></tr> </tbody> </table>                                                                                                                                                                                                                                             | Value | Meaning | 0 | Disabled     | 1 | Enabled     | RW | 0 |
| Value      | Meaning      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |              |   |             |    |   |
| 0          | Disabled     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |              |   |             |    |   |
| 1          | Enabled      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |              |   |             |    |   |
| BRPE       | [3]          | Branch prediction enable bit. This bit controls all branch prediction structures.<br><br><table border="1" style="margin-left: 20px;"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disabled</td></tr> <tr> <td>1</td><td>Enabled</td></tr> </tbody> </table><br>This bit is hard-wired to 0 if branch prediction structure is not supported.                                                                                                                                                                                                                       | Value | Meaning | 0 | Disabled     | 1 | Enabled     | RW | 1 |
| Value      | Meaning      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |              |   |             |    |   |
| 0          | Disabled     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |              |   |             |    |   |
| 1          | Enabled      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |              |   |             |    |   |

| <b>Field Name</b> | <b>Bits</b>                                                  | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>Type</b> | <b>Reset</b> |   |                                                              |   |                               |       |       |   |       |    |   |
|-------------------|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|---|--------------------------------------------------------------|---|-------------------------------|-------|-------|---|-------|----|---|
| ACES              | [5:4]                                                        | <p>Andes Custom Extension (ACE) extension context status field:</p> <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Off</td></tr> <tr> <td>1</td><td>Initial</td></tr> <tr> <td>2</td><td>Clean</td></tr> <tr> <td>3</td><td>Dirty</td></tr> </tbody> </table> <ul style="list-style-type: none"> <li>This field should not be Off (0) for ACE instructions to execute normally. This is done by software program through CSRW instructions.</li> <li>A normal flow to turn on ACE unit will be as follows: <ul style="list-style-type: none"> <li>– ACES is in the Off state.</li> <li>– An ACE instruction executed in the Off state triggers an illegal instruction with sdcause/mdcause == 2 (ACE disabled exception).</li> <li>– The exception handler initializes all ACE register states, changes this field to the Initial state, and then returns from exception.</li> <li>– The ACE instruction is executed again. Since ACES is not in the Off state this time, it shall execute correctly. If any ACE register states are modified, this field (ACES) will be updated to the Dirty state automatically by hardware.</li> </ul> </li> </ul> <p>This field is hard-wired to 0 if ACE extension is not configured.</p> | Value       | Meaning      | 0 | Off                                                          | 1 | Initial                       | 2     | Clean | 3 | Dirty | RW | 0 |
| Value             | Meaning                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                                                              |   |                               |       |       |   |       |    |   |
| 0                 | Off                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                                                              |   |                               |       |       |   |       |    |   |
| 1                 | Initial                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                                                              |   |                               |       |       |   |       |    |   |
| 2                 | Clean                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                                                              |   |                               |       |       |   |       |    |   |
| 3                 | Dirty                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                                                              |   |                               |       |       |   |       |    |   |
| MSA               | [6]                                                          | <p>This field controls whether the load/store instructions can access misaligned memory locations without generating an Address Misaligned exception.</p> <p>Supported instructions: LW/LH/LHU/SW/SH</p> <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Misaligned access generates an Address Misaligned exception.</td></tr> <tr> <td>1</td><td>Misaligned access is allowed.</td></tr> </tbody> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Value       | Meaning      | 0 | Misaligned access generates an Address Misaligned exception. | 1 | Misaligned access is allowed. | RW/RO | IM    |   |       |    |   |
| Value             | Meaning                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                                                              |   |                               |       |       |   |       |    |   |
| 0                 | Misaligned access generates an Address Misaligned exception. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                                                              |   |                               |       |       |   |       |    |   |
| 1                 | Misaligned access is allowed.                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |             |              |   |                                                              |   |                               |       |       |   |       |    |   |

## 18.8.8 Machine CCTL Begin Address

**Mnemonic Name:** mcctlbeginaddr

**IM Requirement:** Cache optional (micm\_cfg.ISZ != 0 or mdcm\_cfg.DSZ != 0) & (mmsc\_cfg.CCTLCSR==1)

**Access Mode:** Machine

**CSR Address:** 0x7cb (non-standard read/write)

This register holds the address information required by CCTL operations:

- For "VA" type of CCTL operations: The mcctlbeginaddr register contains the starting virtual address for CCTL operations triggered by writes to the mcctlcommand register. For CCTL lock operations, the mcctldata register will be updated with a successful (1) or failed (0) status value when the operations complete.

After an update to the mcctlcommand CSR with a "VA" type command, the value of this register will be incremented with the byte size of the corresponding cache line.

- For "Index" type of CCTL operations: The mcctlbeginaddr register contains the cache index for CCTL operations triggered by writes to the mcctlcommand register.

For all Index type commands other than "IX\_RDATA" and "IX\_WDATA": the "way" field in this register will be incremented. If the incremented "way" wraps to 0 (i.e., the first way of a set), then the "set" index field in this register will be incremented.

For "IX\_RDATA" and "IX\_WDATA" commands: the "offset" field in this register will be incremented first to the next offset value. If the incremented "offset" field wraps across 0 (i.e., the first word or double word of a cache line), then the "way" field in this register will be incremented. If the incremented "way" wraps to 0 (i.e., the first way of a set), then the "set" index field in this register will be incremented.

## 18.8.9 Machine CCTL Command

**Mnemonic Name:** mcctlcommand

**IM Requirement:** Cache optional (micm\_cfg.ISZ != 0 or mdcm\_cfg.DSZ != 0) & (mmsc\_cfg.CCTLCSR==1)+

**Access Mode:** Machine

**CSR Address:** 0x7cc (non-standard read/write)

Writing to this register will trigger a CCTL operation, with the type of the operation specified by the value written. Valid CCTL operations are defined in Table 18-18 CCTL Command Definition.

**Table 18-18 CCTL Command Definition**

| <b>Value</b> | <b>Command</b>  | <b>Type</b> |
|--------------|-----------------|-------------|
| 0 0b00_000   | L1D_VA_INVAL    | VA          |
| 1 0b00_001   | L1D_VA_WB       | VA          |
| 2 0b00_010   | L1D_VA_WBINVAL  | VA          |
| 3 0b00_011   | L1D_VA_LOCK     | VA          |
| 4 0b00_100   | L1D_VA_UNLOCK   | VA          |
| 6 0b00_110   | L1D_WBINVAL_ALL | -           |
| 7 0b00_111   | L1D_WB_ALL      | -           |
| 8 0b01_000   | L1I_VA_INVAL    | VA          |
| 11 0b01_011  | L1I_VA_LOCK     | VA          |
| 12 0b01_100  | L1I_VA_UNLOCK   | VA          |
| 16 0b10_000  | L1D_Ix_INVAL    | Index       |
| 17 0b10_001  | L1D_Ix_WB       | Index       |
| 18 0b10_010  | L1D_Ix_WBINVAL  | Index       |
| 19 0b10_011  | L1D_Ix_RTAG     | Index       |
| 20 0b10_100  | L1D_Ix_RDATA    | Index       |
| 21 0b10_101  | L1D_Ix_WTAG     | Index       |
| 22 0b10_110  | L1D_Ix_WDATA    | Index       |
| 23 0b10_111  | L1D_INVAL_ALL   | -           |
| 24 0b11_000  | L1I_Ix_INVAL    | Index       |
| 27 0b11_011  | L1I_Ix_RTAG     | Index       |
| 28 0b11_100  | L1I_Ix_RDATA    | Index       |
| 29 0b11_101  | L1I_Ix_WTAG     | Index       |
| 30 0b11_110  | L1I_Ix_WDATA    | Index       |

### 18.8.10 Machine CCTL Data

**Mnemonic Name:** mcctlidata

**IM Requirement:** Cache optional (micm\_cfg.ISZ != 0 or mdcm\_cfg.DSZ != 0) & (mmsc\_cfg.CCTLCSR==1)

**Access Mode:** Machine

**CSR Address:** 0x7cd (non-standard read/write)

Table 18-19 CCTL Commands Using the mcctlidata Register lists all CCTL operations that access this register.

**Table 18-19 CCTL Commands Using the mcctlidata Register**

| <b>Value of mcctlcommand</b> | <b>Command</b> | <b>Type</b>   |
|------------------------------|----------------|---------------|
| 3                            | 0b00_011       | L1D_VA_LOCK   |
| 4                            | 0b00_100       | L1D_VA_UNLOCK |
| 11                           | 0b01_011       | L1I_VA_LOCK   |
| 12                           | 0b01_100       | L1I_VA_UNLOCK |
| 19                           | 0b10_011       | L1D_IX_RTAG   |
| 20                           | 0b10_100       | L1D_IX_RDATA  |
| 21                           | 0b10_101       | L1D_IX_WTAG   |
| 22                           | 0b10_110       | L1D_IX_WDATA  |
| 27                           | 0b11_011       | L1I_IX_RTAG   |
| 28                           | 0b11_100       | L1I_IX_RDATA  |
| 29                           | 0b11_101       | L1I_IX_WTAG   |
| 30                           | 0b11_110       | L1I_IX_WDATA  |

For CCTL lock operations: The mcctlidata register will be updated with a successful (1) or failed (0) status value when the operations complete.

- For CCTL index read/write-data operations: The mcctlidata[31:0] holds the cache data for the operations.
- For CCTL index read/write-tag operations: The mcctlidata register holds the cache tag for the operations. The bit position annotation is marked with the assumption that the width of physical address is PALEN. For caches which are larger than 2KiB per way, mcctlidata[1:0] will be zero. For caches which are 2KiB per way, mcctlidata[0] will be zero.
- The register format for tag operations is:

| XLEN-1 | XLEN-2 | XLEN-3         | XLEN-4 | PALEN-10 | PALEN-11             | 0 |
|--------|--------|----------------|--------|----------|----------------------|---|
| valid  | lock   | dirty/lock_dup | 0      |          | TAG=PA[(PALEN-1):10] |   |

#### Note

Bit XLEN-3 is the dirty bit for D-Cache and it keeps a duplicated copy of the lock bit to tolerate soft-errors for I-Cache.

### 18.8.11 User CCTL Begin Address

**Mnemonic Name:** ucctlbeginaddr

**IM Requirement:** Cache optional

**Access Mode:** User and above

**CSR Address:** 0x80b (non-standard read/write)

The ucctlbeginaddr register contains the starting virtual address for CCTL operations triggered by writes to the ucctlcommand register. For CCTL lock operations, the mcctlidata and scctlidata register will be updated with a successful (1) or failed (0) status value when the operations complete.

After an update to the ucctlcommand CSR with a "VA" type command, the value of this register will be incremented with the byte size of the

corresponding cache line.

This register is only present when (micm\_cfg.ISZ!=0 or mdcm\_cfg.DSZ!=0) and mmisc\_cfg.CCTLCSR==1 and misa[20]==1.

### 18.8.12 User CCTL Command

**Mnemonic Name:** ucctlcommand

**IM Requirement:** Cache optional

**Access Mode:** User and above

**CSR Address:** 0x80c (non-standard read/write)

Writing to this register will trigger a CCTL operation, with the type of the operation specified by the value written. Valid User CCTL operations are defined in Table 18-20 User CCTL Command Definition. When mcache\_ctl.CCTL\_SUEN is 0, accessing ucctlcommand in U-mode and S-mode will generate an "illegal instruction" exception. When mcache\_ctl.CCTL\_SUEN is 1, U-mode programs can access ucctlcommand. However, if ucctlcommand is write a command with 0 in U-Mode allowed field in Table 18-20 User CCTL Command Definition, an "illegal instruction" exception will be generated.

This register is only present when (micm\_cfg.ISZ!=0 or mdcm\_cfg.DSZ!=0) and mmisc\_cfg.CCTLCSR==1 and misa[20]==1.

**Table 18-20 User CCTL Command Definition**

| <b>Value</b> | <b>Command</b> | <b>Type</b>     | <b>U-Mode allowed</b> |
|--------------|----------------|-----------------|-----------------------|
| 0            | 0b00_000       | L1D_VA_INVAL    | VA 1                  |
| 1            | 0b00_001       | L1D_VA_WB       | VA 1                  |
| 2            | 0b00_010       | L1D_VA_WBINVAL  | VA 1                  |
| 3            | 0b00_011       | L1D_VA_LOCK     | VA 0                  |
| 4            | 0b00_100       | L1D_VA_UNLOCK   | VA 0                  |
| 6            | 0b00_110       | L1D_WBINVAL_ALL | - 0                   |
| 7            | 0b00_111       | L1D_WB_ALL      | - 0                   |
| 8            | 0b01_000       | L1I_VA_INVAL    | VA 1                  |
| 11           | 0b01_011       | L1I_VA_LOCK     | VA 0                  |
| 12           | 0b01_100       | L1I_VA_UNLOCK   | VA 0                  |
| 16           | 0b10_000       | L1D_IX_INVAL    | Index 0               |
| 17           | 0b10_001       | L1D_IX_WB       | Index 0               |
| 18           | 0b10_010       | L1D_IX_WBINVAL  | Index 0               |
| 19           | 0b10_011       | L1D_IX_RTAG     | Index 0               |
| 20           | 0b10_100       | L1D_IX_RDATA    | Index 0               |
| 21           | 0b10_101       | L1D_IX_WTAG     | Index 0               |
| 22           | 0b10_110       | L1D_IX_WDATA    | Index 0               |
| 23           | 0b10_111       | L1D_INVAL_ALL   | - 0                   |
| 24           | 0b11_000       | L1I_IX_INVAL    | Index 0               |
| 27           | 0b11_011       | L1I_IX_RTAG     | Index 0               |
| 28           | 0b11_100       | L1I_IX_RDATA    | Index 0               |
| 29           | 0b11_101       | L1I_IX_WTAG     | Index 0               |
| 30           | 0b11_110       | L1I_IX_WDATA    | Index 0               |

## 18.9 Hardware Stack Protection and Recording Registers

### 18.9.1 Machine Hardware Stack Protection Control

**Mnemonic Name:** mhsp\_ctl

**IM Requirement:** STACKSAFE\_SUPPORT = "yes" (mmsc\_cfg.HSP == 1)

**Access Mode:** Machine

**CSR Address:** 0x7C6 (non-standard read/write)



| Field Name | Bits                                                                | Description                                                                                                                                                                                                                                                                                             | Type  | Reset   |   |                                                                     |   |                                                                    |  |  |
|------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|---------------------------------------------------------------------|---|--------------------------------------------------------------------|--|--|
| OVF_EN     | [0]                                                                 | Enable bit for the stack overflow protection and recording mechanism. This bit will be cleared to 0 automatically by hardware when a stack protection (overflow or underflow) exception is taken.                                                                                                       | RW    | 0       |   |                                                                     |   |                                                                    |  |  |
|            |                                                                     | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The stack overflow protection and recording mechanism are disabled.</td></tr> <tr> <td>1</td><td>The stack overflow protection and recording mechanism are enabled.</td></tr> </tbody> </table> | Value | Meaning | 0 | The stack overflow protection and recording mechanism are disabled. | 1 | The stack overflow protection and recording mechanism are enabled. |  |  |
| Value      | Meaning                                                             |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| 0          | The stack overflow protection and recording mechanism are disabled. |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| 1          | The stack overflow protection and recording mechanism are enabled.  |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| UDF_EN     | [1]                                                                 | Enable bit for the stack underflow protection mechanism. This bit will be cleared to 0 automatically by hardware when a stack protection (overflow or underflow) exception is taken.                                                                                                                    | RW    | 0       |   |                                                                     |   |                                                                    |  |  |
|            |                                                                     | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The stack underflow protection is disabled.</td></tr> <tr> <td>1</td><td>The stack underflow protection is enabled.</td></tr> </tbody> </table>                                                 | Value | Meaning | 0 | The stack underflow protection is disabled.                         | 1 | The stack underflow protection is enabled.                         |  |  |
| Value      | Meaning                                                             |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| 0          | The stack underflow protection is disabled.                         |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| 1          | The stack underflow protection is enabled.                          |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| SCHM       | [2]                                                                 | Selects the operating scheme of the stack protection and recording mechanism.                                                                                                                                                                                                                           | RW    | 0       |   |                                                                     |   |                                                                    |  |  |
|            |                                                                     | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Stack overflow/underflow detection</td></tr> <tr> <td>1</td><td>Top-of-stack recording</td></tr> </tbody> </table>                                                                              | Value | Meaning | 0 | Stack overflow/underflow detection                                  | 1 | Top-of-stack recording                                             |  |  |
| Value      | Meaning                                                             |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| 0          | Stack overflow/underflow detection                                  |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| 1          | Top-of-stack recording                                              |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| U          | [3]                                                                 | Enables the SP protection and recording mechanism in User mode.                                                                                                                                                                                                                                         | RW    | 0       |   |                                                                     |   |                                                                    |  |  |
|            |                                                                     | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The mechanism is disabled in User mode.</td></tr> <tr> <td>1</td><td>The mechanism is enabled in User mode.</td></tr> </tbody> </table>                                                         | Value | Meaning | 0 | The mechanism is disabled in User mode.                             | 1 | The mechanism is enabled in User mode.                             |  |  |
| Value      | Meaning                                                             |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| 0          | The mechanism is disabled in User mode.                             |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| 1          | The mechanism is enabled in User mode.                              |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| M          | [5]                                                                 | Enables the SP protection and recording mechanism in Machine mode.                                                                                                                                                                                                                                      | RW    | 0       |   |                                                                     |   |                                                                    |  |  |
|            |                                                                     | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The mechanism is disabled in Machine mode.</td></tr> <tr> <td>1</td><td>The mechanism is enabled in Machine mode.</td></tr> </tbody> </table>                                                   | Value | Meaning | 0 | The mechanism is disabled in Machine mode.                          | 1 | The mechanism is enabled in Machine mode.                          |  |  |
| Value      | Meaning                                                             |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| 0          | The mechanism is disabled in Machine mode.                          |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |
| 1          | The mechanism is enabled in Machine mode.                           |                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                     |   |                                                                    |  |  |

## 18.9.2 Machine SP Bound Register

**Mnemonic Name:** msp\_bound  
**IM Requirement:** STACKSAFE\_SUPPORT = "yes" (mmsc\_cfg.HSP == 1)  
**Access Mode:** Machine  
**CSR Address:** 0x7c7 (non-standard read/write)



When the SP overflow detection mechanism is properly selected and enabled, any updated value to the SP register (via any instruction) is compared with the msp\_bound register. If the updated value to the SP register is smaller than the msp\_bound register, a stack overflow exception is generated. The stack overflow exception has an exception code of 32 in the mcause register.

When the top of stack recording mechanism is properly selected and enabled, any updated value to the SP register on any instruction is compared with the msp\_bound register. If the updated value to the SP register is smaller than the msp\_bound register, the msp\_bound register is updated with this updated value. It is a RW type register with the all-one reset value (0xFFFFFFFF for RV32 and 0xFFFFFFFFFFFFFF for RV64).

### Programming Note:

- The “csrrw sp, msp\_bound, rs” instruction updates both sp and msp\_bound registers at the same time. When the stack overflow detection mechanism is enabled, using this instruction may generate unpredictable exception behavior.

## 18.9.3 Machine SP Base Register

**Mnemonic Name:** msp\_base  
**IM Requirement:** STACKSAFE\_SUPPORT = "yes" (mmsc\_cfg.HSP == 1)  
**Access Mode:** Machine  
**CSR Address:** 0x7c8 (non-standard read/write)



When the SP underflow detection mechanism is properly selected and enabled, any updated value to the SP register (via any instruction) is compared with the msp\_base register. If the updated value to the SP register is greater than the msp\_base register, a stack underflow exception is generated. The stack underflow exception has an exception code of 33 in the mcause register.

It is a RW type register with the all-one reset value (0xFFFFFFFF for RV32 and 0xFFFFFFFFFFFFFF for RV64).

### Programming Note:

- The “csrrw sp, msp\_base, rs” instruction updates both sp and msp\_base registers at the same time. When the stack underflow detection mechanism is enabled, using this instruction may generate unpredictable exception behavior.

## 18.10 CoDense Registers

### 18.10.1 Instruction Table Base Address Register

**Mnemonic Name:** uitb

**IM Requirement:** CODENSE\_SUPPORT = "yes"

**Access Mode:** User

**CSR Address:** 0x800 (non-standard read/write)

This register defines the base address of the CoDense instruction table. The CoDense instruction table is a table of 32-bit instructions that instructions defined by the Andes CoDense Extension should expand to. The table is typically generated by the compiler for replacing 32-bit instructions with the shorter 16-bit Andes CoDense instructions, hence reducing the code size.

| 31         | ADDR                                                                                                                                     | 2                                                                                                                                                                                                                                                                                                                                                                                                                               | 1     | 0       |      |                                                                                                                                          |   |                                                                                                                       |  |  |  |  |
|------------|------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------|---|-----------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Field Name | Bits                                                                                                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                     |       |         | Type | Reset                                                                                                                                    |   |                                                                                                                       |  |  |  |  |
| HW         | [0]                                                                                                                                      | This bit specifies if the CoDense instruction table is hard-wired.                                                                                                                                                                                                                                                                                                                                                              |       |         | RO   | IM                                                                                                                                       |   |                                                                                                                       |  |  |  |  |
|            |                                                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The instruction table is located in memory. UITB.ADDR should be initialized to point to the table before using the CoDense instructions.</td></tr> <tr> <td>1</td><td>The instruction table is hard-wired. Initialization of UITB.ADDR is not needed before using the CoDense instructions.</td></tr> </tbody> </table> | Value | Meaning | 0    | The instruction table is located in memory. UITB.ADDR should be initialized to point to the table before using the CoDense instructions. | 1 | The instruction table is hard-wired. Initialization of UITB.ADDR is not needed before using the CoDense instructions. |  |  |  |  |
| Value      | Meaning                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |      |                                                                                                                                          |   |                                                                                                                       |  |  |  |  |
| 0          | The instruction table is located in memory. UITB.ADDR should be initialized to point to the table before using the CoDense instructions. |                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |      |                                                                                                                                          |   |                                                                                                                       |  |  |  |  |
| 1          | The instruction table is hard-wired. Initialization of UITB.ADDR is not needed before using the CoDense instructions.                    |                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |      |                                                                                                                                          |   |                                                                                                                       |  |  |  |  |
| Reserved   | [1]                                                                                                                                      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                        |       |         |      | 0                                                                                                                                        |   |                                                                                                                       |  |  |  |  |
| ADDR       | [31:2]                                                                                                                                   | The base address of the CoDense instruction table. This field is reserved if UITB.HW == 1.                                                                                                                                                                                                                                                                                                                                      |       | RW      |      | 0                                                                                                                                        |   |                                                                                                                       |  |  |  |  |

## 18.11 Physical Memory Protection Unit Configuration & Address Registers

### 18.11.1 PMP Configuration Registers

**Mnemonic Name:** pmpcfg0–pmpcfg3

**IM Requirement:** PMP\_SUPPORT**Access Mode:** Machine**CSR Address:** 0x3A0 to 0x3A3 (standard read/write)

0x3A0

| 31 | 24 23   | 16 15   | 8 7     | 0       |
|----|---------|---------|---------|---------|
|    | pmp3cfg | pmp2cfg | pmp1cfg | pmp0cfg |

0x3A1

| 31 | 24 23   | 16 15   | 8 7     | 0       |
|----|---------|---------|---------|---------|
|    | pmp7cfg | pmp6cfg | pmp5cfg | pmp4cfg |

0x3A2

| 31 | 24 23    | 16 15    | 8 7     | 0       |
|----|----------|----------|---------|---------|
|    | pmp11cfg | pmp10cfg | pmp9cfg | pmp8cfg |

0x3A3

| 31 | 24 23    | 16 15    | 8 7      | 0        |
|----|----------|----------|----------|----------|
|    | pmp15cfg | pmp14cfg | pmp13cfg | pmp12cfg |

**PMP Configuration Format**

| 7 | 6 | 5 4  | 3 | 2 | 1 | 0 |
|---|---|------|---|---|---|---|
| L |   | WIRI | A | X | W | R |

| Field Name | Bits                            | Description                                                                                                                                                                                                                        | Type  | Reset   |   |                                 |   |                             |  |  |
|------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|---------------------------------|---|-----------------------------|--|--|
| R          | [0]                             | Read access control.                                                                                                                                                                                                               | RW    | 0       |   |                                 |   |                             |  |  |
|            |                                 | <table border="1"> <thead> <tr> <th>Value</th> <th>Meaning</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>Read accesses are not allowed.</td> </tr> <tr> <td>1</td> <td>Read accesses are allowed.</td> </tr> </tbody> </table>   | Value | Meaning | 0 | Read accesses are not allowed.  | 1 | Read accesses are allowed.  |  |  |
| Value      | Meaning                         |                                                                                                                                                                                                                                    |       |         |   |                                 |   |                             |  |  |
| 0          | Read accesses are not allowed.  |                                                                                                                                                                                                                                    |       |         |   |                                 |   |                             |  |  |
| 1          | Read accesses are allowed.      |                                                                                                                                                                                                                                    |       |         |   |                                 |   |                             |  |  |
| W          | [1]                             | Write access control.                                                                                                                                                                                                              | RW    | 0       |   |                                 |   |                             |  |  |
|            |                                 | <table border="1"> <thead> <tr> <th>Value</th> <th>Meaning</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>Write accesses are not allowed.</td> </tr> <tr> <td>1</td> <td>Write accesses are allowed.</td> </tr> </tbody> </table> | Value | Meaning | 0 | Write accesses are not allowed. | 1 | Write accesses are allowed. |  |  |
| Value      | Meaning                         |                                                                                                                                                                                                                                    |       |         |   |                                 |   |                             |  |  |
| 0          | Write accesses are not allowed. |                                                                                                                                                                                                                                    |       |         |   |                                 |   |                             |  |  |
| 1          | Write accesses are allowed.     |                                                                                                                                                                                                                                    |       |         |   |                                 |   |                             |  |  |

| Field Name | Bits                                                                                                                                                                                                                                                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Type  | Reset   |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|---------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-----------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| X          | [2]                                                                                                                                                                                                                                                                                      | Instruction execution control.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RW    | 0       |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
|            |                                                                                                                                                                                                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Instruction execution is not allowed.</td></tr> <tr> <td>1</td><td>Instruction execution is allowed.</td></tr> </tbody> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Value | Meaning | 0 | Instruction execution is not allowed.                                                             | 1 | Instruction execution is allowed.                                                                                                                                                                                                                                                        |   |           |   |                                                                                                                                                                                                                                                     |  |  |
| Value      | Meaning                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
| 0          | Instruction execution is not allowed.                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
| 1          | Instruction execution is allowed.                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
| A          | [4:3]                                                                                                                                                                                                                                                                                    | Address matching mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW    | 0       |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
|            |                                                                                                                                                                                                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>OFF: PMP entry is disable.</td></tr> <tr> <td>1</td><td>TOR: Top of range. For PMP entry 0, it matches any address <math>A &lt; \text{ppmaddr}_0</math>. For PMP entry <math>i</math>, it matches any address <math>A</math> such that <math>\text{ppmaddr}_i &gt; A \geq \text{ppmaddr}_{i-1}</math>. But the 4-byte range is not supported.</td></tr> <tr> <td>2</td><td>Reserved.</td></tr> <tr> <td>3</td><td>NAPOT: Naturally aligned power-of-2 region, <math>\geq 8</math> bytes. This mode makes use of the low-order bits of the associated address register to encode the size of the range. See Table 81 for range encoding from the value of a PMP address register.</td></tr> </tbody> </table> | Value | Meaning | 0 | OFF: PMP entry is disable.                                                                        | 1 | TOR: Top of range. For PMP entry 0, it matches any address $A < \text{ppmaddr}_0$ . For PMP entry $i$ , it matches any address $A$ such that $\text{ppmaddr}_i > A \geq \text{ppmaddr}_{i-1}$ . But the 4-byte range is not supported.                                                   | 2 | Reserved. | 3 | NAPOT: Naturally aligned power-of-2 region, $\geq 8$ bytes. This mode makes use of the low-order bits of the associated address register to encode the size of the range. See Table 81 for range encoding from the value of a PMP address register. |  |  |
| Value      | Meaning                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
| 0          | OFF: PMP entry is disable.                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
| 1          | TOR: Top of range. For PMP entry 0, it matches any address $A < \text{ppmaddr}_0$ . For PMP entry $i$ , it matches any address $A$ such that $\text{ppmaddr}_i > A \geq \text{ppmaddr}_{i-1}$ . But the 4-byte range is not supported.                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
| 2          | Reserved.                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
| 3          | NAPOT: Naturally aligned power-of-2 region, $\geq 8$ bytes. This mode makes use of the low-order bits of the associated address register to encode the size of the range. See Table 81 for range encoding from the value of a PMP address register.                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
| WIRI       | [6:5]                                                                                                                                                                                                                                                                                    | Reserved WIRI field.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | WIRI  | 0       |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
| L          | [7]                                                                                                                                                                                                                                                                                      | Write lock and permission enforcement bit for Machine mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | W1S*  | 0       |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
|            |                                                                                                                                                                                                                                                                                          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Machine mode writes to PMP entry registers are allowed. R/W/X permissions apply to S and U modes.</td></tr> <tr> <td>1</td><td>For PMP entry <math>i</math>, writes to pmp/cfg and ppmaddr<math>_i</math> are ignored. Additionally, if pmp/cfg.A is set to TOR, writes to ppmaddr<math>_{i-1}</math> is ignored as well. As for permission enforcement, R/W/X permissions apply to all modes. This bit can only be cleared to 0 with a system reset.</td></tr> </tbody> </table>                                                                                                                                                                                                                            | Value | Meaning | 0 | Machine mode writes to PMP entry registers are allowed. R/W/X permissions apply to S and U modes. | 1 | For PMP entry $i$ , writes to pmp/cfg and ppmaddr $_i$ are ignored. Additionally, if pmp/cfg.A is set to TOR, writes to ppmaddr $_{i-1}$ is ignored as well. As for permission enforcement, R/W/X permissions apply to all modes. This bit can only be cleared to 0 with a system reset. |   |           |   |                                                                                                                                                                                                                                                     |  |  |
| Value      | Meaning                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
| 0          | Machine mode writes to PMP entry registers are allowed. R/W/X permissions apply to S and U modes.                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |
| 1          | For PMP entry $i$ , writes to pmp/cfg and ppmaddr $_i$ are ignored. Additionally, if pmp/cfg.A is set to TOR, writes to ppmaddr $_{i-1}$ is ignored as well. As for permission enforcement, R/W/X permissions apply to all modes. This bit can only be cleared to 0 with a system reset. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                   |   |                                                                                                                                                                                                                                                                                          |   |           |   |                                                                                                                                                                                                                                                     |  |  |

**Note!**

W1S means "Write 1 to Set". The "L" bit field is W1S because only a system reset can clear this bit.

## 18.11.2 PMP Address Register

**Mnemonic Name:** pmpaddr0–pmpaddr15

**IM Requirement:** PMP\_SUPPORT

**Access Mode:** Machine

**CSR Address:** 0x3b0 to 0x3bf (standard read/write)



Each PMP address register encodes bits 33–2 of a 34-bit physical address, as shown in the register format. The encoding is described in Table 18-21 N25(F) NAPOT range encoding in PMP address and configuration registers. The "a" in the table represents one bit address, with arbitrary values.

**Table 18-21 N25(F) NAPOT range encoding in PMP address and configuration registers**

| Register Content | Match Size(Byte) |
|------------------|------------------|
| aaaa...aaa0      | 8                |
| aaaa...aa01      | 16               |
| aaaa...a011      | 32               |
| ...              | ...              |
| aa01...1111      | $2^{XLEN}$       |
| a011...1111      | $2^{XLEN+1}$     |
| 0111...1111      | $2^{XLEN+2}$     |
| 1111...1111      | $2^{XLEN+2}$     |

# 19 Instruction Latency

## 19.1 ALU Instructions

The latency and the throughput of ALU instructions are both 1 cycle.  
ALU instructions include:

- Add/Sub: ADD, SUB, ADDI, ADDW, SUBW, ADDIW
- Shift: SLL, SRL, SRA, SLLI, SRLLI, SRAI, SLLW, SRLW, SRAW, SLLIW, SRLLIW, SRAIW
- Logical: AND, OR, XOR, ANDI, ORI, XORI
- Compare: SLT, SLTU, SLTI, SLTIU
- LUI and AUIPC
- Load effective address instructions
- ADDIGP
- String processing: FFB, FFZMISM, FFMISM, FLMISM
- Bit field operation: BFOS, BFOZ

## 19.2 Load Instructions

Table 19-1 Load Instruction Latency

| Instruction                                    | Throughput<br>(cycles/instruction) | Latency (cycles) |
|------------------------------------------------|------------------------------------|------------------|
| load word from DLM/D-Cache                     | 1                                  | 2                |
| load word from ILM                             | 2                                  | 4                |
| load word from AXI/AHB                         | 3                                  | 4                |
| load word from low access-latency AHB          | 1                                  | 2                |
| load byte/halfword from DLM/D-Cache            | 1                                  | 3                |
| load byte/halfword from ILM                    | 2                                  | 4                |
| load byte/halfword from AXI/AHB                | 3                                  | 5                |
| load byte/halfword from low access-latency AHB | 1                                  | 3                |

## 19.3 Multiply Instructions

The latency and throughput of multiply instructions depend on the

multiplier implementation.

**Table 19-2 Multiply Instruction Latency: Radix Multiplier**

| Instruction       | Throughput (cycles/instruction)           | Latency (cycles)                          |
|-------------------|-------------------------------------------|-------------------------------------------|
| MULHU             | $4 + 32 / \text{LOG2}(\text{MUL\_RADIX})$ | $6 + 32 / \text{LOG2}(\text{MUL\_RADIX})$ |
| MUL, MULH, MULHSU | $5 + 32 / \text{LOG2}(\text{MUL\_RADIX})$ | $7 + 32 / \text{LOG2}(\text{MUL\_RADIX})$ |

**Table 19-3 Multiply Instruction Latency: Fast Multiplier**

| Instruction              | Throughput (cycles/instruction) | Latency (cycles) |
|--------------------------|---------------------------------|------------------|
| MUL, MULH, MULHU, MULHSU | 1                               | 3                |

## 19.4 Divide and Remainder Instructions

The divide and remainder instructions are implemented using the non-restoring division algorithm with early termination detection.

| Instruction | Throughput (cycles/instruction) | Latency (cycles) |
|-------------|---------------------------------|------------------|
| DIVU, REMU  | 5–36                            | 7–38             |
| DIV, REM    | 6–37                            | 8–39             |

## 19.5 Branch and Jump Instruction

The branch and jump instruction throughput is 1 cycle/instruction. Branch mis-prediction penalty is 3 cycles.

## 19.6 Trap Return Instruction

The trap return instruction flushes the entire pipeline, and the penalty is 5 cycles.

## 19.7 ACE Instructions

The instruction latencies of FPU instruction groups are shown in the following tables. FPU instructions include:

- Compute: FADD.S, FSUB.S, FMUL.S, FMADD.S, FMSUB.S, FNMMADD.S, FNMSUB.S, FDIV.S, FMIN.S, FMAX.S, FADD.D, FSUB.D, FMUL.D, FMADD.D, FMSUB.D, FNMMADD.D, FNMSUB.D, FDIV.D, FSQRT.D, FMIN.D, FMAX.D
- Load/store: FLD, FSD
- Compare: FEQ.S, FLT.S, FLE.S, FEQ.D, FLT.D, FLE.D
- Move: FSGNJ.S, FSGNJS.N, FSGNJS.X, FSGNJ.D, FSGNJS.N.D, FSGNJS.D
- Classify: FCLASS.S, FCLASS.D

**Table 19-4 FPU Instruction latency**

| Instruction                                                        | Throughput (cycles/instruction) | Latency (cycles) |
|--------------------------------------------------------------------|---------------------------------|------------------|
| FADD.x, FSUB.x, FMUL.x,<br>FMADD.x, FMSUB.x, FNMMADD.x<br>FNMSUB.x | 1                               | 5                |
| FDIV.S, FSQRT.S                                                    | 1                               | 19               |
| FDIV.D, FSQRT.D                                                    | 1                               | 33               |
| FLW, FSW, FLD, FSD                                                 | 1                               | 3                |
| FSGNJ.x, FSGNIN.x, FSGNIX.x,<br>FMIN.x, FMAX.x                     | 1                               | 2                |
| FCLASS.x, FEQ.x, FLT.x, FLE.x                                      | 1                               | 3                |

## 19.8 ACE Instructions

Latencies of ACE instructions are custom-defined. They depend on the complexity of the specified operations.

Two additional cycles are needed when there is GPR dependency between an ACE instruction and its subsequent instruction.

# 20N25(F) AHB Platform

The N25(F) AHB platform is a pre-integrated platform implementing the AE250 memory map that contains an N25(F) processor. The block diagram is depicted in Figure 4-3 Design Hierarchy. The peripheral platform IPs may be available as either unencrypted RTL or encrypted RTL depending on the N25(F) licensing agreements.

## 20.1 AE250 Memory Map

**Table 20-1 N25(F) AE250 Memory Map**

| Address    | Description |                              |
|------------|-------------|------------------------------|
| Begin      | End         |                              |
| 0x00000000 | 0x003FFFFF  | RAM Bridge                   |
| 0x80000000 | 0x800FFFFF  | SPI1 AHB Memory              |
| 0xA0000000 | 0xA01FFFFF  | Local Memory Slave Port: ILM |
| 0xA0200000 | 0xA03FFFFF  | Local Memory Slave Port: DLM |
| 0xE0000000 | 0xE00FFFFF  | BMC                          |
| 0xE0E00000 | 0xE0EFFFFF  | DMAC                         |
| 0xE4000000 | 0xE5FFFFFF  | PLIC                         |
| 0xE6000000 | 0xE60FFFFF  | Machine Timer                |
| 0xE6400000 | 0xE67FFFFF  | PLIC-SWINT                   |
| 0xE6800000 | 0xE68FFFFF  | Debug Module                 |
| 0xF0000000 | 0xF00FFFFF  | APBBRG                       |
| 0xF0100000 | 0xF01FFFFF  | SMU                          |
| 0xF0200000 | 0xF02FFFFF  | UART1                        |
| 0xF0300000 | 0xF03FFFFF  | UART2                        |
| 0xF0400000 | 0xF04FFFFF  | PIT                          |
| 0xF0500000 | 0xF05FFFFF  | WDT                          |
| 0xF0600000 | 0xF06FFFFF  | RTC                          |
| 0xF0700000 | 0xF07FFFFF  | GPIO                         |
| 0xF0A00000 | 0xF0AFFFFF  | I2C                          |
| 0xF0B00000 | 0xF0BFFFFF  | SPI1                         |
| 0xF0F00000 | 0xF0FFFFFF  | SPI2                         |

**Note!**

- The RAM bridge space indicates the size of the RAM behind this bridge. It can be different from the size of the address space allocated to the bridge on the bus. The default setting allocates a 2GiB space (0x00000000 – 0x7FFFFFFF) to the bridge on the bus. When the bridge sees a transaction for addresses outside of the addressable RAM, it will return an error response.
- In addition to the bus view described here, ILM/DLM are accessible by the processor through private address spaces visible only to the processor:
  - The address range of these private address spaces are controlled by \$ILMB and \$DLMB control registers.
  - The private address spaces have higher priority than the bus address spaces in the processor. Accesses will be directed to go through the local memory interfaces and bypass the bus address spaces if they hit the private address spaces.
  - If overlapping of address spaces is not desired, the \$ILMB/\$DLMB control registers could be programmed to avoid overlapping.
  - ILM is visible to the processor at 0x00000000 in the default setting.
  - DLM is visible to the processor at 0x00200000 in the default setting.

## 20.2 Interrupt Assignment

Interrupts in a RISC-V platform are classified into two types: local interrupts and global interrupts. Local interrupts are interrupts that go directly into a RISC-V processor, and global interrupts get arbitrated through a platform-level interrupt controller (PLIC) before going into the RISC-V processor as the external interrupts.

Local interrupts supported by N25(F) include non-maskable interrupts (nmi), machine timer interrupts (mtip) and software interrupts (msip). Additionally, an external interrupt pins (meip) and (seip) accept arbitrated interrupt signaling from PLIC. Table 20-2 N25(F) Interrupt Assignment summarizes the interrupt source connectivity for local interrupts.

In the AE250 platform, the PLIC module is instantiated a second time with all interrupt sources tied to zero as the software interrupt controller (PLIC\_SW). The capability of the PLIC controller to generate interrupts through its programming registers is used for generating software interrupts.

The global interrupt sources in the AE250 platform and their connectivity to PLIC are summarized in Table 20-3 PLIC Interrupt Source.

**Table 20-2 N25(F) Interrupt Assignment**

| <b>Interrupt Signal</b> | <b>Description</b> |
|-------------------------|--------------------|
| nmi                     | WDT                |
| mtip                    | Machine Timer      |
| meip                    | PLIC               |
| seip                    | PLIC               |
| msip                    | PLIC_SW            |

**Table 20-3 PLIC Interrupt Source**

| <b>Interrupt Source</b> | <b>Description</b> |
|-------------------------|--------------------|
| 1                       | RTC period         |
| 2                       | RTC alarm          |
| 3                       | PIT                |
| 4                       | SPI1               |
| 5                       | SPI2               |
| 6                       | IIC                |
| 7                       | GPIO               |
| 8                       | UART1              |
| 9                       | UART2              |
| 10                      | DMAC               |
| 11                      | BMC                |
| 26                      | SMU standby_req    |
| 27                      | SMU wakeup_ok      |

## 20.3 Functional Description

### 20.3.1 ATCBMC200 – AHB Bus Matrix

The Bus Matrix Controller (BMC) switches the matrix connections according to the hardware configuration. In addition, the controller has slave information registers for software to enumerate the AHB bus components. Features of the controller include:

- Support of 24/32 bits address width
- Support of up to 16 AHB masters
- Support of up to 16 AHB slaves
  - Including one internal slave for slave information registers and register programming
- Configurable connectivity between masters and slaves
- Programmable two-level priority arbitration scheme

### 20.3.2 ATCAPBBRG100 – AHB-to-APB Bridge

The AHB-to-APB bridge translates AHB transactions to APB transactions targeting a specific APB slave according to the slave base

address and address space size configurations. Features of the bridge include:

- Compliant with AMBA 4 APB
- Support of 24/32 bits address width
- Support of up to 31 APB slaves
  - Including one internal slave for slave information registers and register programming
- Configurable base/size for each downstream APB slave
- Support of various synchronous AHB/APB clock ratios (N:1, N = 1, 2, 3, . . . )
- Support of write buffering

### **20.3.3 ATCUART100 – UART Controller**

The UART controller handles communications to the Universal Asynchronous Receiver/Transmitter (UART) serial interface. It has the following features:

- Compatible with the 16C550A register structure
- Support of the hardware flow control (CTS/RTS)
- Support of hardware handshaking to the DMA controller
- Option of by-8 or by-16 over-sampling frequency
- Configurable transmit/receive FIFO depth: 16/32/64/128 entries

### **20.3.4 ATCSPI200 – SPI Controller**

The SPI controller handles communications to the Serial Peripheral Interface (SPI). The supported serial data formats range from 4 bits to 32 bits in length. Features of the SPI controller include:

- Support of both master and slave mode operations
- Support of memory-mapped accesses (read-only) through the AHB bus
- Support of hardware handshaking to the DMA controller
- Support of the dual I/O and quad I/O modes
- Support of the 3-line mode

### **20.3.5 ATCIIC100 – I2C Controller**

The I2C controller handles communications to the Inter-Integrated Circuit (IIC or I2C) serial interface. Features of the I2C controller include:

- Programmable to be either a master or a slave device
- Programmable clock/data timing
- Support of the I2C-bus Standard-mode (100 kb/s), Fast-mode (400 kb/s) and Fast-mode plus (1 Mb/s)
- Support of hardware handshaking to the DMA controller
- Support of the master-transmit, master-receive, slave-transmit and slave-receive modes
- Support of the multi-master mode
- Support of 7-bit and 10-bit addressing modes

- Support of general call addressing mode
- Support of auto clock stretch

### 20.3.6 ATCWDT200 – Watchdog Timer

The Watchdog Timer (WDT) controller prevents the system from hanging if software is trapped in a deadlock condition. A decrementing counter (the watchdog timer) is maintained in WDT and a watchdog interrupt will be generated once the watchdog timer reaches zero. The timer should be restarted in the watchdog interrupt service routine. A secondary timer called system reset timer starts ticking after the watchdog interrupt, and it gets canceled upon restart of the watchdog timer. Should the watchdog timer be not restarted in time after the watchdog interrupt is triggered, system reset will be triggered by the system reset timer to reset the system. Features of WDT include:

- Internal/external clock source selection
- Separate timers for the watchdog interrupt and the system reset
  - Eight choices of watchdog timer intervals
  - Four choices of reset timer intervals
- Register write protection for watchdog timer control register and restart register
  - Configurable magic number for register write protection
  - Configurable magic number to restart the watchdog timer

### 20.3.7 ATCRTC100 – Real-Time Clock

Real-time clock (RTC) keeps track of current time relative to a base time. The time is stored in a RTC counter which records the amount of elapsed time since RTC is enabled. Features of RTC include:

- The frequency of clock source (before the clock divider) for the counter is 32.768KHz.
- Separate second, minute, hour and day counters.
- Periodic interrupts: half-second, second, minute, hour and day interrupts.
- Programmable alarm interrupt with specified second, minute and hour values.

RTC duplicates in functionality the RISC-V Machine Timer (Machine Timer). The RTC module is offered for compatibility of existing Andes platform software environment. It may be configured out for a pure RISC-V platform.

### 20.3.8 ATCPIT100 – PIT Controller

The Programmable Interval Timer (PIT) controller is a set of compact multi-function timers, which can be used as pulse width modulators (PWM) or simple timers. Each multi-function timer provides the following 6 usage scenarios:

- One 32-bit timer
  - Two 16-bit timers
  - Four 8-bit timers
  - One 16-bit PWM
  - One 16-bit timer and one 8-bit PWM
  - Two 8-bit timers and one 8-bit PWM
- Features of the PIT controller include:
- Support of AMBA 2.0 APB bus protocol
    - Support of up to 4 multi-function timers
    - Six usage scenarios (combination of timer and PWM) for each multi-function timer
    - Programmable source of timer clock

### 20.3.9 ATCGPIO100 – GPIO Controller

The General Purpose I/O (GPIO) controller supports up to 32 channels with independently programmable input/output control. Features of the GPIO controller include:

- Configurable number of GPIO channels (pins): 1–32
- Independent control of each channel
- Programmable I/O direction
- Optional pull-up/down control
- Optional support of interrupt trigger control
- Flexible combination of interrupt trigger modes: high/low level trigger and rising/falling/both edge trigger
- Optional de-bounce functionality for input channels

### 20.3.10 ATCRAMBRG200 – RAM Bridge

The RAM bridge controller allows standard SRAMs to be accessed on the AHB bus.

- Configurable address width: 24 – 64 bits
- Configurable data width: 32 or 64 bits

### 20.3.11 ATCDMAC100 – DMA Controller

The Direct Memory Access Controller (DMAC) enhances system performance by transferring large data blocks between devices in background to offload the processor. Features of DMAC include:

- Up to 8 configurable DMA channels
- Up to 32 DMA request/acknowledge for hardware handshake
- Group round-robin arbitration scheme with 2 priority levels
- Support of 8, 16, and 32-bit data transfers
- Support of chain transfers

The source/destination IDs are needed for programming the handshake pairs when initiating DMA transfers. Table 20-4 DMA Hardware Handshake ID assigns the handshake ID for all devices of the AE250

platform. The source and destination ID should not be the same for a handshake pair since the DMA controller does not support transferring data back to the same device.

**Table 20-4 DMA Hardware Handshake ID**

| DMA Handshake ID | Devices  |
|------------------|----------|
| 0                | SPI1 TX  |
| 1                | SPI1 RX  |
| 2                | SPI2 TX  |
| 3                | SPI2 RX  |
| 4                | UART1 TX |
| 5                | UART1 RX |
| 6                | UART2 TX |
| 7                | UART2 RX |
| 8                | I2C      |

## 20.4 System Management Unit

### 20.4.1 Summary of Registers

SMU registers are summarized as follows:

**Table 20-5 SMU Register Summary**

| Address Offset | Name         | Description                       |
|----------------|--------------|-----------------------------------|
| 0x00           | SYSTEMVER    | SYSTEM ID & Revision              |
| 0x10           | WRSR         | Wake-up and reset status register |
| 0x14           | SMUCR        | SMU command register              |
| 0x1C           | WRMASK       | Wake-up and reset mask            |
| 0x20           | CER          | Clock enable register             |
| 0x24           | CRR          | Clock ratio register              |
| 0x40           | SCRATCH      | Scratch pad register              |
| 0x50           | RESET_VECTOR | CPU Reset Vector                  |

## 20.4.2 SYSTEM ID & Revision Register (SYSTEMVER) (0x00)

| Field Name | Bits   | Description           | Type | Reset    |
|------------|--------|-----------------------|------|----------|
| MINOR      | [3:0]  | Minor revision number | RO   | 0x0      |
| MAJOR      | [7:4]  | Major revision number | RO   | 0x0      |
| ID         | [31:8] | ID for AE250          | RO   | 0x414525 |

## 20.4.3 Wake-up and Reset Status Register (WRSR) (0x10)

| Field Name | Bits | Description         | Type | Reset |
|------------|------|---------------------|------|-------|
| APOR       | [0]  | AOPD Power-On Reset | W1C  | Note1 |

| Value | Meaning            |
|-------|--------------------|
| 0     | No action          |
| 1     | Reset has occurred |

| Field Name | Bits                       | Description                                                                                                                                                                                                            | Type  | Reset   |   |                            |   |                            |  |  |
|------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|----------------------------|---|----------------------------|--|--|
| MPOR       | [1]                        | MPD Power-On Reset                                                                                                                                                                                                     | W1C   | Note2   |   |                            |   |                            |  |  |
|            |                            | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>No action</td></tr> <tr> <td>1</td><td>Reset has occurred</td></tr> </tbody> </table>                          | Value | Meaning | 0 | No action                  | 1 | Reset has occurred         |  |  |
| Value      | Meaning                    |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 0          | No action                  |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 1          | Reset has occurred         |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| HW         | [2]                        | Hardware Reset                                                                                                                                                                                                         | W1C   | Note3   |   |                            |   |                            |  |  |
|            |                            | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Reset didn't occur</td></tr> <tr> <td>1</td><td>Reset has occurred</td></tr> </tbody> </table>                 | Value | Meaning | 0 | Reset didn't occur         | 1 | Reset has occurred         |  |  |
| Value      | Meaning                    |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 0          | Reset didn't occur         |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 1          | Reset has occurred         |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| WDT        | [3]                        | Watchdog Reset                                                                                                                                                                                                         | W1C   | Note3   |   |                            |   |                            |  |  |
|            |                            | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Reset didn't occur</td></tr> <tr> <td>1</td><td>Reset has occurred</td></tr> </tbody> </table>                 | Value | Meaning | 0 | Reset didn't occur         | 1 | Reset has occurred         |  |  |
| Value      | Meaning                    |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 0          | Reset didn't occur         |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 1          | Reset has occurred         |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| SW         | [4]                        | Software Reset                                                                                                                                                                                                         | W1C   | Note3   |   |                            |   |                            |  |  |
|            |                            | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Reset didn't occur</td></tr> <tr> <td>1</td><td>Reset has occurred</td></tr> </tbody> </table>                 | Value | Meaning | 0 | Reset didn't occur         | 1 | Reset has occurred         |  |  |
| Value      | Meaning                    |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 0          | Reset didn't occur         |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 1          | Reset has occurred         |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| WI         | [8]                        | Wake-up by external events                                                                                                                                                                                             | W1C   | 0       |   |                            |   |                            |  |  |
|            |                            | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Wake-up event didn't occur</td></tr> <tr> <td>1</td><td>Wake-up event has occurred</td></tr> </tbody> </table> | Value | Meaning | 0 | Wake-up event didn't occur | 1 | Wake-up event has occurred |  |  |
| Value      | Meaning                    |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 0          | Wake-up event didn't occur |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 1          | Wake-up event has occurred |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| ALM        | [9]                        | Wake-up by RTC alarm events                                                                                                                                                                                            | W1C   | 0       |   |                            |   |                            |  |  |
|            |                            | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Wake-up event didn't occur</td></tr> <tr> <td>1</td><td>Wake-up event has occurred</td></tr> </tbody> </table> | Value | Meaning | 0 | Wake-up event didn't occur | 1 | Wake-up event has occurred |  |  |
| Value      | Meaning                    |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 0          | Wake-up event didn't occur |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 1          | Wake-up event has occurred |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| DBG        | [10]                       | Wake-up by debug requests                                                                                                                                                                                              | W1C   | 0       |   |                            |   |                            |  |  |
|            |                            | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Wake-up event didn't occur</td></tr> <tr> <td>1</td><td>Wake-up event has occurred</td></tr> </tbody> </table> | Value | Meaning | 0 | Wake-up event didn't occur | 1 | Wake-up event has occurred |  |  |
| Value      | Meaning                    |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 0          | Wake-up event didn't occur |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |
| 1          | Wake-up event has occurred |                                                                                                                                                                                                                        |       |         |   |                            |   |                            |  |  |

### Note

- APOR is reset to 1 during the AOPD power-on reset.
- MPOR is reset to 1 during the MPD power-on reset.
- HW, WDT, and SW are reset to 0 during the AOPD power-on reset.

#### 20.4.4 SMU Command Register (SMUCR) (0x14)

#### 20.4.5 Wake-up and Reset Mask Register (WRMASK) (0x1c)

| Field Name                                                                                                                                                                                         | Bits                   | Description                                               | Type | Reset |         |   |            |   |                        |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----------------------------------------------------------|------|-------|---------|---|------------|---|------------------------|--|
| WIMASK                                                                                                                                                                                             | [8]                    | Indicating whether external events will trigger wake-ups. | RW   | 0     |         |   |            |   |                        |  |
| <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Don't mask</td></tr> <tr> <td>1</td><td>Mask the wake-up event</td></tr> </tbody> </table> |                        |                                                           |      | Value | Meaning | 0 | Don't mask | 1 | Mask the wake-up event |  |
| Value                                                                                                                                                                                              | Meaning                |                                                           |      |       |         |   |            |   |                        |  |
| 0                                                                                                                                                                                                  | Don't mask             |                                                           |      |       |         |   |            |   |                        |  |
| 1                                                                                                                                                                                                  | Mask the wake-up event |                                                           |      |       |         |   |            |   |                        |  |

| Field Name | Bits                   | Description                                                                                                                                                                                        | Type  | Reset   |   |            |   |                        |  |  |
|------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------|---|------------------------|--|--|
| ALMMASK    | [9]                    | Indicating whether RTC events will trigger wake-ups.                                                                                                                                               | RW    | 0       |   |            |   |                        |  |  |
|            |                        | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Don't mask</td></tr> <tr> <td>1</td><td>Mask the wake-up event</td></tr> </tbody> </table> | Value | Meaning | 0 | Don't mask | 1 | Mask the wake-up event |  |  |
| Value      | Meaning                |                                                                                                                                                                                                    |       |         |   |            |   |                        |  |  |
| 0          | Don't mask             |                                                                                                                                                                                                    |       |         |   |            |   |                        |  |  |
| 1          | Mask the wake-up event |                                                                                                                                                                                                    |       |         |   |            |   |                        |  |  |
| DBGMASK    | [10]                   | Indicating whether debug requests will trigger wake-ups.                                                                                                                                           | RW    | 0       |   |            |   |                        |  |  |
|            |                        | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Don't mask</td></tr> <tr> <td>1</td><td>Mask the wake-up event</td></tr> </tbody> </table> | Value | Meaning | 0 | Don't mask | 1 | Mask the wake-up event |  |  |
| Value      | Meaning                |                                                                                                                                                                                                    |       |         |   |            |   |                        |  |  |
| 0          | Don't mask             |                                                                                                                                                                                                    |       |         |   |            |   |                        |  |  |
| 1          | Mask the wake-up event |                                                                                                                                                                                                    |       |         |   |            |   |                        |  |  |

## 20.4.6 Clock Enable Register (CER) (0x20)

This register controls all clocks in the platform. The processor clock, AHB/APB bus clock should be turned on/off following the Processor/Bus Clock Operation Sequences described after the bit fields description.

| Field Name | Bits          | Description                                                                                                                                                                                 | Type  | Reset   |   |               |   |              |  |  |
|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|---------------|---|--------------|--|--|
| CCLK_EN    | [0]           | Processor clock enable. The processor clock disable/enable operation must follow the <i>Processor Clock Operation Sequence</i> .                                                            | RW    | 1       |   |               |   |              |  |  |
|            |               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable clock</td></tr> <tr> <td>1</td><td>Enable clock</td></tr> </tbody> </table> | Value | Meaning | 0 | Disable clock | 1 | Enable clock |  |  |
| Value      | Meaning       |                                                                                                                                                                                             |       |         |   |               |   |              |  |  |
| 0          | Disable clock |                                                                                                                                                                                             |       |         |   |               |   |              |  |  |
| 1          | Enable clock  |                                                                                                                                                                                             |       |         |   |               |   |              |  |  |
| HCLK_EN    | [1]           | AHB bus clock enable.<br>The AHB bus clock disable/enable operation must follow the <i>Bus Clock Operation Sequence</i> .                                                                   | RW    | 1       |   |               |   |              |  |  |
|            |               | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable clock</td></tr> <tr> <td>1</td><td>Enable clock</td></tr> </tbody> </table> | Value | Meaning | 0 | Disable clock | 1 | Enable clock |  |  |
| Value      | Meaning       |                                                                                                                                                                                             |       |         |   |               |   |              |  |  |
| 0          | Disable clock |                                                                                                                                                                                             |       |         |   |               |   |              |  |  |
| 1          | Enable clock  |                                                                                                                                                                                             |       |         |   |               |   |              |  |  |

| <b>Field Name</b> | <b>Bits</b>    | <b>Description</b>                                                                                                                                                                                        | <b>Type</b>  | <b>Reset</b>   |   |               |   |              |  |  |
|-------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------|---|---------------|---|--------------|--|--|
| PCLK_EN           | [2]            | Main APB bus clock enable. The APB bus clock disable/enable operation must follow the <i>Bus Clock Operation Sequence</i> .                                                                               | RW           | 1              |   |               |   |              |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable clock</td></tr> <tr> <td>1</td><td>Enable clock</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Disable clock | 1 | Enable clock |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 0                 | Disable clock  |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 1                 | Enable clock   |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| PCLK_UART1_EN     | [3]            | UART1 APB bus clock enable                                                                                                                                                                                | RW           | 0              |   |               |   |              |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable clock</td></tr> <tr> <td>1</td><td>Enable clock</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Disable clock | 1 | Enable clock |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 0                 | Disable clock  |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 1                 | Enable clock   |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| PCLK_UART2_EN     | [4]            | UART2 APB bus clock enable                                                                                                                                                                                | RW           | 0              |   |               |   |              |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable clock</td></tr> <tr> <td>1</td><td>Enable clock</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Disable clock | 1 | Enable clock |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 0                 | Disable clock  |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 1                 | Enable clock   |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| PCLK_SPI1_EN      | [5]            | SPI1 APB bus clock enable                                                                                                                                                                                 | RW           | 0              |   |               |   |              |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable clock</td></tr> <tr> <td>1</td><td>Enable clock</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Disable clock | 1 | Enable clock |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 0                 | Disable clock  |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 1                 | Enable clock   |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| PCLK_SPI2_EN      | [6]            | SPI2 APB bus clock enable                                                                                                                                                                                 | RW           | 0              |   |               |   |              |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable clock</td></tr> <tr> <td>1</td><td>Enable clock</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Disable clock | 1 | Enable clock |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 0                 | Disable clock  |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 1                 | Enable clock   |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| PCLK_GPIO_EN      | [7]            | GPIO APB bus clock enable                                                                                                                                                                                 | RW           | 0              |   |               |   |              |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable clock</td></tr> <tr> <td>1</td><td>Enable clock</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Disable clock | 1 | Enable clock |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 0                 | Disable clock  |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 1                 | Enable clock   |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| PCLK_I2C_EN       | [8]            | I2C APB bus clock enable                                                                                                                                                                                  | RW           | 0              |   |               |   |              |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable clock</td></tr> <tr> <td>1</td><td>Enable clock</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Disable clock | 1 | Enable clock |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 0                 | Disable clock  |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 1                 | Enable clock   |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| PCLK_WDT_EN       | [9]            | WDT APB bus clock enable                                                                                                                                                                                  | RW           | 0              |   |               |   |              |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable clock</td></tr> <tr> <td>1</td><td>Enable clock</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Disable clock | 1 | Enable clock |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 0                 | Disable clock  |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 1                 | Enable clock   |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| PCLK_PIT_EN       | [10]           | PIT APB bus clock enable                                                                                                                                                                                  | RW           | 0              |   |               |   |              |  |  |
|                   |                | <table border="1"> <thead> <tr> <th><b>Value</b></th><th><b>Meaning</b></th></tr> </thead> <tbody> <tr> <td>0</td><td>Disable clock</td></tr> <tr> <td>1</td><td>Enable clock</td></tr> </tbody> </table> | <b>Value</b> | <b>Meaning</b> | 0 | Disable clock | 1 | Enable clock |  |  |
| <b>Value</b>      | <b>Meaning</b> |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 0                 | Disable clock  |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |
| 1                 | Enable clock   |                                                                                                                                                                                                           |              |                |   |               |   |              |  |  |

### PROCESSOR CLOCK OPERATION SEQUENCE

1. Set RTC alarm in the RTC programming register (optional).
  2. Set CCLK\_EN to 0.
  3. Set standby command in the SMU command register.
    - SMU issues an external interrupt to the processor notifying the standby request.
    - The processor should execute the WFI instruction to make the processor go into the WFI mode.
  4. The Processor clock is disabled after the processor enters the WFI mode.
  5. The Processor clock is enabled and the processor is waked up when a wake-up event arrives.
  6. Clear the SMU command and status registers.
- BUS CLOCK OPERATION SEQUENCE**
7. Set RTC alarm in the RTC programming register (optional).
  8. Set PCLK\_EN, HCLK\_EN or CCLK\_EN to 0.
  9. Set standby command in the SMU command register.
    - SMU issues an external interrupt to the processor notifying the standby request.
    - The processor should execute the WFI instruction to make the processor go into the WFI mode.
  10. The bus clock or processor clock is disabled after the processor enters the WFI mode, depending on the PCLK\_EN, HCLK\_EN and CCLK\_EN setting.
  11. The bus clock is enabled and the processor is waked up when a wake-up event arrives
  12. Clear the SMU command and status registers.

### 20.4.7 Clock Ratio Register (CRR) (0x24)

| Field Name | Bits                                  | Description                                                                                                                                                                                                                                                                                                                                                              | Type  | Reset                                 |   |                |   |                  |   |         |   |           |   |           |     |          |  |  |
|------------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------------------------------------|---|----------------|---|------------------|---|---------|---|-----------|---|-----------|-----|----------|--|--|
| CCLKSEL    | [0]                                   | Processor clock select                                                                                                                                                                                                                                                                                                                                                   | RW    | 0                                     |   |                |   |                  |   |         |   |           |   |           |     |          |  |  |
|            |                                       | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>OSCH (Default)</td></tr> <tr> <td>1</td><td>Divide OSCH by 2</td></tr> </tbody> </table>                                                                                                                                                                         | Value | Meaning                               | 0 | OSCH (Default) | 1 | Divide OSCH by 2 |   |         |   |           |   |           |     |          |  |  |
| Value      | Meaning                               |                                                                                                                                                                                                                                                                                                                                                                          |       |                                       |   |                |   |                  |   |         |   |           |   |           |     |          |  |  |
| 0          | OSCH (Default)                        |                                                                                                                                                                                                                                                                                                                                                                          |       |                                       |   |                |   |                  |   |         |   |           |   |           |     |          |  |  |
| 1          | Divide OSCH by 2                      |                                                                                                                                                                                                                                                                                                                                                                          |       |                                       |   |                |   |                  |   |         |   |           |   |           |     |          |  |  |
| HPCLKSEL   | [3:1]                                 | HCLK and PCLK clock ratio select                                                                                                                                                                                                                                                                                                                                         | RW    | 0                                     |   |                |   |                  |   |         |   |           |   |           |     |          |  |  |
|            |                                       | <table border="1"> <thead> <tr> <th>Value</th><th>core_clk : hclk : pclk<br/>(frequency)</th></tr> </thead> <tbody> <tr> <td>0</td><td>1:1:1</td></tr> <tr> <td>1</td><td>1:1:1/2</td></tr> <tr> <td>2</td><td>1:1:1/4</td></tr> <tr> <td>3</td><td>1:1/2:1/2</td></tr> <tr> <td>4</td><td>1:1/2:1/4</td></tr> <tr> <td>5-7</td><td>Reserved</td></tr> </tbody> </table> | Value | core_clk : hclk : pclk<br>(frequency) | 0 | 1:1:1          | 1 | 1:1:1/2          | 2 | 1:1:1/4 | 3 | 1:1/2:1/2 | 4 | 1:1/2:1/4 | 5-7 | Reserved |  |  |
| Value      | core_clk : hclk : pclk<br>(frequency) |                                                                                                                                                                                                                                                                                                                                                                          |       |                                       |   |                |   |                  |   |         |   |           |   |           |     |          |  |  |
| 0          | 1:1:1                                 |                                                                                                                                                                                                                                                                                                                                                                          |       |                                       |   |                |   |                  |   |         |   |           |   |           |     |          |  |  |
| 1          | 1:1:1/2                               |                                                                                                                                                                                                                                                                                                                                                                          |       |                                       |   |                |   |                  |   |         |   |           |   |           |     |          |  |  |
| 2          | 1:1:1/4                               |                                                                                                                                                                                                                                                                                                                                                                          |       |                                       |   |                |   |                  |   |         |   |           |   |           |     |          |  |  |
| 3          | 1:1/2:1/2                             |                                                                                                                                                                                                                                                                                                                                                                          |       |                                       |   |                |   |                  |   |         |   |           |   |           |     |          |  |  |
| 4          | 1:1/2:1/4                             |                                                                                                                                                                                                                                                                                                                                                                          |       |                                       |   |                |   |                  |   |         |   |           |   |           |     |          |  |  |
| 5-7        | Reserved                              |                                                                                                                                                                                                                                                                                                                                                                          |       |                                       |   |                |   |                  |   |         |   |           |   |           |     |          |  |  |

### 20.4.8 Scratch Pad Register (SCRATCH) (0x40)

This register is a scratch register and it retains values when the rest of

the system is powered down. It could be used to hold some parameters during the power down period.

| Field Name | Bits   | Description      | Type | Reset |
|------------|--------|------------------|------|-------|
| SCRATCH    | [31:0] | Scratch register | RW   | 0     |

#### 20.4.9 Reset Vector (RESET\_VECTOR) (0x50)

This register controls the value driven to the reset\_vector[31:0] input signal of the N25(F) processor.

| Field Name   | Bits   | Description                         | Type | Reset      |
|--------------|--------|-------------------------------------|------|------------|
| RESET_VECTOR | [31:0] | Entry address upon processor reset. | RW   | 0x80000000 |

# 21 Platform-Level Interrupt Controller (PLIC)

## 21.1 Introduction

Andes Platform-Level Interrupt Controller (NCEPLIC100) prioritizes and distributes global interrupts. It is compatible with RISC-V PLIC with the following features:

- Configurable interrupt trigger types
- Software-programmable interrupt generation
- Preemptive priority interrupt extension
- Vectored interrupt extension

The block diagram of NCEPLIC100 is shown in Figure 21-1 NCEPLIC100 Block Diagram. Interrupt sources (e.g., devices) send interrupt requests to NCEPLIC100 through the int\_src signals. The signals can be level-triggered or edge-triggered, and they are converted to interrupt requests by the interrupt gateway. Interrupt requests are prioritized and routed to interrupt targets (e.g., AndesCore processors) according to interrupt settings. Interrupt settings include enable bits, priorities, and priority thresholds, and these settings are programmable through the bus interface.

The tx\_eip (x stands for the target number) signal is an external interrupt pending notification signal to the targets. It is a level signal summarizing the interrupt pending (IP) status of all interrupt sources to target x. When a target takes the external interrupt, it should send an interrupt claim request (bus read request) to retrieve the interrupt ID, upon which the corresponding interrupt pending status bit will be cleared and tx\_eip will be deasserted. tx\_eip is guaranteed to be deasserted for at least one cycle even if there are pending interrupt sources still remaining. This is done to ensure that the interrupt detection logic of the target processor could see the remaining interrupt pending status.

The interrupt gateway stops processing newer interrupt requests from its interrupt sources once it reports an interrupt request. When the target

has serviced the interrupt, it should send the interrupt completion message (bus write request) to NCEPLIC100 such that the interrupt gateway resumes processing newer interrupt requests.

The interrupt pending bit array of the PLIC registers provides a summary of all interrupt sources status. In addition, it is also writable for setting software-programmed interrupts for the corresponding interrupt sources. See [Interrupt Pending](#) for more information.

NCEPLIC100 implements two Andes specific extensions. See [Support for Preemptive Priority Interrupt](#)for information regarding the Andes preemptive priority interrupt extension and [Vectored Interrupts](#) for information regarding the Andes vectored PLIC extension.

**Figure 21-1 NCEPLIC100 Block Diagram**



## 21.2 Support for Preemptive Priority Interrupt

NCEPLIC100 implements the Andes preemptive priority interrupt extension which enables faster responses for high-priority interrupts. With this extension, if a high-priority interrupt arrives and the global interrupt is enabled (i.e., `mstatus.MIE` is 1), the processor will stop servicing the current low-priority interrupt and begin servicing this new high-priority interrupt. The handling of the suspended lower-priority interrupts will resume only after the handling of the higher-priority interrupt ends. Interrupts of same or lower priorities will not cause preemption to take effect and interfere the handling of the current interrupt. They have to wait until the handling of the current interrupt finishes.

To support this feature, the PLIC core is enhanced with a preempted priority stack for each target. The stack saves and restores priorities of the nested/preempted interrupts for the target it is associated. The operation of the preempted stack is implicitly performed through two regular PLIC operations ([Interrupt Claim](#) and [Interrupt Completion](#)). See the next two subsections for more information.

This feature is enabled by setting the `PREEMPT` field (bit 0) of the

Feature Enable Register (offset: 0x0000) to 1.

### 21.2.1 Interrupt Claims with Preemptive Priority

When a target sends an interrupt claim message to the PLIC core, the PLIC core will atomically determine the ID of the highest-priority pending interrupt for the target and then deassert the corresponding source's IP bit. The PLIC core will then return the ID to the target.

At the same time, the priority number in the target's Priority Threshold Register will be saved to a preempted priority stack for that target and the new priority number of the claimed interrupt will be written to the Priority Threshold Register.

### 21.2.2 Interrupt Completion with Preemptive Priority

When a target sends an interrupt completion message to the PLIC core, in addition to forwarding the completion message to the associated gateway, the PLIC core will restore the highest priority number in the preempted priority stack back to the Priority Threshold Register of the target.

Note that out-of-order completion of interrupts is not allowed when this feature is turned on — the latest claimed interrupt should be completed first.

## 21.3 Vectored Interrupts

NCEPLIC100 enhances the RISC-V PLIC functionality with the vector mode extension to allow the interrupt target to receive the interrupt source ID without going through the target claim request protocol. This feature can shorten the latency of interrupt handling by enabling the interrupt target to run the corresponding interrupt handler directly upon accepting the external interrupt. It is enabled by setting the VECTORED field (bit 1) of the Feature Enable Register (offset: 0x0000) to 1.

Two extra interface signals, tx\_eiid and tx\_eiack, are added to facilitate interrupt handling in the vector mode. When a valid interrupt is sent to PLIC, PLIC would send tx\_eip with tx\_eiid. Upon accepting the interrupt, the target asserts tx\_eiack to PLIC and takes tx\_eiid as the interrupt source ID. The assertion of tx\_eiack would cause the deassertion of tx\_eip and clearing of the tx\_IP bit of corresponding interrupt source as does the handling of the interrupt claim request.

Note that interrupt completion messages are still required to notify the interrupt gateway the completion of interrupt handling and to forward additional interrupts to the PLIC core.

The interrupt priority arbitration works differently under the vector mode. In the non-vector mode, PLIC continues to arbitrate among all active interrupts even after the target is notified of occurrence of some interrupts (tx\_eip sent to the target). Arbitration is not final until the claim request

message is processed. In the vector mode, interrupt arbitration is final as soon as tx\_eip is posted to the interrupt target. Interrupt arbitration resumes after tx\_eiack is replied to PLIC and tx\_eip is deasserted. The protocol does not change tx\_eiid on the fly to allow PLIC and the interrupt target to operate at different clock domains.

The vector mode extension is designed such that each interrupt source is statically assigned to a single target. No two targets should compete servicing (claiming) the same interrupt source through the handshaking interface signals (tx\_eiack). Otherwise, unpredictable results may occur. Despite automatic dispatching, the PLIC interrupt claim request protocol still works under the vector mode for the interrupt handler to claim additional interrupts.

### 21.3.1 Vector Mode Protocol

Figure 21-2 NCEPLIC100 Vector Mode Protocol



- tx\_eiid remains stable when tx\_eip is asserted.
- When tx\_eip is asserted, it remains asserted until tx\_eiack is asserted or an interrupt claim request is sent to PLIC.
- The assertion of tx\_eiack causes the deassertion of tx\_eip, which in turn causes the deassertion of tx\_eiack.
- If there are more pending interrupts, tx\_eip is asserted again after deassertion of tx\_eiack.

## 21.4 PLIC Configuration Options

Table 21-1 PLIC Configuration Parameters summarizes all supported configuration parameters and the subsections describe the parameters in detail.

**Table 21-1 PLIC Configuration Parameters**

| Parameter Name      | Type    | Valid Values         | Default Value |
|---------------------|---------|----------------------|---------------|
| INT_NUM             | Integer | 1–1023               | 63            |
| TARGET_NUM          | Integer | 1–16                 | 1             |
| MAX_PRIORITY        | Integer | 3/7/15/31/63/127/255 | 15            |
| EDGE_TRIGGER        | Integer | See Section 19.4.4   | 0             |
| ASYNC_INT           | Integer | See Section 19.4.5   | 0             |
| ADDR_WIDTH          | Integer | $\geq 22$            | 32            |
| DATA_WIDTH          | Integer | 32/64                | 32            |
| VECTOR_PLIC_SUPPORT | String  | "yes"/"no"           | "yes"         |
| PLIC_BUS            | String  | "ahb"/"axi"          | "axi"         |

## 21.4.1 Number of Interrupts

INT\_NUM determines the number of interrupts.

## 21.4.2 Number of Targets

TARGET\_NUM determines the number of interrupt targets.

## 21.4.3 Maximum Interrupt Priority

MAX\_PRIORITY determines the valid priority levels of the interrupt sources and the target threshold. The priority value 0 is reserved to mean "never interrupt", and the larger the priority value, the higher the interrupt priority.

## 21.4.4 Edge Trigger

EDGE\_TRIGGER is regarded as a bit vector and each bit controls whether the corresponding interrupt source is level-triggered or edge-triggered:

- Value 0 means level-triggered; and
- Value 1 means edge-triggered.

The bit width of EDGE\_TRIGGER should be (INT\_NUM+1).

## 21.4.5 Asynchronous Interrupt Source

ASYNC\_INT is a bit vector where each bit indicates whether the corresponding interrupt source is asynchronous or synchronous.

- Value 0 means the interrupt source is synchronous.
- Value 1 means the interrupt source is asynchronous.

The bit width of ASYNC\_INT should be (INT\_NUM+1).

## 21.4.6 Address Width of PLIC Bus Interface

ADDR\_WIDTH determines the address width of PLIC bus. The address width should be greater than or equal to 22 to encompass all addressable PLIC memory space.

### 21.4.7 Data Width of PLIC Bus Interface

DATA\_WIDTH determines the data width of PLIC bus. PLIC AHB interface only supports 32-bit data width and PLIC AXI-4 interface supports both 32-bit and 64-bit data width.

### 21.4.8 Support For Vectored PLIC Extension

VECTOR\_PLIC\_SUPPORT controls whether to include Andes Vectored PLIC Extension or not.

### 21.4.9 Bus Type of PLIC

PLIC\_BUS determines the bus type of PLIC.

- String "ahb" indicates PLIC is an AHB slave device.
- String "axi" indicates PLIC is an AXI-4 slave device.

## 21.5 PLIC Registers

### 21.5.1 Memory Map

NCEPLIC100 registers are accessed through bus transfers, and the memory map is shown in Table 21-2 AndeStar-V5 PLIC Memory Map. Please note that NCEPLIC100 supports only 32-bit transfers. Behaviors of 8-bit and 16-bit transfers are UNDEFINED, and the transfers might be ignored or result in error responses.

**Table 21-2 AndeStar-V5 PLIC Memory Map**

| Address Offset |          | Description                                                               |
|----------------|----------|---------------------------------------------------------------------------|
| Begin          | End      |                                                                           |
| 0x000000       | 0x000003 | Feature enable register                                                   |
| 0x000004       | 0x000007 | Source 1 priority                                                         |
| 0x000008       | 0x00000B | Source 2 priority                                                         |
| ...            | ...      | ...                                                                       |
| 0x000FFC       | 0x000FFF | Source 1023 priority                                                      |
| 0x001000       | 0x00107F | Pending array                                                             |
| 0x001080       | 0x0010FF | Trigger type array                                                        |
| 0x001100       | 0x001103 | Number of interrupts and targets                                          |
| 0x001104       | 0x001107 | Version and max priority register                                         |
| 0x002000       | 0x00207F | Target 0 interrupt enable bits                                            |
| 0x002080       | 0x0020FF | Target 1 interrupt enable bits                                            |
| ...            | ...      | ...                                                                       |
| 0x002780       | 0x0027FF | Target 15 interrupt enable bits                                           |
| 0x200000       | 0x200003 | Target 0 priority threshold                                               |
| 0x200004       | 0x200007 | Target 0 claim/complete                                                   |
| 0x200400       | 0x20041F | Target 0 preempted priority stack                                         |
| 0x201000       | 0x20141F | Target 1 priority threshold, claim/complete,<br>preempted priority stack  |
| ...            | ...      | ...                                                                       |
| 0x20F000       | 0x20F41F | Target 15 priority threshold, claim/complete,<br>preempted priority stack |

## 21.5.2 Feature Enable Register

**Offset:** 0x0



This register enables preemptive priority interrupt feature and the vector mode.

| Field Name | Bits     | Description                                                                                                                                                                       | Type  | Reset   |   |          |   |         |  |  |
|------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|----------|---|---------|--|--|
| PREEMPT    | [0]      | Preemptive priority interrupt enable                                                                                                                                              | RW    | 0       |   |          |   |         |  |  |
|            |          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disabled</td></tr> <tr> <td>1</td><td>Enabled</td></tr> </tbody> </table> | Value | Meaning | 0 | Disabled | 1 | Enabled |  |  |
| Value      | Meaning  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 0          | Disabled |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 1          | Enabled  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |

  

| Field Name | Bits     | Description                                                                                                                                                                       | Type  | Reset   |   |          |   |         |  |  |
|------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|----------|---|---------|--|--|
| VECTORED   | [1]      | Vector mode enable                                                                                                                                                                | RW    | 0       |   |          |   |         |  |  |
|            |          | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Disabled</td></tr> <tr> <td>1</td><td>Enabled</td></tr> </tbody> </table> | Value | Meaning | 0 | Disabled | 1 | Enabled |  |  |
| Value      | Meaning  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 0          | Disabled |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |
| 1          | Enabled  |                                                                                                                                                                                   |       |         |   |          |   |         |  |  |

Please note that both this bit and the mmisc\_ctl.VEC\_PLIC bit of the processor should be turned on for the vectored interrupt support to work correctly. See Section 15.8.7 for the definition of the VEC\_PLIC bit.

### 21.5.3 Interrupt Source Priority

Offset: n\*4



This register determines the priority for interrupt source n ( $1 \leq n \leq 1023$ ).

| Field Name | Bits                                                                      | Description                                                                                                                                                                                                                                                     | Type  | Reset   |   |                  |       |                                                                           |  |  |
|------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------------|-------|---------------------------------------------------------------------------|--|--|
| PRIORITY   | [31:0]                                                                    | Interrupt source priority. The valid range of this field is determined by the MAX_PRIORITY field of the Version & Maximum Priority Configuration Register.                                                                                                      | RW    | 0       |   |                  |       |                                                                           |  |  |
|            |                                                                           | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Never interrupt.</td></tr> <tr> <td>1–255</td><td>Interrupt source priority. The larger the value, the higher the priority.</td></tr> </tbody> </table> | Value | Meaning | 0 | Never interrupt. | 1–255 | Interrupt source priority. The larger the value, the higher the priority. |  |  |
| Value      | Meaning                                                                   |                                                                                                                                                                                                                                                                 |       |         |   |                  |       |                                                                           |  |  |
| 0          | Never interrupt.                                                          |                                                                                                                                                                                                                                                                 |       |         |   |                  |       |                                                                           |  |  |
| 1–255      | Interrupt source priority. The larger the value, the higher the priority. |                                                                                                                                                                                                                                                                 |       |         |   |                  |       |                                                                           |  |  |

### 21.5.4 Interrupt Pending

Offset: 0x1000 to 0x107F

These registers provide the interrupt pending status of interrupt sources, and a way for software to trigger an interrupt without relying on external devices. Every interrupt source occupies 1 bit. There are a total of 32 registers, each 32-bit wide, for 1023 interrupt sources.

When these registers are read, the interrupt pending status of interrupt sources are returned. The pending bits could be set by writing a bit mask that specifies the bit positions to be set, and this action would result in software-programmed interrupts of the corresponding interrupt sources.

The pending bits could only be cleared through the Interrupt Claim requests.

The location of the interrupt pending bit for interrupt source n can be determined by the following equations:

- Word offset address:  $0x1000 + 4 * \text{floor}(n/32)$
- Bit Position: n modulo 32

### 21.5.5 Interrupt Trigger Type

**Offset:** 0x1080 to 0x10FF

These registers are read-only and indicate the configured interrupt trigger type of interrupt sources. Every interrupt source occupies 1 bit. There are a total of 32 registers, each 32-bit wide, for 1023 interrupt sources. The location of the interrupt trigger type bit for interrupt source n can be determined by the following equations:

- Word offset address:  $0x1080 + 4 * \text{floor}(n/32)$
- Bit Position: n modulo 32

The meaning of each bit is shown in Table 21-3 Meaning of Trigger Type.

Table 21-3 Meaning of Trigger Type

| Value | Meaning                   |
|-------|---------------------------|
| 0     | Level-triggered interrupt |
| 1     | Edge-triggered interrupt  |

### 21.5.6 Number of Interrupt and Target Configuration Register

**Offset:** 0x1100



This register indicates the number of supported interrupt sources and supported targets.

| Field Name    | Bits    | Description                               | Type | Reset |
|---------------|---------|-------------------------------------------|------|-------|
| NUM_INTERRUPT | [15:0]  | The number of supported interrupt sources | RO   | IM    |
| NUM_TARGET    | [31:16] | The number of supported targets           | RO   | IM    |

### 21.5.7 Version & Maximum Priority Configuration Register

**Offset:** 0x1104



This register indicates the version and the maximum priority of PLIC implementation.

| Field Name   | Bits    | Description                                | Type | Reset |
|--------------|---------|--------------------------------------------|------|-------|
| VERSION      | [15:0]  | The version of the AndeStar-V5 PLIC design | RO   | IM    |
| MAX_PRIORITY | [31:16] | The maximum priority supported             | RO   | IM    |

## 21.5.8 Interrupt Enable Bits for Target m

**Offset:** (0x2000+m\*128) to (0x207F+m\*128)

These registers control the routing of interrupt source n to target m. Every interrupt source occupies 1 bit for each target to enable interrupt processing for that target. There are a total of 32 registers for 1023 interrupt sources for each target. The location of the interrupt enable bit for interrupt source n to target m can be determined by the following equations:

- Word offset address:  $0x2000 + 128 * m + 4 * \text{floor}(n/32)$
- Bit position: n modulo 32

## 21.5.9 Priority Threshold for Target m

**Offset:** 0x200000+4096\*m



Each interrupt target is associated with one Priority Threshold Register. Only active interrupts with priorities strictly greater than the threshold will cause an interrupt notification to be sent to the target.

| Field Name | Bits   | Description                                                                                                                                                                   | Type | Reset |
|------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| THRESHOLD  | [31:0] | Interrupt priority threshold. The valid range of this field is determined by the <a href="#">MAX_PRIORITY</a> field of the Version & Maximum Priority Configuration Register. | RW   | 0     |

## 21.5.10 Claim and Complete Register for Target m

**Offset:** 0x200004+4096\*m



There is one Claim and Complete Register for each interrupt target. Reading this register claims an interrupt source and returns the ID of that interrupt source.

The interrupt gateway stops processing newer interrupt requests from its interrupt sources until the earlier interrupt request is completed. Writing this register with an interrupt ID serves as the interrupt completion message acknowledging to PLIC that the handling of the claimed interrupt has been serviced in target m and the associated interrupt gateway may resume processing newer interrupt requests.

The interrupt gateway only resumes processing of newer interrupt

requests if the enable bit of the interrupt source for Target m is set. If the enable bit is not set, the interrupt completion message is ignored.

Generally there are no limitations to the order of interrupt claims and completions except when the preemptive priority mode is enabled. When PLIC is in the preemptive priority mode, the latest claimed interrupt should be completed first.

| Field Name   | Bits  | Description                                                                                                                                    | Type | Reset |
|--------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| INTERRUPT_ID | [9:0] | On reads, indicating the interrupt source that has been claimed. On writes, indicating the interrupt source that has been handled (completed). | RW   | 0     |

### 21.5.11 Preempted Priority Stack Registers for Target m

**Offset:** (0x200400+4096\*m) to (0x20041F+4096\*m)

These registers are read/writable registers for accessing the preempted priority stack for target m. The purpose of these registers are for saving and restoring priorities of the nested/preempted interrupts for a particular target.

There are a total of 8 registers, each 32-bit wide, for 255 priority levels. Each bit in these registers indicates if the corresponding priority level has been preempted by a higher-priority interrupt. The location of the priority level bit for priority p of target m (Word offset Address, Bit Position) can be determined by the following equations:

- Word offset Address:  $0x20\_0400 + 4096 * m + 4 * \text{floor}(p/32)$
- Bit Position: P modulo 32

## 21.6 Interrupt Latency

Figure 21-3 Minimum Interrupt Latency illustrates the minimum timing for the processor to execute the first instruction.

When a device asserts INT\_SRC[n], it takes 3 BUS\_CLK cycles for NCEPLIC100 to arbitrate interrupts and assert its MEIP output signal, where BUS\_CLK is the clock source of NCEPLIC100. When the MEIP signal is asserted, it takes one CORE\_CLK cycle for the processor to latch the signal into the mip register. The interrupt is usually taken immediately in the same cycle, unless current operations cannot be interrupted (e.g., load to device regions).

How the processor fetches the trap handler for handling the associated external interrupt depends on its vector interrupt setting. When mmisc\_ctl.VEC\_PLIC is 0, the processor fetches the instruction pointed by mtvec. When mmisc\_ctl.VEC\_PLIC is 1 (vector mode), mtvec points to a table of entry point addresses, one entry for each external interrupt. It takes the processor 3 additional CORE\_CLK cycles to fetch the entry point address, before fetching the first instruction of the associated trap handler. The waveform assumes that instruction fetch returns immediately without

wait states.

The processor implements a 5-stage pipeline, so it takes at least 5 CORE\_CLK cycles for the first instruction of the trap handler to execute and retire.

In summary, the minimum latency is 3 BUS\_CLK and 6 CORE\_CLK cycles. The latency is counted from assertion of INT\_SRC[n] to the end of execution of the first instruction of the trap handler.

**Figure 21-3 Minimum Interrupt Latency**



## 21.7 Interface Signals

NCEPLIC100 offers two type of bus interfaces: AHB interface and AXI interface. The interfaces are selected by the PLIC\_BUS parameter. The interface signals to both interfaces are simultaneously present on its module port list and only the selected one will be used. The other group of signals will be unused and left floating.

The tables below describes the interface signals of NCEPLIC100 and the clock to NCEPLIC100 should be synchronous to that of N25(F).

Table 21-7 Valid AHB Transactions for NCEPLIC100 andTable 21-8 Valid AXI Transactions for NCEPLIC100 summarize valid transactions that NCEPLIC100 accepts. It responds to invalid transactions by returning undefined values for read transactions and ignoring writes. On the AXI interface, SLVERR is also set on rresp or bresp for invalid transactions.

**Table 21-4 General Signals of NCEPLIC100**

| Signal Name        | Direction | Description                                                                                                                                  |
|--------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|
| clk                | input     | Clock                                                                                                                                        |
| reset_n            | input     | Reset (Active-Low)                                                                                                                           |
| int_src[INT_NUM:1] | input     | Interrupt sources. The sources could be configured to be asynchronous inputs through the ASYNC_INT parameter. See Section 19.4.5 for detail. |
| tx_eip             | output    | External interrupt pending for target x.                                                                                                     |
| tx_eiid[9:0]       | output    | External interrupt id for target x, see Section 19.3 for detail.                                                                             |
| tx_eiack           | input     | Interrupt acknowledgment from target x, see Section 19.3 for detail.                                                                         |

**Table 21-5 AHB Interface Signals of NCEPLIC100**

| Signal Name           | Direction | Description                     |
|-----------------------|-----------|---------------------------------|
| hsel                  | input     | Slave Select                    |
| hrdata[31:0]          | output    | Read data bus                   |
| hready                | input     | Transfer done signal of AHB bus |
| hreadyout             | output    | Transfer done signal of PLIC    |
| hresp[1:0]            | output    | Transfer response               |
| haddr[ADDR_WIDTH-1:0] | input     | Address bus                     |
| hburst[2:0]           | input     | Burst type                      |
| hlock                 | input     | Locked transfer                 |
| hprot[3:0]            | input     | Protection control              |
| hsize[2:0]            | input     | Transfer size                   |
| htrans[1:0]           | input     | Transfer type                   |
| hwdata[31:0]          | input     | Write data bus                  |
| hwrite                | input     | Transfer direction              |



**Table 21-6 AXI Interface Signals of NCEPLIC100**

| <b>Signal Name</b>     | <b>Direction</b> | <b>Description</b>    |
|------------------------|------------------|-----------------------|
| awid[3:0]              | input            | Write address ID      |
| awaddr[ADDR_WIDTH-1:0] | input            | Write address         |
| awlen[7:0]             | input            | Write burst length    |
| awszie[2:0]            | input            | Write burst size      |
| awburst[1:0]           | input            | Write burst type      |
| awlock                 | input            | Write lock type       |
| awcache[3:0]           | input            | Write cache type      |
| awport[2:0]            | input            | Write protection type |
| awvalid                | input            | Write address valid   |
| awready                | output           | Write address ready   |
| wdata[DATA_WIDTH-1:0]  | input            | Write data            |
| wstrb[3:0]             | input            | Write strobes         |
| wlast                  | input            | Write last            |
| wvalid                 | input            | Write valid           |
| wready                 | output           | Write ready           |
| bid[3:0]               | output           | Write response ID     |
| bresp[1:0]             | output           | Write response        |
| bvalid                 | output           | Write response valid  |
| bready                 | input            | Write response ready  |
| arid[3:0]              | input            | Read address ID       |
| araddr[ADDR_WIDTH-1:0] | input            | Read address          |
| arlen[7:0]             | input            | Read burst length     |
| arsize[2:0]            | input            | Read burst size       |
| arburst[1:0]           | input            | Read burst type       |
| arlock                 | input            | Read lock type        |
| arcache[3:0]           | input            | Read cache type       |
| arprot[2:0]            | input            | Read protection type  |
| arvalid                | input            | Read address valid    |
| arready                | output           | Read address ready    |
| rid[3:0]               | output           | Read ID tag           |
| rdata[DATA_WIDTH-1:0]  | output           | Read data             |
| rresp[1:0]             | output           | Read response         |
| rlast                  | output           | Read last             |
| rvalid                 | output           | Read valid            |
| rready                 | input            | Read ready            |



**Table 21-7 Valid AHB Transactions for NCEPLIC100**

| <b>Transaction Type</b> |
|-------------------------|
| Single WORD             |
| INCR WORD               |
| WRAP4 WORD              |
| INCR4 WORD              |
| WRAP8 WORD              |
| INCR8 WORD              |
| WRAP16 WORD             |
| INCR16 WORD             |

**Table 21-8 Valid AXI Transactions for NCEPLIC100**

| <b>Transaction Type</b> |
|-------------------------|
| Single WORD             |

# 22 Machine Timer

## 22.1 Introduction

The RISC-V architecture defines a machine timer that provides a real-time counter and generates timer interrupts. NCEPLMT100 is an implementation of the machine timer, and the block diagram is shown in the following figure.

This timer is not to be confused with the real-time clock timer of typical computing platforms. Per RISC-V privileged specification, the timer clock (`mtime_clk`) could be clocked at any arbitrary frequency as long as it is a fixed frequency clock that is not affected by clock gating or frequency scaling of clocks in the rest of the platform. On the other hand, real-time clock timer is usually clocked by a 32768Hz clock. The linux kernel expects microsecond resolution for the `mtime`, so it imposes an additional requirement that `mtime_clk` has to be greater than 1MHz. For non-linux applications, `mtime_clk` could share the same clock source as the real-time clock timer.

The RISC-V privileged specification expects that software discovers the frequency of `mtime_clk` through a platform specific mechanism. For linux kernels, this is achieved through the Device Tree specification.

NCEPLMT100 imposes a frequency limitation on the frequency of the `mtime_clk` clock. The `mtime` update synchronization logic requires that the frequency of the bus interface of NCEPLMT100 should be at least 2x faster than that of the `mtime_clk` clock when `mtime` is accessed.

On Andes evaluation platforms, the frequency of `mtime_clk` is set to the normal operating frequency of APB clocks to minimize the number of clock sources in FPGA.

NCEPLMT100 primarily consists of two registers: `mtime` and `mtimecmp`. The `mtime` register is a 64-bit real-time counter clocked by `mtime_clk`. The `mtimecmp` register stores a 64-bit value for comparing with `mtime`. When the value in `mtime` is greater than or equal to the value in `mtimecmp`, the `mtip` signal is asserted for generating a timer interrupt.

When mtimecmp is written, the interrupt is cleared and the mtip signal is deasserted.

**Figure 22-1 NCEPLMT100 Block Diagram**



## 22.2 Machine Timer Registers

NCEPLMT100 registers are accessed through the bus interface, and their memory map is shown in Table 22-1 N25(F) NCEPLMT100 Memory Map.

Please note that NCEPLMT100 supports only 32-bit transfers. Behaviors of 8-bit and 16-bit transfers are UNDEFINED, and these transfers might be ignored as well as result in error responses or unexpected register updates.

**Table 22-1 N25(F) NCEPLMT100 Memory Map**

| Address Offset | Description     |
|----------------|-----------------|
| 0x0 – 0x3      | mtime[31:0]     |
| 0x4 – 0x7      | mtime[63:32]    |
| 0x8 – 0xB      | mtimecmp[31:0]  |
| 0xC – 0xF      | mtimecmp[63:32] |

The mtime register is driven by mtime\_clk, which is assumed to be slower than the clock of the bus interface. A mtime\_shadow shadow register is maintained in the bus clock domain to reduce the latency of accessing the mtime register in the slow clock domain. The values of mtime and mtime\_s hadow registers are constantly synchronized such that mtime\_shadow maintains the most up-to-date values of mtime. The value in mtime\_shadow is instantly returned when reading mtime register. When writing the mtime register, bus write transactions finish when the values are written to the mti me\_shadow register, and NCEPLMT100 handles the synchronization to mtime in the background.

## 22.3 Machine Timer Configuration Options

Table 22-2 Machine Timer Configuration Parameters summarizes all supported configuration parameters and the subsections describe the parameters in detail.

**Table 22-2 Machine Timer Configuration Parameters**

| Parameter Name | Type    | Valid Values | Default Value |
|----------------|---------|--------------|---------------|
| ADDR_WIDTH     | Integer | $\geq 10$    | 32            |
| BUS_TYPE       | String  | "ahb"/"axi"  | "ahb"         |

### 22.3.1 Address Width of Machine Timer Interface

ADDR\_WIDTH determines the address width of Machine timer bus. The address width should be greater than or equal to 10 to encompass all addressable Machine timer memory space.

### 22.3.2 Bus Type of Machine Timer

- BUS\_TYPE determines the bus type of Machine Timer.
- String "ahb" indicates Machine Timer is an AHB slave device.
  - String "axi" indicates Machine Timer is an AXI-4 slave device.

## 22.4 Interface Signals

The interface ports of the NCEPLMT100 are described in this section. All signals are Active-High unless otherwise indicated.

NCEPLMT100 offers two type of bus interfaces: AHB interface and AXI interface. The interfaces are selected by the BUS\_TYPE parameter. The interface signals to both interfaces are simultaneously present on its module port list and only the selected one will be used. The other group of signals will be unused and left floating.

The tables below describes the interface signals of NCEPLMT100 and the clock to NCEPLMT100 should be synchronous to that of N25(F).

Table 22-6 and Table 22-7 summarize valid transactions that NCEPLMT100 accepts.

**Table 22-3 General Signals of NCEPLMT100**

| Signal Name | Direction | Description                                                     |
|-------------|-----------|-----------------------------------------------------------------|
| clk         | input     | Clock for the bus interface                                     |
| resetn      | input     | Reset for the bus interface (Active-Low)                        |
| mtime_clk   | input     | Clock for the mtime counter. See Section 20.1.                  |
| pwr_on_rstn | input     | Power on reset (Active-Low) for initializing the mtime counter. |

**Table 22-4 AHB Interface Signals of NCEPLMT100**

| Signal Name           | Direction | Description                           |
|-----------------------|-----------|---------------------------------------|
| hsel                  | input     | Slave Select                          |
| hrdata[31:0]          | output    | Read data bus                         |
| hready                | input     | Transfer done signal of AHB bus       |
| hreadyout             | output    | Transfer done signal of Machine Timer |
| hresp[1:0]            | output    | Transfer response                     |
| haddr[ADDR_WIDTH-1:0] | input     | Address bus                           |
| hburst[2:0]           | input     | Burst type                            |
| hlock                 | input     | Locked transfer                       |
| hprot[3:0]            | input     | Protection control                    |
| hsize[2:0]            | input     | Transfer size                         |
| htrans[1:0]           | input     | Transfer type                         |
| hwdata[31:0]          | input     | Write data bus                        |
| hwrite                | input     | Transfer direction                    |

**Table 22-5 AXI Interface Signals of NCEPLMT100**

| <b>Signal Name</b>     | <b>Direction</b> | <b>Description</b>    |
|------------------------|------------------|-----------------------|
| awid[3:0]              | input            | Write address ID      |
| awaddr[ADDR_WIDTH-1:0] | input            | Write address         |
| awlen[7:0]             | input            | Write burst length    |
| awszie[2:0]            | input            | Write burst size      |
| awburst[1:0]           | input            | Write burst type      |
| awlock                 | input            | Write lock type       |
| awcache[3:0]           | input            | Write cache type      |
| awport[2:0]            | input            | Write protection type |
| awvalid                | input            | Write address valid   |
| awready                | output           | Write address ready   |
| wdata[31:0]            | input            | Write data            |
| wstrb[3:0]             | input            | Write strobes         |
| wlast                  | input            | Write last            |
| wvalid                 | input            | Write valid           |
| wready                 | output           | Write ready           |
| bid[3:0]               | output           | Write response ID     |
| bresp[1:0]             | output           | Write response        |
| bvalid                 | output           | Write response valid  |
| bready                 | input            | Write response ready  |
| arid[3:0]              | input            | Read address ID       |
| araddr[ADDR_WIDTH-1:0] | input            | Read address          |
| arlen[7:0]             | input            | Read burst length     |
| arsize[2:0]            | input            | Read burst size       |
| arburst[1:0]           | input            | Read burst type       |
| arlock                 | input            | Read lock type        |
| arcache[3:0]           | input            | Read cache type       |
| arprot[2:0]            | input            | Read protection type  |
| arvalid                | input            | Read address valid    |
| arready                | output           | Read address ready    |
| rid[3:0]               | output           | Read ID tag           |
| rdata[31:0]            | output           | Read data             |
| rresp[1:0]             | output           | Read response         |
| rlast                  | output           | Read last             |
| <hr/>                  |                  |                       |
| <b>Signal Name</b>     | <b>Direction</b> | <b>Description</b>    |
| rvalid                 | output           | Read valid            |
| rready                 | input            | Read ready            |

**Table 22-6 Valid AHB Transactions for NCEPLMT100**

| <b>Transaction Type</b> |
|-------------------------|
| Single WORD             |

**Table 22-7 Valid AXI Transactions for NCEPLMT100**

| <b>Transaction Type</b> |
|-------------------------|
| Single WORD             |

# 23 Debug Subsystem

## 23.1 Overview

The N25(F) debug subsystem implements RISC-V External Debug Support (TD003) V0.13. Figure 23-1 Debug Subsystem Block Diagram shows the block diagram of the debug subsystem, which contains two components: NCEPLDM200 and NCEJDTM200. NCEPLDM200 is the debug module, which could be accessed through its two AHB slave ports. One is the system interface port, which is for an AndesCore processor to access the debug module through the system bus. The other one is the Debug Memory Interface (DMI) port, which is accessed by NCEJDTM200 (JTAG Debug Transport Module). NCEJDTM200 converts debug commands in JTAG interfaces of external debuggers to bus read/write requests to the DMI port.

Figure 23-1 Debug Subsystem Block Diagram



Debug interrupts cause N25(F) to enter the debug mode and redirect

the instruction fetch to the debug exception handler, whose entry point should be the base address of NCEPLDM200 and defined by the DEBUG\_VEC parameter of N25(F).

NCEPLDM200 includes a Debug ROM at its base address that defines the debug exception handler. When invoked, the debug handler polls NCEPLDM200 internal registers to process commands issued by the external debugger through the NCEJDTM200 module. Typical debug commands include accessing processor registers, accessing memories, and executing programs written in the Program Buffer, which is a memory region writable by the external debugger.

Correct operations of the debug subsystem require clocks, resets and I/O interfaces to be connected in a certain way, as well as making sure the DEBUG\_VEC parameter is within a device region (Device Regions). Please see the next subsection for information.

## 23.2 Integration Requirements

For proper operations of the debug subsystem, the following platform-level requirements of reset, clock and I/O signals should be met:

- NCEJDTM200 should be reset by power-on resets, which will not be triggered by other resets in the system.
- NCEPLDM200 should be reset by dmi\_hresetn that is generated by NCEJDTM200.
- ndmreset (non-debug-module reset) should connect to the platform reset generator for triggering platform-wide resets, which shall include core\_reset\_n that drives AndesCore processors. As the name suggests, ndmreset should not reset both NCEJDTM200 and NCEPLDM200. Please also note that the platform reset should not affect the pin-muxing of the external debug interface (JTAG) pins to preserve connectivity to the external debugger throughout resets.
- ndmreset should not cause assertion of power-on resets (pwr\_rst\_n).
- The clock signal (clk) to NCEJDTM200 and NCEPLDM200 should keep running during the assertion of ndmreset. Stopped clocks will impede the deassertion of ndmreset.
- The bus interfaces of NCEJDTM200 and NCEPLDM200 should be in the same clock domain.
- Both tck and tms pins of the JTAG interface should not be floating when the external debugger is not attached:
  - tck can be either pulled up to HIGH or pulled down to LOW.
  - tms should be pulled up to HIGH.

## 23.3 NCEPLDM200

Table 23-1 System Memory Map of NCEPLDM200 summarizes the memory map within the NCEPLDM200 address space as viewed from the system bus interface. Please note that the offset for Program Buffer could

be discovered by the external debugger through execution of the AUIPC instruction as the first instruction in Program Buffer, and the starting offset of Abstract Data is defined as `hartinfo.DATAADDR`. The offsets could be used as offsets of load/store instructions with the zero register as the base register to access this memory space. The zero register is automatically mapped to the base of the NCEPLDM200 for load/store instructions in Debug Mode.

This system bus address space of NCEPLDM200 is defined through the `DEBUG_VEC` parameter. It should be within a device region for the proper operation of the Debug ROM and the external debugger support. Please see Device Regions for information on how to setup this address space as device regions.

Table 23-2 DMI Memory Map of NCEPLDM200 summarizes the memory map as viewed from the DMI interface. The address[8:2] value in the table follows the address value assignment of the debug module debug bus registers as described in RISC-V External Debug Support (TD003) V0.13.

**Table 23-1 System Memory Map of NCEPLDM200**

| Address Offset  | Description               |
|-----------------|---------------------------|
| 0x0000 – 0x007F | Debug ROM                 |
| 0x0080 – 0x00BF | Program Buffer            |
| 0x00C0 – 0x00CF | Abstract Data 0–3         |
| 0x00D0 – 0x01FF | Reserved for internal use |

**Table 23-2 DMI Memory Map of NCEPLDM200**

| Address     | Description                          |
|-------------|--------------------------------------|
| 0x04 – 0x07 | Abstract Data 0–3                    |
| 0x10        | Debug Module Control                 |
| 0x11        | Debug Module Status                  |
| 0x12        | Hart Info                            |
| 0x13        | Halt Summary                         |
| 0x14        | Hart Array Window Select             |
| 0x15        | Hart Array Window                    |
| 0x16        | Abstract Control and Status          |
| 0x17        | Abstract Command                     |
| 0x18        | Abstract Command Autoexec            |
| 0x19 – 0x1C | Device Tree Addr 0–3                 |
| 0x20 – 0x2F | Program Buffer 0–15                  |
| 0x30        | Authentication Data                  |
| 0x38        | System Bus Access Control and Status |
| 0x39 – 0x3B | System Bus Address                   |
| 0x3C – 0x3F | System Bus Data                      |

### 23.3.1 Abstract Data 0–3 (data0–3)

Basic read/write registers that may be read or changed by abstract commands.

The registers are accessible from both the DMI interface and the system bus interface to support data exchanges between the external debugger and the processor (i.e., instructions in the Program Buffer).

### 23.3.2 Debug Module Control (dmcontrol)

| 31      | 30        | 29 | 28           | 27 | 26    | 25      | 16 | 15       | 2        | 1 | 0 |
|---------|-----------|----|--------------|----|-------|---------|----|----------|----------|---|---|
| haltreq | resumereq | 0  | ackhavereset | 0  | hasel | hartsel | 0  | ndmreset | dmactive |   |   |

| Field Name   | Bits                                             | Description                                                                                                                                                                                                                                                                                                                                                                   | Type  | Reset   |   |                                                  |   |                                      |  |  |
|--------------|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|--------------------------------------------------|---|--------------------------------------|--|--|
| dmactive     | [0]                                              | Controlling reset signal for Debug Module itself.                                                                                                                                                                                                                                                                                                                             | RW    | 0x0     |   |                                                  |   |                                      |  |  |
|              |                                                  | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The Debug Module's state takes its reset values.</td></tr> <tr> <td>1</td><td>The Debug Module functions normally.</td></tr> </tbody> </table>                                                                                                                        | Value | Meaning | 0 | The Debug Module's state takes its reset values. | 1 | The Debug Module functions normally. |  |  |
| Value        | Meaning                                          |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                                                  |   |                                      |  |  |
| 0            | The Debug Module's state takes its reset values. |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                                                  |   |                                      |  |  |
| 1            | The Debug Module functions normally.             |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                                                  |   |                                      |  |  |
| ndmreset     | [1]                                              | Controlling reset signal from the Debug Module to the rest of the system.                                                                                                                                                                                                                                                                                                     | RW    | 0x0     |   |                                                  |   |                                      |  |  |
|              |                                                  | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Deassert system reset signal.</td></tr> <tr> <td>1</td><td>Assert system reset signal.</td></tr> </tbody> </table>                                                                                                                                                    | Value | Meaning | 0 | Deassert system reset signal.                    | 1 | Assert system reset signal.          |  |  |
| Value        | Meaning                                          |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                                                  |   |                                      |  |  |
| 0            | Deassert system reset signal.                    |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                                                  |   |                                      |  |  |
| 1            | Assert system reset signal.                      |                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                                                  |   |                                      |  |  |
| hartsel      | [25:16]                                          | Selecting the target hart to be debugged.                                                                                                                                                                                                                                                                                                                                     | RW    | 0x0     |   |                                                  |   |                                      |  |  |
| hasel        | [26]                                             | How harts are selected. This field is 0x0 for N25(F) indicating that there is only one hart selected through <code>hartsel</code> .                                                                                                                                                                                                                                           | RO    | 0x0     |   |                                                  |   |                                      |  |  |
| ackhavereset | [28]                                             | Writing 1 to this bit clears the havereset bits for any selected harts. Harts are selected based on the new value of <code>hartsel</code> and <code>hasel</code> being written.                                                                                                                                                                                               | RW    | 0x0     |   |                                                  |   |                                      |  |  |
| resumereq    | [30]                                             | Writes the resume request bit for all currently selected harts. When set to 1, each selected hart will resume if it is currently halted. The resume request bit is ignored while the halt request bit is set. Harts are selected based on the new value of <code>hartsel</code> and <code>hasel</code> being written.                                                         | WO    | 0x0     |   |                                                  |   |                                      |  |  |
| haltreq      | [31]                                             | Writes the halt request bit for all currently selected harts. When set to 1, each selected hart will halt if it is not currently halted. Writing 1 or 0 has no effect on a hart which is already halted, but the bit must be cleared to 0 before the hart is resumed. Harts are selected based on the new value of <code>hartsel</code> and <code>hasel</code> being written. | WO    | 0x0     |   |                                                  |   |                                      |  |  |

### 23.3.3 Debug Module Status (dmstatus)

|                |                |               |              |              |              |              |         |
|----------------|----------------|---------------|--------------|--------------|--------------|--------------|---------|
| 9              | 8              | 7             | 6            | 5            | 4            | 3            | 0       |
| allhalted      | anyhalted      | authenticated | authbusy     | 0            | devtreevalid |              | version |
| 15             | 14             | 13            | 12           | 11           | 10           |              |         |
| allnonexistent | anynonexistent | allunavail    | anyunavail   | allrunning   | anyrunning   |              |         |
| 31             | 23             | 22            | 21           | 20           | 19           | 18           | 16      |
| 0              | impebreak      | 0             | allhavereset | anyhavereset | allresumeack | anyresumeack |         |

| Field Name    | Bits                                                                                   | Description                                                                                                                                                                                                                                                                               | Type  | Reset   |   |                                                                                        |   |                                    |  |  |
|---------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|----------------------------------------------------------------------------------------|---|------------------------------------|--|--|
| Version       | [3:0]                                                                                  | Version of the implemented RISC-V External Debug Support. 0x2 indicates that the current implemented version is 0.13.                                                                                                                                                                     | RO    | 0x2     |   |                                                                                        |   |                                    |  |  |
| devtreevalid  | [4]                                                                                    | Whether the information in devtreeaddr0 – devtreeaddr3 registers hold the address of the Device Tree.                                                                                                                                                                                     | RO    | 0x0     |   |                                                                                        |   |                                    |  |  |
| authbusy      | [6]                                                                                    |                                                                                                                                                                                                                                                                                           | RO    | 0x0     |   |                                                                                        |   |                                    |  |  |
|               |                                                                                        | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The authentication module is ready to process the next read/write to <i>authdata</i>.</td></tr> <tr> <td>1</td><td>The authentication module is busy.</td></tr> </tbody> </table> | Value | Meaning | 0 | The authentication module is ready to process the next read/write to <i>authdata</i> . | 1 | The authentication module is busy. |  |  |
| Value         | Meaning                                                                                |                                                                                                                                                                                                                                                                                           |       |         |   |                                                                                        |   |                                    |  |  |
| 0             | The authentication module is ready to process the next read/write to <i>authdata</i> . |                                                                                                                                                                                                                                                                                           |       |         |   |                                                                                        |   |                                    |  |  |
| 1             | The authentication module is busy.                                                     |                                                                                                                                                                                                                                                                                           |       |         |   |                                                                                        |   |                                    |  |  |
| authenticated | [7]                                                                                    |                                                                                                                                                                                                                                                                                           | RO    | 0x1     |   |                                                                                        |   |                                    |  |  |
|               |                                                                                        | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Authentication is required before using the Debug Module.</td></tr> <tr> <td>1</td><td>Authentication check has passed.</td></tr> </tbody> </table>                               | Value | Meaning | 0 | Authentication is required before using the Debug Module.                              | 1 | Authentication check has passed.   |  |  |
| Value         | Meaning                                                                                |                                                                                                                                                                                                                                                                                           |       |         |   |                                                                                        |   |                                    |  |  |
| 0             | Authentication is required before using the Debug Module.                              |                                                                                                                                                                                                                                                                                           |       |         |   |                                                                                        |   |                                    |  |  |
| 1             | Authentication check has passed.                                                       |                                                                                                                                                                                                                                                                                           |       |         |   |                                                                                        |   |                                    |  |  |
| anyhalted     | [8]                                                                                    | Indicating whether any currently selected hart is halted.                                                                                                                                                                                                                                 | RO    | 0x0     |   |                                                                                        |   |                                    |  |  |
| allhalted     | [9]                                                                                    | Indicating whether all currently selected harts are halted.                                                                                                                                                                                                                               | RO    | 0x0     |   |                                                                                        |   |                                    |  |  |
| anyrunning    | [10]                                                                                   | Indicating whether any currently selected hart is running.                                                                                                                                                                                                                                | RO    | 0x0     |   |                                                                                        |   |                                    |  |  |

| Field Name      | Bits | Description                                                                                                               | Type | Reset |
|-----------------|------|---------------------------------------------------------------------------------------------------------------------------|------|-------|
| allrunning      | [11] | Indicating whether all currently selected harts are running.                                                              | RO   | 0x0   |
| anyunavail      | [12] | Indicating whether any currently selected hart is unavailable.                                                            | RO   | 0x0   |
| allunavail      | [13] | Indicating whether all currently selected harts are unavailable.                                                          | RO   | 0x0   |
| any nonexistent | [14] | Indicating whether any currently selected hart does not exist in this system.                                             | RO   | 0x0   |
| all nonexistent | [15] | Indicating whether all currently selected harts do not exist in this system.                                              | RO   | 0x0   |
| anyresumeack    | [16] | Indicating whether any currently selected hart has acknowledged the previous resume request.                              | RO   | 0x0   |
| allresumeack    | [17] | Indicating whether all currently selected harts have acknowledged the previous resume request.                            | RO   | 0x0   |
| anyhavreset     | [18] | Indicating whether any currently selected hart has been reset but the reset has not been acknowledged                     | RO   | 0x0   |
| allhavreset     | [19] | Indicating whether all currently selected harts have been reset but the reset has not been acknowledged                   | RO   | 0x0   |
| impebreak       | [22] | Indicating whether there is an implicit ebreak instruction at the non-existent word immediately after the Program Buffer. | RO   | 0x1   |

### 23.3.4 Hart Info (hartinfo)



| Field Name | Bits                                                                                                               | Description                                                                                                                                                                                                                                                                                                                                              | Type  | Reset   |   |                                                                      |   |                                                                                                                    |  |  |
|------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|----------------------------------------------------------------------|---|--------------------------------------------------------------------------------------------------------------------|--|--|
| dataaddr   | [11:0]                                                                                                             | Signed offset for accessing the shadowed <i>data</i> registers by the processor, to be used as offsets for load/store instructions with the zero register as the base register in Debug Mode.                                                                                                                                                            | RO    | 0xC0    |   |                                                                      |   |                                                                                                                    |  |  |
| datasize   | [15:12]                                                                                                            | Number of 32-bit words in the memory map dedicated to shadowing the data registers.                                                                                                                                                                                                                                                                      | RO    | 0x4     |   |                                                                      |   |                                                                                                                    |  |  |
| dataaccess | [16]                                                                                                               | The method for accessing the shadowed <i>data</i> registers. The value of this field is 0x1 for N25(F), indicating that the <i>data</i> registers are shadowed in the memory map under Debug Mode.                                                                                                                                                       | RO    | 0x1     |   |                                                                      |   |                                                                                                                    |  |  |
|            |                                                                                                                    | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The <i>data</i> registers are shadowed in the hart by CSR registers.</td></tr> <tr> <td>1</td><td>The <i>data</i> registers are shadowed in the hart's memory map. Each register takes up 4 bytes in the memory map.</td></tr> </tbody> </table> | Value | Meaning | 0 | The <i>data</i> registers are shadowed in the hart by CSR registers. | 1 | The <i>data</i> registers are shadowed in the hart's memory map. Each register takes up 4 bytes in the memory map. |  |  |
| Value      | Meaning                                                                                                            |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                      |   |                                                                                                                    |  |  |
| 0          | The <i>data</i> registers are shadowed in the hart by CSR registers.                                               |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                      |   |                                                                                                                    |  |  |
| 1          | The <i>data</i> registers are shadowed in the hart's memory map. Each register takes up 4 bytes in the memory map. |                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                      |   |                                                                                                                    |  |  |
| nscratch   | [23:20]                                                                                                            | Number of dscratch registers available for the debugger to use during program buffer execution, starting from dscratch0.                                                                                                                                                                                                                                 | RO    | 0x2     |   |                                                                      |   |                                                                                                                    |  |  |

### 23.3.5 Halt Summary (haltsum)

|    |   |          |   |
|----|---|----------|---|
| 31 | 0 | 1        | 0 |
|    |   | halt31_0 |   |

Bit 0 contains the logical OR of 32 halt bits for hart 0 – hart 31.

### 23.3.6 Hart Array Window Select (hawindowsel)

This register is hard-wired to zero in NCEPLDM200.

### 23.3.7 Hart Array Window (hawindow)

This register is hard-wired to zero in NCEPLDM200.

### 23.3.8 Abstract Control and Status (abstractcs)

|    |             |       |      |    |        |    |           |     |   |
|----|-------------|-------|------|----|--------|----|-----------|-----|---|
| 31 | 29 28       | 24 23 | 13   | 12 | 11     | 10 | 8 7       | 5 4 | 0 |
| 0  | progbufsize | 0     | busy | 0  | cmderr | 0  | datacount |     |   |

| Field Name   | Bits    | Description                                                                                                                                                                                        | Type  | Reset                                                                                                                                                           |
|--------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| datacount    | [4:0]   | Number of <i>data</i> registers that are implemented.                                                                                                                                              | RO    | 0x4                                                                                                                                                             |
| cmderr       | [10:8]  | Error code indicating that an abstract command fails. The bits in this field remain set until they are cleared by writing 1 to them. No abstract command is started until the value is reset to 0. | R/W1C | 0x0                                                                                                                                                             |
| <b>Value</b> |         |                                                                                                                                                                                                    |       | <b>Meaning</b>                                                                                                                                                  |
|              |         |                                                                                                                                                                                                    |       | 0 None: no error                                                                                                                                                |
|              |         |                                                                                                                                                                                                    |       | 1 Busy: an abstract command was executing while command, abstractcs, abstractauto was written, or when one of the data or progbuf registers was read or written |
|              |         |                                                                                                                                                                                                    |       | 2 Not supported: the requested command is not supported.                                                                                                        |
|              |         |                                                                                                                                                                                                    |       | 3 Exception: an exception occurred while executing the command.                                                                                                 |
|              |         |                                                                                                                                                                                                    |       | 4 Halt/resume: an abstract command couldn't execute because the hart wasn't in the expected state (running/halted).                                             |
| busy         | [12]    | Flag indicating an abstract command is currently being executed.                                                                                                                                   | RO    | 0x0                                                                                                                                                             |
| progbufsize  | [28:24] | Size of the program buffer, in 32-bit words.                                                                                                                                                       | RO    | 0x8                                                                                                                                                             |

### 23.3.9 Abstract Command

| 31           | 24      | 23                                                              | control | 0                         |          |       |       |    |    |   |
|--------------|---------|-----------------------------------------------------------------|---------|---------------------------|----------|-------|-------|----|----|---|
| cmdtype      |         |                                                                 |         |                           |          |       |       |    |    |   |
| Field Name   | Bits    | Description                                                     | Type    | Reset                     |          |       |       |    |    |   |
| control      | [23:0]  | The field is interpreted in a command-specific manner.          | WO      | 0x0                       |          |       |       |    |    |   |
| cmdtype      | [31:24] | Controlling the overall functionality of this abstract command. | WO      | 0x0                       |          |       |       |    |    |   |
| <b>Value</b> |         |                                                                 |         | <b>Meaning</b>            |          |       |       |    |    |   |
|              |         |                                                                 |         | 0 Access Register Command |          |       |       |    |    |   |
|              |         |                                                                 |         | 1 Quick Access            |          |       |       |    |    |   |
| 31           | 24      | 23                                                              | 22      | 20                        | 19       | 18    | 17    | 16 | 15 | 0 |
| cmdtype (0)  | 0       | size                                                            | 0       | postexec                  | transfer | write | regno |    |    |   |

This command gives the debugger access to CPU registers and program buffer.

| Field Name  | Bits                                                                                    | Description                                                                                                                                                                                                                                                                                                                                  | Type  | Reset   |   |                                                                                         |   |                                                                                     |  |  |
|-------------|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-----------------------------------------------------------------------------------------|---|-------------------------------------------------------------------------------------|--|--|
| regno       | [15:0]                                                                                  | Number of the register to access.                                                                                                                                                                                                                                                                                                            | WO    | 0x0     |   |                                                                                         |   |                                                                                     |  |  |
| write       | [16]                                                                                    | The direction of data transfer.                                                                                                                                                                                                                                                                                                              | WO    | 0x0     |   |                                                                                         |   |                                                                                     |  |  |
|             |                                                                                         | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Copy data from the specified register into arg0 portion of the Abstract Data registers.</td></tr> <tr> <td>1</td><td>Copy data from arg0 portion of Abstract Data registers into the specified register.</td></tr> </tbody> </table> | Value | Meaning | 0 | Copy data from the specified register into arg0 portion of the Abstract Data registers. | 1 | Copy data from arg0 portion of Abstract Data registers into the specified register. |  |  |
| Value       | Meaning                                                                                 |                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                                                                         |   |                                                                                     |  |  |
| 0           | Copy data from the specified register into arg0 portion of the Abstract Data registers. |                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                                                                         |   |                                                                                     |  |  |
| 1           | Copy data from arg0 portion of Abstract Data registers into the specified register.     |                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                                                                         |   |                                                                                     |  |  |
| Field Name  | Bits                                                                                    | Description                                                                                                                                                                                                                                                                                                                                  | Type  | Reset   |   |                                                                                         |   |                                                                                     |  |  |
| transfer    | [17]                                                                                    | Indicating whether to perform data transfer.                                                                                                                                                                                                                                                                                                 | WO    | 0x0     |   |                                                                                         |   |                                                                                     |  |  |
|             |                                                                                         | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Don't do the operation specified by write.</td></tr> <tr> <td>1</td><td>Do the operation specified by write.</td></tr> </tbody> </table>                                                                                             | Value | Meaning | 0 | Don't do the operation specified by write.                                              | 1 | Do the operation specified by write.                                                |  |  |
| Value       | Meaning                                                                                 |                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                                                                         |   |                                                                                     |  |  |
| 0           | Don't do the operation specified by write.                                              |                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                                                                         |   |                                                                                     |  |  |
| 1           | Do the operation specified by write.                                                    |                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                                                                         |   |                                                                                     |  |  |
| postexec    | [18]                                                                                    | <p>Indicating whether to execute the program in the Program Buffer.</p> <p>If this field is set, execute the program in the Program Buffer exactly once after performing the transfer, if any.</p>                                                                                                                                           | WO    | 0x0     |   |                                                                                         |   |                                                                                     |  |  |
| size        | [22:20]                                                                                 |                                                                                                                                                                                                                                                                                                                                              | WO    | 0x0     |   |                                                                                         |   |                                                                                     |  |  |
|             |                                                                                         | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>2</td><td>Access the lowest 32 bits of the register</td></tr> <tr> <td>3</td><td>Access the lowest 64 bits of the register.</td></tr> </tbody> </table>                                                                                        | Value | Meaning | 2 | Access the lowest 32 bits of the register                                               | 3 | Access the lowest 64 bits of the register.                                          |  |  |
| Value       | Meaning                                                                                 |                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                                                                         |   |                                                                                     |  |  |
| 2           | Access the lowest 32 bits of the register                                               |                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                                                                         |   |                                                                                     |  |  |
| 3           | Access the lowest 64 bits of the register.                                              |                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                                                                         |   |                                                                                     |  |  |
| 31          | 24 23                                                                                   |                                                                                                                                                                                                                                                                                                                                              | 0     |         |   |                                                                                         |   |                                                                                     |  |  |
| cmdtype (1) |                                                                                         | 0                                                                                                                                                                                                                                                                                                                                            |       |         |   |                                                                                         |   |                                                                                     |  |  |

Perform the following sequence of operations:

- If the hart is halted already, the command sets cmderr to halt/resume and does not continue.
- Halt the hart. If the hart halts for some other reason (e.g., breakpoint), the command sets cmderr to halt/resume and does not continue.
- Execute the Program Buffer. If an exception occurs, cmderr is set to exception and the program buffer execution ends, but the quick access command continues.
- Resume the hart.

### 23.3.10 Abstract Command Autoexec (abstractauto)

| Field Name      | Bits    | Description                                                                                                                                | Type | Reset |
|-----------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| autoexecdata    | [3:0]   | When a bit in this field is 1, read or write accesses to the corresponding data word cause the command in command to be executed again.    | RW   | 0x0   |
| autoexecprogbuf | [23:16] | When a bit in this field is 1, read or write accesses to the corresponding progbuf word cause the command in command to be executed again. | RW   | 0x0   |

### 23.3.11 Device Tree Addr 0-3 (devtreeaddr0-3)

The devicetreeaddr registers are hard-wired to zeros in NCEPLDM200.

### 23.3.12 Program Buffer 0-15 (progbuf0-15)

The progbuf registers provide read/write access to the program buffer. NCEPLDM200 supports programbuffer 0–7 only. Program buffer 8–15 are hard-wired to 32'h00100073 (the EBREAK instruction).

These registers are read/write accessible from both the DMI interface and the system bus, in addition to being a valid region for instruction fetches. They hold small programs written by the external debugger and these small programs will be fetched and executed by the processor upon execution of the abstract commands which require execution of the program buffer.

Programs in progbuf must end with EBREAK or C.EBREAK instructions if the program size is less than 8 words (32 bytes).

### 23.3.13 Authentication Data (authdata)

The authdata register is hard-wired to zeros in NCEPLDM200.

### 23.3.14 System Bus Access Control and Status (sbcs)

The sbcs register is hard-wired to zeros in NCEPLDM200.

### 23.3.15 System Bus Address (sbaddress0-2)

The sbaddress registers are hard-wired to zeros in NCEPLDM200.

### 23.3.16 System Bus Data (sbdata0-3)

The sbdata registers are hard-wired to zeros in NCEPLDM200.

## 23.4 Interface Signals

The interface ports of the NCEPLDM200 are described in this section.

All signals are Active-High unless otherwise indicated.

The interface ports consist of four groups of interfaces: a DMI interface, a bus slave interface, a system bus master interface and the rest of signals (the General Signals interface).

The DMI interface is a dedicated bus interface for communicating with debug transport modules (NCEJDTM200).

The bus slave interface is the bus interface for the target processor and the Debug Module to exchange data.

The system bus master interface is an optional interface for supporting the direct System Bus Access feature of the RISC-V External Debug Specification. This feature is not enabled by default and it can be turned on through the SYSTEM\_BUS\_ACCESS\_SUPPORT parameter of NCEPLDM200. The interface signals, however, are always present on the module port list regardless of configuration. They should be left floating and ignored when not enabled.

NCEPLDM200 offers two type of bus interfaces for the bus slave interface and the system bus interface: AHB interface and AXI interface. The interfaces are selected by the RV\_BUS\_TYPE and SYS\_BUS\_TYPE parameters. The interface signals to both interfaces are simultaneously present on its module port list and only the selected one will be used. The other group of signals will be unused and left floating. The values of RV\_BUS\_TYPE and SYS\_BUS\_TYPE parameters should match that of the BIU\_BUS type of N25(F). Note that the bus protocol of the DMI interface is not configurable and unconditionally the AHB interface.

The rest of signals include the clock and reset signals, processor status and debug-interrupt signals. NCEPLDM200 support multi-hart (multi-target) debugging. The number of hart supported is controlled by its NHART parameter, and the width of all hart specific signals are NHART-wide, one bit per hart.

The tables below describes the interface signals of NCEPLDM200 and the clock to NCEPLDM200 should be synchronous to that of N25(F). Note that the slave bus interface signals and the system bus master signals are listed in the same tables, grouped according to their bus interface types.

Please see also Integration Requirements for integration requirements of NCEPLDM200.

**Table 23-3 General Signals of NCEPLDM200**

| Signal Name                 | Direction | Description                                                                                                                                                                                                      |
|-----------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| clk                         | input     | Clock input. This clock should also drive the DMI interface of NCEJDTM200. Furthermore, this clock should not be stopped during <code>ndmreset</code> . See Section 21.2 for integration requirements.           |
| reset_n                     | input     | Reset (Active-Low). The reset signal should be driven by NCEJDTM200. It should not be active when <code>ndmreset</code> is asserted. See Section 21.2 for integration requirements.                              |
| hart_halted[NHART-1:0]      | input     | Hart halted, one bit per hart. Each bit will be 1 if the corresponding hart is halted (in the debug mode).                                                                                                       |
| hart_unavail[NHART-1:0]     | input     | Hart unavailable, one bit per hart. Each bit will be 1 if the corresponding hart is not available for accesses by the external debugger. The hart could be in the reset or some kind of power-gating state.      |
| hart_under_reset[NHART-1:0] | input     | Hart under reset, one bit per hart. Each bit will be 1 if the corresponding hart is under reset.                                                                                                                 |
| debug_int[NHART-1:0]        | output    | Debug interrupt, one bit per hart. Each bit will be 1 if the external debugger makes a debug request to the corresponding hart. Each hart should respond to the request by entering the debug mode.              |
| dmactive                    | output    | Debug module active. This signal reflects the value of <code>dmcontrol.DMACTIVE</code> .                                                                                                                         |
| ndmreset                    | output    | Non-debug module reset. This signal should be routed to the platform reset controller, so that the external debugger could trigger system reset for the platform. See Section 21.2 for integration requirements. |

**Table 23-4 DMI Interface Signals of NCEPLDM200**

|                  |        |                                 |
|------------------|--------|---------------------------------|
| dmi_hrdma[31:0]  | output | DMI read data bus               |
| dmi_hreadyout    | output | DMI transfer done of NCEPLDM200 |
| dmi_hresp[1:0]   | output | DMI transfer response           |
| dmi_hsel         | input  | DMI selection                   |
| dmi_htrans[1:0]  | input  | DMI transfer type               |
| dmi_haddr[9:0]   | input  | DMI address bus                 |
| dmi_hburst[2:0]  | input  | DMI burst type                  |
| dmi_hprot[3:0]   | input  | DMI protection control          |
| dmi_hsize[2:0]   | input  | DMI transfer size               |
| dmi_hready       | input  | DMI transfer done               |
| dmi_hwwrite      | input  | DMI transfer direction          |
| dmi_hwdata[31:0] | input  | DMI write data bus              |

**Table 23-5 AHB Interface Signals of NCEPLDM200**

| <b>Signal Name</b>            | <b>Direction</b> | <b>Description</b>                    |
|-------------------------------|------------------|---------------------------------------|
| rv_hrdra[BIU_DATA_WIDTH-1:0]  | output           | Processor read data bus               |
| rv_hreadyout                  | output           | Processor transfer done of NCEPLDM200 |
| rv_hresp[1:0]                 | output           | Processor transfer response           |
| rv_haddr[31:0]                | input            | Processor address bus                 |
| rv_hburst[2:0]                | input            | Processor burst type                  |
| rv_hprot[3:0]                 | input            | Processor protection control          |
| rv_hsize[2:0]                 | input            | Processor transfer size               |
| rv_htrans[1:0]                | input            | Processor transfer type               |
| rv_hwdata[BIU_DATA_WIDTH-1:0] | input            | Processor write data bus              |
| rv_hwrite                     | input            | Processor transfer direction          |
| rv_hsel                       | input            | Processor selection                   |
| rv_hready                     | input            | Processor transfer done               |
| sys_hrdra[BIU_DATA_WIDTH-1:0] | input            | System bus read data bus              |
| sys_hready                    | input            | System bus transfer done              |
| sys_hgrant                    | input            | System bus bus grant                  |
| sys_hresp[1:0]                | input            | System bus transfer response          |
| sys_haddr[31:0]               | output           | System bus address bus                |
| sys_hburst[2:0]               | output           | System bus burst type                 |
| sys_hprot[3:0]                | output           | System bus protection control         |

  

| <b>Signal Name</b> | <b>Direction</b> | <b>Description</b>     |
|--------------------|------------------|------------------------|
| sys_hbusreq        | output           | System bus bus request |

**Table 23-6 AXI Interface Signals of NCEPLDM200**

| Signal Name                  | Direction | Description                     |
|------------------------------|-----------|---------------------------------|
| rv_awid[3:0]                 | input     | Processor write address ID      |
| rv_awaddr[31:0]              | input     | Processor write address         |
| rv_awlen[7:0]                | input     | Processor write burst length    |
| rv_awsize[2:0]               | input     | Processor write burst size      |
| rv_awburst[1:0]              | input     | Processor write burst type      |
| rv_awlock                    | input     | Processor write lock type       |
| rv_awcache[3:0]              | input     | Processor write cache type      |
| rv_awport[2:0]               | input     | Processor write protection type |
| rv_awvalid                   | input     | Processor write address valid   |
| rv_awready                   | output    | Processor write address ready   |
| rv_wdata[BIU_DATA_WIDTH-1:0] | input     | Processor write data            |
| rv_wstrb[3:0]                | input     | Processor write strobes         |
| rv_wlast                     | input     | Processor write last            |
| rv_wvalid                    | input     | Processor write valid           |
| rv_wready                    | output    | Processor write ready           |
| rv_bid[3:0]                  | output    | Processor write response ID     |
| rv_bresp[1:0]                | output    | Processor write response        |
| rv_bvalid                    | output    | Processor write response valid  |
| rv_bready                    | input     | Processor write response ready  |
| rv_arid[3:0]                 | input     | Processor read address ID       |
| rv_araddr[31:0]              | input     | Processor read address          |
| rv_arlen[7:0]                | input     | Processor read burst length     |
| rv_arsize[2:0]               | input     | Processor read burst size       |
| rv_arburst[1:0]              | input     | Processor read burst type       |
| rv_arlock                    | input     | Processor read lock type        |
| rv_arcache[3:0]              | input     | Processor read cache type       |
| rv_arprot[2:0]               | input     | Processor read protection type  |
| rv_arvalid                   | input     | Processor read address valid    |
| rv_arready                   | output    | Processor read address ready    |

| Signal Name                   | Direction | Description                      |
|-------------------------------|-----------|----------------------------------|
| rv_rid[3:0]                   | output    | Processor read ID tag            |
| rv_rdata[BIU_DATA_WIDTH-1:0]  | output    | Processor read data              |
| rv_rresp[1:0]                 | output    | Processor read response          |
| rv_rlast                      | output    | Processor read last              |
| rv_rvalid                     | output    | Processor read valid             |
| rv_rready                     | input     | Processor read ready             |
| sys_awid[3:0]                 | output    | System bus write address ID      |
| sys_awaddr[31:0]              | output    | System bus write address         |
| sys_awlen[7:0]                | output    | System bus write burst length    |
| sys_awsize[2:0]               | output    | System bus write burst size      |
| sys_awburst[1:0]              | output    | System bus write burst type      |
| sys_awlock                    | output    | System bus write lock type       |
| sys_awcache[3:0]              | output    | System bus write cache type      |
| sys_awprot[2:0]               | output    | System bus write protection type |
| sys_awvalid                   | output    | System bus write address valid   |
| sys_awready                   | input     | System bus write address ready   |
| sys_wdata[BIU_DATA_WIDTH-1:0] | output    | System bus write data            |
| sys_wstrb[3:0]                | output    | System bus write strobes         |
| sys_wlast                     | output    | System bus write last            |
| sys_wvalid                    | output    | System bus write valid           |
| sys_wready                    | input     | System bus write ready           |
| sys_bid[3:0]                  | input     | System bus write response ID     |
| sys_bresp[1:0]                | input     | System bus write response        |
| sys_bvalid                    | input     | System bus write response valid  |
| sys_bready                    | output    | System bus write response ready  |
| sys_arid[3:0]                 | output    | System bus read address ID       |
| sys_araddr[31:0]              | output    | System bus read address          |
| sys_arlen[7:0]                | output    | System bus read burst length     |
| sys_arsize[2:0]               | output    | System bus read burst size       |
| sys_arburst[1:0]              | output    | System bus read burst type       |
| sys_arlock                    | output    | System bus read lock type        |
| sys_arcache[3:0]              | output    | System bus read cache type       |
| sys_arprot[2:0]               | output    | System bus read protection type  |

| Signal Name                   | Direction | Description                   |
|-------------------------------|-----------|-------------------------------|
| sys_arvalid                   | output    | System bus read address valid |
| sys_arready                   | input     | System bus read address ready |
| sys_rid[3:0]                  | input     | System bus read ID tag        |
| sys_rdata[BIU_DATA_WIDTH-1:0] | input     | System bus read data          |
| sys_rresp[1:0]                | input     | System bus read response      |
| sys_rlast                     | input     | System bus read last          |
| sys_rvalid                    | input     | System bus read valid         |
| sys_rready                    | output    | System bus read ready         |

## 23.5 NCEJDTM200

NCEJDTM200 implements JTAG debug transport module (DTM), as defined by the spec: RISC-V

External Debug Support (TD003) V0.13. It implements a IEEE 1149.1 style test access port controller

(TAP). The supported commands are summarized in Table 23-7 TAP Instruction NCEJDTM200.

Table 23-7 TAP Instruction NCEJDTM200

| Encoding | Instruction |
|----------|-------------|
| b11111   | BYPASS      |
| b00001   | IDCODE      |
| b10000   | dtmcs       |
| b10001   | dmi         |

### 23.5.1 BYPASS

When TAP instruction is BYPASS, a single-bit register is connected to tdi and tdo. In Capture-DR state, the register is loaded by 0. In Shift-DR state, data is transferred from tdi to tdo through the single-bit register.

### 23.5.2 IDCODE

This register contains device identification code: 0x1000563D.

| 31      | 28 | 27         | 12 | 11      | 1 | 0 |
|---------|----|------------|----|---------|---|---|
| Version |    | PartNumber |    | ManufId |   | 1 |

| Field Name | Bits    | Description                                         | Type | Reset  |
|------------|---------|-----------------------------------------------------|------|--------|
| ManufId    | [11:1]  | Identifies the designer/manufacturer of this part.  | RO   | 0x31E  |
| PartNumber | [27:12] | Identifies the designer's part number of this part. | RO   | 0x0005 |
| Version    | [31:28] | Identifies the release version of this part.        | RO   | 0x1    |

### 23.5.3 DTM Control and Status (dtmcs)

| 31 | 18           | 17 | 16       | 15 | 14   | 12 | 11      | 10 | 9     | 4 | 3       | 0 |
|----|--------------|----|----------|----|------|----|---------|----|-------|---|---------|---|
| 0  | dmihardreset |    | dmireset | 0  | idle |    | dmistat |    | abits |   | Version |   |

| Field Name   | Bits                                                                                      | Description                                                                                                                                                                                                                                                                                                                                                                      | Type  | Reset   |   |          |   |          |   |                                           |   |                                                                                           |  |  |
|--------------|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|----------|---|----------|---|-------------------------------------------|---|-------------------------------------------------------------------------------------------|--|--|
| Version      | [3:0]                                                                                     | Version of the implemented DTM. 0x1 indicates that the current implementation conforms to <i>RISC-V External Debug Support (TD003) V0.13.</i>                                                                                                                                                                                                                                    | RO    | 0x1     |   |          |   |          |   |                                           |   |                                                                                           |  |  |
| abits        | [9:4]                                                                                     | Bit width of DMI address is 7                                                                                                                                                                                                                                                                                                                                                    | RO    | 0x7     |   |          |   |          |   |                                           |   |                                                                                           |  |  |
| dmistat      | [11:10]                                                                                   | State of DMI                                                                                                                                                                                                                                                                                                                                                                     | RO    | 0x0     |   |          |   |          |   |                                           |   |                                                                                           |  |  |
|              |                                                                                           | <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>No error</td></tr> <tr> <td>1</td><td>Reserved</td></tr> <tr> <td>2</td><td>An operation failed (resulted in op of 2)</td></tr> <tr> <td>3</td><td>An operation was attempted while a DMI access was still in progress (resulted in op of 3)</td></tr> </tbody> </table> | Value | Meaning | 0 | No error | 1 | Reserved | 2 | An operation failed (resulted in op of 2) | 3 | An operation was attempted while a DMI access was still in progress (resulted in op of 3) |  |  |
| Value        | Meaning                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |          |   |          |   |                                           |   |                                                                                           |  |  |
| 0            | No error                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |          |   |          |   |                                           |   |                                                                                           |  |  |
| 1            | Reserved                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |          |   |          |   |                                           |   |                                                                                           |  |  |
| 2            | An operation failed (resulted in op of 2)                                                 |                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |          |   |          |   |                                           |   |                                                                                           |  |  |
| 3            | An operation was attempted while a DMI access was still in progress (resulted in op of 3) |                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |          |   |          |   |                                           |   |                                                                                           |  |  |
| idle         | [14:12]                                                                                   | This is a hint to the debugger of the minimum number of cycles a debugger should spend in RunTest/Idle after every DMI scan to avoid a <i>busy</i> return code (dmistat of 3).                                                                                                                                                                                                   | RO    | 0x7     |   |          |   |          |   |                                           |   |                                                                                           |  |  |
| dmireset     | [16]                                                                                      | Writing 1 to this bit clears the sticky error state and allows the DTM to retry or complete the previous transaction.                                                                                                                                                                                                                                                            | W1    | 0       |   |          |   |          |   |                                           |   |                                                                                           |  |  |
| dmihardreset | [17]                                                                                      | Writing 1 to this bit does a hard reset of the DTM, causing the DTM to forget about any outstanding DMI transactions. In general, this should only be used when the Debugger has reason to expect that the outstanding DMI transaction will never complete (e.g., a reset condition causes an inflight DMI transaction to be canceled).                                          | W1    | 0       |   |          |   |          |   |                                           |   |                                                                                           |  |  |

### 23.5.4 Debug Module Interface Access (dmi)

This register allows accesses to the Debug Module Interface (DMI).



| Field Name | Bits                                                                                                                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Type  | Reset   |   |                                |   |                           |   |                                |   |          |       |         |   |                                                |   |          |   |                              |   |                                                                                                                                |    |   |
|------------|--------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|--------------------------------|---|---------------------------|---|--------------------------------|---|----------|-------|---------|---|------------------------------------------------|---|----------|---|------------------------------|---|--------------------------------------------------------------------------------------------------------------------------------|----|---|
| op         | [1:0]                                                                                                                          | Write operation:<br><br><table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Ignore data and address. (nop)</td></tr> <tr> <td>1</td><td>Read from address. (read)</td></tr> <tr> <td>2</td><td>Write data to address. (write)</td></tr> <tr> <td>3</td><td>Reserved</td></tr> </tbody> </table><br>Read operation:<br><br><table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The previous operation completed successfully.</td></tr> <tr> <td>1</td><td>Reserved</td></tr> <tr> <td>2</td><td>A previous operation failed.</td></tr> <tr> <td>3</td><td>An operation was attempted while a DMI request is still in progress. The data scanned into dmi in this access will be ignored.</td></tr> </tbody> </table> | Value | Meaning | 0 | Ignore data and address. (nop) | 1 | Read from address. (read) | 2 | Write data to address. (write) | 3 | Reserved | Value | Meaning | 0 | The previous operation completed successfully. | 1 | Reserved | 2 | A previous operation failed. | 3 | An operation was attempted while a DMI request is still in progress. The data scanned into dmi in this access will be ignored. | RW | 2 |
| Value      | Meaning                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                |   |                           |   |                                |   |          |       |         |   |                                                |   |          |   |                              |   |                                                                                                                                |    |   |
| 0          | Ignore data and address. (nop)                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                |   |                           |   |                                |   |          |       |         |   |                                                |   |          |   |                              |   |                                                                                                                                |    |   |
| 1          | Read from address. (read)                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                |   |                           |   |                                |   |          |       |         |   |                                                |   |          |   |                              |   |                                                                                                                                |    |   |
| 2          | Write data to address. (write)                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                |   |                           |   |                                |   |          |       |         |   |                                                |   |          |   |                              |   |                                                                                                                                |    |   |
| 3          | Reserved                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                |   |                           |   |                                |   |          |       |         |   |                                                |   |          |   |                              |   |                                                                                                                                |    |   |
| Value      | Meaning                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                |   |                           |   |                                |   |          |       |         |   |                                                |   |          |   |                              |   |                                                                                                                                |    |   |
| 0          | The previous operation completed successfully.                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                |   |                           |   |                                |   |          |       |         |   |                                                |   |          |   |                              |   |                                                                                                                                |    |   |
| 1          | Reserved                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                |   |                           |   |                                |   |          |       |         |   |                                                |   |          |   |                              |   |                                                                                                                                |    |   |
| 2          | A previous operation failed.                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                |   |                           |   |                                |   |          |       |         |   |                                                |   |          |   |                              |   |                                                                                                                                |    |   |
| 3          | An operation was attempted while a DMI request is still in progress. The data scanned into dmi in this access will be ignored. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                |   |                           |   |                                |   |          |       |         |   |                                                |   |          |   |                              |   |                                                                                                                                |    |   |
| data       | [33:2]                                                                                                                         | The data to send to the DM over the DMI during Update-DR, and the data returned from the DM as a result of the previous operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RW    | 0       |   |                                |   |                           |   |                                |   |          |       |         |   |                                                |   |          |   |                              |   |                                                                                                                                |    |   |
| addr       | [40:34]                                                                                                                        | Address used for DMI access. In Update-DR this value is used to access the DM over the DMI.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RW    | 0       |   |                                |   |                           |   |                                |   |          |       |         |   |                                                |   |          |   |                              |   |                                                                                                                                |    |   |

# 24 ATCWDT200

## 24.1 Introduction

The ATCWDT200 watchdog timer prevents a system from lock-up when the program execution goes astray.

### 24.1.1 Features

- Supports AMBA 2.0 APB bus
- Provides combinations of interrupt and reset when the watchdog timer expires
- Provides a write protection mechanism for the Control/Restart Registers
- Programmable source of timer clock
- Configurable magic numbers for write protection of registers and restart of the timer
- Watchdog timer could be externally paused

### 24.1.2 Block Diagram

Figure 24-1 ATCWDT200 Block Diagram shows the block diagram of the ATCWDT200 watchdog timer.

Figure 24-1 ATCWDT200 Block Diagram



### 24.1.3 Function Description

The ATCWDT200 watchdog timer provides a two-stage mechanism to prevent a system from lock-up. The first stage is called “interrupt stage”. If the watchdog interrupt is enabled and the watchdog timer is not restarted during the interrupt stage, the interrupt signal, *wdt\_int*, will be asserted. The second stage, reset stage, begins right after the interrupt stage. If the watchdog reset is enabled and the watchdog timer is not restarted during the reset stage, the reset signal, *wdt\_RST*, will be asserted.

Figure 24-2 Stages of the Watchdog Timer



## 24.2 Signal Description

The input/output (I/O) signals of the ATCWDT200 watchdog timer are shown in Table 24-1 Signal Description of ATCWDT200.

**Table 24-1 Signal Description of ATCWDT200**

| Name                    | I/O Type | Description                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>System signals</b>   |          |                                                                                                                                                                                                                                                                                                                                                                              |
| extclk                  | I        | External clock for the timer clock<br><br>The watchdog timer is a single clock domain design clocked by PCLK and the EXTCLK signal does not drive any sequential logics. Instead, the signal is used as a data signal whose rising edge increases the counter of the watchdog timer. As a result, the frequency of EXTCLK must be at least 3 times slower than that of PCLK. |
| wdt_RST                 | O        | Watchdog system reset<br><br>Active high                                                                                                                                                                                                                                                                                                                                     |
| wdt_INT                 | O        | Watchdog interrupt<br><br>Active high                                                                                                                                                                                                                                                                                                                                        |
| wdt_PAUSE               | I        | Watchdog pause<br><br>This signal causes the watchdog timer to pause and delays the triggering of the watchdog interrupt.                                                                                                                                                                                                                                                    |
| <b>AMBA APB signals</b> |          |                                                                                                                                                                                                                                                                                                                                                                              |
| pclk                    | I        | AMBA APB clock                                                                                                                                                                                                                                                                                                                                                               |
| presetn                 | I        | AMBA APB reset signal; active low                                                                                                                                                                                                                                                                                                                                            |
| psel                    | I        | APB Slave select signal from the APB decoder                                                                                                                                                                                                                                                                                                                                 |
| penable                 | I        | AMBA APB enable signal                                                                                                                                                                                                                                                                                                                                                       |
| pwrite                  | I        | AMBA APB transfer direction signal<br><br>This signal indicates a write access when driven as HIGH and a read access when driven as LOW                                                                                                                                                                                                                                      |
| paddr[4:2]              | I        | AMBA APB address bus                                                                                                                                                                                                                                                                                                                                                         |
| prdata[31:0]            | O        | AMBA APB read data bus                                                                                                                                                                                                                                                                                                                                                       |
| pwdata[31:0]            | I        | AMBA APB write data bus                                                                                                                                                                                                                                                                                                                                                      |

## 24.3 Programming Model

The following sections describe ATCWDT200 registers in detail.

### 24.3.1 Summary of Registers

Table 24-2 Summary of registers shows the summary of ATCWDT200 programming registers.

**Table 24-2 Summary of registers**

| Offset     | Name    | Description              |
|------------|---------|--------------------------|
| +0x00      | IdRev   | ID and Revision Register |
| +0x04~ 0xC | -       | Reserved                 |
| +0x10      | Ctrl    | Control Register         |
| +0x14      | Restart | Restart Register         |
| +0x18      | WrEn    | Write Enable Register    |
| +0x1C      | St      | Status Register.         |

### 24.3.2 Register Description

The following sections describe ATCWDT200 registers in detail. The abbreviations for the Type column are summarized below.

RO: read only

WO: write only

R/W1C: readable and write 1 to clear

WP: write protected

R/WP: readable and write protected

DC: don't care

### 24.3.3 ID and Revision Register (0x00)

This register holds the ID number and the revision number. The reset values of the two revision fields are revision dependent.

**Table 24-3 ID and Revision Register**

| Name     | Bit   | Type | Description             | Reset                 |
|----------|-------|------|-------------------------|-----------------------|
| ID       | 31:12 | RO   | ID number for ATCWDT200 | 0x03002               |
| RevMajor | 11:4  | RO   | Major revision number   | Revision<br>dependent |
| RevMinor | 3:0   | RO   | Minor revision number   | Revision<br>dependent |

### 24.3.4 Control Register (0x10)

The Control Register is write-protected to protect against accidental overwrites. The Write Enable Register (Section 0) must be written before writing this register.

**Table 24-4 Control Register**

| Name    | Bit   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset |
|---------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| -       | 31:11 | -    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | -     |
| RstTime | 10:8  | R/WP | The time interval of the reset stage:<br>0: Clock period × 2 <sup>7</sup><br>1: Clock period × 2 <sup>8</sup><br>2: Clock period × 2 <sup>9</sup><br>3: Clock period × 2 <sup>10</sup><br>4: Clock period × 2 <sup>11</sup><br>5: Clock period × 2 <sup>12</sup><br>6: Clock period × 2 <sup>13</sup><br>7: Clock period × 2 <sup>14</sup>                                                                                                                                                                        | oxo   |
| IntTime | 7:4   | R/WP | The timer interval of the interrupt stage:<br>0: Clock period × 2 <sup>6</sup><br>1: Clock period × 2 <sup>8</sup><br>2: Clock period × 2 <sup>10</sup><br>3: Clock period × 2 <sup>11</sup><br>4: Clock period × 2 <sup>12</sup><br>5: Clock period × 2 <sup>13</sup><br>6: Clock period × 2 <sup>14</sup><br>7: Clock period × 2 <sup>15</sup><br><br>The following options are only valid when<br>`ATCWDT200_32BIT_TIMER is defined:<br>8: Clock period × 2 <sup>17</sup><br>9: Clock period × 2 <sup>19</sup> | oxo   |



| Name   | Bit | Type | Description                                                                                                                                                                                                          | Reset |
|--------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|        |     |      | 10: Clock period $\times 2^{21}$<br>11: Clock period $\times 2^{23}$<br>12: Clock period $\times 2^{25}$<br>13: Clock period $\times 2^{27}$<br>14: Clock period $\times 2^{29}$<br>15: Clock period $\times 2^{31}$ |       |
| RstEn  | 3   | R/WP | Enable or disable the watchdog reset<br>0: Disable<br>1: Enable                                                                                                                                                      | oxo   |
| IntEn  | 2   | R/WP | Enable or disable the watchdog interrupt<br>0: Disable<br>1: Enable                                                                                                                                                  | oxo   |
| ClkSel | 1   | R/WP | Clock source of timer:<br>0: EXTCLK<br>1: PCLK                                                                                                                                                                       | oxo   |
| En     | 0   | R/WP | Enable or disable the watchdog timer<br>0: Disable<br>1: Enable                                                                                                                                                      | oxo   |

### 24.3.5 Restart Register (0x14)

The Restart Register is write-protected to protect against accidental overwrites. The Write

Enable Register (Section 0) must be written before writing this register.

When the Restart Register is written with the preconfigured value

ATCWDT200\_RESTART\_NUM, it restarts the interrupt timer and cancels the system reset timer. When the value is not

ATCWDT200\_RESTART\_NUM, the controller just ignores the write.

Table 24-5 Restart Register

| Name    | Bit   | Type | Description                                                                       | Reset |
|---------|-------|------|-----------------------------------------------------------------------------------|-------|
| -       | 31:16 | -    | Reserved                                                                          | -     |
| Restart | 15:0  | WP   | Write the magic number<br>ATCWDT200_RESTART_NUM to restart the<br>watchdog timer. | DC    |

### 24.3.6 Write Enable Register (0x18)

The Control Register and Restart Register should be programmed through a two-step write scheme. The Write Enable Register should be programmed with a magic number (ATCWDT200\_WP\_NUM) to disable the write protection before either of the two registers could be updated.

The register write-protection is enabled again upon the subsequent write to any of the watchdog registers is received.

**Table 24-6 Write Enable Register**

| Name | Bit   | Type | Description                                                                                                                        | Reset |
|------|-------|------|------------------------------------------------------------------------------------------------------------------------------------|-------|
| -    | 31:16 | -    | Reserved                                                                                                                           | -     |
| WEn  | 15:0  | WO   | Write the magic number<br>ATCWDT200_WP_NUM to disable the write<br>protection of the Control Register and the<br>Restart Register. | DC    |

### 24.3.7 Status Register (0x1C)

**Table 24-7 Status Register (0x1C)**

| Name       | Bit  | Type  | Description                                                                                      | Reset |
|------------|------|-------|--------------------------------------------------------------------------------------------------|-------|
| -          | 31:1 | -     | Reserved                                                                                         | -     |
| IntExpired | 0    | R/WiC | The status of the watchdog interrupt timer<br>0: timer is not expired yet<br>1: timer is expired | 0x0   |

## 24.4 Hardware Configuration Options

### 24.4.1 Magic Number for Write Protection

ATCWDT200\_WP\_NUM should be a 16-bit number. The value is the magic number for disabling the write protection. The following example defines the magic number to 0x5aa5:

```
define ATCWDT200_WP_NUM 16'h5aa5
```

### 24.4.2 Magic Number for Restarting the Watchdog Timer

ATCWDT200\_RESTART\_NUM should be a 16-bit number. The value is the magic number for restarting the watchdog timer. The following example defines the magic number to 0xcafe:

```
`define ATCWDT200_RESTART_NUM 16'hcae
```

### 24.4.3 Duration of Watchdog Interrupt Timer Interval

The default watchdog interrupt timer is a 16-bit counter. The maximum watchdog timer duration would therefore be 215 cycles of either PCLK or EXTCLK periods. Given a 1MHz clock, that will be 32.768ms. It is expected that the use of a slower EXTCLK (e.g., from a 32768Hz Oscillator) may achieve longer intervals (one second). If the available frequency of PCLK/EXTCLK is too high or the desired interval duration needs to be much longer, 32-bit counter may be needed by defining the ATCWDT200\_32BIT\_TIMER macro:

```
`define ATCWDT200_32BIT_TIMER
```

## 24.5 Programming Sequence

### 24.5.1 Setup and Enable the Watchdog Timer:

1. Write the magic number ATCWDT200\_WP\_NUM to the Write Enable Register.
2. Write the Control Register: Select the clock source of timer, set the intervals of interrupt and reset, and enable the watchdog interrupt (IntEn=1), the watchdog reset (RstEn=1), and the watchdog time (En=1).

### 24.5.2 Restart the Watchdog Timer

Once the watchdog timer is enabled, it must be restarted by software to avoid the watchdog interrupt/reset. The restart procedure is as follows.

1. Write the magic number ATCWDT200\_WP\_NUM to the Write Enable Register.
2. Write “ATCWDT200\_RESTART\_NUM” to the Restart Register.

### 24.5.3 Disable the Watchdog Timer

1. Write the magic number ATCWDT200\_WP\_NUM to the Write Enable Register.
2. Write the Control Register: Disable the watchdog timer (En=0).

# 25 ATCRTC100

## 25.1 Introduction

### 25.1.1 Description

AndeShape ATCRTC100 is a low-power real-time clock (RTC) which keeps track of current time information and provides periodic and alarm interrupts.

### 25.1.2 Features

- AMBA 2.0 APB interface for register accesses
- Configurable counter size
- Periodic interrupts: half-second, second, minute, hour and day
- Programmable alarm interrupt
- Hardware digital trimming to compensate for inaccuracies of the external clock source

### 25.1.3 Block Diagram

Figure 25-1 ATCRTC100 Block Diagram shows the block diagram of ATCRTC100:

Figure 25-1 ATCRTC100 Block Diagram



## 25.2 Signal Description

Table 25-1 Signal Description of ATCRTC100 describes the input/output (I/O) signals of ATCRTC100.

**Table 25-1 Signal Description of ATCRTC100**

| Name                          | I/O Type | Description                                                                                                                               |
|-------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------|
| <b>APB Bus Interface</b>      |          |                                                                                                                                           |
| pclk                          | I        | AMBA APB clock                                                                                                                            |
| presetn                       | I        | AMBA APB reset signal (Active-Low)                                                                                                        |
| psel                          | I        | AMBA APB slave select signal from the APB decoder                                                                                         |
| penable                       | I        | AMBA APB enable signal                                                                                                                    |
| pwrite                        | I        | AMBA APB transfer direction signal.<br><br>This signal indicates a write access when driven as HIGH and a read access when driven as LOW. |
| paddr[4:2]                    | I        | AMBA APB address bus                                                                                                                      |
| prdata[31:0]                  | O        | AMBA APB read data bus                                                                                                                    |
| pwdata[31:0]                  | I        | AMBA APB write data bus                                                                                                                   |
| <b>RTC Signals</b>            |          |                                                                                                                                           |
| rtc_clk                       | I        | RTC clock source, 32.768 kHz                                                                                                              |
| rtc_rstn                      | I        | RTC reset (Active-Low)                                                                                                                    |
| rtc_int_hsec                  | O        | Half-second interrupt signal                                                                                                              |
| rtc_int_sec                   | O        | Second interrupt signal                                                                                                                   |
| rtc_int_min                   | O        | Minute interrupt signal                                                                                                                   |
| rtc_int_hour                  | O        | Hour interrupt signal                                                                                                                     |
| rtc_int_day                   | O        | Day interrupt signal                                                                                                                      |
| rtc_int_alarm                 | O        | Alarm interrupt signal                                                                                                                    |
| alarm_wakeup                  | O        | Alarm wakeup signal                                                                                                                       |
| <b>Frequency Test Signals</b> |          |                                                                                                                                           |
| freq_test_out                 | O        | 512Hz frequency test output signal                                                                                                        |
| freq_test_en                  | O        | Frequency test output enable signal, to be connected to the output enable port of the output pad for the frequency test pin.              |



## 25.3 Programming Model

### 25.3.1 Summary of Registers

Table 25-2 Summary of Registers

| Offset     | Name  | Description               |
|------------|-------|---------------------------|
| +0x00      | IdRev | ID and Revision Register  |
| +0x04~0x0C | -     | Reserved                  |
| +0x10      | Cntr  | Counter Register          |
| +0x14      | Alarm | Alarm Register            |
| +0x18      | Ctrl  | Control Register          |
| +0x1C      | St    | Status Register           |
| +0x20      | Trim  | Digital Trimming Register |

### 25.3.2 Register Description

The following sections describe ATCRTC100 registers in detail. The abbreviations for the Type column are summarized below.

RO: Read only

WO: Write only

R/W: Readable and writable

W1C: Write 1 to clear

### 25.3.3 ID and Revision Register (0x00)

This register holds the ID number and the revision number. The reset values of the two revision fields are revision dependent.

Table 25-3 ID and Revision Register

| Name  | Bit  | Type | Description             | Reset              |
|-------|------|------|-------------------------|--------------------|
| ID    | 31:8 | RO   | ID number for ATCRTC100 | 0x030110           |
| Major | 7:4  | RO   | Major revision number   | Revision dependent |
| Minor | 3:0  | RO   | Minor revision number   | Revision dependent |

### 25.3.4 Counter Register (0x10)

The Counter Register records the current time.

**Table 25-4 Counter Register**

| Name | Bit       | Type | Description                                                                                            | Reset |
|------|-----------|------|--------------------------------------------------------------------------------------------------------|-------|
| Day  | (N+17):17 | R/W  | Day passed after RTC enabled;<br>N = (ATCRTC100_DAY_BITS - 1), see Section<br>4.1 for more information | 0x0   |
| Hour | 16:12     | R/W  | Hour field of current time; range: 0 ~ 23                                                              | 0x0   |
| Min  | 11:6      | R/W  | Minute field of current time; range: 0 ~ 59                                                            | 0x0   |
| Sec  | 5:0       | R/W  | Second field of current time; range: 0 ~ 59                                                            | 0x0   |

**Note!**

If the counters are set to out-of-range values, their behaviors are undefined.

### 25.3.5 Alarm Register (0x14)

The alarm interrupt and/or the alarm wakeup signal are triggered when the value of Counter Register matches the value of Alarm Register.

Control Register fields “Alarm\_Int” and “Alarm\_Wakeup” control the alarm interrupt and alarm wakeup signal.

**Table 25-5 Alarm Register**

| Name | Bit   | Type | Description                                  | Reset |
|------|-------|------|----------------------------------------------|-------|
| Hour | 16:12 | R/W  | Hour field of alarm setting; range: 0 ~ 23   | 0x0   |
| Min  | 11:6  | R/W  | Minute field of alarm setting; range: 0 ~ 59 | 0x0   |
| Sec  | 5:0   | R/W  | Second field of alarm setting; range: 0 ~ 59 | 0x0   |

### 25.3.6 Control Register (0x18)

The Control Register controls the RTC enable and interrupts.

**Table 25-6 Control Register**

| Name              | Bit | Type | Description                                                                                              | Reset |
|-------------------|-----|------|----------------------------------------------------------------------------------------------------------|-------|
| Freq_Test_En      | 8   | R/W  | Enable the 512 Hz frequency test output                                                                  | 0x0   |
| Hsec <sup>1</sup> | 7   | R/W  | Enable half-second interrupt; half-second interrupt is generated when half a second passed               | 0x0   |
| Sec               | 6   | R/W  | Enable “second” interrupt; “second” interrupt is generated when one second passed                        | 0x0   |
| Min               | 5   | R/W  | Enable minute interrupt; minute interrupt is generated when the seconds of RTC time changes from 59 to 0 | 0x0   |
| Hour              | 4   | R/W  | Enable hour interrupt; hour interrupt is generated when the minutes of RTC time changes from 59 to 0     | 0x0   |
| Day               | 3   | R/W  | Enable day interrupt; day interrupt is generated when the hours of RTC time changes from 23 to 0         | 0x0   |
| Alarm_Int         | 2   | R/W  | Enable alarm interrupt                                                                                   | 0x0   |
| Alarm_Wakeup      | 1   | R/W  | Enable alarm wakeup signal                                                                               | 0x0   |
| RTC_En            | 0   | R/W  | Enable RTC                                                                                               | 0x0   |

**Note !**

1 Exists only if ATCRTC100\_HALF\_SECOND\_SUPPORT is defined.

### 25.3.7 Status Register (0x1C)

The Status Register records the interrupt status and synchronization status of RTC register updates.

**Table 25-7 Interrupt Status Register**

| Name      | Bit  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Reset |
|-----------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| WriteDone | 16   | RO   | <p>This bit indicates the synchronization progress of RTC register updates. This bit becomes zero when any of RTC control registers (the Counter, Alarm and Control registers) are updated. It returns to one when all prior updates to these three registers have been successfully synchronized to the RTC clock domain. While an RTC register update is being synchronized to the RTC clock domain, a second update to the same register may be dropped.</p> <p>Each of the RTC registers is synchronized independently while their synchronization status are lumped into this single bit. Thus writes to different RTC registers can be done in a batch before checking this bit.</p> <p>Since the frequency of the RTC clock is quite slow when compared to the typical frequency of the APB clock, the synchronization period can be pretty long. The APB clock domain should not be shut down while the synchronization is still in progress.</p> | 1     |
| Reserved  | 15:8 | -    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -     |
| Hsec      | 7    | W1C  | Half-second interrupt status, write 1 to clear                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x0   |
| Sec       | 6    | W1C  | Second interrupt status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0   |
| Min       | 5    | W1C  | Minute interrupt status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0   |
| Hour      | 4    | W1C  | Hour interrupt status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0   |
| Day       | 3    | W1C  | Day interrupt status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0   |
| Alarm_Int | 2    | W1C  | Alarm interrupt status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x0   |

### 25.3.8 Digital Trimming Register (0x20)

The Digital Trimming Register holds the trimming values and the respective directions for each RTC time period. This register should be programmed with RTC disabled. Please see Hardware Digital Trimming for usage of this register.

**Table 25-8 Digital Trimming Register**

| Name      | Bit   | Type | Description                                                                                                                 | Reset |
|-----------|-------|------|-----------------------------------------------------------------------------------------------------------------------------|-------|
| Day_Sign  | 31    | R/W  | Sign bit for the trimming value for the second on the day boundary:<br>1: Slow down the timer.<br>0: Speed up the timer.    | ox0   |
| Reserved  | 30:29 | -    | -                                                                                                                           | -     |
| Day_Trim  | 28:24 | R/W  | Digital trimming value for the second on the day boundary.                                                                  | ox0   |
| Hour_Sign | 23    | R/W  | Sign bit for the trimming value for the second on the hour boundary:<br>1: Slow down the timer.<br>0: Speed up the timer.   | ox0   |
| Reserved  | 22:21 | -    | -                                                                                                                           | -     |
| Hour_Trim | 20:16 | R/W  | Digital trimming value for the second on the hour boundary.                                                                 | ox0   |
| Min_Sign  | 15    | R/W  | Sign bit for the trimming value for the second on the minute boundary:<br>1: Slow down the timer.<br>0: Speed up the timer. | ox0   |
| Reserved  | 14:13 | -    | -                                                                                                                           | -     |
| Min_Trim  | 12:8  | R/W  | Digital trimming value for the second on the minute boundary.                                                               | ox0   |
| Sec_Sign  | 7     | R/W  | Sign bit for the trimming value for the rest of seconds:<br>1: Slow down the timer.<br>0: Speed up the timer.               | ox0   |
| Reserved  | 6:5   | -    | -                                                                                                                           | -     |
| Sec_Trim  | 4:0   | R/W  | Digital trimming value for the rest of seconds                                                                              | ox0   |

## 25.4 Hardware Configuration Options

### 25.4.1 Day Counter Bits

Define [ATCRTC100\\_DAY\\_BITS](#) to configure the size of the day counter. The available range is 1–15.

For example, define [ATCRTC100\\_DAY\\_BITS](#) to 5 for counting up to  $2^5 = 32$  days.

```
`define ATCRTC100_DAY_BITS 5
```

## 25.4.2 Half-second Interrupt Support

Define `ATCRTC100_HALF_SECOND_SUPPORT` to support the half-second interrupt.

```
'define ATCRTC100_HALF_SECOND_SUPPORT
```

# 25.5 Programming Sequence

## 25.5.1 Adjust Time and Interrupts on the Hour

1. Wait until the WriteDone field of the Status Register equals 1.
2. Set the Counter Register to the current time; set the Day field to 0 to count from day 0.
3. Enable RTC and hourly interrupt: set the Control Register to 0x11.

## 25.5.2 Trigger an Alarm Interrupt at a Specific Time

1. Wait until the WriteDone field of the Status Register equals 1.
2. Set the Alarm Register to the time when an alarm will be issued.
3. Enable RTC and alarm interrupt: set the Control Register to 0x5.

## 25.5.3 Trigger an Alarm Wakeup Signal at a Specific Time

The behaviors of the alarm wakeup signal and the alarm interrupt are mostly the same except the following differences:

- Alarm interrupt is kept HIGH until writing 1 to the Alarm\_Int field of the Status Register; alarm wakeup signal is a 1/32768 second-wide pulse.
- Alarm interrupt is an APB clock domain signal while the alarm wakeup signal is an RTC domain signal. The alarm interrupt signal will be disabled when the APB clock domain is off but the alarm wakeup signal will not be affected.

The following shows an example to trigger an alarm wakeup signal at a specific time:

1. Wait until the WriteDone field of the Status Register equals 1.
2. Set the Alarm Register to the time you want to wake up the system.
3. Enable RTC and alarm wakeup: set the Control Register to 0x3.

## 25.5.4 Hardware Digital Trimming

ATCRTC100 is primarily driven by the external 32768 Hz clock source, and its pulse generator generates an internal 1Hz pulse for incrementing its time counters. The 1Hz pulse is generated by counting the number of clock cycles of the external clock source. By default, the pulse generator outputs a one-cycle-wide pulse every 32768 clock cycles. Therefore the period of the 1Hz pulse will be one second and the second counter is incremented every second if the external clock source is exactly 32768Hz. However, the resulting period won't be exactly one second if the external clock cycle is inaccurate. The provided digital trimming function compensates these

inaccuracies by increasing or decreasing the period to generate the 1 Hz pulses.

An adjustment value could be specified and adjustments are performed every second. However, the alternate values of adjustments could be specified depending on whether it is the second on the minute, hour or day boundary. Each adjustment value consists of a trimming value and a trimming sign bit in the Digital Trimming Register (0x20).

- Digital trimming value
  - The number of cycles to adjust for generating the 1Hz pulse.
  - Trimming is enabled if this value is not zero.
- Sign bit for the trimming value
  - Indicates the direction of digital trimming.
    - 1: Slow down the clock by enlarging the period of the 1Hz pulse by the trimming value.
    - 0: Speed up the clock by shortening the period of the 1Hz pulse by the trimming value.

The second trimming value (Sec\_Trim) is applied every second if no other trimming values are specified. If any of the minute/hour/day trimming values (Min\_Trim, Hour\_Trim, and Day\_Trim) is set, the specified trimming value is applied on the minute/day/hour boundary instead. The longer period trimming values will take priority on the second of multiple time period boundaries. That is, if both Sec\_Trim and Min\_Trim are set, the 1Hz pulse periods for the first 59 seconds are adjusted using Sec\_Trim, while the Min\_Trim is applied to the last second of one minute. If Hour\_Trim is also set, it will be applied to the last second of the last minute of an hour.

The multitude of trimming values that ATCRTC100 supports allow better calibration of the clock source. The second trimming value may over/under-trim the clock source while the longer period trimming values could compensate it back by adjusting for the accumulated errors in the respective periods.

There are two methods to determine the trimming value. The first one is to measure the frequency of a 512 Hz output signal directly and calculate the deviation from the ideal frequency. The second one is to observe the amount of time gained or lost over a calibrated wall clock time period.

## 25.5.5 Determining Trimming Value by Measuring Frequency

The following procedure shows how to decide the trimming value and sign bit by measuring the 512 Hz test frequency output:

1. Wait until the WriteDone field of the Status Register equals 1.
2. Set the Digital Trimming Register with an all-zero value (default).
3. Program the pin mux of the chip such that the RTC frequency test output is driven to the test pin.
4. Enable RTC and the frequency test output: set the Control Register to 0x81.

5. Measure the output frequency from the frequency test output pin with a calibration tool.
6. Calculate the trimming value from clock frequency deviation per second (see the following equation).
  - Calculate the trimming value from the frequency deviation:  

$$\text{trimming value} = 32768 \times (F_{\text{measured}} - F_{\text{ideal}}) / F_{\text{ideal}}$$

Where:

  - $F_{\text{measured}}$  is the measured frequency of the `freq_test_out` pin.
  - $F_{\text{ideal}} = 512$  Hz.
  - If the above “trimming value” is positive, the measured frequency is faster than the ideal frequency. The trimming sign bit needs to be set.
  - If the above “trimming value” is negative, the measured frequency is slower than the ideal frequency. The trimming sign bit needs to be cleared.
7. Disable RTC: set the Control Register to 0x0.
8. Wait until the WriteDone field of the Status Register equals 1.
9. Set the Sec\_Trim and Sec\_Sign fields of the Digital Trimming Register with the computed trimming value and sign bit.
10. Enable RTC: set the Control Register to 0x1.

### 25.5.6 Determining Trimming Value by Observing Time Deviation

The following procedure shows how to decide the trimming value and the sign bit by observing the deviation over a period of time.

1. Wait until the WriteDone field of the Status Register equals 1.
2. Set the Digital Trimming Register with an all-zero value (default).
3. Enable RTC: set the Control Register to 0x1.
4. Compare the elapsed RTC timer against that of a calibrated wall clock.
5. Calculate the trimming value from time period deviation (see the following equation).
  - Calculate the trimming value from time period deviation observation:

$$\begin{aligned} \text{SEC}_{\text{dev}} &= \text{SEC}_{\text{measured}} - \text{SEC}_{\text{ideal}} \\ \text{PPM}_{\text{dev}} &= (\text{SEC}_{\text{dev}} / \text{SEC}_{\text{ideal}}) \times 10^6 \end{aligned}$$

Where:

- $\text{SEC}_{\text{ideal}}$  is the observed ideal time period in seconds.
- $\text{SEC}_{\text{measured}}$  is the elapsed RTC seconds according to ATCRTC100 during  $\text{SEC}_{\text{ideal}}$ .
- $\text{SEC}_{\text{dev}}$  is the number of seconds gained or lost during  $\text{SEC}_{\text{ideal}}$ .
- If the  $\text{PPM}_{\text{dev}}$  is positive, ATCRTC100 is counting faster than the ideal clock. The trimming sign bit needs to be set.
- If the  $\text{PPM}_{\text{dev}}$  is negative, ATCRTC100 is counting slower than the ideal clock. The trimming sign bit needs to be cleared.
- The trimming value is determined as:

$$\text{trimming value} = PPM_{\text{dev}} \times 32768 / 10^6$$

6. Disable RTC: set the Control Register to 0x0.
7. Wait until the WriteDone field of the Status Register equals 1.
8. Set the Sec\_Trim and Sec\_Sign fields of the Digital Trimming Register with the computed trimming value and sign bit.
9. Enable RTC: set the Control Register to 0x1.
10. Please note that a longer observation period will improve the accuracy of measurement

### 25.5.7 Trimming Capabilities

The following table shows the trimming capability of all trimming values supported by ATCRTC100. The capabilities represent the amount of deviations of the external clock source that could be corrected by the respective trimming value alone, i.e., assuming the rest of trimming values are set to zero.

**Table 25-9 Trimming Capabilities**

| Trimming Value | Capability (PPM)      |
|----------------|-----------------------|
| Second         | +/- 30.5 ~ 946        |
| Minute         | +/- 0.508 ~ 15.77     |
| Hour           | +/- 0.008 ~ 0.262     |
| Day            | +/- 0.000353 ~ 0.0109 |

The capability is computed by dividing the minimum and the maximum trimming value over the number of ideal clock counts within the respective time range. The range of trimming values is 1 to 31, so the capability of the second trimming value is:

$$\text{Capability}_{\text{MAX}}(\text{Sec_Trim}) = \text{Sec_Trim}_{\text{MAX}} / 32768 = 31/32768 = 946 \times 10^{-6}$$

$$\text{Capability}_{\text{MIN}}(\text{Sec_Trim}) = \text{Sec_Trim}_{\text{MIN}} / 32768 = 1/32768 = 30.56 \times 10^{-6}$$

And the capability of the minute trimming value is:

$$\text{Capability}_{\text{MAX}}(\text{Min_Trim}) = \text{Min_Trim}_{\text{MAX}} / (32768 \times 60) = 31 / (32768 \times 60) = 15.77 \times 10^{-6}$$

$$\text{Capability}_{\text{MIN}}(\text{Min_Trim}) = \text{Min_Trim}_{\text{MIN}} / (32768 \times 60) = 1 / (32768 \times 60) = 0.508 \times 10^{-6}$$

Like-wise, the trimming capability for the hour and day trimming values are computed similarly.

# 26 ATCPIT100

## 26.1 Introduction

The ATCPIT100 Programmable Interval Timer (PIT) is a set of compact multi-function timers, which can be used as pulse width modulators (PWM) as well as simple timers.

### 26.1.1 Features

- Supports AMBA 2.0 APB bus
- Supports up to 4 multi-function timers
- Each multi-function timer provides 6 usage scenarios (combinations of timer and PWM)
- Programmable source of timer clock
- Timers can be externally paused

### 26.1.2 Block Diagram

Figure 26-1 ATCPIT100 Block Diagram shows the block diagram of ATCPIT100.

**Figure 26-1 ATCPIT100 Block Diagram**

### 26.1.3 Function Description

ATCPIT100 supports up to 4 PIT channels. Each PIT channel is a multi-function timer and provides the following 6 usage scenarios:

- one 32-bit timer
- two 16-bit timers
- four 8-bit timers
- one 16-bit PWM
- one 16-bit timer and one 8-bit PWM
- two 8-bit timers and one 8-bit PWM

An n-bit timer means the timer contains an n-bit counter to generate periodic interrupts. An n-bit PWM means the PWM contains two n-bit counters to generate periodic square waves with programmable duty cycles. The more bits a counter contains, the larger period it can support.

Table 26-1 Effective Devices of Channel Modes shows the effective devices of the corresponding channel modes.

**Table 26-1 Effective Devices of Channel Modes**

| Channel Mode   | 32-bit Timer   | 16-bit Timers | 8-bit Timers | PWM        | Mixed Timer    | Mixed PWM/Timers |
|----------------|----------------|---------------|--------------|------------|----------------|------------------|
| 32-bit Timer 0 | 16-bit Timer 0 | 8-bit Timer 0 |              |            | 16-bit Timer 0 | 8-bit Timer 0    |
|                | 16-bit Timer 1 | 8-bit Timer 1 |              |            |                | 8-bit Timer 1    |
|                |                | 8-bit Timer 2 |              |            |                |                  |
|                |                | 8-bit Timer 3 |              |            |                |                  |
|                |                |               |              | 16-bit PWM | 8-bit PWM      | 8-bit PWM        |

## 26.2 Signal Description

ATCPIT100 input/output (I/O) signals are shown in Table 26-2 Signal Description of ATCPIT100.

**Table 26-2 Signal Description of ATCPIT100**

| Name                    | I/O Type | Description                                                                                                                                |
|-------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------|
| <b>AMBA APB signals</b> |          |                                                                                                                                            |
| pclk                    | I        | AMBA APB clock                                                                                                                             |
| presetn                 | I        | AMBA APB reset signal; active low                                                                                                          |
| psel                    | I        | AMBA APB slave select signal from the APB decoder                                                                                          |
| penable                 | I        | AMBA APB enable signal                                                                                                                     |
| pwrite                  | I        | AMBA APB transfer direction signal<br><br>This signal indicates a write access when driven as HIGH<br>and a read access when driven as LOW |
| paddr[6:2]              | I        | AMBA APB address bus                                                                                                                       |
| prdata[31:0]            | O        | AMBA APB read data bus                                                                                                                     |
| pwdata[31:0]            | I        | AMBA APB write data bus                                                                                                                    |
| <b>PIT Signals</b>      |          |                                                                                                                                            |
| extclk                  | I        | External counting reference signal<br><br>extclk frequency must be 3 times slower than pclk                                                |
| pit_intr                | O        | Timer interrupt                                                                                                                            |
| pit_pause               | I        | Timer pause<br><br>This signal pauses timers and suspends all timer/PWM activities.                                                        |
| chn_pwm                 | O        | Channel <i>n</i> PWM output                                                                                                                |
| chn_pwmoe               | O        | Channel <i>n</i> PWM output enable                                                                                                         |

## 26.3 Programming Model

### 26.3.1 Summary of Registers

Table 26-3 Summary of registers shows the summary of ATCPIT100 programming registers.

**Table 26-3 Summary of registers**

| <b>Offset</b> | <b>Name</b> | <b>Description</b>         |
|---------------|-------------|----------------------------|
| +0x000        | IdRev       | ID and Revision Register   |
| +0x04~0x0C    | -           | Reserved                   |
| +0x10         | Cfg         | Configuration Register     |
| +0x14         | IntEn       | Interrupt Enable Register  |
| +0x18         | IntSt       | Interrupt Status Register  |
| +0x1C         | ChEn        | Channel Enable Register    |
| +0x20         | ChoCtrl     | Channel 0 Control Register |
| +0x24         | ChoReload   | Channel 0 Reload Register  |
| +0x28         | ChoCntr     | Channel 0 Counter Register |
| +0x2C         | -           | Reserved                   |
| +0x30         | Ch1Ctrl     | Channel 1 Control Register |
| +0x34         | Ch1Reload   | Channel 1 Reload Register  |
| +0x38         | Ch1Cntr     | Channel 1 Counter Register |
| +0x3C         | -           | Reserved                   |
| +0x40         | Ch2Ctrl     | Channel 2 Control Register |
| +0x44         | Ch2Reload   | Channel 2 Reload Register  |
| +0x48         | Ch2Cntr     | Channel 2 Counter Register |
| +0x4C         | -           | Reserved                   |
| +0x50         | Ch3Ctrl     | Channel 3 Control Register |
| +0x54         | Ch3Reload   | Channel 3 Reload Register  |
| +0x58         | Ch3Cntr     | Channel 3 Counter Register |

## 26.3.2 Register Description

The following sections describe ATCPIT100 registers in detail. The abbreviations for the Type column are summarized below.

RO: read only

R/W: readable and writable

W1C: write 1 to clear

## 26.3.3 ID and Revision Register (0x00)

This register holds the ID number and the revision number. The reset values of the two revision fields are revision dependent.

**Table 26-4 ID and Revision Register**

| Name     | Bit   | Type | Description           | Reset              |
|----------|-------|------|-----------------------|--------------------|
| ID       | 31:12 | RO   | ID number for PIT     | 0x03031            |
| RevMajor | 11:4  | RO   | Major revision number | Revision dependent |
| RevMinor | 3:0   | RO   | Minor revision number | Revision dependent |

### 26.3.4 Configuration Register (0x10)

**Table 26-5 Configuration Register**

| Name  | Bit  | Type | Description            | Reset                   |
|-------|------|------|------------------------|-------------------------|
| -     | 31:3 | -    | Reserved               | 0x0                     |
| NumCh | 2:0  | RO   | Number of PIT channels | Configuration dependent |

## 26.3.5 Interrupt Enable Register (0x14)

Table 26-6 Interrupt Enable Register

| Name       | Bit   | Type | Description                        | Reset |
|------------|-------|------|------------------------------------|-------|
| -          | 31:16 | -    | Reserved                           | -     |
| Ch3Int3En  | 15    | R/W  | Channel 3 Timer 3 interrupt enable | ox0   |
| CH3Int2En  | 14    | R/W  | Channel 3 Timer 2 interrupt enable | ox0   |
| Ch3Int1En  | 13    | R/W  | Channel 3 Timer 1 interrupt enable | ox0   |
| CH3IntoEn  | 12    | R/W  | Channel 3 Timer 0 interrupt enable | ox0   |
| Ch2Int3En  | 11    | R/W  | Channel 2 Timer 3 interrupt enable | ox0   |
| Ch2Int2En  | 10    | R/W  | Channel 2 Timer 2 interrupt enable | ox0   |
| Ch2Int1En  | 9     | R/W  | Channel 2 Timer 1 interrupt enable | ox0   |
| Ch2IntoEn  | 8     | R/W  | Channel 2 Timer 0 interrupt enable | ox0   |
| Ch1Int3En  | 7     | R/W  | Channel 1 Timer 3 interrupt enable | ox0   |
| Ch1Int2En  | 6     | R/W  | Channel 1 Timer 2 interrupt enable | ox0   |
| Ch1Int1En  | 5     | R/W  | Channel 1 Timer 1 interrupt enable | ox0   |
| Ch1IntoEn  | 4     | R/W  | Channel 1 Timer 0 interrupt enable | ox0   |
| ChoInt3En  | 3     | R/W  | Channel 0 Timer 3 interrupt enable | ox0   |
| ChoInt2En  | 2     | R/W  | Channel 0 Timer 2 interrupt enable | ox0   |
| ChoInt1En  | 1     | R/W  | Channel 0 Timer 1 interrupt enable | ox0   |
| ChoIntoEn  | 0     | R/W  | Channel 0 Timer 0 interrupt enable | ox0   |
| o: Disable |       |      |                                    |       |
| 1: Enable  |       |      |                                    |       |

## 26.3.6 Interrupt Status Register (0x18)

Table 26-7 Interrupt Status Register

| Name    | Bit   | Type | Description                        | Reset |
|---------|-------|------|------------------------------------|-------|
| -       | 31:16 | -    | Reserved                           | -     |
| Ch3Int3 | 15    | W1C  | Channel 3 Timer 3 interrupt status | oxo   |
| Ch3Int2 | 14    | W1C  | Channel 3 Timer 2 interrupt status | oxo   |
| Ch3Int1 | 13    | W1C  | Channel 3 Timer 1 interrupt status | oxo   |
| Ch3Into | 12    | W1C  | Channel 3 Timer 0 interrupt status | oxo   |
| Ch2Int3 | 11    | W1C  | Channel 2 Timer 3 interrupt status | oxo   |
| Ch2Int2 | 10    | W1C  | Channel 2 Timer 2 interrupt status | oxo   |
| Ch2Int1 | 9     | W1C  | Channel 2 Timer 1 interrupt status | oxo   |
| Ch2Into | 8     | W1C  | Channel 2 Timer 0 interrupt status | oxo   |
| Ch1Int3 | 7     | W1C  | Channel 1 Timer 3 interrupt status | oxo   |
| Ch1Int2 | 6     | W1C  | Channel 1 Timer 2 interrupt status | oxo   |
| Ch1Int1 | 5     | W1C  | Channel 1 Timer 1 interrupt status | oxo   |
| Ch1Into | 4     | W1C  | Channel 1 Timer 0 interrupt status | oxo   |
| ChoInt3 | 3     | W1C  | Channel 0 Timer 3 interrupt status | oxo   |
|         |       |      | 0: No effect                       |       |
|         |       |      | 1: Timer 3 time up                 |       |
| ChoInt2 | 2     | W1C  | Channel 0 Timer 2 interrupt status | oxo   |
|         |       |      | 0: No effect                       |       |
|         |       |      | 1: Timer 2 time up                 |       |
| ChoInt1 | 1     | W1C  | Channel 0 Timer 1 interrupt status | oxo   |
|         |       |      | 0: No effect                       |       |
|         |       |      | 1: Timer 1 time up                 |       |
| ChoInto | 0     | W1C  | Channel 0 Timer 0 interrupt status | oxo   |
|         |       |      | 0: No effect                       |       |
|         |       |      | 1: Timer 0 time up                 |       |

### 26.3.7 Channel Enable Register (0x1C)

Table 26-8 Channel Enable Register

| Name       | Bit   | Type | Description                                         | Reset |
|------------|-------|------|-----------------------------------------------------|-------|
| -          | 31:16 | -    | Reserved                                            | -     |
| Ch3TMR3En/ | 15    | R/W  | ChMode = 1, 2, 3<br>Channel 3 Timer 3 enable        | oxo   |
| CH3PWMEEn  |       |      | ChMode = 4, 6, 7<br>Channel 3 PWM enable            |       |
| Ch3TMR2En  | 14    | R/W  | Channel 3 Timer 2 enable                            | oxo   |
| Ch3TMR1En  | 13    | R/W  | Channel 3 Timer 1 enable                            | oxo   |
| Ch3TMROEn  | 12    | R/W  | Channel 3 Timer 0 enable                            | oxo   |
| Ch2TMR3En/ | 11    | R/W  | ChMode = 1, 2, 3<br>Channel 2 Timer 3 enable        | oxo   |
| CH2PWMEEn  |       |      | ChMode = 4, 6, 7<br>Channel 2 PWM enable            |       |
| Ch2TMR2En  | 10    | R/W  | Channel 2 Timer 2 enable                            | oxo   |
| Ch2TMR1En  | 9     | R/W  | Channel 2 Timer 1 enable                            | oxo   |
| Ch2TMROEn  | 8     | R/W  | Channel 2 Timer 0 enable                            | oxo   |
| Ch1TMR3En/ | 7     | R/W  | ChMode = 1, 2, 3<br>Channel 1 Timer 3 enable        | oxo   |
| CH1PWMEEn  |       |      | ChMode = 4, 6, 7<br>Channel 1 PWM enable            |       |
| Ch1TMR2En  | 6     | R/W  | Channel 1 Timer 2 enable                            | oxo   |
| Ch1TMR1En  | 5     | R/W  | Channel 1 Timer 1 enable                            | oxo   |
| Ch1TMROEn  | 4     | R/W  | Channel 1 Timer 0 enable                            | oxo   |
| ChoTMR3En/ | 3     | R/W  | ChMode = 1, 2, 3<br>Channel 0 Timer 3 enable        | oxo   |
| ChoPWMEEn  |       |      | ChMode = 4, 6, 7<br>Channel 0 PWM enable            |       |
| ChoTMR2En  | 2     | R/W  | Channel 0 Timer 2 enable                            | oxo   |
| ChoTMR1En  | 1     | R/W  | Channel 0 Timer 1 enable                            | oxo   |
| ChoTMROEn  | 0     | R/W  | Channel 0 Timer 0 enable<br>0: Disable<br>1: Enable | oxo   |

Note that a timer or PWM cannot be enabled if the corresponding channel does not exist or it is not a valid device in the channel mode. For example, Timer 1 of Channel 0 cannot be enabled when Channel 0 is set to

the 32-bit Timer mode.

### 26.3.8 Chn Control Register ( $0x20 + n * 0x10$ )

Table 26-9 Channel 0~3 Control Register ( $0x20 + n * 0x10$ )

| Name    | Bit  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Reset |
|---------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| -       | 31:5 | -    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | -     |
| PWMPark | 4    | R/W  | <p>PWM park value. When this channel is disabled, this bit reflects the output of PWM and writing to it will change the output of PWM. The value of this bit also governs how the PWM waveform is generated when this channel is enabled.</p> <p>0: the PWM output is LOW when the channel is disabled; the low-period PWM counter will be counted first before toggling the output to HIGH and counting the high-period PWM counter when this channel is enabled.</p> <p>1: the PWM output is HIGH when the channel is disabled; the high-period PWM counter will be counted first before toggling</p> | 0x0   |

| Name  | Bit | Type | Description                                                                             | Reset |
|-------|-----|------|-----------------------------------------------------------------------------------------|-------|
|       |     |      | the output to LOW and counting the low-period PWM counter when this channel is enabled. |       |
| ChClk | 3   | R/W  | Channel clock source:<br>0: External clock<br>1: APB clock                              | 0x0   |

  

| Name   | Bit | Type | Description                                                                                                                                                               | Reset |
|--------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| ChMode | 2:0 | R/W  | Channel mode:<br>0: Reserved<br>1: 32-bit timer<br>2: 16-bit timers<br>3: 8-bit timers<br>4: PWM<br>5: Reserved<br>6: Mixed PWM/16-bit timer<br>7: Mixed PWM/8-bit timers | 0x0   |

### 26.3.9 Chn Reload Register ( $0x24 + n * 0x10$ )

The Reload Register keeps the initial/reload value(s) for PWM/timer counter(s). The definition of the Reload Register varies according to the channel mode. The period of PWM/timer is equal to the reload value plus one. For example, in the 32-bit Timer mode, a timer interrupt will be generated every  $(TMR32\_0 + 1)$  cycles. In the PWM mode, the high period is  $(PWM16\_Hi + 1)$  cycles and the low period is  $(PWM16\_Lo + 1)$  cycles. Table 26-10 Reload Register for 32-bit Timer Mode (ChMode=1) to Table 26-15 Reload Register for Mixed PWM/8-bit Timers Mode (ChMode=7) shows the definition of Reload Register with respect to the channel mode.

Table 26-10 Reload Register for 32-bit Timer Mode (ChMode=1)

| Name    | Bit  | Type | Description                     | Reset |
|---------|------|------|---------------------------------|-------|
| TMR32_0 | 31:0 | R/W  | Reload value for 32-bit Timer 0 | 0x0   |

Table 26-11 Reload Register for 16-bit Timers Mode (ChMode=2)

| Name    | Bit   | Type | Description                     | Reset |
|---------|-------|------|---------------------------------|-------|
| TMR16_1 | 31:16 | R/W  | Reload value for 16-bit Timer 1 | 0x0   |
| TMR16_0 | 15:0  | R/W  | Reload value for 16-bit Timer 0 | 0x0   |

**Table 26-12 Reload Register for 8-bit Timers Mode (ChMode=3)**

| Name   | Bit   | Type | Description                    | Reset |
|--------|-------|------|--------------------------------|-------|
| TMR8_3 | 31:24 | R/W  | Reload value for 8-bit Timer 3 | oxo   |
| TMR8_2 | 23:16 | R/W  | Reload value for 8-bit Timer 2 | oxo   |
| TMR8_1 | 15:8  | R/W  | Reload value for 8-bit Timer 1 | oxo   |
| TMR8_0 | 7:0   | R/W  | Reload value for 8-bit Timer 0 | oxo   |

**Table 26-13 Reload Register for PWM Mode (ChMode=4)**

| Name     | Bit   | Type | Description                      | Reset |
|----------|-------|------|----------------------------------|-------|
| PWM16_Hi | 31:16 | R/W  | Reload value for PWM high period | oxo   |
| PWM16_Lo | 15:0  | R/W  | Reload value for PWM low period  | oxo   |

**Table 26-14 Reload Register for Mixed PWM/16-bit Timer Mode (ChMode=6)**

| Name    | Bit   | Type | Description                      | Reset |
|---------|-------|------|----------------------------------|-------|
| PWM8_Hi | 31:24 | R/W  | Reload value for PWM high period | oxo   |
| PWM8_Lo | 23:16 | R/W  | Reload value for PWM low period  | oxo   |
| TMR16_0 | 15:0  | R/W  | Reload value for 16-bit Timer 0  | oxo   |

**Table 26-15 Reload Register for Mixed PWM/8-bit Timers Mode (ChMode=7)**

| Name    | Bit   | Type | Description                      | Reset |
|---------|-------|------|----------------------------------|-------|
| PWM8_Hi | 31:24 | R/W  | Reload value for PWM high period | oxo   |
| PWM8_Lo | 23:16 | R/W  | Reload value for PWM low period  | oxo   |
| TMR8_1  | 15:8  | R/W  | Reload value for 8-bit Timer 1   | oxo   |
| TMR8_0  | 7:0   | R/W  | Reload value for 8-bit Timer 0   | oxo   |

### 26.3.10 Chn Counter Register ( $0x28 + n * 0x10$ )

Chn Counter Register indicates the remaining cycles for the next timer interrupt or PWM toggle. Like the Reload Register, the field definition of Counter Register varies according to the channel mode.

| Name    | Bit  | Type | Description                                                                                                                              | Reset |
|---------|------|------|------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Counter | 31:0 | RO   | The counter for the counting of Timer/PWM<br>Refer to Table 10 ~ Table 15 for the field<br>definitions with respect to the channel mode. | oxo   |

## 26.4 Hardware Configuration Options

### 26.4.1 Number of PIT Channels

Define ATCPIT100\_NUM\_CHANNEL\_mto configure mPIT channels, where mis the number ranging from 1~4. For example, define “[ATCPIT100\\_NUM\\_CHANNEL\\_3](#)” to configure 3 PIT channels.

```
define ATCPIT100_NUM_CHANNEL_3
```

## 26.5 Programming Sequence

Each PIT channel may select either APB or external clock as its clock source. ChClk of PIT

Control Register determines the clock source selection.  
The following sections give some usage examples.

### 26.5.1 Generate 2 Periodic Interrupts with Channel 0

Using channel 0 to generate 2 interrupts: one for every 1000 APB clock cycles and another for every 3000 APB cycles.

1. Set Channel 0 Control Register:  
ChMode = 2 (16-bit Timers)  
ChClk = 1 (APB clock)
2. Set Channel 0 Reload Register, refer to Table 11:  
TMR16\_0 = 999  
TMR16\_1 = 2999
3. Set Interrupt Enable Register to enable interrupt:  
Ch0Int0En = 1  
Ch0Int1En = 1
4. Enable Timer 0 and Timer 1 of channel 0.  
Ch0TMR0En = 1  
Ch0TMR1En = 1

### 26.5.2 Generate 2 Aligned PWM Output

Figure 26-2 PWM Example Waveform



To drive the waveform illustrated in Figure 26-2 PWM Example

Waveform:

PWM0: period = 30 external clock cycles, duty cycle = 1/3

PWM1: period = 60 external clock cycles, duty cycle = 1/3

Two PWMs are aligned at positive edge

1. Set Control Register:

Channel 0: ChMode = 4 (PWM), ChClk = 0 (External Clock),  
PWMPark = 1

Channel 1: ChMode = 4 (PWM), ChClk = 0 (External Clock),  
PWMPark = 1

2. Set Reload Register, see Table 13.

Channel 0: PWM16\_Hi = 9, PWM16\_Lo = 19

Channel 1: PWM16\_Hi = 19, PWM16\_Lo = 39

3. Enable PWM.

Set Channel Enable Register: Ch0PWMEn = 1, Ch1PWMEn = 1.

### 26.5.3 Changing the PIT Modes

To change the mode of PIT channel that is currently working, the channel must be disabled first. Then set the channel to a new mode and enable it.

# 27 ATCBUSDEC200

## 27.1 Introduction

ATCBUSDEC200 is an AMBA AHB-Lite decoder. It receives bus transactions from the upstream port and dispatches the transactions to the downstream ports according to the slave base address and space size configurations. This decoder also provides slave information registers for software to lookup the memory space assignment information.

### 27.1.1 Features

- Compliant with the AMBA AHB-Lite protocol
- Provides the slave base/size information through the internal slave device
- Supports one upstream port
- Supports up to 31 downstream ports
- Configurable base/size for each downstream port
- Configurable address width: 24, 32 bits
- Configurable data width: 32, 64, 128 bits

### 27.1.2 Block Diagram

Figure 27-1 ATCBUSDEC200 Block Diagram shows the block diagram of the ATCBUSDEC200 decoder, which consists of the interconnect logic, the internal slave, and the default slave.

**Figure 27-1 ATCBUSDEC200 Block Diagram**



### 27.1.3 Interconnect Logic

The interconnect logic includes the address decoder and the downstream-to-upstream multiplexor. The address decoder dispatches the upstream transactions to the appropriate slave ports according to the slave base address and size configurations. The downstream-to-upstream multiplexor collects the returned data/responses to the upstream port.

### 27.1.4 Internal Slave

The internal slave contains registers recording the base/size information of downstream ports. The internal slave is designated the slave number 0. It is an optional slave that could be configured out by undefining the [ATCBUSDEC200\\_SLV0\\_SUPPORT](#) macro.

### 27.1.5 Default Slave

A transaction that does not hit any slave is directed to the default slave, which may be configured to generate ERROR as responses. See AHB-Lite Default Slave Error Response for detail.

## 27.2 Signal Description

Figure 27-2 Signal Diagram shows the signal overview and gives the detailed descriptions of I/O signals.

**Figure 27-2 Signal Diagram**



**Table 27-1 ATCBUSDEC200 Signal Description**

| Signal Name                          | I/O Type | Description                                                                         |
|--------------------------------------|----------|-------------------------------------------------------------------------------------|
| <b>AHB-Lite global signals</b>       |          |                                                                                     |
| hclk                                 | I        | AHB-Lite bus clock                                                                  |
| hresetn                              | I        | AHB-Lite bus reset                                                                  |
| <b>Upstream AHB-Lite interface</b>   |          |                                                                                     |
| us_haddr[ADDR_MSB:o]                 | I        | AHB-Lite address bus                                                                |
| us_htrans                            | I        | AHB-Lite transfer type                                                              |
| us_hsel                              | I        | AHB-Lite slave select                                                               |
| us_hready                            | I        | AHB-Lite input ready from upstream ports                                            |
| us_hrdtata[DATA_MSB:o]               | O        | AHB-Lite read data bus                                                              |
| us_hreadyout                         | O        | AHB-Lite transfer done (internally connected with ds_hready)                        |
| us_hresp                             | O        | AHB-Lite transfer response                                                          |
| <b>Downstream AHB-Lite interface</b> |          |                                                                                     |
| dsn_hsel                             | O        | AHB-Lite slave select for the $n^{\text{th}}$ downstream port ( $n=1\sim 31$ )      |
| ds_hready                            | O        | AHB-Lite input ready for all downstream ports (internally connected with us_hready) |
| dsn_hrdtata[DATA_MSB:o]              | I        | AHB-Lite read data bus for the $n^{\text{th}}$ downstream port ( $n=1\sim 31$ )     |
| dsn_hreadyout                        | I        | AHB-Lite transfer done for the $n^{\text{th}}$ downstream port ( $n=1\sim 31$ )     |
| dsn_hresp                            | I        | AHB-Lite transfer response for the $n^{\text{th}}$ downstream port ( $n=1\sim 31$ ) |

## 27.3 Programming Model

The registers for ATCBUSDEC200 are all informational only. They reside in the internal slave (slave 0) so they are only available when slave 0 is configured. That is, the hardware configuration option [ATCBUSDEC200\\_SLV0\\_SUPPORT](#) has to be defined for these registers to be available.

### 27.3.1 Summary of Registers

Table 27-2 Register Summary provides a summary of registers. All registers are read-only and writes to them are silently ignored. All undefined/reserved registers will be read as zero.

**Table 27-2 Register Summary**

| Offset     | Name      | Description                                              |
|------------|-----------|----------------------------------------------------------|
| +0x00      | IdRev     | ID and revision register                                 |
| +0x04~0x1C | -         | Reserved                                                 |
| +0x20~0x98 | BaseSizen | Base/size register of downstream port $n$ ( $1\sim 31$ ) |

### 27.3.2 Register Description

Note that the registers are only available when the internal slave (slave 0) is defined. See beginning of this chapter for detail.

### 27.3.3 ID and Revision Register

This register holds the ID number and the revision number. The reset values of the two revision fields are revision dependent.

**Table 27-3 ID and Revision Register (0x00)**

| Name     | Bit  | Description                | Reset              |
|----------|------|----------------------------|--------------------|
| ID       | 31:8 | ID number for ATCBUSDEC200 | 0x000320           |
| RevMajor | 7:4  | Major revision number      | Revision dependent |
| RevMinor | 3:0  | Minor revision number      | Revision dependent |

### 27.3.4 Base/Size Register

These registers hold the base and size information for each downstream port.

**Table 27-4 Base/Size Register of Downstream Port 1~n (0x1c + n\*0x4) in 24-bit Address Mode**

| Name     | Bit      | Description                                                                                                                                                                                                                                                              | Reset                        |
|----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| Reserved | 23:M     | M=ATCBUSDEC200_ADDR_DECODE_WIDTH                                                                                                                                                                                                                                         | 0x0                          |
| Base     | (M-1):10 | Base address offset                                                                                                                                                                                                                                                      | Depends on the configuration |
| Reserved | 9:4      | -                                                                                                                                                                                                                                                                        | 0x0                          |
| Size     | 3:0      | Size of the slave address space<br>0x0: Invalid (for absent ports)<br>0x1: 1KB<br>0x2: 2KB<br>0x3: 4KB<br>0x4: 8KB<br><br>0x5: 16KB<br>0x6: 32KB<br>0x7: 64KB<br>0x8: 128KB<br>0x9: 256KB<br>0xA: 512KB<br>0xB: 1MB<br>0xC: 2MB<br>0xD: 4MB<br>0xE: 8MB<br>0xF: Reserved | Depends on the configuration |

**Table 27-5 Base/Size Register of Downstream Port 1~n ( $0x1c + n*0x4$ ) in 32-bit Address Mode**

| Name     | Bit      | Description                                                                                                                                                                                                                                        | Reset                        |
|----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| Reserved | 31:M     | M=ATCBUSDEC200_ADDR_DECODE_WIDTH                                                                                                                                                                                                                   | 0x0                          |
| Base     | (M-1):20 | Base address offset                                                                                                                                                                                                                                | Depends on the configuration |
| Reserved | 19:4     | -                                                                                                                                                                                                                                                  | 0x0                          |
| Size     | 3:0      | Size of the slave address space<br>0x0: Invalid (for absent ports)<br>0x1: 1MB<br>0x2: 2MB<br>0x3: 4MB<br>0x4: 8MB<br>0x5: 16MB<br>0x6: 32MB<br>0x7: 64MB<br>0x8: 128MB<br>0x9: 256MB<br>0xA: 512MB<br>0xB: 1GB<br>0xC: 2GB<br>0xE ~ 0xF: Reserved | Depends on the configuration |

## 27.4 Hardware Configuration Options

### 27.4.1 AHB-Lite Bus Address Width

Define `ATCBUSDEC200_ADDR_WIDTH_24` to set the address width to 24 bits. The default address width is 32 bits.

```
`define ATCBUSDEC200_ADDR_WIDTH_24
```

### 27.4.2 AHB-Lite Address Decode Width

The upstream address decoding logic only performs partial decoding of the address bits received from the AHB-Lite master. Define `ATCBUSDEC200_ADDR_DECODE_WIDTH` to specify the amount of partial address bits to use for decoding. This value also reflects the total address space size available to all downstream ports. For the 24-bit mode, this macro could be 11 – 24; for the 32-bit mode, this macro could be 21 – 32. For example,

```
define ATCBUSDEC200_ADDR_DECODE_WIDTH 22
```

In this case, the address decoding logic only decodes address bits [21:0] for selecting the target slave port.

### 27.4.3 AHB-Lite Bus Data Width

Define one of the following macro to set the data width to 64 bits or 128 bits. The default address width is 32 bits when neither of them is defined.

```
`define ATCBUSDEC200_DATA_WIDTH_64
`define ATCBUSDEC200_DATA_WIDTH_128
```

### 27.4.4 AHB-Lite Slave Ports

Define ATCBUSDEC200\_SLVn\_SUPPORT to enable the  $n^{\text{th}}$  downstream port, where  $n = 0\sim31$ . The macros do not need to be defined sequentially. For example,

```
`define ATCBUSDEC200_SLV0_SUPPORT
`define ATCBUSDEC200_SLV1_SUPPORT
`define ATCBUSDEC200_SLV15_SUPPORT
`define ATCBUSDEC200_SLV31_SUPPORT
```

**Note!**

- Slave 0 is the optional internal slave which provides accesses to the ATCBUSDEC200 programming registers.
- ATCBUSDEC200\_SLV0\_SUPPORT needs to be defined explicitly to enable slave 0.

### 27.4.5 AHB-Lite Slave Size

Define ATCBUSDEC200\_SLVn\_SIZE ( $n=1\sim31$ ) to specify the address space size of the  $n^{\text{th}}$  downstream port. The values are defined in Table 4 and Table 5 for the 24-bit mode and the 32-bit mode, respectively. For example, specify the address space size of the 2nd downstream port to be 4KB in the 24-bit mode:

```
`define ATCBUSDEC200_SLV2_SIZE 3
```

And the same value means 4MB in the 32-bit mode.

**Note!**

The address space size of slave 0 (the internal slave) is not configurable and it is predefined to be 4KB in the 24-bit mode and 1MB in the 32-bit mode.

### 27.4.6 AHB-Lite Slave Base Address Offset

Define ATCBUSDEC200\_SLVn\_OFFSET ( $n=0\sim31$ ) to specify the base address offset of the  $n^{\text{th}}$  downstream port. The value must be slave-size aligned. For example, suppose the size of the entire decoded address space is 2GB and the size of the 3<sup>rd</sup> downstream port is 8MB, specify the

address offset of the 3<sup>rd</sup> downstream port to be 0x10800000 as below:

```
`define ATCBUSDEC200_ADDR_DECODE_WIDTH 31
`define ATCBUSDEC200_SLV3_SIZE 4
`define ATCBUSDEC200_SLV3_OFFSET
```

[ATCBUSDEC200\\_ADDR\\_DECODE\\_WIDTH'h10800000](#)

### 27.4.7 AHB-Lite Default Slave Error Response

Use [ATCBUSDEC200\\_OOR\\_ERR\\_EN](#) to control the responses of transactions that do not target any valid downstream port. When defined, the default slave will return the two-cycle ERROR response; otherwise, it will return the [OKAY](#) response.

```
'define ATCBUSDEC200_OOR_ERR_EN
```

## 27.5 Integration Guideline

Figure 27-3 ATCBUSDEC200 Connection Example shows an example use of ATCBUSDEC200, which connects an AHB-Lite master to two AHB-Lite slaves.

- An AHB-Lite master is connected to the upstream port of ATCBUSDEC200.
- Slave 3 and slave 9 are connected to the 3rd and 9th downstream ports of ATCBUSDEC200.
- misc indicates the AHB-Lite interface signals [hwdata](#), [hsiz](#), [hprot](#), [hmastlock](#), and [hburst](#) from the upstream. These signals are connected to all slaves directly.

Figure 27-3 ATCBUSDEC200 Connection Example



## 27.6 Access Latencies

Table 26-6 summarizes the ATCBUSDEC200 access latencies, the number of elapsed clock cycles on the upstream port between the moment

a request is accepted and the moment the last response for the request is available. The table is made with the following assumptions:

- LEN stands for the value of the length indicated by hburst
- The downstream slave inserts no wait states

Table 27-6 ATCBUSDEC200 Access Latencies

| Type of Request | Latency |
|-----------------|---------|
| Read            | LEN     |
| Write           | LEN     |

# 28 ATCBMC200

## 28.1 Introduction

AndeShape™ ATCBMC200 Bus Matrix Controller is an AHB fabric that allows multiple simultaneous bus transactions. Programmable two-level priority scheme is used for arbitration.

### 28.1.1 Features

- Supports AMBA™ 2 AHB protocol specification
  - Split transfers are not supported
  - All transfers behave as locked transfers
- Supports 24/32-bit address bus
- Configurable number of AHB masters (1–16)
- Configurable number of AHB slaves (1–15)
- Configurable connectivity between AHB masters and slaves
- Programmable two level priority arbitration scheme

### 28.1.2 Block Diagram

Figure 28-1 ATCBMC200 Block Diagram shows the block diagram of the ATCBMC200 controller.

**Figure 28-1 ATCBMC200 Block Diagram**



### 28.1.3 Function Description

The AndeShape™ ATCBMC200 bus matrix accepts requests from AHB masters and dispatches the transactions to the target AHB slaves. The transactions from multiple masters can proceed simultaneously as long as there is no resource conflict.

### 28.1.4 MST Commander

Each MST Commander interfaces one AHB master and it decides which AHB slave should process the bus transfer based on the address map information (as defined by the Base/Size Registers). The Bus Matrix will then route the transfer to the corresponding slave accordingly.

### 28.1.5 SLV Commander

Each SLV commander interfaces one AHB slave and it is responsible for arbitrating requests to that slave. The arbitration scheme is two-level priority arbitration.

### 28.1.6 Bus Matrix

The Bus Matrix routes the transfer between AHB masters and slaves according to the address decoding result provided by the MST Commander. However, the connectivity inside the matrix is configurable and there might not be paths between all master/slave pairs. Please see Hardware Configuration Options Master and Slave Ports Connectivity for detail.

## 28.1.7 AHB Slave Grouping

AHB slaves are partitioned into two groups:

- Fixed address map group
- Programmable address map group

The difference is the programmability of the base address and the size as summarized in Table 28-1 Programmability of Base Address and Size Registers for AHB Slave 1–15. It is recommended to connect memory devices to AHB slave 11–15.

**Table 28-1 Programmability of Base Address and Size Registers for AHB Slave 1–15**

| AHB slave number | Base Address     | Slave Size       | Usage                                    |
|------------------|------------------|------------------|------------------------------------------|
| <b>1–10</b>      | Non-programmable | Non-programmable | Memory (fixed address and size) / Device |
| <b>11–15</b>     | Programmable     | Programmable     | Memory (adjustable address and size)     |

## 28.2 Signal Description

Figure 28-2 ATCBMC200 I/O Signals shows the input/output (I/O) signals of the ATCBMC200 controller.

**Figure 28-2 ATCBMC200 I/O Signals**



**Table 28-2 ATCBMC200 Signal Definition** gives the detailed descriptions of ATCBMC200 I/O signals.

**Table 28-2 ATCBMC200 Signal Definition**

| Signal Name                 | I/O Type | Description                                                                                                                                                                                                                                                   |
|-----------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>System</b>               |          |                                                                                                                                                                                                                                                               |
| hclk                        | I        | AHB clock                                                                                                                                                                                                                                                     |
| hresetn                     | I        | AHB reset signal; Active Low                                                                                                                                                                                                                                  |
| bmc_intr                    | O        | Interrupt signal; Active High<br><br>The signal is asserted when there are no target slaves or multiple target slaves after decoding the address bus.                                                                                                         |
| <b>AHB Master Interface</b> |          |                                                                                                                                                                                                                                                               |
| hmm_haddr[W:o]              | I        | AHB master <i>m</i> address bus<br><br>W = 31 in 32-bit address mapping mode<br><br>W = 23 in 24-bit address mapping mode                                                                                                                                     |
| hmm_hburst[2:o]             | I        | AHB master <i>m</i> burst type signal                                                                                                                                                                                                                         |
| hmm_hprot[3:o]              | I        | AHB master <i>m</i> protect signal                                                                                                                                                                                                                            |
| hmm_hsize[2:o]              | I        | AHB master <i>m</i> data size signal                                                                                                                                                                                                                          |
| hmm_htrans[1:o]             | I        | AHB master <i>m</i> transfer type signal                                                                                                                                                                                                                      |
| hmm_hwdata[31:o]            | I        | AHB master <i>m</i> write data bus                                                                                                                                                                                                                            |
| hmm_hwwrite                 | I        | AHB master <i>m</i> read/write control signal                                                                                                                                                                                                                 |
| hmm_hrdata[31:o]            | O        | AHB master <i>m</i> read data bus                                                                                                                                                                                                                             |
| hmm_hready                  | O        | AHB master <i>m</i> hready signal. Indicates that a transfer has been finished on the bus                                                                                                                                                                     |
| hmm_hresp[1:o]              | O        | AHB master <i>m</i> response signal                                                                                                                                                                                                                           |
| <b>AHB Slave Interface</b>  |          |                                                                                                                                                                                                                                                               |
| hs <i>n</i> _bmc_hready     | I        | AHB hready from slave <i>n</i> , indicating that a transfer to/from slave <i>n</i> has finished, <i>n</i> =1–15<br><br>To avoid cyclic timing loop, the fan-in of h <i>n</i> _bmc_hready must not include bmc_h <i>n</i> _hready through combinational logic. |

| Signal Name      | I/O Type | Description                                                                                                      |
|------------------|----------|------------------------------------------------------------------------------------------------------------------|
| hsn_hrdet[31:0]  | I        | AHB slave $n$ read data bus. The read data bus transfers data from bus slaves to bus masters for read operations |
| hsn_hresp[1:0]   | I        | AHB slave $n$ response signal. The signal provides response status of the transfer                               |
| bmc_hsn_hready   | O        | AHB hready for slave $n$ , indicating that the bus is ready to issue a new transfer. $n=1-15$                    |
| hsn_haddr[W:o]   | O        | AHB slave $n$ address bus<br>W = 31 in 32-bit address mapping mode<br>W = 23 in 24-bit address mapping mode      |
| hsn_hburst[2:0]  | O        | AHB slave $n$ write data bus                                                                                     |
| hsn_hprot[3:0]   | O        | AHB slave $n$ protect signal                                                                                     |
| hsn_hsel         | O        | AHB slave $n$ select signal                                                                                      |
| hsn_hsize[2:0]   | O        | AHB slave $n$ data size signal, indicating the size of the transfer                                              |
| hsn_htrans[1:0]  | O        | AHB slave $n$ transfer type signal, indicating the type of the current transfer                                  |
| hsn_hwdata[31:0] | O        | AHB slave $n$ write data bus                                                                                     |
| hsn_hwrite       | O        | AHB slave $n$ transfer direction. HIGH indicates a write transfer and LOW indicates a read transfer              |

## 28.3 Programming Model

### 28.3.1 Summary of Registers

Table 28-3 ATCBMC200 Register Summary shows a summary of the ATCBMC200 registers.

Table 28-3 ATCBMC200 Register Summary

| Offset      | Name       | Description                                            |
|-------------|------------|--------------------------------------------------------|
| +0x00       | IdRev      | ID and revision register                               |
| +0x04-0x0C  | -          | Reserved                                               |
| +0x10       | Priority   | Priority register                                      |
| +0x14       | Ctrl       | Control register                                       |
| +0x18       | IntrStatus | Interrupt status register                              |
| +0x1C       | -          | Reserved                                               |
| +0x20-e0x58 | BaseSizen  | Base/Size registers for AHB slave $n$ , where $n=1-15$ |

### 28.3.2 Register Description

The abbreviations for the Type column are summarized below.

RO: read only

RW: readable and writable

RW1C: readable and write 1 to clear

### 28.3.3 ID and Revision Register (0x00)

This register holds the ID number and the revision number. The reset values of the revision fields are revision dependent.

**Table 28-4 ID and Revision Register**

| Name     | Bit   | Type | Description             | Reset              |
|----------|-------|------|-------------------------|--------------------|
| ID       | 31:12 | RO   | ID number for ATCBMC200 | 0x000002           |
| RevMajor | 11:4  | RO   | Major revision number   | Revision dependent |
| RevMinor | 3:0   | RO   | Minor revision number   | Revision dependent |

### 28.3.4 Priority Register (0x10)

The ATCBMC200 controller provides two arbitration modes — fixed priority mode and two level round-robin mode. The modes are controlled by the Priority field of the Priority Register. When all 16 bits of the Priority field equal zero, the arbitration mode is the fixed mode, where the master number determines the priority with the lower masters getting higher priorities. When the Priority field is not all zero, the arbiter works in the two-level round-robin mode where each bit of the Priority field indicates the priority group of the corresponding master. The masters are partitioned into two groups, group-0 and group-1, according to their corresponding Priority bit values. Group-1 masters are given higher priorities than group-0 masters, and the priorities within the same group are round-robin.

Under the two-level round-robin mode, Bit-0 of the Priority field indicates the priority of Master 0, bit-1 indicates that of Master 1, etc. If Master mdoes not exist, then bit-m is read as zero and write ignored.

Master 0 can be set to the top priority by setting the PHigh0 field to 1 regardless of the priority mode.

**Table 28-5 Priority Register**

| Name     | Bit   | Type | Description                                                                                                                                                                                                                                                                                                                         | Reset  |
|----------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| PHigho   | 31    | RW   | Master 0 is the highest priority master regardless of the Priority mode<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                  | 0      |
| Reserved | 30:16 | -    | -                                                                                                                                                                                                                                                                                                                                   | -      |
| Priority | 15:0  | RW   | Priority Mode<br>0x0: Fixed mode. The priority from high to low is Master 0, Master 1, Master 2 ... Master 15.<br>Other values: Two-level round-robin mode.<br>The behavior of two-level round-robin partitions the masters into high priority group and low priority group. Within each group, the priority policy is round-robin. | 0xFFFF |

### 28.3.5 Control Register (0x14)

**Table 28-6 Control Register**

| Name         | Bit  | Type | Description                                                                                                             | Reset |
|--------------|------|------|-------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved     | 31:2 | -    | -                                                                                                                       | -     |
| IntrEn       | 1    | RW   | Interrupt enable<br>0: Disable interrupt<br>1: Enable interrupt                                                         | 0     |
| UnmappedResp | 0    | RW   | The response type when there is no slave selected after decoding the address bus<br>0: OK response<br>1: ERROR response | 0     |

## 28.3.6 Interrupt Status Register (0x18)

Table 28-7 Interrupt Status Register

| Name             | Bit   | Type | Description                                                                                                         | Reset |
|------------------|-------|------|---------------------------------------------------------------------------------------------------------------------|-------|
| Reserved         | 31:16 | -    | -                                                                                                                   | -     |
| Intr_Mst15SelErr | 15    | RW1C | Master15 address selection error<br>0: No error<br>1: The transfer address from Master15 does not map to any slaves | 0     |
| Intr_Mst14SelErr | 14    | RW1C | Master14 address selection error<br>0: No error<br>1: The transfer address from Master14 does not map to any slaves | 0     |
| Intr_Mst13SelErr | 13    | RW1C | Master13 address selection error<br>0: No error<br>1: The transfer address from Master13 does not map to any slaves | 0     |
| Intr_Mst12SelErr | 12    | RW1C | Master12 address selection error<br>0: No error<br>1: The transfer address from Master12 does not map to any slaves | 0     |
| Intr_Mst11SelErr | 11    | RW1C | Master11 address selection error<br>0: No error<br>1: The transfer address from Master11 does not map to any slaves | 0     |
| Intr_Mst10SelErr | 10    | RW1C | Master10 address selection error<br>0: No error<br>1: The transfer address from Master10 does not map to any slaves | 0     |

| Name            | Bit | Type | Description                                                                                                       | Reset |
|-----------------|-----|------|-------------------------------------------------------------------------------------------------------------------|-------|
| Intr_Mst9SelErr | 9   | RW1C | Master9 address selection error<br>0: No error<br>1: The transfer address from Master9 does not map to any slaves | 0     |
| Intr_Mst8SelErr | 8   | RW1C | Master8 address selection error<br>0: No error<br>1: The transfer address from Master8 does not map to any slaves | 0     |
| Intr_Mst7SelErr | 7   | RW1C | Mastery address selection error<br>0: No error<br>1: The transfer address from Mastery does not map to any slaves | 0     |
| Intr_Mst6SelErr | 6   | RW1C | Master6 address selection error<br>0: No error<br>1: The transfer address from Master6 does not map to any slaves | 0     |
| Intr_Mst5SelErr | 5   | RW1C | Master5 address selection error<br>0: No error<br>1: The transfer address from Master5 does not map to any slaves | 0     |
| Intr_Mst4SelErr | 4   | RW1C | Master4 address selection error<br>0: No error<br>1: The transfer address from Master4 does not map to any slaves | 0     |
| Intr_Mst3SelErr | 3   | RW1C | Master3 address selection error<br>0: No error<br>1: The transfer address from Master3 does not map to any slaves | 0     |
| Intr_Mst2SelErr | 2   | RW1C | Master2 address selection error<br>0: No error<br>1: The transfer address from Master2 does not map to any slaves | 0     |
| Intr_Mst1SelErr | 1   | RW1C | Master1 address selection error<br>0: No error<br>1: The transfer address from Master1 does not map to any slaves | 0     |
| Intr_Mst0SelErr | 0   | RW1C | Master0 address selection error<br>0: No error<br>1: The transfer address from Master0 does not map to any slaves | 0     |

### 28.3.7 Base/Size Register of AHB Slave 1-10 (0x20-0x44)

These registers hold the base address and the size of AHB slave 1–10 and they are read only. The register format is shown in Table 28-8

Base/Size Register of AHB Slave 1–10 in 24-bit Mode and Table Table 28-9  
Base/Size Register of AHB Slave 1–10 in 32-bit Mode for 24-bit and 32-bit addressing modes, respectively.

Table 28-8 Base/Size Register of AHB Slave 1-10 in 24-bit Mode

| Name     | Bit   | Type | Description               |               | Reset                        |
|----------|-------|------|---------------------------|---------------|------------------------------|
| Base     | 23:10 | RO   | Base address              |               | Depends on the configuration |
| Reserved | 9:4   | -    | -                         |               | -                            |
| Size     | 3:0   | RO   | Size of the address space |               | Depends on the configuration |
|          |       |      | ox0: Invalid slave        | ox8: 128K     |                              |
|          |       |      | ox1: 1K                   | ox9: 256K     |                              |
|          |       |      | ox2: 2K                   | oxA: 512K     |                              |
|          |       |      | ox3: 4K                   | oxB: 1M       |                              |
|          |       |      | ox4: 8K                   | oxC: 2M       |                              |
|          |       |      | ox5: 16K                  | oxD: 4M       |                              |
|          |       |      | ox6: 32K                  | oxE: 8M       |                              |
|          |       |      | ox7: 64K                  | oxF: Reserved |                              |

Table 28-9 Base/Size Register of AHB Slave 1-10 in 32-bit Mode

| Name     | Bit   | Type | Description                |                   | Reset                        |
|----------|-------|------|----------------------------|-------------------|------------------------------|
| Base     | 31:20 | RO   | Base address               |                   | Depends on the configuration |
| Reserved | 19:4  | -    | -                          |                   | -                            |
| Size     | 3:0   | RO   | Size of the address space: |                   | Depends on the configuration |
|          |       |      | ox0: Invalid slave         | ox8: 128M         |                              |
|          |       |      | ox1: 1M                    | ox9: 256M         |                              |
|          |       |      | ox2: 2M                    | oxA: 512M         |                              |
|          |       |      | ox3: 4M                    | oxB: 1G           |                              |
|          |       |      | ox4: 8M                    | oxC: 2G           |                              |
|          |       |      | ox5: 16M                   | oxD–oxF: Reserved |                              |
|          |       |      | ox6: 32M                   |                   |                              |
|          |       |      | ox7: 64M                   |                   |                              |

### 28.3.8 Base/Size Register of AHB Slave 11–15 (0x48–0x58)

These registers show the base address and the size of AHB slave 11–15. Contrary to the read only Base/Size registers of AHB Slave 1–10, these registers are readable and writable. The register format is shown in Table 28-10 Base/Size Register of AHB Slave 11–15 in 24-bit Mode and Table 28-11 Base/Size Register of AHB Slave 11–15 in 32-bit Mode for 24-bit and 32-bit addressing modes, respectively. Note that the base address must be aligned to multiple of the size of the corresponding AHB slave address space.

**Table 28-10 Base/Size Register of AHB Slave 11–15 in 24-bit Mode**

| Name     | Bit   | Type | Description                |               | Reset                        |
|----------|-------|------|----------------------------|---------------|------------------------------|
| Base     | 23:10 | RW   | Base address               |               | Depends on the configuration |
| Reserved | 9:4   | -    | -                          |               | -                            |
| Size     | 3:0   | RW   | Size of the address space: |               | Depends on the configuration |
|          |       |      | ox0: Invalid slave         | ox8: 128K     |                              |
|          |       |      | ox1: 1K                    | ox9: 256K     |                              |
|          |       |      | ox2: 2K                    | oxA: 512K     |                              |
|          |       |      | ox3: 4K                    | oxB: 1M       |                              |
|          |       |      | ox4: 8K                    | oxC: 2M       |                              |
|          |       |      | ox5: 16K                   | oxD: 4M       |                              |
|          |       |      | ox6: 32K                   | oxE: 8M       |                              |
|          |       |      | ox7: 64K                   | oxF: Reserved |                              |

**Table 28-11 Base/Size Register of AHB Slave 11–15 in 32-bit Mode**

| Name     | Bit   | Type | Description                |                   | Reset                        |
|----------|-------|------|----------------------------|-------------------|------------------------------|
| Base     | 31:20 | RW   | Base address               |                   | Depends on the configuration |
| Reserved | 19:4  | -    | -                          |                   | -                            |
| Size     | 3:0   | RW   | Size of the address space: |                   | Depends on the configuration |
|          |       |      | ox0: Invalid slave         | ox8: 128M         |                              |
|          |       |      | ox1: 1M                    | ox9: 256M         |                              |
|          |       |      | ox2: 2M                    | oxA: 512M         |                              |
|          |       |      | ox3: 4M                    | oxB: 1G           |                              |
|          |       |      | ox5: 16M                   | oxC: 2G           |                              |
|          |       |      | ox6: 32M                   | oxD–oxF: reserved |                              |
|          |       |      | ox7: 64M                   |                   |                              |

## 28.4 Hardware Configuration Options

### 28.4.1 Address Width

Define the following macro to set the address width to 24-bit. Default address width is 32-bit.

```
`define ATCBMC200_ADDR_WIDTH_24
```

### 28.4.2 Number of AHB Master Ports

Define ATCBMC200\_AHB\_MSTm to enable the respective AHB master port, where valid values for mrange from 1 to 15. For example, to enable AHB master 1 and 3, the following macros shall be defined:

```
`define ATCBMC200_AHB_MST1
`define ATCBMC200_AHB_MST3
```

### 28.4.3 Number of AHB Slave Ports

Define ATCBMC200\_AHB\_SLVn to enable the respective AHB slave port, where valid values for n range from 1 to 15. For example, to enable AHB slave 2 and 5, the following macros shall be defined:

```
`define ATCBMC200_AHB_SLV2
`define ATCBMC200_AHB_SLV5
```

### 28.4.4 Master and Slave Ports Connectivity

Define ATCBMC200\_MSTm\_SLVn to enable the bus matrix connection between AHB master mand slave n. For example, to create a bus matrix where slave 0, 1 and 2 are connected to master 0; slave 0 and 2 are connected to master 1; slave 1 and 2 are connected to master 3, the following macros shall be defined:

```
`define ATCBMC200_MST0_SLV0
`define ATCBMC200_MST0_SLV1
`define ATCBMC200_MST0_SLV2
`define ATCBMC200_MST1_SLV0
`define ATCBMC200_MST1_SLV2
`define ATCBMC200_MST3_SLV1
`define ATCBMC200_MST3_SLV2
```

### 28.4.5 Slave Base Address

The default base address of AHB slave n is defined by macro ATCBMC200\_AHB\_SLVn\_BASE, where valid values of n ranges from 0 to 15. These are the reset values for the Base field of the Base/Size Registers. The values are read-only for slave 1–10 and the values for slave 11–15 are programmable. Note that the slave base address must be slave-size aligned.

In the 32-bit address mapping mode, the value should be 32-bit wide.

In addition, bit[19:0] shall be 0 because the minimum space in 32-bit mode is 1MB. The following example assigns AHB slave 5 to 0x90300000:

```
'define ATCBMC200_AHB_SLV5_BASE 32'h9030_0000
```

In 24-bit address mapping mode, the value should be 24-bit wide. In addition, bit[9:0] shall be 0 because the minimum space in 24-bit mode is 1KB. The following example assigns AHB slave 6 to 0x7a0000:

```
'define ATCBMC200_AHB_SLV6_BASE 24'h7a_0000
```

## 28.4.6 Slave Size

The default size of AHB slave n is defined by macro ATCBMC200\_AHB\_SLVn\_SIZE, where valid values of n ranges from 1 to 15. These are reset values for the Size field of the Base/Size Registers. The values are read-only for slave 1–10 and the values for slave 11–15 are programmable.

Table 28-12 Slave Sizes Encoding Tables shows the valid values for this macro. The encoding has different meaning depending on the address mapping mode (32-bit or 24-bit mode). The following example defines a 16MB space for AHB slave 3 in the 32-bit mode:

```
'define ATCBMC200_AHB_SLV3_SIZE 4'h5
```

Table 28-12 Slave Sizes Encoding Table

| ATCBMC200_AHB_SLVn_SIZE | Address Space Size in 32-bit mode | Address Space Size in 24-bit mode |
|-------------------------|-----------------------------------|-----------------------------------|
| 4'ho                    | No slave                          | No slave                          |
| 4'h1                    | 1M                                | 1K                                |
| 4'h2                    | 2M                                | 2K                                |
| 4'h3                    | 4M                                | 4K                                |
| 4'h4                    | 8M                                | 8K                                |
| 4'h5                    | 16M                               | 16K                               |
| 4'h6                    | 32M                               | 32K                               |
| 4'h7                    | 64M                               | 64K                               |
| 4'h8                    | 128M                              | 128K                              |
| 4'h9                    | 256M                              | 256K                              |
| 4'hA                    | 512M                              | 512K                              |
| 4'hB                    | 1G                                | 1M                                |
| 4'hC                    | 2G                                | 2M                                |
| 4'hD                    | Reserved                          | 4M                                |
| 4'hE                    | Reserved                          | 8M                                |
| 4'hF                    | Reserved                          | Reserved                          |

# 29 ATCAPBBRG100

## 29.1 Introduction

The AndeShape ATCAPBBRG100 bridge converts transactions between an AHB bus and an APB bus.

### 29.1.1 Features

- Compliant with the AMBA 2 AHB protocol
- Compliant with the AMBA 4 APB protocol
- Support of various synchronous AHB/APB clock ratios (N:1, N = 1, 2, 3, ...)
- Support of up to 31 APB slaves
- Support of 32-bit or 24-bit addressing mode
- Support of write buffering
- Hardware-configurable base address and size for each APB slave
- Slave information registers for automatic bus component discovery

### 29.1.2 Block Diagram

Figure 29-1 ATCAPBBRG100 Block Diagram shows the block diagram of the ATCAPBBRG100 bridge.

**Figure 29-1 ATCAPBBRG100 Block Diagram**



### 29.1.3 Function Description

The AndeShape ATCAPBBRG100 bridge converts transactions between an AHB bus and an APB bus. The bridge is compliant with AMBA 4 specifications. It is a slave on the AHB bus and is the only master on the APB bus.

AHB transactions are dispatched to APB slaves according to the slave base address and space size configurations. APB slave 0 represents the bridge for the register file access.

The register file keeps the configuration information for software to get the ATCAPBBRG100 ability and to enumerate the APB slaves. It also contains a field to control the write buffering scheme.

## 29.2 Signal Description

Figure 29-2 ATCAPBBRG100 Logic Symbol shows the logic symbol of the ATCAPBBRG100 bridge.

Figure 29-2 ATCAPBBRG100 Logic Symbol



Table 29-1 ATCAPBBRG100 Signal Definition gives the detailed descriptions of ATCAPBBRG100 I/O signals.

**Table 29-1 ATCAPBBRG100 Signal Definition**

| Signal Name              | I/O Type | Description                                                                                                                                                                       |
|--------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>AHB Bus Interface</b> |          |                                                                                                                                                                                   |
| hclk                     | I        | AHB clock                                                                                                                                                                         |
| apb2ahb_clken            | I        | AHB clock enable is an AHB domain signal indicating the valid AHB clock cycles to sample and update APB domain signals when the AHB frequency is a multiple of the APB frequency. |
| hresetn                  | I        | AHB reset signal (Active -Low)                                                                                                                                                    |
| hsel                     | I        | AHB slave select signal                                                                                                                                                           |
| haddr[ADDR_MSB:o]        | I        | AHB address bus. The value of ADDR_MSB depends on the configuration.                                                                                                              |
| hprot[3:o]               | I        | AHB protect signal                                                                                                                                                                |
| hsize[2:o]               | I        | AHB data size signal                                                                                                                                                              |
| htrans[1:o]              | I        | AHB transfer type signal                                                                                                                                                          |
| hready_in                | I        | AHB hready signal to indicate the previous transfer is complete                                                                                                                   |
| hwdata[31:o]             | I        | AHB write data bus                                                                                                                                                                |
| hwrite                   | I        | AHB read/write control signal                                                                                                                                                     |
| hready                   | O        | AHB hready signal is returned to the master                                                                                                                                       |
| hrdata[31:o]             | O        | AHB read data bus is returned to the master                                                                                                                                       |
| hresp[1:o]               | O        | AHB response signal is returned to the master                                                                                                                                     |
| <b>APB Bus Interface</b> |          |                                                                                                                                                                                   |
| pclk                     | I        | APB clock                                                                                                                                                                         |
| presetn                  | I        | APB reset signal (Active-Low)                                                                                                                                                     |
| psn_psel                 | O        | APB select signal<br>This signal indicates that APB slave <i>n</i> is selected                                                                                                    |
| psn_prdata[31:o]         | I        | APB read data of slave <i>n</i><br>The read data bus is driven by APB slave <i>n</i> device during the read cycles                                                                |

| Signal Name              | I/O Type | Description                                                                                                                                                    |
|--------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>psn_pready</i>        | I        | APB ready of slave <i>n</i><br>The slave uses this signal to extend an APB transfer                                                                            |
| <i>psn_pslverr</i>       | I        | This signal indicates a transfer failure of the slave <i>n</i>                                                                                                 |
| <i>paddr[ADDR_MSB:0]</i> | O        | APB address bus. The value of ADDR_MSB depends on the configuration.<br>ADDR_MSB = 23 for 24-bit addressing mode;<br>ADDR_MSB = 31 for 32-bit addressing mode. |
| <i>penable</i>           | O        | APB enable signal translated from the AHB master port                                                                                                          |
| <i>pprot[2:0]</i>        | O        | APB protect signal translated from the AHB master port.                                                                                                        |
| <i>pstrb[3:0]</i>        | O        | APB write strobe signal translated from the AHB master port.                                                                                                   |
| <i>pwrite</i>            | O        | APB write signal translated from the AHB master port                                                                                                           |
| <i>pwdata[31:0]</i>      | O        | APB write data bus translated from the AHB master port                                                                                                         |

## 29.2.1 Clock Enable Signal

The ATCAPBBRG100 design has an AHB clock enable input signal. The clock enable signal indicates the valid AHB clock cycles to sample and update APB domain signals when the AHB frequency is an integer multiple of the APB frequency. It must assert for one AHB clock cycle for each APB clock. An example is illustrated in Figure 29-3 ATCAPBBRG100 Clock Enable Signal for 4:1 AHB-to-APB Clock Ratio for the case that the AHB frequency is 4 times of the APB frequency. For the special case that AHB clock and APB clock are identical, the clock enable signal must be always high.

Figure 29-3 ATCAPBBRG100 Clock Enable Signal for 4:1 AHB-to-APB Clock Ratio



## 29.3 Programming Model

### 29.3.1 Summary of Registers

Table 29-2 ATCAPBBRG100 Register Summary shows a summary of the ATCAPBBRG100 registers.

Table 29-2 ATCAPBBRG100 Register Summary

| Offset     | Name      | Description                                             |
|------------|-----------|---------------------------------------------------------|
| +0x00      | IdRev     | ID and revision register                                |
| +0x04~0x10 | -         | Reserved                                                |
| +0x14      | Ctrl      | Control register                                        |
| +0x18~0x1C | -         | Reserved                                                |
| +0x20~0x98 | BaseSizen | Base/size register of APB slave $n$ ( $n = 1 \sim 31$ ) |

### 29.3.2 Register Description

The abbreviations for the Type column are summarized below.

RO: read only

RW: readable and writable

### 29.3.3 ID and Revision Register (0x00)

This register holds the ID number and the revision number. The reset values of the two revision fields are revision dependent.

**Table 29-3 ID and Revision Register**

| Name     | Bit  | Type | Description                | Reset              |
|----------|------|------|----------------------------|--------------------|
| ID       | 31:8 | RO   | ID number for ATCAPBBRG100 | 0x0000210          |
| RevMajor | 7:4  | RO   | Major revision number      | Revision dependent |
| RevMinor | 3:0  | RO   | Minor revision number      | Revision dependent |

### 29.3.4 Control Register (0x14)

This register controls the behavior of the ATCAPBBRG100 bridge. The **WBUF\_EN** bit enables write buffering on the bridge. When write buffering is enabled, responses are returned to the master immediately before the write transaction is issued to the APB bus. This effectively shortens the write transaction latency. All buffered write transactions are issued to the APB bus in order and a subsequent read transaction waits until the buffered write transaction completes.

**Table 29-4 Configuration Register**

| Name     | Bit  | Type | Description                                                                                                                                                                                                                                                                                                             | Reset |
|----------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved | 31:1 | -    | -                                                                                                                                                                                                                                                                                                                       | -     |
| WBUF_EN  | 0    | RW   | Force the write buffering for all writes<br>1: Set this bit to force write buffering.<br>All write transactions from the AHB<br>master will be buffered in the bridge.<br>0: Writing buffering is based on AHB<br>HPROT signal.<br>Note: When toggling this bit, there<br>should be no outstanding APB<br>transactions. | 0     |

### 29.3.5 Base/Size Register of Slave 1~n (0x20 + (n-1) \* 0x4)

This register shows the base address offset and the size of APB slave n (n = 1 ~ 31). The register format is shown in Table 29-5 Base/Size Register of Slave 1~n in 24-bit mode and Table 29-6 Base/Size Register of Slave 1~n in 32-bit mode for 24-bit and 32-bit addressing modes, respectively.

**Table 29-5 Base/Size Register of Slave 1~n in 24-bit mode**

| Name     | Bit      | Type | Description                                                                                                                                                                                                                                                                                                                      | Reset                        |
|----------|----------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| Reserved | 23:M     | -    | M =<br><br>ATCAPBBRG100_ADDR_DECODE_WIDTH                                                                                                                                                                                                                                                                                        | -                            |
| Base     | (M-1):10 | RO   | Base address offset                                                                                                                                                                                                                                                                                                              | Depends on the configuration |
| Reserved | 9:4      | -    | -                                                                                                                                                                                                                                                                                                                                | -                            |
| Size     | 3:0      | RO   | Size of the address space:<br><br>0x0: invalid slave<br><br>0x1: 1KiB<br><br>0x2: 2KiB<br><br>0x3: 4KiB<br><br>0x4: 8KiB<br><br>0x5: 16KiB<br><br>0x6: 32KiB<br><br>0x7: 64KiB<br><br>0x8: 128KiB<br><br>0x9: 256KiB<br><br>0xA: 512KiB<br><br>0xB: 1MiB<br><br>0xC: 2MiB<br><br>0xD: 4MiB<br><br>0xE: 8MiB<br><br>0xF: Reserved | Depends on the configuration |

**Table 29-6 Base/Size Register of Slave 1~n in 32-bit mode**

| Name     | Bit      | Type | Description                                                                                                                                                                                                                                                                                        | Reset                        |
|----------|----------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| Reserved | 31:M     | -    | M =<br><br>ATCAPBBRG100_ADDR_DECODE_WIDTH                                                                                                                                                                                                                                                          | -                            |
| Base     | (M-1):20 | RO   | Base address offset                                                                                                                                                                                                                                                                                | Depends on the configuration |
| Reserved | 19:4     | -    |                                                                                                                                                                                                                                                                                                    | -                            |
| Size     | 3:0      | RO   | Size of the address space:<br><br>ox0: invalid slave<br><br>ox1: 1MiB<br><br>ox2: 2MiB<br><br>ox3: 4MiB<br><br>ox4: 8MiB<br><br>ox5: 16MiB<br><br>ox6: 32MiB<br><br>ox7: 64MiB<br><br>ox8: 128MiB<br><br>ox9: 256MiB<br><br>oxA: 512MiB<br><br>oxB: 1GiB<br><br>oxC: 2GiB<br><br>oxD~oxF: Reserved | Depends on the configuration |

## 29.4 Hardware Configuration Options

### 29.4.1 Address Width

Define the following macro to set the address width to 24-bit. Default address width is 32-bit.

```
`define ATCAPBBRG100_ADDR_WIDTH_24
```

### 29.4.2 Address Decode Width

Define [ATCAPBBRG100\\_ADDR\\_DECODE\\_WIDTH](#) to identify the width of the APB address decoding logic. The APB address decoding logic only decodes the partial address bits receiving from the AHB slave port. For 24-bit mode, this macro could be 11~24; for 32-bit mode, this macro could be 21~32. For example,

```
`define ATCAPBBRG100_ADDR_DECODE_WIDTH 16
```

In this case, the address decoding logic only decodes the address bit [15:0] to select the target APB slave.

### 29.4.3 APB Slave Ports

Define ATCAPBBRG100\_SLV\_n to enable the nth APB slave ports, where n=1~31. For example,

```
`define ATCAPBBRG100_SLV_1
`define ATCAPBBRG100_SLV_2
```

### 29.4.4 APB Slave Size

Define ATCAPBBRG100\_SLVn\_SIZE (n=1~31) to identify the space size of the nth APB slave based on Table 5 and Table 6 for 24-bit mode and 32-bit mode, respectively. For example, specify the space size of APB slave #1 to be 4KiB in 24-bit mode:

```
`define ATCAPBBRG100_SLV1_SIZE 3
```

### 29.4.5 APB Slave Base Address Offset

Define ATCAPBBRG100\_SLVn\_OFFSET (n=1~31) to identify the base address offset of the n<sup>th</sup> APB slave. The value of the offset must be slave-size aligned and it should be a Verilog hexadecimal constant number with bit width specified. The bit width should be equal to the Address Decode Width, which reflects the total address space size of the APB bus (see Address Decode Width).

For example, suppose the size of the entire APB bus address space is 64KiB and the size of the APB slave 1 is 4KiB. The offset value must be an integral multiple of 4KiB (e.g., 0x1000), and the width of the offset value should be  $\log_2(64K) = 16$ . Thus, the definition for specifying the address offset of the APB slave 1 at 0x1000 is:

```
`define ATCAPBBRG100_SLV1_OFFSET 16'h1000
```

## 29.5 Access Latencies

Table 29-7 ATCAPBBRG100 Access Latencies summarizes the ATCAPBBRG100 access latencies, the number of elapsed clock cycles on the upstream port between the moment an address is accepted and the moment the corresponding data/status is available. Table 29-7 ATCAPBBRG100 Access Latencies shows the minimum latency cycles, which are made with the following assumptions:

- The downstream APB interface inserts zero wait state.
- Zero arbitration wait state
- The frequency ratio of the AHB clock to the APB clock is n:1. The two clocks are synchronously related.

**Table 29-7 ATCAPBBRG100 Access Latencies**

| <b>Request Type</b>                                         | <b>Latencies (AHB Clock Cycles)</b> |
|-------------------------------------------------------------|-------------------------------------|
| <b>AHB Interface (1:1 Identical Clock Configuration)</b>    |                                     |
| Read                                                        | 2                                   |
| Non-bufferable Write                                        | 3                                   |
| Bufferable Write (when buffer is NOT full)                  | 1                                   |
| Bufferable Write (when buffer is full)                      | 2                                   |
| <b>AHB Interface (n :1 Synchronous Clock Configuration)</b> |                                     |
| Read                                                        | $2n + (n-1)$                        |
| Non-bufferable Write                                        | $2n+1$                              |
| Bufferable Write (when buffer is NOT full)                  | 1                                   |
| Bufferable Write (when buffer is full)                      | $2n$                                |

For bufferable writes, the upstream interface always receives an OKAY response if an internal buffer entry is available (not full). This means that the minimum access latency of bufferable writes is one AHB clock cycle. If the buffer is full, an additional access latency of at least  $2n$  AHB clock cycles will occur, which is the amount of time for the downstream interface to drain one internal buffer entry.

The propagation delay of the specific bufferable write request from the upstream interface to the downstream interface is two AHB clock cycles minimally.

# 30 ATCAPBDEC100

## 30.1 Introduction

AndeShape™ ATCAPBDEC100 is an APB bus decoder dispatching bus transactions from an APB master to APB slaves according to the bus address mapping, which is hardware-configurable.

### 30.1.1 Features

- Compliant with AMBA™ 3 APB protocol specification
- Supports up to 31 APB slaves
- Supports 32-bit or 24-bit addressing mode
- Hardware-configurable base address and size for each APB slave
- Slave information registers for automatic bus component discovery

### 30.1.2 Block Diagram

Figure 30-1 ATCAPBDEC100 Block Diagram shows the block diagram of the ATCAPBDEC100 decoder.

Figure 30-1 ATCAPBDEC100 Block Diagram



### 30.1.3 Function Description

AndeShape™ ATCAPBDEC100 is an APB bus decoder dispatching bus transactions from the APB master to APB slaves. The decoder is compliant with AMBA™ 3 specifications. It has the following blocks:

- an upstream APB port receiving transactions from an APB master,
- a combinational decoding logic for dispatching the transactions,
- a downstream APB port transmitting transactions to APB slaves,
- a register file recording informations about the slaves.

APB transactions from the master are dispatched to APB slaves according to the slave base address and space size configurations. APB slave 0 is the ATCAPBDEC100 register file. The register file keeps the configuration information about the ATCAPBDEC100 capabilities and the slave address mappings.

## 30.2 Signal Description

The signal overview is illustrated in Figure 29-2 ATCAPBBRG100 Logic Symbol

Figure 30-2 ATCAPBDEC100 Input/Output Signals



Table 30-1 ATCAPBDEC100 Signal Definition gives the descriptions of the ATCAPBDEC100 input/output (I/O) signals.

Table 30-1 ATCAPBDEC100 Signal Definition

| Signal Name       | I/O Type | Description                                                                                                                    |
|-------------------|----------|--------------------------------------------------------------------------------------------------------------------------------|
| pclk              | I        | APB clock                                                                                                                      |
| presetn           | I        | APB reset signal. (active low)                                                                                                 |
| psel              | I        | APB select signal from the APB master.                                                                                         |
| paddr[ADDR_MSB:o] | I        | APB address bus from the APB master.<br>ADDR_MSB = 23 for 24-bit addressing mode;<br>ADDR_MSB = 31 for 32-bit addressing mode. |
| prdata[31:o]      | O        | APB read data bus for the APB master.                                                                                          |
| pready            | O        | APB ready for the APB master.                                                                                                  |
| pslverr           | O        | APB slave error for the APB master.                                                                                            |
| psn_psel          | O        | APB select signal for the slave <i>n</i> .<br>This signal indicates that the APB slave <i>n</i> is selected.                   |
| psn_prdata[31:o]  | I        | APB read data from the slave <i>n</i> .<br>The read data bus is driven by the APB slave <i>n</i> during the read cycles.       |
| psn_pready        | I        | APB ready from the slave <i>n</i> .<br>The slave uses this signal to extend an APB transfer.                                   |
| psn_pslverr       | I        | This signal indicates a transfer failure from the slave <i>n</i> .                                                             |

## 30.3 Programming Model

### 30.3.1 Summary of Registers

Table 29-2 ATCAPBBRG100 Register Summary shows a summary of the ATCAPBDEC100 registers.

**Table 30-2 ATCAPBDEC100 Register Summary**

| Offset     | Name      | Description                                             |
|------------|-----------|---------------------------------------------------------|
| +0x00      | IdRev     | ID and revision register                                |
| +0x04~0x1C | -         | Reserved                                                |
| +0x20~0x98 | BaseSizen | Base/size register of APB slave $n$ ( $n = 1 \sim 31$ ) |

### 30.3.2 Register Description

The abbreviations for the Type column are summarized below.

RO: read only

RW: readable and writable

### 30.3.3 ID and Revision Register (0x00)

This register holds the ID number and the revision number. The reset values of the two revision fields are revision dependent.

**Table 30-3 ID and Revision Register**

| Name     | Bit   | Type | Description                | Reset              |
|----------|-------|------|----------------------------|--------------------|
| ID       | 31:12 | RO   | ID number for ATCAPBDEC100 | 0x000031           |
| RevMajor | 11:4  | RO   | Major revision number      | Revision dependent |
| RevMinor | 3:0   | RO   | Minor revision number      | Revision dependent |

### 30.3.4 Base/Size Register of Slave 1~ n (0x20 + (n-1) \* 0x4)

This register holds the base address offset and the size of APB slave  $n$  ( $n = 1 \sim 31$ ). The register format is shown in Table 29-4 Configuration Register and Table 29-5 Base/Size Register of Slave 1~n in 24-bit mode for 24-bit and 32-bit addressing mode, respectively.

**Table 30-4 Base/Size Register of Slave 1~n in the 24-bit Mode**

| Name     | Bit      | Type | Description                                                                                                                                                                                                                          | Reset                        |
|----------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| Reserved | 23:M     | -    | M = ATCAPBDEC100_ADDR_DECODE_WIDTH                                                                                                                                                                                                   | -                            |
| Base     | (M-1):10 | RO   | Base address offset                                                                                                                                                                                                                  | Depends on the configuration |
| Reserved | 9:4      | -    | -                                                                                                                                                                                                                                    | -                            |
| Size     | 3:0      | RO   | Size of the address space:<br>0x0: invalid slave<br>0x1: 1K<br>0x2: 2K<br>0x3: 4K<br>0x4: 8K<br>0x5: 16K<br>0x6: 32K<br>0x7: 64K<br>0x8: 128K<br>0x9: 256K<br>0xA: 512K<br>0xB: 1M<br>0xC: 2M<br>0xD: 4M<br>0xE: 8M<br>0xF: Reserved | Depends on the configuration |

**Table 30-5 Base/Size Register of Slave 1~n in the 32-bit Mode**

| Name     | Bit      | Type | Description                                                                                                                                                                                                        | Reset                        |
|----------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| Reserved | 31:M     | -    | M = ATCAPBDEC100_ADDR_DECODE_WIDTH                                                                                                                                                                                 | -                            |
| Base     | (M-1):20 | RO   | Base address offset                                                                                                                                                                                                | Depends on the configuration |
| Reserved | 19:4     | -    | -                                                                                                                                                                                                                  | -                            |
| Size     | 3:0      | RO   | Size of the address space:<br>0x0: invalid slave<br>0x1: 1M<br>0x2: 2M<br>0x3: 4M<br>0x4: 8M<br>0x5: 16M<br>0x6: 32M<br>0x7: 64M<br>0x8: 128M<br>0x9: 256M<br>0xA: 512M<br>0xB: 1G<br>0xC: 2G<br>0xD~0xF: Reserved | Depends on the configuration |

## 30.4 Hardware Configuration Options

### 30.4.1 Hardware Configuration Options

Define the following macro to set the address width to 24-bit. Default address width is 32-bit.

```
`define ATCAPBDEC100_ADDR_WIDTH_24
```

### 30.4.2 Address Decode Width

Define ATCAPBDEC100\_ADDR\_DECODE\_WIDTH to identify the partial address bits for APB address decoding. The APB address decoding logic only decodes the partial address bits received from the APB master. This value also reflects the total address space size of the APB bus. For the 24-bit mode, this macro could be 11~24; for the 32-bit mode, this macro could be 21~32. For example,

```
`define ATCAPBDEC100_ADDR_DECODE_WIDTH 16
```

In this case, the address decoding logic only decodes the address bit [15:0] for selecting the target APB slave.

### 30.4.3 APB Slave Ports

Define ATCAPBDEC100\_SLV\_n to enable the n<sup>th</sup> APB slave port,

where n=1~31. For example,

```
`define ATCAPBDEC100_SLV_1  
`define ATCAPBDEC100_SLV_2
```

#### 30.4.4 APB Slave Size

Define ATCAPBDEC100\_SLVn\_SIZE (n=1~31) to identify the address space size of the  $n^{\text{th}}$  APB slave. The values are defined in Table 29-4 and Table 29-5 for the 24-bit mode and the 32-bit mode, respectively. For example, specify the address space size of APB slave #1 to be 4KB in the 24-bit mode:

```
`define ATCAPBDEC100_SLV1_SIZE 3
```

#### 30.4.5 APB Slave Base Address Offset

Define ATCAPBDEC100\_SLVn\_OFFSET (n=1~31) to identify the base address offset of the  $n^{\text{th}}$  APB slave. The value of the offset must be slave-size aligned and it should be a Verilog hexadecimal constant number with bit width specified. The bit width should be equal to the Address Decode Width, which reflects the total address space size of the APB bus (see Address Decode Width).

For example, suppose the size of the entire APB bus address space is 64KB and the size of the APB slave 1 is 4KB. The offset value must be integral multiple of 4K (e.g., 0x1000), and the width of the offset value should be  $\log_2(64K) = 16$ . Thus, the definition for specifying the address offset of the APB slave 1 at 0x1000 is:

```
`define ATCAPBDEC100_SLV1_OFFSET 16'h1000
```

# 31 ATCDMAC100

## 31.1 Introduction

AndeShape ATCDMAC100 is a direct memory access controller which transfers regions of data efficiently on bus.

### 31.1.1 Features

- Compliant with AMBA 2 AHB protocol specification
- Support of up to 8 DMA channels
- Support of up to 32 request/acknowledge pairs for hardware handshaking
- Support of round-robin arbitration with 2 priority levels
- Support of 8/16/32-bit wide data transfer
- Support of 24/32-bit address bus
- Support of chain transfer

### 31.1.2 Block Diagram

Figure 31-1 ATCDMAC100 Block Diagram shows the block diagram of ATCDMAC100, which contains one AHB master interface for data transfer and one AHB slave interface for register programming.

**Figure 31-1 ATCDMAC100 Block Diagram**



### 31.1.3 Function Description

ATCDMAC100 supports up to 8 DMA channels. Each DMA channel provides a set of registers to describe the intended data transfers. Multiple DMA channels can be enabled concurrently, but the DMA controller services one channel at a time.

Figure 31-2 Example of DMA Data Transfers shows an illustration of data transfer timing for a channel. To prevent channels from being starved, the DMA controller services all ready-channels alternatively, performing at most SrcBurstSize data transfers each time. Consequently, the data transfers of a channel may be split into several chunks when the total transfer size (TranSize) is larger than the source burst size (SrcBurstSize). When the overall data transfers of a channel complete, the DMA controller will update the interrupt status register, IntStatus, and assert the `dma_int` interrupt signal if the terminal count interrupt is enabled.

The data transfers of a channel will be stopped when an error occurs. The data transfers of a channel can also be aborted by software. In either case, the DMA controller will disable the channel, and assert `dma_int` if the corresponding interrupt is enabled.

**Figure 31-2 Example of DMA Data Transfers**



### 31.1.4 Channel Arbitration

ATCDMAC100 provides two priority levels for channel arbitration. Every channel is associated with a priority level by the Priority field of the channel control register, ChnCtrl. During the channel arbitration, the DMA controller selects a high priority channel first. A low priority channel is only selected if there is no high priority channel. Channels of the same priority level will be selected by the round-robin scheme.

### 31.1.5 Hardware Handshaking

ATCDMAC100 provides up to 32 pairs of hardware handshake signals ([dma\\_req/dma\\_ack](#)) for data transfers with low-speed devices. Figure 31-3 Example of Hardware Handshaking gives an example of hardware handshaking. The device should assert [dma\\_req](#) only when it prepares enough data to transfer or when it has enough empty space to receive the incoming data. The DMA controller only issues bus requests to read/write the data when it sees the [dma\\_req](#) asserted, avoiding holding the bus in the wait state indefinitely. The DMA controller asserts [dma\\_ack](#) when it completes SrcBurstSize data transfers from/to the device. The device should de-assert [dma\\_req](#) after detecting the assertion of [dma\\_ack](#). The DMA controller should de-assert [dma\\_ack](#) after detecting the de-assertion of [dma\\_req](#). If an error is encountered during the data transfers, the DMA controller will disable the channel without asserting [dma\\_ack](#). The error handling software should reset both the source and destination of the DMA transfer to deassert [dma\\_req](#).

**Figure 31-3 Example of Hardware Handshaking**



### 31.1.6 Chain Transfer

ATCDMAC100 provides the chain transfer function, with which multiple blocks of data can be transferred consecutively without the intervention of the main processor.

Before a chain transfer is started, a linked list structure must be built to describe the data blocks to move and the associated control setups. The first element of the list (the head of the list) is described by the channel control registers. The rest of elements of the list are specified by the linked list descriptors stored in the memory, where the linked list descriptor holds the control values to load to the channel control registers to continue the data transfer. Figure 31-4 Linked List Structure for Chain Transfers shows an example of the linked list structure.

When the channel is enabled, the DMA controller will first transfer data according to the channel control registers. After the data transfer completes, the DMA controller will continue the data transfer by following the ChnLLPointer. The content of the linked list descriptor pointed by ChnLLPointer will be loaded to the channel control registers if ChnLLPointer is not zero. The loaded descriptor becomes the new head of the list and this process repeats until the ChnLLPointer is zero.

Figure 31-4 Linked List Structure for Chain Transfers



When the terminal count interrupt (IntTCMask) of a channel is enabled, the DMA controller will generate an interrupt and disable the channel when the data transfer for the head of the list is done. If the ChnLLPointer is not zero, the channel control registers will be preloaded with the next descriptor before the interrupt is generated. The interrupt handling software could resume the chain transfer by just re-enabling the channel.

Table 31-1 Format of Linked List Descriptor shows the format of the linked list descriptor. The bit field definition of each descriptor word is the same as the corresponding channel control register except the channel enable bit, which is reserved in the linked list descriptor.

**Table 31-1 Format of Linked List Descriptor**

| <b>Name</b> | <b>Offset</b> | <b>Description</b>  | <b>Format</b> |
|-------------|---------------|---------------------|---------------|
| Ctrl        | 0x00          | Channel control     | See Table 10  |
| SrcAddr     | 0x04          | Source address      | See Table 11  |
| DstAddr     | 0x08          | Destination address | See Table 12  |
| TranSize    | 0x0C          | Total transfer size | See Table 13  |
| LLPointer   | 0x10          | Linked list pointer | See Table 14  |

### 31.1.7 Data Order

ATCDMAC100 provides three address control modes: increment mode, decrement mode, and fixed mode. At the increment mode, the address is increased after the DMA controller accesses a data of the source/destination. At the decrement mode, the address is decreased after the DMA controller accesses a data of the source/destination. At the fixed mode, the address remains unchanged after the DMA controller accesses a data of the source/destination.

When the address control mode of the source is the same as that of the destination, the DMA controller maintains the same byte order of the data between the source and the destination. When the address control mode of the source is opposite to that of the destination, the data written to the destination will be in the reverse byte order of that read from the source. The data order of the fixed mode is treated the same as that of the increment mode.

Figure 31-5 Data Order at the Destination when the Source Address Mode is the Increment Mode, Figure 31-6 Data Order at the Destination when the Source Address Mode is the Decrement Mode and Figure 31-7 Data Order at the Destination when the Source Address Mode is the Fixed Mode illustrate the byte order of the data at the destination when the source address mode is increment, decrement, and fixed respectively.

**Figure 31-5 Data Order at the Destination when the Source Address Mode is the Increment Mode**



**Figure 31-6 Data Order at the Destination when the Source Address Mode is the Decrement Mode**



**Figure 31-7 Data Order at the Destination when the Source Address Mode is the Fixed Mode**



## 31.2 Signal Description

Figure 31-8 ATCDMAC100 Interfaces shows the interfaces of the ATCDMAC100.

**Figure 31-8 ATCDMAC100 Interfaces**



Table 31-2 ATCDMAC100 Signal Definition gives the detailed descriptions of ATCDMAC100 I/O signals.

**Table 31-2 ATCDMAC100 Signal Definition**

| Signal Name               | I/O Type | Description                                                                         |
|---------------------------|----------|-------------------------------------------------------------------------------------|
| <b>AHB global signals</b> |          |                                                                                     |
| hclk                      | I        | System bus clock                                                                    |
| hresetn                   | I        | System bus reset                                                                    |
| <b>DMA signals</b>        |          |                                                                                     |
| dma_int                   | O        | Interrupt request                                                                   |
| dma_req[M:o]              | I        | Burst transfer request<br>(M is `ATCDMAC100_REQ_ACK_NUM - 1)                        |
| dma_ack[M:o]              | O        | Burst transfer acknowledge                                                          |
| <b>AHB slave signals</b>  |          |                                                                                     |
| haddr[N:o]                | I        | AHB address bus<br>(N is 23 and 31 for AHB 24-bit and 32-bit address, respectively) |
| htrans[1:o]               | I        | AHB transfer type                                                                   |
| hwrite                    | I        | AHB write signal                                                                    |
| hsize[2:o]                | I        | AHB transfer size                                                                   |
| hburst[2:o]               | I        | AHB burst type                                                                      |
| hwdata[31:o]              | I        | AHB write data bus                                                                  |
| hsel                      | I        | AHB slave select signal                                                             |
| hreadyin                  | I        | AHB ready input                                                                     |
| hrdata[31:o]              | O        | AHB read data bus                                                                   |
| hresp[1:o]                | O        | AHB transfer response                                                               |
| hready                    | O        | AHB ready output                                                                    |
| <b>AHB master signals</b> |          |                                                                                     |
| haddr_mst[N:o]            | O        | AHB address bus                                                                     |
| htrans_mst[1:o]           | O        | AHB transfer type                                                                   |

| Signal Name      | I/O Type | Description            |
|------------------|----------|------------------------|
| hwrite_mst       | O        | AHB write signal       |
| hsize_mst[2:0]   | O        | AHB transfer size      |
| hprot_mst[3:0]   | O        | AHB protection control |
| hlock_mst        | O        | AHB lock request       |
| hburst_mst[2:0]  | O        | AHB burst type         |
| hwdata_mst[31:0] | O        | AHB write data bus     |
| hrdata_mst[31:0] | I        | AHB read data bus      |
| hresp_mst[1:0]   | I        | AHB transfer response  |
| hready_mst       | I        | AHB data ready input   |
| hbusreq_mst      | O        | AHB bus request signal |
| hgrant_mst       | I        | AHB bus grant signal   |

## 31.3 Programming Model

### 31.3.1 Register Summary

ATCDMAC100 Register Summary shows a summary of the ATCDMAC100 registers.

Table 31-3 ATCDMAC100 Register Summary

| Offset                           | Name         | Description                              |
|----------------------------------|--------------|------------------------------------------|
| <b>ID and revision register</b>  |              |                                          |
| +0x00                            | IdRev        | ID and revision register                 |
| +0x04~0xC                        | -            | Reserved                                 |
| <b>Configuration register</b>    |              |                                          |
| +0x10                            | DMACfg       | DMAC configuration register              |
| +0x14~0x1C                       | -            | Reserved                                 |
| <b>Global control registers</b>  |              |                                          |
| +0x20                            | DMACtrl      | DMAC control register                    |
| +0x24~0x2C                       | -            | Reserved                                 |
| <b>Channel status register</b>   |              |                                          |
| +0x30                            | IntStatus    | Interrupt status register                |
| +0x34                            | ChEN         | Channel enable register                  |
| +0x38~0x3C                       | -            | Reserved                                 |
| <b>Channel control registers</b> |              |                                          |
| +0x40                            | ChAbort      | Channel abort register                   |
| +0x44 + $n \cdot 0x14$           | ChnCtrl      | Channel $n$ control register             |
| +0x48 + $n \cdot 0x14$           | ChnSrcAddr   | Channel $n$ source address register      |
| +0x4C + $n \cdot 0x14$           | ChnDstAddr   | Channel $n$ destination address register |
| +0x50 + $n \cdot 0x14$           | ChnTranSize  | Channel $n$ transfer size register       |
| +0x54 + $n \cdot 0x14$           | ChnLLPointer | Channel $n$ linked list pointer register |

### 31.3.2 Register Description

The following sections describe ATCDMAC100 registers in detail. The abbreviations for the Type column are summarized below:

**RO:** Read only

**WO:** Write only

**R/W:** Readable and writable

**R/W1C:** Readable and write 1 to clear

### 31.3.3 ID and Revision Register (Offset 0x00)

This register holds the ID number and the revision number. The reset values of the two revision fields are revision dependent.

**Table 31-4 ID and Revision Register**

| Name     | Bit   | Type | Description           | Reset              |
|----------|-------|------|-----------------------|--------------------|
| ID       | 31:12 | RO   | ID number for DMAC    | 0x01021            |
| RevMajor | 11:4  | RO   | Major revision number | Revision dependent |
| RevMinor | 3:0   | RO   | Minor revision number | Revision dependent |

### 31.3.4 DMAC Configuration Register (Offset 0x10)

**Table 31-5 DMAC Configuration Register**

| Name       | Bit   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     | Reset                   |
|------------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| ChainXfr   | 31    | RO   | Chain transfer<br>0x0: chain transfer is not configured<br>0x1: chain transfer is configured                                                                                                                                                                                                                                                                                                                                                    | Configuration dependent |
| ReqSync    | 30    | RO   | DMA request synchronization. The DMA request synchronization should be configured to avoid signal integrity problems when the request signal is not clocked by the system bus clock, which the DMA control logic operates in. If the request synchronization is not configured, the request signal is sampled directly without synchronization.<br>0x0: request synchronization is not configured<br>0x1: request synchronization is configured | Configuration dependent |
| Reserved   | 29:16 | -    | -                                                                                                                                                                                                                                                                                                                                                                                                                                               | -                       |
| ReqNum     | 15:10 | RO   | Request/acknowledge number                                                                                                                                                                                                                                                                                                                                                                                                                      | Configuration dependent |
| FIFODepth  | 9:4   | RO   | FIFO depth                                                                                                                                                                                                                                                                                                                                                                                                                                      | Configuration dependent |
| ChannelNum | 3:0   | RO   | Channel number                                                                                                                                                                                                                                                                                                                                                                                                                                  | Configuration dependent |

### 31.3.5 DMAC Control Register (Offset 0x20)

Table 31-6 DMAC Control Register

| Name     | Bit  | Type | Description                                                                               | Reset |
|----------|------|------|-------------------------------------------------------------------------------------------|-------|
| Reserved | 31:1 | -    | -                                                                                         | -     |
| Reset    | 0    | WO   | Software reset control. Set this bit to 1 to reset the DMA core and disable all channels. | ox0   |

### 31.3.6 Interrupt Status Register (Offset 0x30)

This register contains the terminal count, error, and abort status. The terminal count status of a channel is asserted when the channel encounters the terminal counter event. The error/abort status of a channel is asserted when the channel encounters the error/abort event. There is one bit of status for each channel and the status bit is zero when the corresponding channel is not configured.

Table 31-7 Interrupt Status Register

| Name     | Bit   | Type  | Description                                                                                                                                                                                                                                                     | Reset |
|----------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved | 31:24 | -     | -                                                                                                                                                                                                                                                               | -     |
| TC       | 23:16 | R/W1C | The terminal count status of DMA channels, one bit per channel. The terminal count status is asserted when a channel transfer finishes without abort or error event.<br>ox0: channel N has no terminal count status<br>ox1: channel N has terminal count status | ox0   |
| Abort    | 15:8  | R/W1C | The abort status of channel, one bit per channel. The abort status is asserted when a channel transfer is aborted.<br>ox0: channel N has no abort status<br>ox1: channel N has abort status                                                                     | ox0   |

| Name  | Bit | Type  | Description                                                                                                                                                                                                                                                                                                                                                          | Reset |
|-------|-----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Error | 7:0 | R/W1C | The error status, one bit per channel. The error status is asserted when a channel transfer encounters the following error events: <ul style="list-style-type: none"><li>▪ Bus error</li><li>▪ Unaligned address</li><li>▪ Unaligned transfer width</li><li>▪ Reserved configuration</li></ul> oxo: channel N has no error status<br>ox1: channel N has error status | ox0   |

### 31.3.7 Channel Enable Register (Offset 0x34)

The register shows the DMA channel enable status. The status fields only exist when the corresponding channels are configured. This register is an alias of the Enable fields of all ChnCtrl registers.

Table 31-8 Channel Enable Register

| Name | Bit | Type | Description                                        | Reset |
|------|-----|------|----------------------------------------------------|-------|
| ChEN | N:0 | RO   | Alias of the Enable field of all ChnCtrl registers | ox0   |

### 31.3.8 Channel Abort Register (Offset 0x40)

The register controls the abortion of the DMA channel transfers, one-bit per channel. Write 1 to stop the current transfer of the corresponding channel. The abort bit is automatically cleared by hardware when the corresponding status bit in the interrupt status register is cleared.

Table 31-9 Channel Abort Register

| Name    | Bit | Type | Description                                                                                                                                                                                           | Reset |
|---------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| ChAbort | N:0 | WO   | Write 1 to this field to stop the channel transfer.<br>The bits can only be set when the corresponding channels are enabled. Otherwise, the writes will be ignored for channels that are not enabled. | ox0   |

### 31.3.9 Channel n Control Register (Offset 0x44+n\*0x14)

Table 31-10 Channel n Control Register

| Name         | Bit   | Type | Description                                                                                                                                                                                                                                                                                                                         | Reset |
|--------------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| SrcReqSelB5  | 31    | R/W  | Bit 5 of the source DMA request selection                                                                                                                                                                                                                                                                                           | 0x0   |
| DstReqSelB5  | 30    | R/W  | Bit 5 of the destination DMA request selection                                                                                                                                                                                                                                                                                      | 0x0   |
| Priority     | 29    | R/W  | Channel priority level<br>0x0: lower priority<br>0x1: higher priority                                                                                                                                                                                                                                                               | 0x0   |
| Reserved     | 28:25 | -    | -                                                                                                                                                                                                                                                                                                                                   | -     |
| SrcBurstSize | 24:22 | R/W  | Source burst size. This field indicates the number of transfers before DMA channel re-arbitration.<br><br>Total byte of a burst is SrcBurstSize * SrcWidth.<br><br>0x0: 1 transfer<br>0x1: 2 transfers<br>0x2: 4 transfers<br>0x3: 8 transfers<br>0x4: 16 transfers<br>0x5: 32 transfers<br>0x6: 64 transfers<br>0x7: 128 transfers | 0x0   |

| Name     | Bit   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Reset |
|----------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| SrcWidth | 21:20 | R/W  | <p>Source transfer width</p> <p>0x0: byte transfer</p> <p>0x1: half-word transfer</p> <p>0x2: word transfer</p> <p>0x3: reserved, setting the field with this value triggers error exception</p>                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x2   |
| DstWidth | 19:18 | R/W  | <p>Destination transfer width.</p> <p>Both the total transfer byte and the total burst bytes should be aligned to the destination transfer width; otherwise the error event will be triggered. For example, destination transfer width should be set as byte transfer if total transfer byte is not aligned to word or half-word. See SrcBurstSize field above for the definition of total burst byte and section 3.12 for the definition of the total transfer bytes.</p> <p>0x0: byte transfer</p> <p>0x1: half-word transfer</p> <p>0x2: word transfer</p> <p>0x3: reserved, set the field as this value triggers error exception</p> | 0x2   |
| SrcMode  | 17    | R/W  | <p>Source DMA handshake mode</p> <p>0x0: normal mode</p> <p>0x1: handshake mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0   |
| DstMode  | 16    | R/W  | <p>Destination DMA handshake mode</p> <p>0x0: normal mode</p> <p>0x1: handshake mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0   |

| Name        | Bit   | Type | Description                                                                                                                                                                                                   | Reset |
|-------------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| SrcAddrCtrl | 15:14 | R/W  | <p>Source address control</p> <p>ox0: increment address</p> <p>ox1: decrement address</p> <p>ox2: fixed address</p> <p>ox3: reserved, setting the field with this value triggers the error exception</p>      | ox0   |
| DstAddrCtrl | 13:12 | R/W  | <p>Destination address control</p> <p>ox0: increment address</p> <p>ox1: decrement address</p> <p>ox2: fixed address</p> <p>ox3: reserved, setting the field with this value triggers the error exception</p> | ox0   |
| SrcReqSel   | 11:8  | R/W  | <p>Bits 4~0 of the source DMA request selection. {SrcReqSelB5, SrcReqSel} select the request/ack handshake pair that the source device is connected to.</p>                                                   | ox0   |
| DstReqSel   | 7:4   | R/W  | <p>Bits 4~0 of the destination DMA request selection. {DstReqSelB5, DstReqSel} select the request/ack handshake pair that the destination device is connected to.</p>                                         | ox0   |
| IntAbtMask  | 3     | R/W  | <p>Channel abort interrupt mask</p> <p>ox0: allow the abort interrupt to be triggered</p> <p>ox1: disable the abort interrupt</p>                                                                             | ox0   |
| IntErrMask  | 2     | R/W  | <p>Channel error interrupt mask</p> <p>ox0: allow the error interrupt to be triggered</p> <p>ox1: disable the error interrupt</p>                                                                             | ox0   |
| IntTCMask   | 1     | R/W  | <p>Channel terminal count interrupt mask.</p> <p>ox0: allow the terminal count interrupt to be triggered</p> <p>ox1: disable the terminal count interrupt</p>                                                 | ox0   |
| Enable      | 0     | R/W  | <p>Channel enable bit</p> <p>ox0: disable</p> <p>ox1: enable</p>                                                                                                                                              | ox0   |

### 31.3.10 Channel n Source Address Register (Offset 0x48+n\*0x14)

Table 31-11 Channel n Source Address Register

| Name    | Bit  | Type | Description                                                                                                                                                                                                                      | Reset |
|---------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| SrcAddr | 31:0 | R/W  | Source starting address. When a transfer completes, its value is updated to the ending address + sizeof(SrcWidth).<br><br>This address must be aligned to the source transfer size; otherwise, an error event will be triggered. | ox0   |

### 31.3.11 Channel n Destination Address Register (Offset 0x4C+n\*0x14)

Table 31-12 Channel n Destination Address Register

| Name    | Bit  | Type | Description                                                                                                                                                                                                                                | Reset |
|---------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| DstAddr | 31:0 | R/W  | Destination starting address. When a transfer completes, its value is updated to the ending address + sizeof(DstWidth).<br><br>This address must be aligned to the destination transfer size; otherwise the error event will be triggered. | ox0   |

### 31.3.12 Channel n Transfer Size Register (Offset 0x50+n\*0x14)

Table 31-13 Channel n Transfer Size Register

| Name     | Bit   | Type | Description                                                                                                                                                                                                                                                                                     | Reset |
|----------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved | 31:22 | -    | -                                                                                                                                                                                                                                                                                               | -     |
| TranSize | 21:0  | R/W  | Total transfer size from source. The total number of transferred bytes is TranSize * SrcWidth. The value is updated to zero when the DMA transfer is done.<br><br>If a channel is enabled with zero total transfer size, the error event will be triggered and the transfer will be terminated. | ox0   |

### 31.3.13 Channel n Linked List Pointer Register (Offset 0x54+n\*0x14)

Table 31-14 Channel Linked List Pointer Register

| Name      | Bit  | Type | Description                                                             | Reset |
|-----------|------|------|-------------------------------------------------------------------------|-------|
| LLPointer | 31:2 | R/W  | Pointer to the next block descriptor. The pointer must be word aligned. | 0x0   |
| Reserved  | 1:0  | -    | -                                                                       | -     |

## 31.4 Hardware Configuration Options

### 31.4.1 Number of DMA Channels

Define ATCDMAC100\_CH\_NUM\_n to specify the number of DMA channels, where n=1~8. The following example configures ATCDMAC100 with 4 channels:

```
`define ATCDMAC100_CH_NUM_4
```

### 31.4.2 FIFO Size

Define ATCDMAC100\_FIFO\_DEPTH\_n to specify the FIFO size as n entries (each entry is 32-bit). n could be 4, 8, 16, and 32. The following example configures the FIFO size as 8 entries:

```
`define ATCDMAC100_FIFO_DEPTH_8
```

### 31.4.3 DMA Request/Acknowledge Number

Define ATCDMAC100\_REQ\_ACK\_NUM to specify the number of request/acknowledge pairs for hardware handshaking. The value could be 1 to 32. The following example configures ATCDMAC100 with 8 request/acknowledge pairs.

```
`define ATCDMAC100_REQ_ACK_NUM 8
```

### 31.4.4 DMA Request Synchronization Support

Define ATCDMAC100\_REQ\_SYNC\_SUPPORT to add synchronizers at all DMA request input ports. Under this configuration, the DMA requests are allowed to be clocked by different clocks other than the system bus clock.

### 31.4.5 Chain Transfer Support

Define ATCDMAC100\_CHAIN\_TRANSFER\_SUPPORT to support the chain transfer.

### 31.4.6 Address Width

Define ATCDMAC100\_ADDR\_WIDTH\_24 to set the address width to 24-bit. Default address width is 32-bit.

## 31.5 Programming Sequence

### 31.5.1 Transfer without Chain Transfer

The following sample programming sequence sets up channel 2 for

- Transfer of 32-words
- Source: 32-bit wide system memory
- Destination: fixed address, 32-bit wide device
- 32-transfer burst
- Hardware handshaking is enabled. Source is connected to pair 1 and destination is connected to pair 2.
- All interrupts are enabled

Check ChannelNum in the Configuration Register (0x10) bit[3:0] for the existence of channel 2.

Set Channel Control Registers of channel 2 as Table 31-15

Register Setup Sample for Transfer without Chain Transfer.

Ch2Ctrl should be programmed the last since the DMA channel becomes enabled once the register is programmed.

Wait for the DMA interrupt and check the Interrupt Status Register (0x30).

The following example demonstrates DMA interrupt handling:

1. Check Interrupt Status Register (0x30) to determine the cause of the interruption.
2. Handle the interrupt accordingly.
3. Clear interrupt status by writing 1's to the Interrupt Status Register.

**Table 31-15 Register Setup Sample for Transfer without Chain Transfer**

| <b>Name</b>  | <b>Offset</b> | <b>Value of the control register</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
|--------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|----------|-----|--------------|-----|----------|-----|----------|-----|---------|-----|---------|-----|-------------|-----|-------------|-----|-----------|-----|-----------|-----|------------|-----|------------|-----|-----------|-----|--------|-----|
| Ch2Ctrl      | 0x44+2*0x14   | 0x216B2121                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
|              |               | <table border="1"> <thead> <tr> <th>Field</th><th>Value</th></tr> </thead> <tbody> <tr> <td>Priority</td><td>0x1</td></tr> <tr> <td>SrcBurstSize</td><td>0x5</td></tr> <tr> <td>SrcWidth</td><td>0x2</td></tr> <tr> <td>DstWidth</td><td>0x2</td></tr> <tr> <td>SrcMode</td><td>0x1</td></tr> <tr> <td>DstMode</td><td>0x1</td></tr> <tr> <td>SrcAddrCtrl</td><td>0x0</td></tr> <tr> <td>DstAddrCtrl</td><td>0x2</td></tr> <tr> <td>SrcReqSel</td><td>0x1</td></tr> <tr> <td>DstReqSel</td><td>0x2</td></tr> <tr> <td>IntAbtMask</td><td>0x0</td></tr> <tr> <td>IntErrMask</td><td>0x0</td></tr> <tr> <td>IntTCMask</td><td>0x0</td></tr> <tr> <td>Enable</td><td>0x1</td></tr> </tbody> </table> | Field | Value | Priority | 0x1 | SrcBurstSize | 0x5 | SrcWidth | 0x2 | DstWidth | 0x2 | SrcMode | 0x1 | DstMode | 0x1 | SrcAddrCtrl | 0x0 | DstAddrCtrl | 0x2 | SrcReqSel | 0x1 | DstReqSel | 0x2 | IntAbtMask | 0x0 | IntErrMask | 0x0 | IntTCMask | 0x0 | Enable | 0x1 |
| Field        | Value         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| Priority     | 0x1           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| SrcBurstSize | 0x5           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| SrcWidth     | 0x2           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| DstWidth     | 0x2           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| SrcMode      | 0x1           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| DstMode      | 0x1           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| SrcAddrCtrl  | 0x0           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| DstAddrCtrl  | 0x2           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| SrcReqSel    | 0x1           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| DstReqSel    | 0x2           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| IntAbtMask   | 0x0           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| IntErrMask   | 0x0           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| IntTCMask    | 0x0           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| Enable       | 0x1           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| Ch2SrcAddr   | 0x48+2*0x14   | The source address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| Ch2DstAddr   | 0x4c+2*0x14   | The destination address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| Ch2TranSize  | 0x50+2*0x14   | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| Ch2LLPointer | 0x54+2*0x14   | 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |

### 31.5.2 Chain Transfer

The following sample programming sequence sets up channel 0 for

- Transfer of 128 words split into four 32-word discontinuous data blocks
- Source: 32-bit wide memory
- Destination: fixed address, 32-bit wide device
- 32-transfer burst
- Hardware handshake is disabled
- All interrupts are enabled

1. Check ChannelNum in the Configuration Register (0x10) bit[3:0] for the existence of channel 0.
2. Create a linked list of block descriptors for the last three data blocks. Each block descriptor describes the transfer for the respective 32-word data block.

3. Set Channel Control Registers according to Table 16 for the first data block and start the transfer. Ch0Ctrl should be programmed the last since the DMA channel becomes enabled once the register is programmed.
4. Wait for the DMA interrupt and check the Interrupt Status Register (0x30).

The following sequence demonstrates DMA interrupt handling for chain transfers:

5. Check Interrupt Status Register (0x30) to determine the cause of the interruption.
6. Handle the interrupt accordingly.
7. Clear interrupt status by writing 1's to the Interrupt Status Register.
8. Enable the channel if the interruption type is the terminal count interrupt and the chain transfer has more blocks to transfer (CnLLPointer !=0).

Table 31-16 Register Setup Sample for Transfer with Chain Transfer

| Name         | Offset      | Value of the control register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
|--------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|----------|-----|--------------|-----|----------|-----|----------|-----|---------|-----|---------|-----|-------------|-----|-------------|-----|-----------|-----|-----------|-----|------------|-----|------------|-----|-----------|-----|--------|-----|
| ChoCtrl      | 0x44+0*0x14 | 0x2168200F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
|              |             | <table border="1"> <thead> <tr> <th>Field</th><th>Value</th></tr> </thead> <tbody> <tr> <td>Priority</td><td>0x1</td></tr> <tr> <td>SrcBurstSize</td><td>0x5</td></tr> <tr> <td>SrcWidth</td><td>0x2</td></tr> <tr> <td>DstWidth</td><td>0x2</td></tr> <tr> <td>SrcMode</td><td>0x0</td></tr> <tr> <td>DstMode</td><td>0x0</td></tr> <tr> <td>SrcAddrCtrl</td><td>0x0</td></tr> <tr> <td>DstAddrCtrl</td><td>0x2</td></tr> <tr> <td>SrcReqSel</td><td>0x1</td></tr> <tr> <td>DstReqSel</td><td>0x2</td></tr> <tr> <td>IntAbtMask</td><td>0x1</td></tr> <tr> <td>IntErrMask</td><td>0x1</td></tr> <tr> <td>IntTCMask</td><td>0x1</td></tr> <tr> <td>Enable</td><td>0x1</td></tr> </tbody> </table> | Field | Value | Priority | 0x1 | SrcBurstSize | 0x5 | SrcWidth | 0x2 | DstWidth | 0x2 | SrcMode | 0x0 | DstMode | 0x0 | SrcAddrCtrl | 0x0 | DstAddrCtrl | 0x2 | SrcReqSel | 0x1 | DstReqSel | 0x2 | IntAbtMask | 0x1 | IntErrMask | 0x1 | IntTCMask | 0x1 | Enable | 0x1 |
| Field        | Value       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| Priority     | 0x1         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| SrcBurstSize | 0x5         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| SrcWidth     | 0x2         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| DstWidth     | 0x2         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| SrcMode      | 0x0         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| DstMode      | 0x0         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| SrcAddrCtrl  | 0x0         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| DstAddrCtrl  | 0x2         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| SrcReqSel    | 0x1         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| DstReqSel    | 0x2         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| IntAbtMask   | 0x1         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| IntErrMask   | 0x1         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| IntTCMask    | 0x1         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| Enable       | 0x1         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| ChoSrcAddr   | 0x48+0*0x14 | The source address for the first data block                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| ChoDstAddr   | 0x4c+0*0x14 | The destination address (fixed)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| ChoTranSize  | 0x50+0*0x14 | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |
| ChoLLPointer | 0x54+0*0x14 | Pointer to the subsequent link list descriptor in the memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |       |          |     |              |     |          |     |          |     |         |     |         |     |             |     |             |     |           |     |           |     |            |     |            |     |           |     |        |     |

# 32ATCGPIO100

## 32.1 Introduction

### 32.1.1 Description

AndeShape ATCGPIO100 is a general purpose I/O (GPIO) controller which supports up to 32 channels with independently programmable input/output control.

### 32.1.2 Features

- Compliant with AMBA™ 2 APB protocol specification
- Up to 32 independent I/O channels
- Support of programmable pull-up/pull-down for each channel
- Support of programmable de-bounce function for each input channel
- Each input channel can be programmed as an interrupt input source
- The interrupt source could be level or edge triggered.

### 32.1.3 Block Diagram

Figure 32-1 ATCGPIO100 Block Diagram



### 32.1.4 Function Description

The ATCGPIO100 controller provides up to 32 independent GPIO channels. Each channel can be individually programmed to be an input or an output port. As an input port, the controller samples the input signal and could generate an interrupt. As an output port, the controller could drive the output signal with pull-up/pull-down.

This controller also provides the de-bounce function, which filters out the glitches for input channels. The function can be enabled individually for each channel. The de-bounce duration is programmable as well.

## 32.2 Signal Description

Figure 32-2 ATCGPIO100 Pin Connection Diagram



Table 32-1 ATCGPIO100 Pin Description

| Name                  | Type   | Source/Dest          | Description                                                                                                                                               |
|-----------------------|--------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>System signals</b> |        |                      |                                                                                                                                                           |
| extclk                | Input  | Clock generator      | External de-bouncing clock source. The clock source must be at least 4x slower than pclk.                                                                 |
| gpio_intr             | Output | Interrupt controller | ATCGPIO100 interrupt signal                                                                                                                               |
| <b>APB signals</b>    |        |                      |                                                                                                                                                           |
| pclk                  | Input  | APB                  | APB clock, used to time all the bus transfers                                                                                                             |
| presetn               | Input  | APB                  | APB reset signal (Active-Low)                                                                                                                             |
| psel                  | Input  | APB                  | APB select signal<br>When set to 1, this signal indicates that the slave device has been selected by the APB bridge and that a data transfer is required. |
| penable               | Input  | APB                  | APB enable signal                                                                                                                                         |
| pwrite                | Input  | APB                  | APB transfer direction signal                                                                                                                             |

| Name                | Type   | Source/Dest | Description                                                                |
|---------------------|--------|-------------|----------------------------------------------------------------------------|
|                     |        |             | This signal indicates a write access when high and a read access when low. |
| paddr[7:0]          | Input  | APB         | APB address bus                                                            |
| prdata[31:0]        | Output | APB         | APB read data bus                                                          |
| pwdata[31:0]        | Input  | APB         | APB write data bus                                                         |
| <b>GPIO signals</b> |        |             |                                                                            |
| gpio_in[N:o]        | Input  | PAD         | GPIO input data                                                            |
| gpio_oe[N:o]        | Output | PAD         | GPIO output data enable signal. Active high                                |
| gpio_out[N:o]       | Output | PAD         | GPIO output data                                                           |
| gpio_pullup[N:o]    | Output | PAD         | GPIO output pull-up enable signal                                          |
| gpio_pulldown[N:o]  | Output | PAD         | GPIO output pull-down enable signal                                        |

#### Note!

\* N = ATCGPIO100\_GPIO\_NUM – 1

## 32.3 Programming Model

### 32.3.1 Summary of Registers

Table 32-2 ATCGPIO100 Register Summary shows a summary of the ATCGPIO100 registers. Pull control registers, interrupt control registers and de-bounce control registers only exist when the corresponding option is configured.

**Table 32-2 ATCGPIO100 Register Summary**

| <b>Offset</b>                      | <b>Name</b>  | <b>Description</b>              |
|------------------------------------|--------------|---------------------------------|
| <b>ID and Revision Register</b>    |              |                                 |
| +0x00                              | IdRev        | ID and revision register        |
| +0x04~0x0C                         | -            | Reserved                        |
| <b>Configuration Register</b>      |              |                                 |
| +0x10                              | Cfg          | Configuration register          |
| +0x14~0x1C                         | -            | Reserved                        |
| <b>Channel Control Registers</b>   |              |                                 |
| +0x20                              | DataIn       | Channel data-in register        |
| +0x24                              | DataOut      | Channel data-out register       |
| +0x28                              | ChannelDir   | Channel direction register      |
| +0x2C                              | DoutClear    | Channel data-out clear register |
| +0x30                              | DoutSet      | Channel data-out set register   |
| +0x34~0x3C                         | -            | Reserved                        |
| <b>Pull Control Registers</b>      |              |                                 |
| +0x40                              | PullEn       | Pull enable register            |
| +0x44                              | PullType     | Pull type register              |
| +0x48~0x4C                         | -            | Reserved                        |
| <b>Interrupt Control Registers</b> |              |                                 |
| +0x50                              | IntrEn       | Interrupt enable register       |
| <b>Offset</b>                      | <b>Name</b>  | <b>Description</b>              |
| +0x54                              | IntrMode0    | Interrupt mode register (0~7)   |
| +0x58                              | IntrMode1    | Interrupt mode register (8~15)  |
| +0x5C                              | IntrMode2    | Interrupt mode register (16~23) |
| +0x60                              | IntrMode3    | Interrupt mode register (24~31) |
| +0x64                              | IntrStatus   | Interrupt status register       |
| +0x68~0x6C                         | -            | Reserved                        |
| <b>De-bounce control registers</b> |              |                                 |
| +0x70                              | DeBounceEn   | De-bounce enable register       |
| +0x74                              | DeBounceCtrl | De-bounce control register      |
| +0x78~0x7C                         | -            | Reserved                        |

### 32.3.2 Register Description

The abbreviations for the Type column are summarized below.

RO: read only

R/W: readable and writable

W1C: write 1 to clear

WO: write only (read as zero)

### 32.3.3 ID and Revision Register (Offset 0x00)

This register holds the ID number and the revision number. The reset values of the two revision fields are revision dependent.

Table 32-3 ID and Revision Register

| Name     | Bit  | Type | Description              | Reset              |
|----------|------|------|--------------------------|--------------------|
| ID       | 31:8 | RO   | ID number for ATCGPIO100 | 0x020310           |
| RevMajor | 7:4  | RO   | Major revision number    | Revision dependent |
| RevMinor | 3:0  | RO   | Minor revision number    | Revision dependent |

### 32.3.4 Configuration Register (Offset 0x10)

Table 32-4 Configuration Register

| Name       | Bit  | Type | Description                                                                                          | Reset                   |
|------------|------|------|------------------------------------------------------------------------------------------------------|-------------------------|
| Pull       | 31   | RO   | Pull option<br>0x0: Pull option is not configured<br>0x 1: Pull option is configured                 | Configuration dependent |
| Intr       | 30   | RO   | Interrupt option<br>0x 0: interrupt option is not configured<br>0x 1: interrupt option is configured | Configuration dependent |
| Debounce   | 29   | RO   | De-bounce option<br>0x 0: de-bounce option is not configured<br>0x 1: de-bounce option is configured | Configuration dependent |
| -          | 28:6 | -    | Reserved                                                                                             | -                       |
| ChannelNum | 5:0  | RO   | Number of channels                                                                                   | Configuration dependent |

### 32.3.5 Channel Data-In Register (Offset 0x20)

Table 32-5 Channel Data-In Register

| Name   | Bit | Type | Description                 | Reset |
|--------|-----|------|-----------------------------|-------|
| DataIn | N:0 | RO   | Channel data input register | 0x0   |

### 32.3.6 Channel Data-Out Register (Offset 0x24)

Table 32-6 Channel Data-Out Register

| Name    | Bit | Type | Description      | Reset |
|---------|-----|------|------------------|-------|
| DataOut | N:o | R/W  | GPIO data output | 0x0   |

### 32.3.7 Channel Direction Register (Offset 0x28)

Table 32-7 Channel Direction Register

| Name       | Bit | Type | Description                                         | Reset |
|------------|-----|------|-----------------------------------------------------|-------|
| ChannelDir | N:o | R/W  | GPIO channel direction<br>0x0: input<br>0x1: output | 0x0   |

### 32.3.8 Channel Data-Out Clear Register (Offset 0x2C)

Table 32-8 Channel Data-Out Clear Register

| Name      | Bit | Type | Description                                                              | Reset |
|-----------|-----|------|--------------------------------------------------------------------------|-------|
| DoutClear | N:o | WO   | GPIO data-out clear; write 1 to clear the corresponding output channels. | 0x0   |

### 32.3.9 Channel Data-Out Set Register (Offset 0x30)

Table 32-9 Channel Data-Out Set Register

| Name    | Bit | Type | Description                                                          | Reset |
|---------|-----|------|----------------------------------------------------------------------|-------|
| DoutSet | N:o | WO   | GPIO data-out set; write 1 to set the corresponding output channels. | 0x0   |

### 32.3.10 Pull Enable Register (Offset 0x40)

Table 32-10 Pull Enable Register

| Name   | Bit | Type | Description                                                                          | Reset |
|--------|-----|------|--------------------------------------------------------------------------------------|-------|
| PullEn | N:o | R/W  | GPIO pull enable; write 1 to enable pull-up/pull-down of the corresponding channels. | 0x0   |

### 32.3.11 Pull Type Register (Offset 0x44)

Table 32-11 Pull Type Register

| Name     | Bit | Type | Description                                         | Reset |
|----------|-----|------|-----------------------------------------------------|-------|
| PullType | N:o | R/W  | GPIO pull control<br>0x0: pull-up<br>0x1: pull-down | 0x0   |

### 32.3.12 Interrupt Enable Register (Offset 0x50)

Table 32-12 Interrupt Enable Register

| Name  | Bit | Type | Description                                                                           | Reset |
|-------|-----|------|---------------------------------------------------------------------------------------|-------|
| IntEn | N:o | R/W  | GPIO interrupt enable; write 1 to enable<br>interrupts of the corresponding channels. | 0x0   |

### 32.3.13 Interrupt Mode Register (Offset 0x54, 0x58, 0x5C, 0x60):

Table 32-13 Channel (0~7) Interrupt Mode Register (0x54) -

Table 32-16 Channel (24~31) Interrupt Mode Register (0x60) describe the interrupt trigger mode of the corresponding GPIO channel. See the Ch0IntrM field for the mode encodings. The field becomes reserved if the channel does not exist.

Table 32-13 Channel (0~7) Interrupt Mode Register (0x54)

| Name     | Bit   | Type | Description              | Reset |
|----------|-------|------|--------------------------|-------|
| -        | 31    | -    | Reserved                 | -     |
| Ch7IntrM | 30:28 | R/W  | Channel 7 interrupt mode | 0x0   |
| -        | 27    | -    | Reserved                 | -     |
| Ch6IntrM | 26:24 | R/W  | Channel 6 interrupt mode | 0x0   |
| -        | 23    | -    | Reserved                 | -     |
| Ch5IntrM | 22:20 | R/W  | Channel 5 interrupt mode | 0x0   |
| -        | 19    | -    | Reserved                 | -     |
| Ch4IntrM | 18:16 | R/W  | Channel 4 interrupt mode | 0x0   |
| -        | 15    | -    | Reserved                 | -     |
| Ch3IntrM | 14:12 | R/W  | Channel 3 interrupt mode | 0x0   |
| -        | 11    | -    | Reserved                 | -     |
| Ch2IntrM | 10:8  | R/W  | Channel 2 interrupt mode | 0x0   |
| -        | 7     | -    | Reserved                 | -     |
| Ch1IntrM | 6:4   | R/W  | Channel 1 interrupt mode | 0x0   |
| -        | 3     | -    | Reserved                 | -     |
| ChoIntrM | 2:0   | R/W  | Channel 0 interrupt mode | 0x0   |
|          |       |      | 0x0: No operation        |       |
|          |       |      | 0x2: High-level          |       |
|          |       |      | 0x3: Low-level           |       |
|          |       |      | 0x5: Negative-edge       |       |
|          |       |      | 0x6: Positive-edge       |       |
|          |       |      | 0x7: Dual-edge           |       |
|          |       |      | 0x1, 0x4: Reserved       |       |

**Table 32-14 Channel (8~15) Interrupt Mode Register (0x58)**

| Name      | Bit   | Type | Description               | Reset |
|-----------|-------|------|---------------------------|-------|
| -         | 31    | -    | Reserved                  | -     |
| Ch15IntrM | 30:28 | R/W  | Channel 15 interrupt mode | ox0   |
| -         | 27    | -    | Reserved                  | -     |
| Ch14IntrM | 26:24 | R/W  | Channel 14 interrupt mode | ox0   |
| -         | 23    | -    | Reserved                  | -     |
| Ch13IntrM | 22:20 | R/W  | Channel 13 interrupt mode | ox0   |
| -         | 19    | -    | Reserved                  | -     |
| Ch12IntrM | 18:16 | R/W  | Channel 12 interrupt mode | ox0   |
| -         | 15    | -    | Reserved                  | -     |
| Ch11IntrM | 14:12 | R/W  | Channel 11 interrupt mode | ox0   |
| -         | 11    | -    | Reserved                  | -     |
| Ch10IntrM | 10:8  | R/W  | Channel 10 interrupt mode | ox0   |
| -         | 7     | -    | Reserved                  | -     |
| Ch9IntrM  | 6:4   | R/W  | Channel 9 interrupt mode  | ox0   |
| -         | 3     | -    | Reserved                  | -     |
| Ch8IntrM  | 2:0   | R/W  | Channel 8 interrupt mode  | ox0   |

**Table 32-15 Channel (16~23) Interrupt Mode Register (0x5C)**

| Name      | Bit   | Type | Description               | Reset |
|-----------|-------|------|---------------------------|-------|
| -         | 31    | -    | Reserved                  | -     |
| Ch23IntrM | 30:28 | R/W  | Channel 23 interrupt mode | ox0   |
| -         | 27    | -    | Reserved                  | -     |
| Ch22IntrM | 26:24 | R/W  | Channel 22 interrupt mode | ox0   |
| -         | 23    | -    | Reserved                  | -     |
| Ch21IntrM | 22:20 | R/W  | Channel 21 interrupt mode | ox0   |
| -         | 19    | -    | Reserved                  | -     |
| Ch20IntrM | 18:16 | R/W  | Channel 20 interrupt mode | ox0   |

| Name      | Bit   | Type | Description                    | Reset |
|-----------|-------|------|--------------------------------|-------|
| -         | 15    | -    | Reserved                       | -     |
| Ch19IntrM | 14:12 | R/W  | Channel 19 interrupt mode      | oxo   |
| -         | 11    | -    | Reserved                       | -     |
| Ch18IntrM | 10:8  | R/W  | GPIO channel 18 interrupt mode | oxo   |
| -         | 7     | -    | Reserved                       | -     |
| Ch17IntrM | 6:4   | R/W  | Channel 17 interrupt mode      | oxo   |
| -         | 3     | -    | Reserved                       | -     |
| Ch16IntrM | 2:0   | R/W  | Channel 16 interrupt mode      | oxo   |

Table 32-16 Channel (24~31) Interrupt Mode Register (0x60)

| Name      | Bit   | Type | Description                    | Reset |
|-----------|-------|------|--------------------------------|-------|
| -         | 31    | -    | Reserved                       | -     |
| Ch31IntrM | 30:28 | R/W  | Channel 31 interrupt mode      | oxo   |
| -         | 27    | -    | Reserved                       | -     |
| Ch30IntrM | 26:24 | R/W  | Channel 30 interrupt mode      | oxo   |
| -         | 23    | -    | Reserved                       | -     |
| Ch29IntrM | 22:20 | R/W  | Channel 29 interrupt mode      | oxo   |
| -         | 19    | -    | Reserved                       | -     |
| Ch28IntrM | 18:16 | R/W  | Channel 28 interrupt mode      | oxo   |
| -         | 15    | -    | Reserved                       | -     |
| Ch27IntrM | 14:12 | R/W  | Channel 27 interrupt mode      | oxo   |
| -         | 11    | -    | Reserved                       | -     |
| Ch26IntrM | 10:8  | R/W  | GPIO channel 26 interrupt mode | oxo   |
| -         | 7     | -    | Reserved                       | -     |
| Ch25IntrM | 6:4   | R/W  | Channel 25 interrupt mode      | oxo   |
| -         | 3     | -    | Reserved                       | -     |
| Ch24IntrM | 2:0   | R/W  | Channel 24 interrupt mode      | oxo   |

### 32.3.14 Channel Interrupt Status Register (Offset 0x64):

Table 32-17 Channel Interrupt Status Register

| Name       | Bit | Type  | Description                                                                                                 | Reset |
|------------|-----|-------|-------------------------------------------------------------------------------------------------------------|-------|
| IntrStatus | N:o | R/WIC | The interrupt status of the corresponding channel; write 1 to clear.<br>ox0: No interrupt<br>ox1: Interrupt | ox0   |

### De-bounce Enable Register (Offset 0x70):

Table 32-18 De-bounce Enable Register

| Name       | Bit | Type | Description                                                                            | Reset |
|------------|-----|------|----------------------------------------------------------------------------------------|-------|
| DeBounceEn | N:o | R/W  | Data-in de-bounce enable; write 1 to enable de-bouncing of the corresponding channels. | ox0   |

### De-bounce Control Register (Offset 0x74):

Table 32-19 De-bounce Control Register

| Name       | Bit  | Type | Description                                                                                                                                                                                                                                                               | Reset |
|------------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| DBClkSel   | 31   | R/W  | GPIO de-bounce clock source selection. Select pclk (the faster clock) as the de-bounce clock source would shorten the de-bounce latency.<br>ox0: extclk<br>ox1: pclk                                                                                                      | ox0   |
| -          | 30:8 | -    | Reserved                                                                                                                                                                                                                                                                  | -     |
| DBPreScale | 7:0  | R/W  | GPIO pre-scale base, to scale the de-bounce clock source before it is used as the actual de-bounce clock. The de-bounce period would be multiplied by (DBPreScale+1); e.g., setting DBPreScale to 3 would filter out pulses which are less than 4 de-bounce clock period. | ox0   |

## 32.4 Hardware Configuration Options

### 32.4.1 GPIO Channel Number

Define `ATCGPIO100_GPIO_NUM` to specify the number of GPIO channels. The value ranges from 1 to 32. The following shows an example to define 16 GPIO channels.

```
`define ATCGPIO100_GPIO_NUM 16
```

### 32.4.2 Pull Support

Define `ATCGPIO100_PULL_SUPPORT` to support the GPIO pull-up/pull-down.

### 32.4.3 Interrupt

Define `ATCGPIO100_INTR_SUPPORT` to support the interrupt.

### 32.4.4 De-bounce

Define `ATCGPIO100_DEBOUNCE_SUPPORT` to support the de-bounce function.

## 32.5 Programming Sequence

### 32.5.1 Output Channel Programming

The following shows an example to program channel 0 as an output port.

- Set the channel direction register (0x28) bit[0] to 1.
- To drive 1 as the output value:
  - Set the channel data-out register (0x24) bit[0] to 1, or
  - Set the channel data-out set register (0x30) bit[0] to 1.
- To drive 0 as the output value:
  - Set the channel data-out register (0x24) bit[0] to 0, or
  - Set the channel data-out clear register (0x2c) bit[0] to 1.

### 32.5.2 Input Channel Programming

The following shows an example to program channel 0 as an input port.

### 32.5.3 Basic Input Channel

- Set the channel direction register (0x28) bit[0] to 0.
- Read the channel data-in register (0x20) bit[0] to get the input value.

### 32.5.4 Input Channel with Additional Functions

- Check the configuration register for pull, de-bounce, and interrupt support.

- Set the pull control registers if the pull function is supported.
- Set the pull type.
  - Set the pull type register (0x44) bit[0] to 0 to select the pull-up type, or
  - Set the pull type register (0x44) bit[0] to 1 to select the pull-down type.
- Set the pull enable register (0x40) bit[0] to 1 to enable pull.
- Set the de-bounce registers if the de-bounce function is supported.
- Set the de-bounce control register (0x74) bit[31] to 1 to select the external clock as the de-bounce clock source.
- Set the de-bounce control register (0x74) bit [7:0] to 0x3 to filter out the glitches which are shorter than 4 de-bounce clock periods.
- Set the de-bounce enable register (0x70) bit[0] to 1 to enable de-bounce.
- Set the interrupt registers if the interrupt function is supported.
- Set channel (0~7) interrupt mode register (0x54) bit [2:0]. See Channel n Linked List Pointer Register (Offset 0x54+n\*0x14) for the interrupt mode setting.
- Set the interrupt enable register (0x50) bit[0] to 1 to enable interrupt.
- Set the channel direction register (0x28) bit[0] to 0.
- Check the interrupt status when the interrupt function is supported and enabled.
- Once a GPIO interrupt occurs, check the interrupt status register (0x64) bit[0], or
- Poll the interrupt status register (0x64) bit[0] directly.

# 33 ATCIIC100

## 33.1 Introduction

The ATCIIC100 controller is an I<sup>2</sup>C (Inter-Integrated Circuit) master/slave controller.

### 33.1.1 Features

- Supports AMBA 2.0 APB bus
- Supports Standard-mode (100 Kb/s), Fast-mode (400 Kb/s) and Fast-mode Plus (1 Mb/s) protocols
- Programmable Master/Slave mode
- Supports 7-bit and 10-bit addressing mode
- Supports general call address
- Auto clock stretching
- Programmable clock/data timing
- Supports direct memory access (DMA)

### 33.1.2 Block Diagram

Figure 33-1 ATCIIC100 Block Diagram



The ATCIIC100 controller can act as either an I<sup>2</sup>C master device or an

I<sup>2</sup>C slave device, depending on the control register settings.

### 33.1.3 I<sup>2</sup>C Master

As an I<sup>2</sup>C master, the controller provides an efficient way to initiate I<sup>2</sup>C transactions. Every transaction can be delineated by four phases: Start, Address, Data and Stop. At the Start phase, a START condition is generated. At the Address phase, an address is sent. At the Data phase, one or more data bytes are transferred. At the Stop phase, a STOP condition is generated. The existence of each phase can be controlled independently.

### 33.1.4 I<sup>2</sup>C Slave

As an I<sup>2</sup>C slave, the controller is addressed when the address byte of an I<sup>2</sup>C transaction matches the Address Register. An Address Hit interrupt can be generated for the software to prepare for the subsequent operations.

### 33.1.5 General Call Address

The General Call Address is a special address to address all slave devices on the I<sup>2</sup>C-bus. The ATCIIC100 controller at the slave mode will respond with an ACK to the general call address and set the GenCall field of the Status Register.

### 33.1.6 Auto Clock Stretch

The ATCIIC100 can automatically pause bus transactions by stretching clocks on the I<sup>2</sup>C-bus when the software is not ready for the next byte of data or when the FIFO is full. Auto Clock Stretch is supported at both the master mode and the slave mode.

### 33.1.7 Auto-ACK

With Auto-ACK, the ATCIIC100 automatically generates proper acknowledgements for each byte received. Every received byte will be responded with an ACK, except for the last byte, which should be responded with a NACK according to the I<sup>2</sup>C-bus protocol. On the other hand, if the software needs to determine each byte's acknowledgement status, Auto-ACK can be turned off by enabling the Byte Receive Interrupt.

### 33.1.8 Timing Parameter Multiplier

ATCIIC100 provides an I<sup>2</sup>C Timing Parameter Multiplier Register (TPM), which enables ATCIIC100 to meet the I<sup>2</sup>C-bus timing requirement while running under a relatively faster APB clock frequency. The actual values of all timing parameters in the Setup Register are multiplied by (TPM+1). Please see Timing Parameter Multiplierfor how to determine the multiplier value.

## 33.2 Signal Description

Table 33-1 ATCIIC100 Signal Descriptions shows the input/output (I/O) signal description of ATCIIC100.

**Table 33-1 ATCIIC100 Signal Description**

| Name                                     | I/O Type | Description                                                                                                                             |
|------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------|
| <b>AMBA APB signals</b>                  |          |                                                                                                                                         |
| pclk                                     | I        | AMBA APB clock                                                                                                                          |
| presetn                                  | I        | AMBA APB reset signal; active low                                                                                                       |
| psel                                     | I        | AMBA APB slave select signal from the APB decoder                                                                                       |
| penable                                  | I        | AMBA APB enable signal                                                                                                                  |
| pwrite                                   | I        | AMBA APB transfer direction signal<br><br>This signal indicates a write access when driven as HIGH and a read access when driven as LOW |
| paddr[5:2]                               | I        | AMBA APB address bus                                                                                                                    |
| prdata[31:0]                             | O        | AMBA APB read data bus                                                                                                                  |
| pwdata[31:0]                             | I        | AMBA APB write data bus                                                                                                                 |
| <b>I<sup>2</sup>C controller signals</b> |          |                                                                                                                                         |
| i2c_int                                  | O        | Interrupt signal                                                                                                                        |
| i2c_req                                  | O        | DMA request                                                                                                                             |
| i2c_ack                                  | I        | DMA acknowledge                                                                                                                         |
| sda_o                                    | O        | I <sup>2</sup> C serial data output                                                                                                     |
| scl_o                                    | O        | I <sup>2</sup> C serial clock output                                                                                                    |
| sda_i                                    | I        | I <sup>2</sup> C serial data input                                                                                                      |
| scl_i                                    | I        | I <sup>2</sup> C serial clock input                                                                                                     |

## 33.3 Programming Model

### 33.3.1 Summary of Registers

Table 33-2 ATCIIC100 Registers Summary shows the summary of ATCIIC100 registers.

**Table 33-2 ATCIIC100 Registers Summary**

| <b>Offset</b> | <b>Name</b> | <b>Description</b>                                    |
|---------------|-------------|-------------------------------------------------------|
| +0x00         | IdRev       | ID and Revision Register                              |
| +0x04 ~ +0x0C | -           | Reserved                                              |
| +0x10         | Cfg         | Configuration Register                                |
| +0x14         | IntEn       | Interrupt Enable Register                             |
| +0x18         | Status      | Status Register                                       |
| +0x1C         | Addr        | Address Register                                      |
| +0x20         | Data        | Data Register                                         |
| +0x24         | Ctrl        | Control Register                                      |
| +0x28         | Cmd         | Command Register                                      |
| +0x2C         | Setup       | Setup Register                                        |
| +0x30         | TPM         | I <sup>2</sup> C Timing Parameter Multiplier Register |

The following sections describe ATCIIC100 registers in detail.  
Registers may have different behavior when the controller is at the master mode or the slave mode. The behaviors will be described separately.

The abbreviations for the Type column are summarized below:

RO: read only

WO: write only

R/W: readable and writable

R/W1C: readable and write 1 to clear

### 33.3.2 ID and Revision Register

This register holds the ID number and the revision number. The reset values of the two revision fields are revision dependent.

**Table 33-3 ID and Revision Register**

| <b>Name</b> | <b>Bit</b> | <b>Type</b> | <b>Description</b>      | <b>Reset</b>          |
|-------------|------------|-------------|-------------------------|-----------------------|
| ID          | 31:8       | RO          | ID number for ATCIIC100 | 0x020210              |
| RevMajor    | 7:4        | RO          | Major revision number   | Revision<br>Dependent |
| RevMinor    | 3:0        | RO          | Minor revision number   | Revision<br>Dependent |

### 33.3.3 Configuration Register

The Configuration Register keeps the size of data FIFO.

**Table 33-4 Configuration Register**

| Name     | Bit  | Type | Description                                                         | Reset                      |
|----------|------|------|---------------------------------------------------------------------|----------------------------|
| Reserved | 31:2 | -    | -                                                                   | -                          |
| FIFOSize | 1:0  | RO   | FIFO size:<br>0: 2 bytes<br>1: 4 bytes<br>2: 8 bytes<br>3: 16 bytes | Configuration<br>Dependent |

### 33.3.4 Interrupt Enable Register

The Interrupt Enable Register can enable or disable interrupts.

**Table 33-5 Interrupt Enable Register**

| Name     | Bit   | Type | Description                                                                                                                                                                                                                                           | Reset |
|----------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved | 31:10 | -    | -                                                                                                                                                                                                                                                     | -     |
| Cmpl     | 9     | R/W  | Set to enable the Completion Interrupt.<br><br>Master: interrupts when a transaction is issued from this master and completed without losing the bus arbitration.<br><br>Slave: interrupts when a transaction addressing the controller is completed. | 0x0   |
| ByteRecv | 8     | R/W  | Set to enable the Byte Receive Interrupt.<br><br>Interrupts when a byte of data is received<br>Auto-ACK will be disabled if this interrupt is enabled, that is, the software needs to ACK/NACK the received byte manually.                            | 0x0   |

| Name      | Bit | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset |
|-----------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| ByteTrans | 7   | R/W  | Set to enable the Byte Transmit Interrupt.<br><br>Interrupts when a byte of data is transmitted.                                                                                                                                                                                                                                                                                                                                              | ox0   |
| Start     | 6   | R/W  | Set to enable the START Condition Interrupt.<br><br>Interrupts when a START condition/repeated START condition is detected.                                                                                                                                                                                                                                                                                                                   | ox0   |
| Stop      | 5   | R/W  | Set to enable the STOP Condition Interrupt.<br><br>Interrupts when a STOP condition is detected.                                                                                                                                                                                                                                                                                                                                              | ox0   |
| ArbLose   | 4   | R/W  | Set to enable the Arbitration Lose Interrupt.<br><br>Master: interrupts when the controller loses the bus arbitration<br><br>Slave: not available in this mode                                                                                                                                                                                                                                                                                | ox0   |
| AddrHit   | 3   | R/W  | Set to enable the Address Hit Interrupt.<br><br>Master: interrupts when the addressed slave returned an ACK.<br><br>Slave: interrupts when the controller is addressed.                                                                                                                                                                                                                                                                       | ox0   |
| FIFOHalf  | 2   | R/W  | Set to enable the FIFO Half Interrupt.<br><br>Receiver: Interrupts when the FIFO is half-full, i.e. there is $\geq 1/2$ entries in the FIFO.<br><br>Transmitter: Interrupts when the FIFO is half-empty, i.e. there is $\leq 1/2$ entries in the FIFO.<br><br>This interrupt depends on the transaction direction; don't enable this interrupt unless the transfer direction is determined, otherwise unintended interrupts may be triggered. | ox0   |
| FIFOFull  | 1   | R/W  | Set to enable the FIFO Full Interrupt.<br><br>Interrupts when the FIFO is full.                                                                                                                                                                                                                                                                                                                                                               | ox0   |
| FIFOEmpty | 0   | R/W  | Set to enable the FIFO Empty Interrupt.<br><br>Interrupts when the FIFO is empty.                                                                                                                                                                                                                                                                                                                                                             | ox0   |

### 33.3.5 Status Register

The Status Register keeps the interrupt status and I<sup>2</sup>C-bus status.

**Table 33-6 Status Register**

| Name     | Bit   | Type | Description                                                                                                                                                                | Reset           |
|----------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| Reserved | 31:15 | -    | -                                                                                                                                                                          | -               |
| LineSDA  | 14    | RO   | Indicates the current status of the SDA line on the bus.<br>1: High<br>0: Low                                                                                              | SDA line status |
| LineSCL  | 13    | RO   | Indicates the current status of the SCL line on the bus.<br>1: High<br>0: Low                                                                                              | SCL line status |
| GenCall  | 12    | RO   | Indicates that the address of the current transaction is a general call address.<br><br>This status is only valid in slave mode.<br>1: General call<br>0: Not general call | ox0             |
| BusBusy  | 11    | RO   | Indicates that the bus is busy.<br><br>The bus is busy when a START condition is on bus and it ends when a STOP condition is seen on bus.<br>1: Busy<br>0: Not busy        | ox0             |
| ACK      | 10    | RO   | Indicates the type of the last received/transmitted acknowledgement bit.<br>1: ACK<br>0: NACK                                                                              | ox0             |

| Name      | Bit | Type  | Description                                                                                                                                                                                                                                                                                                                                                               | Reset |
|-----------|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Cmpl      | 9   | R/W1C | Transaction Completion<br><br>Master: Indicates that a transaction has been issued from this master and completed without losing the bus arbitration.<br><br>Slave: Indicates that a transaction addressing the controller has been completed. This status bit must be cleared to receive the next transaction; otherwise, the next incoming transaction will be blocked. | ox0   |
| ByteRecv  | 8   | R/W1C | Indicates that a byte of data has been received.                                                                                                                                                                                                                                                                                                                          | ox0   |
| ByteTrans | 7   | R/W1C | Indicates that a byte of data has been transmitted.                                                                                                                                                                                                                                                                                                                       | ox0   |
| Start     | 6   | R/W1C | Indicates that a START Condition or a repeated START condition has been transmitted/received.                                                                                                                                                                                                                                                                             | ox0   |
| Stop      | 5   | R/W1C | Indicates that a STOP Condition has been transmitted/received.                                                                                                                                                                                                                                                                                                            | ox0   |
| ArbLose   | 4   | R/W1C | Indicates that the controller has lost the bus arbitration (master mode only).                                                                                                                                                                                                                                                                                            | ox0   |
| AddrHit   | 3   | R/W1C | Master: indicates that a slave has responded to the transaction.<br><br>Slave: indicates that a transaction is targeting the controller (including the General Call).                                                                                                                                                                                                     | ox0   |
| FIFOHalf  | 2   | RO    | Transmitter: Indicates that the FIFO is half-empty.<br><br>Receiver: Indicates that the FIFO is half-full.                                                                                                                                                                                                                                                                | ox0   |
| FIFOFull  | 1   | RO    | Indicates that the FIFO is full.                                                                                                                                                                                                                                                                                                                                          | ox0   |
| FIFOEmpty | 0   | RO    | Indicates that the FIFO is empty.                                                                                                                                                                                                                                                                                                                                         | ox1   |

### 33.3.6 Address Register

The Address Register keeps the slave address. When programmed as a master, it is the target slave address for the next transaction. When programmed as a slave, it is the controller's address on the bus.

**Table 33-7 Address Register**

| Name     | Bit   | Type | Description                                                                                                                                           | Reset |
|----------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved | 31:10 | -    | -                                                                                                                                                     | -     |
| Addr     | 9:0   | R/W  | The slave address.<br><br>For 7-bit addressing mode, the most significant 3 bits are ignored and only the least-significant 7 bits of Addr are valid. | ox0   |

### 33.3.7 Data Register

The Data Register is the data access port for the FIFO.

**Table 33-8 Data Register**

| Name     | Bit  | Type | Description                                                                                                               | Reset |
|----------|------|------|---------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved | 31:8 | -    | -                                                                                                                         | -     |
| Data     | 7:0  | R/W  | Write this register to put one byte of data to the FIFO.<br><br>Read this register to get one byte of data from the FIFO. | ox0   |

### 33.3.8 Control Register

The Control Register controls a transaction's phase choices and records the progress of Data phase.

**Table 33-9 Control Register**

| Name        | Bit   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Reset |
|-------------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved    | 31:13 | -    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -     |
| Phase_start | 12    | R/W  | Enable this bit to send a START condition at the beginning of transaction.<br><br>Master mode only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x1   |
| Phase_addr  | 11    | R/W  | Enable this bit to send the address after START condition.<br><br>Master mode only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x1   |
| Phase_data  | 10    | R/W  | Enable this bit to send the data after Address phase.<br><br>Master mode only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x1   |
| Phase_stop  | 9     | R/W  | Enable this bit to send a STOP condition at the end of a transaction.<br><br>Master mode only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x1   |
| Dir         | 8     | R/W  | Transaction direction<br><br>Master: Set this bit to determine the direction for the next transaction.<br><br>0: Transmitter<br><br>1: Receiver<br><br>Slave: The direction of the last received transaction.<br><br>0: Receiver<br><br>1: Transmitter                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x0   |
| DataCnt     | 7:0   | R/W  | Data counts in bytes.<br><br>Master: The number of bytes to transmit/receive. 0 means 256 bytes. DataCnt will be decreased by one for each byte transmitted/received.<br><br>Slave: the meaning of DataCnt depends on the DMA mode:<br><br>If DMA is not enabled, DataCnt is the number of bytes transmitted/received from the bus master. It is reset to 0 when the controller is addressed and then increased by one for each byte of data transmitted/received.<br><br>If DMA is enabled, DataCnt is the number of bytes to transmit/receive. It will not be reset to 0 when the slave is addressed and it will be decreased by one for each byte of data transmitted/received. | 0x0   |

### 33.3.9 Command Register

Table 33-10 Command Register

| Name     | Bit  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|----------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved | 31:3 | -    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | -     |
| CMD      | 2:0  | R/W  | <p>Write this register with the following values to perform the corresponding actions:</p> <p>ox0: no action</p> <p>ox1: issue a data transaction (Master only)</p> <p>ox2: respond with an ACK to the received byte</p> <p>ox3: respond with a NACK to the received byte</p> <p>ox4: clear the FIFO</p> <p>ox5: reset the I<sup>2</sup>C controller (abort current transaction, set the SDA and SCL line to the open-drain mode, reset the Status Register and the Interrupt Enable Register, and empty the FIFO)</p> <p>When issuing a data transaction by writing ox1 to this register, the CMD field stays at ox1 for the duration of the entire transaction, and it is only cleared to ox0 after when the transaction has completed or when the controller loses the arbitration.</p> <p>Note: No transaction will be issued by the controller when all phases (Start, Address, Data and Stop) are disabled.</p> | ox0   |

### 33.3.10 Setup Register

The Setup Register keeps the programmable configurations and the I<sup>2</sup>C-bus timing parameters.

For detail timing settings, see Timing Setup Guide Timing Setup Guide.

**Table 33-11 Controller Setting Register**

| Name     | Bit   | Type | Description                                                                                                                                                                                                                                                                                    | Reset |
|----------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved | 31:29 | -    | -                                                                                                                                                                                                                                                                                              | -     |
| T_SUDAT  | 28:24 | R/W  | <p>T_SUDAT defines the data setup time before releasing the SCL.</p> <p>Setup time = <math>(2 * t_{pclk}) + (2 + T\_SP + T\_SUDAT) * t_{pclk} * (TPM+1)</math></p> <p><math>t_{pclk}</math> = PCLK period</p> <p>TPM = The multiplier value in Timing Parameter</p> <p>Multiplier Register</p> | 0x5   |
| T_SP     | 23:21 | R/W  | <p>T_SP defines the pulse width of spikes that must be suppressed by the input filter.</p> <p>Pulse width = <math>T\_SP * t_{pclk} * (TPM+1)</math></p>                                                                                                                                        | 0x1   |
| T_HDDAT  | 20:16 | R/W  | <p>T_HDDAT defines the data hold time after SCL goes LOW</p> <p>Hold time = <math>(2 * t_{pclk}) + (2 + T\_SP + T\_HDDAT) * t_{pclk} * (TPM+1)</math></p>                                                                                                                                      | 0x5   |

| Name       | Bit   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Reset |
|------------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved   | 15:14 | -    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | -     |
| T_SCLRatio | 13    | R/W  | <p>The LOW period of the generated SCL clock is defined by the combination of T_SCLRatio and T_SCLHi values.</p> <p>When T_SCLRatio = 0, the LOW period is equal to HIGH period. When T_SCLRatio = 1, the LOW period is roughly two times of HIGH period.</p> $\text{SCL LOW period} = (2 * t_{\text{clk}}) + (2 + T_{\text{SP}} + T_{\text{SCLHi}} * \text{ratio}) * t_{\text{clk}} * (\text{TPM}+1)$ <p>1: ratio = 2<br/>0: ratio = 1</p> <p>This field is only valid when the controller is in the master mode.</p> | 0x1   |
| T_SCLHi    | 12:4  | R/W  | <p>The HIGH period of generated SCL clock is defined by T_SCLHi.</p> $\text{SCL HIGH period} = (2 * t_{\text{clk}}) + (2 + T_{\text{SP}} + T_{\text{SCLHi}}) * t_{\text{clk}} * (\text{TPM}+1)$ <p>The T_SCLHi value must be greater than T_SP and T_HDDAT values.</p> <p>This field is only valid when the controller is in the master mode.</p>                                                                                                                                                                      | 0x10  |
| DMAEn      | 3     | R/W  | <p>Enable the direct memory access mode data transfer.</p> <p>1: Enable<br/>0: Disable</p>                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x0   |
| Master     | 2     | R/W  | <p>Configure this device as a master or a slave.</p> <p>1: Master mode<br/>0: Slave mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                           | 0x0   |
| Addressing | 1     | R/W  | <p>I<sup>2</sup>C addressing mode:</p> <p>1: 10-bit addressing mode<br/>0: 7-bit addressing mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0   |
| IICEn      | 0     | R/W  | <p>Enable the ATCIIIC100 I<sup>2</sup>C controller.</p> <p>1: Enable<br/>0: Disable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x0   |

### 33.3.11 Timing Parameter Multiplier Register

The Timing Parameter Multiplier Register holds a multiplier value that enlarges the I<sup>2</sup>C-bus timing parameters defined in the Setup Register. The multiplier number helps the controller to meet timing requirements of the I<sup>2</sup>C-bus interface when the controller is operating at a higher APB frequency. Please see Timing Parameter Multiplier for the procedures to compute its value.

**Table 33-12 Timing Parameter Multiplier Register**

| Name     | Bit  | Type | Description                                                                                                                               | Reset |
|----------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved | 31:5 | -    | -                                                                                                                                         | -     |
| TPM      | 4:0  | R/W  | A multiplication value for I <sub>2</sub> C timing parameters. All the timing parameters in the Setup Register are multiplied by (TPM+1). | ox0   |

## 33.4 RTL Configuration

### 33.4.1 Data FIFO Size

The ATCIIC100 controller uses a FIFO as buffer to the I<sup>2</sup>C-bus. The data to be transmitted or received are stored in the FIFO. Define [ATCIIC100\\_FIFO\\_DEPTH\\_n](#) to configure an n-byte FIFO, where n is the number 2, 4, 8 or 16.

## 33.5 Programming Sequence

### 33.5.1 Timing Setup Guide

Before enabling the ATCIIC100 controller, you must:

1. Setup the timing parameter multiplier by programming the Timing Parameter Multiplier Register
2. Setup the I<sup>2</sup>C-bus timing parameters1 by programming the Setup Register

As an I<sup>2</sup>C slave, the spike suppression width, the data setup time and the data hold time must be programmed properly according to the APB clock frequency and the speed of the I<sup>2</sup>C-bus. As an I<sup>2</sup>C master, the I<sup>2</sup>C-bus clock frequency must be programmed as well.

By default, the I<sup>2</sup>C-bus interface timings are specified by timing parameters in the Setup Register in units of APB clock cycles. Since the bit widths of timing parameters are limited, if the APB clock frequency is too high, the timing parameter settings may not meet the required I<sup>2</sup>C-bus interface timing values. In this case, the Timing Parameter Multiplier Register could be set to enlarge the actual values of the timing parameters. It expands the effective range of timing parameters in the Setup Register

and makes them fall into the valid parameter value ranges. The Timing Parameter Multiplier Register should be programmed while the I<sup>2</sup>C bus is idle and ATCII100 is disabled ([Setup.IICEn=0](#))

The following sub-sections show how to determine the Setup Register to meet the I<sup>2</sup>C-bus timing parameters. All the examples assume that the APB clock frequency is 40MHz, i.e. the APB clock period is 25ns. If the APB clock frequency of your design is not 40MHz, please derive the register fields accordingly.

<sup>1</sup> See NXP Semiconductors' "I<sup>2</sup>C-bus specification and user manual" for details.

### 33.5.2 Spike Suppression Width

Table 33-13 Timing Parameters for Spike Suppression shows the pulse width of spikes that must be suppressed by the input filter. For the Fast-mode and the Fast-mode Plus, spikes less than 50ns must be suppressed (assuming TPM == 0). i.e.,

$$T_{SP} = 50\text{ns} / (25\text{ns} * (TPM + 1)) = 2$$

Table 33-13 Timing Parameters for Spike Suppression

| Symbol          | Parameter                                                          | Standard-mode |     | Fast-mode |     | Fast-mode Plus |     | Unit |
|-----------------|--------------------------------------------------------------------|---------------|-----|-----------|-----|----------------|-----|------|
|                 |                                                                    | Min           | Max | Min       | Max | Min            | Max |      |
| t <sub>SP</sub> | Pulse width of spikes that must be suppressed by the input filter. | -             | -   | 0         | 50  | 0              | 50  | ns   |

### 33.5.3 Data Setup Time

Data setup time defines the time in which the SDA should be held steady before the SCL rising edge. Table 33-14 Timing Parameters for the Data Setup Time shows the timing parameters for the data setup time. The equation of data setup time shown in Table 11 is:

$$\text{Setup time} = (2 * \text{tpclk}) + (2 + T_{SP} + T_{SUDAT}) * \text{tpclk} * (\text{TPM} + 1)$$

For the Standard-mode (assuming TPM == 0),

$$250\text{ns} = 50\text{ns} + (2 + 2 + T_{SUDAT}) * 25\text{ns}$$

Then,

$$T_{SUDAT} = 4$$

For the other modes, T\_SUDAT can be calculated similarly

Table 33-14 Timing Parameters for the Data Setup Time

| Symbol             | Parameter       | Standard-mode |     | Fast-mode |     | Fast-mode Plus |     | Unit |
|--------------------|-----------------|---------------|-----|-----------|-----|----------------|-----|------|
|                    |                 | Min           | Max | Min       | Max | Min            | Max |      |
| t <sub>SUDAT</sub> | Data setup time | 250           | -   | 100       | -   | 50             | -   | ns   |

### 33.5.4 Data Hold Time

Data hold time defines the time in which the SDA should be held steady after the SCL falling edge. Table 33-15 Timing Parameters for the Data Hold Time shows the timing parameters for the data hold time. The equation of data hold time shown in Table 33-11 Controller Setting Register is:

$$\text{Hold time} = (2 * t_{\text{pclk}}) + (2 + T_{\text{SP}} + T_{\text{HDDAT}}) * t_{\text{pclk}} * (\text{TPM} + 1)$$

For the Standard-mode (assuming TPM == 0),

$$300\text{ns} = 50\text{ns} + (4 + 2 + T_{\text{HDDAT}}) * 25\text{ns}$$

Then,

$$T_{\text{HDDAT}} = 4$$

For the other modes, T\_HDDAT can be calculated similarly.

Table 33-15 Timing Parameters for the Data Hold Time

| Symbol             | Parameter      | Standard-mode |     | Fast-mode |     | Fast-mode Plus |     | Unit |
|--------------------|----------------|---------------|-----|-----------|-----|----------------|-----|------|
|                    |                | Min           | Max | Min       | Max | Min            | Max |      |
| t <sub>HDDAT</sub> | Data hold time | 300           | -   | 300       | -   | 0              | -   | ns   |

### 33.5.5 I<sup>2</sup>C-Bus Clock Frequency:

The I<sup>2</sup>C-bus clock frequency is specified by the t<sub>HIGH</sub> and t<sub>LOW</sub> parameters, which are shown in Table 16 and can be achieved through the T\_SCLHi and T\_SCLRatio fields of the Setup Register.

Table 33-16 Timing Parameters for the SCL Clock

| Symbol            | Parameter                    | Standard-mode |     | Fast-mode |     | Fast-mode Plus |     | Unit |
|-------------------|------------------------------|---------------|-----|-----------|-----|----------------|-----|------|
|                   |                              | Min           | Max | Min       | Max | Min            | Max |      |
| t <sub>HIGH</sub> | HIGH period of the SCL clock | 4.0           | -   | 0.6       | -   | 0.26           | -   | μs   |
| t <sub>LOW</sub>  | LOW period of the SCL clock  | 4.7           | -   | 1.3       | -   | 0.5            | -   | μs   |

For the Standard-mode, the minimum requirements of t<sub>HIGH</sub> and t<sub>LOW</sub> are close, so T\_SCLRatio can be set to 0 (i.e., ratio = 1) to simplify the settings. The equations for the SCL periods shown in Table 33-11 Controller Setting Register are:

$$\text{SCL HIGH period} = (2 * t_{\text{pclk}}) + (2 + T_{\text{SP}} + T_{\text{SCLHi}}) * t_{\text{pclk}} * (\text{TPM} + 1) \geq 4000\text{ns}$$

$$\text{SCL LOW period} = (2 * t_{\text{pclk}}) + (2 + T_{\text{SP}} + T_{\text{SCLHi}} * \text{ratio}) * t_{\text{pclk}} * (\text{TPM} + 1) \geq 4700\text{ns}$$

Substitute 2 for T<sub>SP</sub>, 1 for ratio and 25ns for t<sub>pclk</sub>, the equations become (assuming TPM == 0):

$$50\text{ns} + (2 + 2 + T_{\text{SCLHi}}) * 25\text{ns} * (0 + 1) \geq 4000\text{ns}$$

$$50\text{ns} + (2 + 2 + T_{\text{SCLHi}} * 1) * 25\text{ns} * (0 + 1) \geq 4700\text{ns}$$

$T_{SCLHi} \geq 182$

For the Fast-mode, the minimum requirement of  $t_{LOW}$  is about 2 times of  $t_{HIGH}$ , so  $T_{SCLRatio}$  can be set to 1 (i.e. ratio = 2). The equations for the SCL periods are:

$$\text{SCL HIGH period} = (2 * t_{pclk}) + (2 + T_{SP} + T_{SCLHi}) * t_{pclk} * (TPM + 1) \geq 600\text{ns}$$

$$\text{SCL LOW period} = (2 * t_{pclk}) + (2 + T_{SP} + T_{SCLHi} * \text{ratio}) * t_{pclk} * (TPM + 1) \geq 1300\text{ns}$$

Substitute 2 for  $T_{SP}$ , 2 for ratio and 25ns for  $t_{pclk}$ , the equations become (assuming  $TPM == 0$ ):

$$50\text{ns} + (4 + T_{SCLHi}) * 25\text{ns} * (0 + 1) \geq 600\text{ns}$$

$$50\text{ns} + (4 + T_{SCLHi} * 2) * 25\text{ns} * (0 + 1) \geq 1300\text{ns}$$

$$T_{SCLHi} \geq 23$$

For the Fast-mode Plus,  $T_{SCLHi}$  can be calculated using the same flow as the example in the Fast-mode.

### 33.5.6 Timing Parameter Multiplier

The Timing Parameter Multiplier Register could be adjusted to enlarge the effective values of the timing parameters in the Setup Register. This is only needed if the APB clock frequency is sohigh that it is impossible to meet the required I<sup>2</sup>C-bus interface timing specifications with the maximum values of timing parameters in the Setup Register alone (i.e., with  $TPM==0$ ).

The procedure to determine the (non-zero) TPM value to meet the I<sup>2</sup>C bus timing requirements is as follows:

1. Compute  $TPM$  by assigning maximum value (511) to  $T_{SCLHi}$  and minimum valid value (1) to  $T_{SP}$ . These values will be referred to as  $T_{SCLHi}'$  and  $T_{SP}'$  in discussions below to avoid confusion with the final  $T_{SCLHi}$  and  $T_{SP}$  values.
2. Compute  $T_{SCLHi}$  and  $T_{SP}$  based on the TPM value obtained above.

Note that the final

$T_{SCLHi}$  will most likely not be 511, but some value smaller than 511.

For example, consider operating ATCIIC100 under 2ns APB-bus clock period ( $t_{pclk} = 2\text{ns}$ ) with Standard-mode I2C bus timing requirements as described in Table 16 with additional requirement of 50ns spike suppression period. That is,  $t_{SP} = 50\text{ns}$ ,  $t_{HIGH} = 4.0\mu\text{s}$  and  $t_{LOW} = 4.7\mu\text{s}$ .

First of all, based on equations for timing parameters in Table 11:

$$\text{SCL HIGH period} = 2 * t_{pclk} + (2 + T_{SP}' + T_{SCLHi}') * t_{pclk} * (TPM + 1) \geq 4.0\mu\text{s}$$

$$\text{SCL LOW period} = 2 * t_{pclk} + (2 + T_{SP}' + T_{SCLHi}' * \text{ratio}) * t_{pclk} * (TPM + 1) \geq 4.7\mu\text{s}$$

With  $T_{SP}' = 1$ ,  $T_{SCLHi}' = 511$ , ratio = 1 and  $t_{pclk} = 2\text{ns}$ :

$$\text{SCL HIGH period} = 2 * 2\text{ns} + (2 + 1 + 511) * 2\text{ns} * (TPM + 1) \geq 4.0\mu\text{s}$$

$$\text{SCL LOW period} = 2 * 2\text{ns} + (2 + 1 + 511 * 1) * 2\text{ns} * (TPM + 1) \geq$$

**4.7us**

Therefore,

$$2 * 2\text{ns} + (2 + 1 + 511) * 2\text{ns} * (\text{TPM} + 1) \geq 4000\text{ns}$$

$$2 * 2\text{ns} + (2 + 1 + 511 * 1) * 2\text{ns} * (\text{TPM} + 1) \geq 4700\text{ns}$$

So:

$$(\text{TPM} + 1) \geq 4.57$$

$$\text{TPM} \geq 3.57$$

Pick **TPM** = 4, and compute all timing parameters again based on formulae in 32-Table 11. That is, compute **T\_SP** as:

$$\text{T}_\text{SP} \geq 50\text{ns} / ((\text{TPM}+1) * t_\text{pclk}) = 50\text{ns} / ((4+1)*2\text{ns}) = 5$$

And **T\_SCLHi** is computed by:

$$\text{SCL HIGH period} = 2 * t_\text{pclk} + (2 + \text{T}_\text{SP} + \text{T}_\text{SCLHi}) * t_\text{pclk} * (\text{TPM} + 1) \geq 4000\text{ns}$$

$$\text{SCL LOW period} = 2 * t_\text{pclk} + (2 + \text{T}_\text{SP} + \text{T}_\text{SCLHi} * \text{ratio}) * t_\text{pclk} * (\text{TPM} + 1) \geq 4700\text{ns}$$

So,

$$\text{SCL HIGH period} = 2 * 2\text{ns} + (2 + 5 + \text{T}_\text{SCLHi}) * 2\text{ns} * (4 + 1) \geq 4000\text{ns}$$

$$\text{SCL LOW period} = 2 * 2\text{ns} + (2 + 5 + \text{T}_\text{SCLHi}) * 2\text{ns} * (4 + 1) \geq 4700\text{ns}$$

Combine the two equations to reach:

$$2 * 2\text{ns} + (2 + 5 + \text{T}_\text{SCLHi}) * 2\text{ns} * (4 + 1) \geq 4700\text{ns}$$

$$7 + \text{T}_\text{SCLHi} \geq (4700 - 4) / (2^5)$$

$$\text{T}_\text{SCLHi} \geq 462.6$$

So the timing parameters for the Standard-mode I<sup>2</sup>C bus timing requirement for 2ns APB-bus clock period with 50ns spike suppression would be: **T\_SCLHi** = 463, **T\_SP** = 5, and **TPM** = 4.

### 33.5.7 Master Mode

The following examples demonstrate how to initiate I<sup>2</sup>C transactions at the Master mode.

### 33.5.8 Data Transmit without DMA

1. Setup the timing parameter multiplier by programming the Timing Parameter Multiplier Register if necessary.
2. Setup the controller by programming the Setup Register:
  - Master = 1
  - IICEn = 1
  - timing parameters.
3. Set the data count, direction and phase choices in the Control Register:
  - Phase\_start = 1
  - Phase\_addr = 1
  - Phase\_data = 1
  - Phase\_stop = 1

- Dir = 0
  - DataCnt = data counts in bytes.
4. Write the address of the target slave to the Address Register.
  5. Enable the Completion Interrupt and FIFO Empty Interrupt in the Interrupt Enable Register:
    - Cmpl = 1
    - FIFOEmpty = 1.
  6. Write 0x1 to the Command register to issue the transaction.
  7. Wait for Interrupts:
    - I. FIFO Empty Interrupt: push data into the FIFO by writing the data to the Data Register until the FIFO becomes full. If all data are pushed into the FIFO, disable the FIFO Empty Interrupt. Otherwise, repeat Step 6.
    - II. Completion Interrupt: check the AddrHit field of the Status Register to make sure the targeted slave correctly receives the transaction. Write 1 to the Cmpl field of the Status Register to clear the completion status and go to Step 7.
  8. Disable all interrupts and check the DataCnt field of the Control Register to know if all data are successfully transmitted.

### 33.5.9 Data Receive without DMA

1. Setup the timing parameter multiplier by programming the Timing Parameter Multiplier Register if necessary.
2. Setup the controller by programming the Setup Register:
  - Master = 1
  - IICEn = 1
  - timing parameters.
3. Set the data count, direction and phase choices in the Control Register:
  - Phase\_start = 1
  - Phase\_addr = 1
  - Phase\_data = 1
  - Phase\_stop = 1
  - Dir = 1
  - DataCnt = data counts in bytes.
4. Write the address of the target slave to the Address Register.
5. Enable the Completion Interrupt and FIFO Full Interrupt in the Interrupt Enable Register:
  - Cmpl = 1
  - FIFOFull = 1.
6. Write 0x1 to the Command register to issue the transaction.
7. Wait for Interrupts:
  - I. FIFO Full Interrupt: get data from the FIFO by reading the Data Register until the FIFO becomes empty; repeat **Step 6**.
  - II. Completion Interrupt: check the AddrHit field of the Status

- Register to make sure the targeted slave correctly receives the transaction. Get all of the remaining data from the FIFO, write 1 to the Cmpl field of the Status Register to clear the completion status and go to **Step 7**.
8. Disable all interrupts and check the DataCnt of the Control Register to know if all data are successfully received.
- Data Transaction with DMA:**
1. Setup the timing parameter multiplier by programming the Timing Parameter Multiplier Register if necessary.
  2. Set the Controller by programming the Setup Register:
    - Master = 1
    - IICEn = 1
    - DMAEn = 1
    - timing parameters.
  3. Setup the DMA controller.
  4. Set data count, direction and phase choices in the Control Register:
    - Phase\_start = 1
    - Phase\_addr = 1
    - Phase\_data = 1
    - Phase\_stop = 1
    - Dir = Transmitter/Receiver
    - DataCnt = data counts in bytes.
  5. Write the address of the target slave to the Address Register.
  6. Enable the Completion Interrupt in the Interrupt Enable Register:
    - Cmpl = 1.
  7. Write 0x1 to the Command Register to issue the transaction.
  8. Wait for the Completion Interrupt: check the DataCnt of the Control Register to know if all data are successfully transferred.

### 33.5.10 Arbitration Lost in the Multi-Master Mode

When there are multiple masters on the I2C-bus, they may start transactions at the same time and the I2C-bus protocol defines an arbitration scheme to resolve the bus contention. Only one master will win the bus arbitration, and the other master(s) will lose the arbitration.

When the controller loses the arbitration, the arbitration lose interrupt will be triggered and the following steps should be done to restart the transaction.

1. If DMA is used, abort the DMA transfer and disable the I2C DMA request by setting the DMAEn field of the Setup Register to 0, then write 0x4 to the Command Register to clear the FIFO.
2. Wait for bus not busy by polling the BusBusy field of the Status Register.
3. Restart the transaction.

### 33.5.11 Slave Mode

The following examples demonstrate how to operate the I<sup>2</sup>C controller at the Slave mode.

### 33.5.12 Data Transaction without DMA:

1. Set the Address Register to the slave controller's I<sup>2</sup>C-bus address.
2. Setup the timing parameter multiplier by programming the Timing Parameter Multiplier Register if needed.
3. Setup the Controller by programming the Setup Register:
  - Master = 0
  - IICEn = 1
  - timing parameters.
4. Enable the Address Hit Interrupt and Completion Interrupt in the Interrupt Enable Register:
  - AddrHit = 1
  - Cmpl = 1.
5. Wait for the Address Hit Interrupt: read the Dir field of the Control Register to identify the transaction direction. Read the Status Register if more transaction information is need, for example, the GenCall field to identify a General Call transaction. I. Receiver: enable the FIFOFull Interrupt and go to Step 5. II. Transmitter: enable the FIFOEmpty interrupt and go to Step 6.
6. Receiver:
  - I. Wait for the FIFO full Interrupt until the Completion Interrupt asserted.
  - II. If the FIFO Full Interrupt asserts: get data from the FIFO by reading the Data Register until the FIFO becomes empty, then go to (I).
7. Transmitter:
  - I. Wait the FIFO Empty Interrupt until the Completion Interrupt asserted.
  - II. If the FIFO Empty Interrupt asserts: push data to the FIFO by writing data to the Data Register until the FIFO becomes full, then go to (I).
8. During Step 5 or Step 6, if the Completion Interrupt asserts, clear the FIFO and go to step 8.
9. Check the DataCnt of the Control Register to know how many data are transferred. Clear the Completion Interrupt status of the Status Register when the software is ready to receive the next transaction.

### 33.5.13 Data transaction with DMA

The DMA should only be used when the next transaction's direction and data counts are known.

1. Set the Address Register to the controller's address.
2. Setup the timing parameter multiplier by programming the Timing Parameter Multiplier Register if necessary.
3. Setup the Controller by programming the Setup Register:
  - Master = 0
  - IICEn = 1
  - timing parameters.
4. Enable the Address Hit Interrupt and Completion Interrupt in the Interrupt Enable Register:
  - AddrHit = 1
  - Cmpl = 1.
5. Wait for the Address Hit Interrupt: read the Dir field of the Control Register to check the direction. If it is not the designed direction, fall back to normal transfer without DMA (Data Transmit without DMA, Step 5 Read the Status Register if more transaction information is need, for example, the GenCall field to identify a General Call transaction).
6. Setup the DMA controller.
7. Set the data count of the the transaction in the Control Register: DataCnt = data counts in byte.
8. Enable the DMA by set the DMAEn of the Setup Register and wait for the Completion Interrupt.
9. After the Completion Interrupt asserted, check the DataCnt of the Control Register to know how many data are transferred.
10. **0** Disable the DMA.
11. **1** Clear the Completion Interrupt status of the Status Register when the software is ready to receive the next transaction.

# 34 ATCSPI200

## 34.1 Introduction

AndeShape ATCSPI200 is a Serial Peripheral Interface (SPI) controller which serves as a SPI master or a SPI slave. As a SPI master, the controller connects various SPI devices. As a SPI slave, the controller responds to the master requests for data exchange.

### 34.1.1 Features

- Compliant with AMBA 2 AHB protocol specification
- Compliant with AMBA 3 APB protocol specification
- Support of MSB/LSB first transfer
- Support of Direct Memory Access (DMA) data transfer
- Support of programmable SPI SCLK
- Support of memory-mapped access (read-only) through AHB bus or EILM bus
- Support of SPI slave mode
- Configurable Dual and Quad I/O SPI interfaces
- Configurable TX/RX FIFO depth (The depth could be 2, 4, 8 or 16)
- Configurable programming port location on AHB/APB/EILM interfaces

### 34.1.2 Block Diagram

Figure 34-1 ATCSPI200 Block Diagram shows the block diagram of the ATCSPI200 controller.

**Figure 34-1 ATCSPI200 Block Diagram**



This section describes the SPI controller functions in four sub-sections for master mode, slave mode, dual I/O mode, and quad I/O mode. The master mode and slave mode sections describe the transfer initiation mechanism and the SPI frame formats. The dual mode and quad mode sections describe the other two transfer formats in comparison to the regular mode.

### 34.1.3 Master Mode

The ATCSPI200 controller can act as a SPI master initiating SPI transfers on the SPI bus. The SPI transfer format and interface timing are programmable via the AHB/APB programming port. The SPI transfers are initiated through the memory-mapped read access on the AHB/EILM bus or through register programming.

For SPI transfers initiated through the memory-mapped AHB/EILM read transactions, the read transactions are translated to the SPI interface based on the read command format setup in the SPI Memory Access Control Register. The default reset value of the register is hardware configurable to support booting from SPI ROMs. The size of the addressable memory-mapped space depends on the interface: up to 16MB on the AHB bus and 4MB on the EILM bus.

The AHB/EILM address received from the memory-mapped interface

is passed directly to the SPI slave since ATCSPI200 has no knowledge of the address and size of the slave. If addresses sent to the slave should be biased, the corresponding AHB/EILM address bits should be directly tied to the intended values.

For SPI transfers initiated by register programming, Figure 34-2 SPI Transfer Format shows an example of SPI transfer format which includes command, address, and data phases for TX/RX data transfers. The controller provides dedicated registers to specify the contents of command, address, and data fields. The data register is shared by both TX and RX data transfers. Data transfers can be initiated through Programmed IO (PIO) or Direct Memory Access (DMA).

The ATCSPI200 controller provides TX/RX FIFO threshold interrupts to ease flow control under the PIO programming. The controller also has a programmable bit to issue an interrupt once the transfer completes.

In addition to the supported transfer format, the SPI controller allows direct control of the signals on the SPI interface. This capability enables communication with SPI devices which require special transfer formats. See SPI Direct IO Control Register (0x14) for more information.

**Figure 34-2 SPI Transfer Format**



#### 34.1.4 Slave Mode

The ATCSPI200 controller can also act as a SPI slave and accepts common commands as shown in Table 34-1 Supported Commands under the Slave Mode. In addition, the controller supports user-defined commands where the slave data field format is defined by the transfer control register.

The ATCSPI200 slave interprets the packet on the SPI I/O interface as three fields: slave command, slave dummy and slave data. The slave command field and slave dummy field are always 8-bit in length. The slave data field format is defined by the received command and the Transfer Control Register.

**Table 34-1 Supported Commands under the Slave Mode**

| Slave Command Name    | OP Code                                          | Slave Data                                           |
|-----------------------|--------------------------------------------------|------------------------------------------------------|
| Read Status Single IO | 0x05                                             | 32-bit Status                                        |
| Read Status Dual IO   | 0x15                                             | 32-bit Status                                        |
| Read Status Quad IO   | 0x25                                             | 32-bit Status                                        |
| Read Data Single IO   | 0x0B                                             | Reply data from the Data Register in the FIFO manner |
| Read Data Dual IO     | 0x0C                                             | Reply data from the Data Register in the FIFO manner |
| Read Data Quad IO     | 0x0E                                             | Reply data from the Data Register in the FIFO manner |
| Write Data Single IO  | 0x51                                             | Data saved to the Data Register in the FIFO manner   |
| Write Data Dual IO    | 0x52                                             | Data saved to the Data Register in the FIFO manner   |
| Write Data Quad IO    | 0x54                                             | Data saved to the Data Register in the FIFO manner   |
| User-defined          | Any 8-bit numbers other than the listed OP Codes | Depending on the Transfer Controller Register        |

For the status-reading commands, the slave returns the value of the Slave Status Register. The protocol format is illustrated in Figure 34-3

Timing Diagram of Status-Reading Commands (MSB First, DataMerge=0).

**Figure 34-3 Timing Diagram of Status-Reading Commands (MSB First, DataMerge=0)**



For the data-reading and data-writing commands, the protocol formats are illustrated in Figure 34-4 Timing Diagram of Data-Reading Commands (MSB First, Merge Mode), Figure 34-5 Timing Diagram of Data-Writing Commands (MSB First, Merge Mode), and Figure 34-6 Timing Diagram of Data-Reading Commands (MSB First, Data Length = 16 Bits).

**Figure 34-4 Timing Diagram of Data-Reading Commands (MSB First, Merge Mode)**



**Figure 34-5 Timing Diagram of Data-Writing Commands (MSB First, Merge Mode)**



**Figure 34-6 Timing Diagram of Data-Reading Commands (MSB First, Data Length = 16 Bits)**



For user-defined commands, the slave data field format is defined by the SPI Transfer Control Register (0x20). For example, if the transfer mode is {Dummy, Write}, only the write field will be logged into the data register and the dummy field is dropped.

**Figure 34-7 Timing Diagram of Slave User-Defined Command (MSB First, Merge Mode, TransMode = {Dummy,Write}, DualQuad = Quad, DummyCnt = 1, WrTranCnt = 3, Data length = 8 Bits)**



### 34.1.5 Dual I/O Mode

The dual I/O mode doubles the SPI bandwidth by treating the master-input/slave-output (**MISO**) and master-output/slave-input (**MOSI**) signals as bidirectional wires. The SPI controller provides two transfer formats at the dual I/O mode. In one format, both address phase and data phase make use of the two wires (**MISO** and **MOSI**). In the other format, only the data phase makes use of the two wires. See **AddrFmt** and **DualQuad** bits in the SPI Transfer Format Register (SPI Transfer Control Register (0x20)) for more information. Figure 34-8 SPI Dual I/O Transfer (3-byte address) shows an example of dual I/O transfer.

**Figure 34-8 SPI Dual I/O Transfer (3-byte address)**

### 34.1.6 Quad I/O Mode

The quad I/O mode quadruples the SPI bandwidth by treating the master-input/slave-output (**MISO**), master-output/slave-input (**MOSI**), write protect (**WP**), and **HOLD** signals as bidirectional wires. The SPI controller provides two transfer formats at the quad I/O mode. In one format, both address phase and data phase make use of the four wires (**MISO**, **MOSI**, **WP** and **HOLD**). In the other format, only the data phase makes use of the four wires. See **AddrFmt** and **DualQuad** bits in the SPI Transfer Format Register (SPI Transfer Control Register (0x20)) for more information.

Figure 34-9 SPI Quad I/O Mode Transfer (3-byte address) shows an example of quad I/O transfer.

**Figure 34-9 SPI Quad I/O Mode Transfer (3-byte address)**

## 34.2 Signal Description

Table 34-2 ATCSPI200 Signal Definition gives the detailed descriptions of ATCSPI200 I/O signals.

**Table 34-2 ATCSPI200 Signal Definition**

| Signal Name                 | I/O Type | Description                                                                                                                                                                                                  |
|-----------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SPI Clock signals</b>    |          |                                                                                                                                                                                                              |
| spi_clock                   | I        | The clock source for the SPI interface. The <b>SCLK</b> signal of the SPI interface is generated by dividing this clock source with a programmable value.                                                    |
| <b>AHB Global Signals</b>   |          |                                                                                                                                                                                                              |
| hclk                        | I        | AHB clock                                                                                                                                                                                                    |
| hresetn                     | I        | AHB reset signal (Active-Low)                                                                                                                                                                                |
| apb2ahb_elken               | I        | APB to AHB clock enable is an AHB domain signal indicating the valid AHB clock cycles to sample and update APB domain signals when the AHB frequency is a multiple of the APB frequency.                     |
| <b>AHB Memory Read Port</b> |          |                                                                                                                                                                                                              |
| hsel_mem                    | I        | AHB slave select                                                                                                                                                                                             |
| htrans_mem[1:0]             | I        | AHB transfer type                                                                                                                                                                                            |
| haddr_mem[N:o]              | I        | AHB address bus<br>N is 23 if AHB address width is 24-bit. It is 31 if the AHB address width is 32-bit.<br>Unused most significant bits must be padded with zero, otherwise undetermined behavior may occur. |
| hreadyin_mem                | I        | AHB bus ready                                                                                                                                                                                                |
| hwrite_mem                  | I        | AHB transfer direction                                                                                                                                                                                       |
| hwdata_mem[31:0]            | I        | AHB write data bus                                                                                                                                                                                           |
| hreadyout_mem               | O        | AHB slave transfer done                                                                                                                                                                                      |

| Signal Name                          | I/O Type | Description                                                                                                                                                                                  |
|--------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| hresp_mem                            | O        | AHB transfer response                                                                                                                                                                        |
| hrdata_mem[31:0]                     | O        | AHB read data bus                                                                                                                                                                            |
| <b>EILM Memory Read Port</b>         |          |                                                                                                                                                                                              |
| eilm_clk                             | I        | EILM bus clock                                                                                                                                                                               |
| ahb2eilm_clken                       | I        | AHB to EILM clock enable is an EILM domain signal indicating the valid EILM clock cycles to sample and update AHB domain signals when the EILM frequency is a multiple of the AHB frequency. |
| apb2eilm_clken                       | I        | APB to EILM clock enable is an EILM domain signal indicating the valid EILM clock cycles to sample and update APB domain signals when the EILM frequency is a multiple of the APB frequency. |
| eilm_resetn                          | I        | EILM bus reset signal                                                                                                                                                                        |
| eilm_req                             | I        | EILM request                                                                                                                                                                                 |
| eilm_web[3:0]                        | I        | EILM write enable                                                                                                                                                                            |
| eilm_wait                            | O        | EILM early wait state<br><br>ox0: Data will be ready at the next cycle<br><br>ox1: The interface should be in the wait state for the next cycle                                              |
| eilm_wait_cnt[1:0]                   | I        | Represents the static wait cycles for the CPU<br><br>Note that eilm_wait_cnt should not be zero.                                                                                             |
| eilm_wdata[31:0]                     | I        | EILM write data                                                                                                                                                                              |
| eilm_addr[21:2]                      | I        | EILM address bus                                                                                                                                                                             |
| eilm_rdata[31:0]                     | O        | EILM read data                                                                                                                                                                               |
| <b>AHB Register Programming Port</b> |          |                                                                                                                                                                                              |
| hsel_reg                             | I        | AHB slave select                                                                                                                                                                             |
| htrans_reg[1:0]                      | I        | AHB transfer type                                                                                                                                                                            |
| haddr_reg[N:0]                       | I        | AHB address bus<br><br>N is 23 if AHB address width is 24-bit. It is 31 if the AHB address width is 32-bit.                                                                                  |
| hreadyin_reg                         | I        | AHB bus ready                                                                                                                                                                                |

| Signal Name                          | I/O Type | Description                                               |
|--------------------------------------|----------|-----------------------------------------------------------|
| hwrite_reg                           | I        | AHB transfer direction                                    |
| hwdata_reg[31:0]                     | I        | AHB write data bus                                        |
| hreadyout_reg                        | O        | AHB slave transfer done                                   |
| hresp_reg                            | O        | AHB transfer response                                     |
| hrdata_reg[31:0]                     | O        | AHB read data bus                                         |
| <b>APB Register Programming Port</b> |          |                                                           |
| pclk                                 | I        | APB clock (must be synchronous with the AHB/EILM clock)   |
| presetn                              | I        | APB reset signal (Active-Low)                             |
| paddr[31:0]                          | I        | APB address bus                                           |
| penable                              | I        | APB enable signal                                         |
| pwrite                               | I        | APB write signal                                          |
| psel                                 | I        | APB select signal                                         |
| pwdata[31:0]                         | I        | APB write data bus                                        |
| prdata[31:0]                         | O        | APB read data                                             |
| pready                               | O        | APB slave transfer done                                   |
| <b>SPI Interface</b>                 |          |                                                           |
| spi_sclk_in                          | I        | Status of the SPI SCLK signal                             |
| spi_cs_n_in                          | I        | Status of the SPI CS (chip select) signal                 |
| spi_miso_in                          | I        | Status of the SPI master-input/slave-output (MISO) signal |
| spi_mosi_in                          | I        | Status of the SPI master-output/slave-input (MOSI) signal |
| spi_wp_n_in                          | I        | Status of the SPI Flash write protect signal              |
| spi_hold_n_in                        | I        | Status of the SPI Flash hold signal                       |
| spi_sclk_out                         | O        | Output value for the SPI SCLK signal                      |
| spi_cs_n_out                         | O        | Output value for the SPI CS signal                        |
| spi_miso_out                         | O        | Output value for the SPI MISO signal                      |
| spi_mosi_out                         | O        | Output value for the SPI MOSI signal                      |
| spi_wp_n_out                         | O        | Output value for the SPI Flash write protect signal       |

| Signal Name          | I/O Type | Description                                                                                                                                                       |
|----------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| spi_hold_n_out       | O        | Output value for the SPI Flash hold signal                                                                                                                        |
| spi_sclk_oe          | O        | Output enable for the SPI <b>SCLK</b> signal                                                                                                                      |
| spi_cs_n_oe          | O        | Output enable for the SPI <b>CS</b> signal                                                                                                                        |
| spi_miso_oe          | O        | Output enable for the SPI <b>MISO</b> signal                                                                                                                      |
| spi_mosi_oe          | O        | Output enable for the SPI <b>MOSI</b> signal                                                                                                                      |
| spi_wp_n_oe          | O        | Output enable for the SPI Flash write protect signal                                                                                                              |
| spi_hold_n_oe        | O        | Output enable for the SPI Flash hold signal                                                                                                                       |
| <b>Miscellaneous</b> |          |                                                                                                                                                                   |
| spi_default_mode3    | I        | Select the default SPI mode<br>ox0: Default values of both <b>CPOL</b> and <b>CPHA</b> are ox0<br>ox1: Default values of both <b>CPOL</b> and <b>CPHA</b> are ox1 |
| spi_default_as_slave | I        | Set the ATCSPI200 controller as a slave after reset<br>ox0: Default as a master<br>ox1: Default as a slave                                                        |
| spi_tx_dma_ack       | I        | TX FIFO DMA acknowledge                                                                                                                                           |
| spi_rx_dma_ack       | I        | RX FIFO DMA acknowledge                                                                                                                                           |
| spi_tx_dma_req       | O        | TX FIFO DMA request                                                                                                                                               |
| spi_rx_dma_req       | O        | RX FIFO DMA request                                                                                                                                               |
| spi_boot_intr        | O        | The SPI controller interrupt                                                                                                                                      |
| scan_enable          | I        | Scan enable (Active-High during ATPG scan/shift phase)                                                                                                            |
| scan_test            | I        | Scan test mode (Active-High during ATPG test)                                                                                                                     |

## 34.3 Programming Model

### 34.3.1 Summary of Registers

Table 34-3 ATCSPI200 Register Summary shows the summary of ATCSPI200 registers.

**Table 34-3 ATCSPI200 Register Summary**

| Offset      | Name       | Description                                                                                          |
|-------------|------------|------------------------------------------------------------------------------------------------------|
| 0x00        | IdRev      | ID and Revision Register                                                                             |
| 0x04~0x0C   | -          | Reserved                                                                                             |
| 0x10        | TransFmt   | SPI Transfer Format Register                                                                         |
| 0x14        | DirectIO   | SPI Direct IO Control Register                                                                       |
| 0x18~0x1C   |            | Reserved                                                                                             |
| 0x20        | TransCtrl  | SPI Transfer Control Register                                                                        |
| 0x24        | Cmd        | SPI Command Register                                                                                 |
| 0x28        | Addr       | SPI Address Register                                                                                 |
| 0x2C        | Data       | SPI Data Register                                                                                    |
| 0x30        | Ctrl       | SPI Control Register                                                                                 |
| 0x34        | Status     | SPI Status Register                                                                                  |
| 0x38        | IntrEn     | SPI Interrupt Enable Register                                                                        |
| 0x3C        | IntrSt     | SPI Interrupt Status Register                                                                        |
| 0x40        | Timing     | SPI Interface Timing Register                                                                        |
| 0x44 ~ 0x4C |            | Reserved                                                                                             |
| 0x50        | MemCtrl    | SPI Memory Access Control Register                                                                   |
| 0x54 ~ 0x5C |            | Reserved                                                                                             |
| 0x60        | SlvSt      | SPI Slave Status Register<br>(Present only when <code>ATCSPI200_SLAVE_SUPPORT</code> is defined)     |
| 0x64        | SlvDataCnt | SPI Slave Data Count Register<br>(Present only when <code>ATCSPI200_SLAVE_SUPPORT</code> is defined) |
| 0x68~0x78   |            | Reserved                                                                                             |
| 0x7C        | Config     | Configuration Register                                                                               |

### 34.3.2 Register Description

The abbreviations for the Type column are summarized below.

RO: read only

RW: readable and writable

W1C: readable and write 1 to clear

### 34.3.3 ID and Revision Register (0x00)

This register holds the ID number and the revision number. The reset values of the two revision fields are revision dependent.

**Table 34-4 ID and Revision Register**

| Name     | Bit  | Type | Description             | Reset              |
|----------|------|------|-------------------------|--------------------|
| ID       | 31:8 | RO   | ID number for ATCSPI200 | 0x020020           |
| RevMajor | 7:4  | RO   | Major revision number   | Revision dependent |
| RevMinor | 3:0  | RO   | Minor revision number   | Revision dependent |

### 34.3.4 SPI Transfer Format Register (0x10)

This register defines the SPI transfer format.

**Table 34-5 SPI Transfer Format Register**

| Name      | Bit   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset |
|-----------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved  | 31:18 | -    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | -     |
| AddrLen   | 17:16 | RW   | Address length in bytes<br>0x0: 1 byte<br>0x1: 2 bytes<br>0x2: 3 bytes<br>0x3: 4 bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x2   |
| Reserved  | 15:13 | -    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | -     |
| DataLen   | 12:8  | RW   | The length of each data unit in bits<br>The actual bit number of a data unit is ( <a href="#">DataLen + 1</a> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x07  |
| DataMerge | 7     | RW   | Enable Data Merge mode, which does automatic data split on write and data coalescing on read.<br>This bit only takes effect when <a href="#">DataLen</a> = 0x7.<br>Under Data Merge mode, each write to the Data Register will transmit all fourbytes of the write data; each read from the Data Register will retrieve four bytes of received data as a single word data.<br>When Data Merge mode is disabled, only the least ( <a href="#">DataLen+1</a> ) significant bits of the Data Register are valid for read/write operations; no automatic data split/coalescing will be performed. | 0x1   |
| Reserved  | 6:5   | -    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | -     |
| MOSIBiDir | 4     | RW   | Bi-directional <a href="#">MOSI</a> in regular (single) mode<br>0x0: <a href="#">MOSI</a> is uni-directional signal in regular mode.<br>0x1: <a href="#">MOSI</a> is bi-directional signal in regular mode.<br>This bi-directional signal replaces the two                                                                                                                                                                                                                                                                                                                                    | 0x0   |

| Name                                                        | Bit | Type | Description                                                                                                                                                    | Reset                                             |
|-------------------------------------------------------------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|
| uni-directional data signals, <b>MOSI</b> and <b>MISO</b> . |     |      |                                                                                                                                                                |                                                   |
| LSB                                                         | 3   | RW   | Transfer data with the least significant bit first<br><br>ox0: Most significant bit first<br>ox1: Least significant bit first                                  | ox0                                               |
| SlvMode                                                     | 2   | RW   | SPI Master/Slave mode selection<br><br>ox0: Master mode<br>ox1: Slave mode<br><br>(Exist only when configuration<br><b>ATCSP1200_SLAVE_SUPPORT</b> is defined) | Depends on pin<br><br><b>spi_default_as_slave</b> |
| CPOL                                                        | 1   | RW   | SPI Clock Polarity<br><br>ox0: <b>SCLK</b> is LOW in the idle states<br>ox1: <b>SCLK</b> is HIGH in the idle states                                            | Depends on pin<br><br><b>spi_default_mod_e3</b>   |
| CPHA                                                        | 0   | RW   | SPI Clock Phase<br><br>ox0: Sampling data at odd <b>SCLK</b> edges<br>ox1: Sampling data at even <b>SCLK</b> edges                                             | Depends on pin<br><br><b>spi_default_mod_e3</b>   |

### 34.3.5 SPI Direct IO Control Register (0x14)

This register enables the direct control of the SPI interface signals.  
The register is valid only when the configuration  
**ATCSP1200\_DIRECT\_IO\_SUPPORT** is defined.

**Table 34-6 SPI Direct IO Control Register****Table 6. SPI Direct IO Control Register**

| Name       | Bit   | Type | Description                                          | Reset                                           |
|------------|-------|------|------------------------------------------------------|-------------------------------------------------|
| Reserved   | 31:25 | -    | -                                                    | -                                               |
| DirectIOEn | 24    | RW   | Enable Direct IO<br>0x0: Disable<br>0x1: Enable      | 0x0                                             |
| Reserved   | 23:22 | -    | -                                                    | -                                               |
| HOLD_OE    | 21    | RW   | Output enable for the SPI Flash hold signal          | 0x0                                             |
| WP_OE      | 20    | RW   | Output enable for the SPI Flash write protect signal | 0x0                                             |
| MISO_OE    | 19    | RW   | Output enable for the SPI MISO signal                | 0x0                                             |
| MOSI_OE    | 18    | RW   | Output enable for the SPI MOSI signal                | 0x0                                             |
| SCLK_OE    | 17    | RW   | Output enable for the SPI SCLK signal                | 0x0                                             |
| CS_OE      | 16    | RW   | Output enable for SPI CS (chip select) signal        | 0x0                                             |
| Reserved   | 15:14 | -    | -                                                    | -                                               |
| HOLD_O     | 13    | RW   | Output value for the SPI Flash hold signal           | 0x1                                             |
| WP_O       | 12    | RW   | Output value for the SPI Flash write protect signal  | 0x1                                             |
| MISO_O     | 11    | RW   | Output value for the SPI MISO signal                 | 0x0                                             |
| MOSI_O     | 10    | RW   | Output value for the SPI MOSI signal                 | 0x0                                             |
| SCLK_O     | 9     | RW   | Output value for the SPI SCLK signal                 | 0x0                                             |
| CS_O       | 8     | RW   | Output value for the SPI CS (chip select) signal     | 0x1                                             |
| Reserved   | 7:6   | -    | -                                                    | -                                               |
| HOLD_I     | 5     | RO   | Status of the SPI Flash hold signal                  | Depends on pin<br><a href="#">spi_hold_n_in</a> |
| WP_I       | 4     | RO   | Status of the SPI Flash write protect signal         | Depends on pin<br><a href="#">spi_wp_n_in</a>   |
| MISO_I     | 3     | RO   | Status of the SPI MISO signal                        | Depends on pin<br><a href="#">spi_miso_in</a>   |
| MOSI_I     | 2     | RO   | Status of the SPI MOSI signal                        | Depends on pin<br><a href="#">spi_mosi_in</a>   |
| SCLK_I     | 1     | RO   | Status of the SPI SCLK signal                        | Depends on pin<br><a href="#">spi_clk_in</a>    |
| CS_I       | 0     | RO   | Status of the SPI CS (chip select) signal            | Depends on pin<br><a href="#">spi_cs_n_in</a>   |

### 34.3.6 SPI Transfer Control Register (0x20)

This register controls aspects of SPI transfers. Please see SPI Command Register (0x24) for starting a SPI transfer.

**Table 34-7 SPI Transfer Control Register**

| Name      | Bit   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                 | Reset |
|-----------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| CmdEn     | 30    | RW   | The SPI command phase enable<br><br>0x0: Disable the command phase<br><br>0x1: Enable the command phase<br><br>(Master mode only)                                                                                                                                                                                                                                                                           | 0x0   |
| AddrEn    | 29    | RW   | The SPI address phase enable<br><br>0x0: Disable the address phase<br><br>0x1: Enable the address phase<br><br>(Master mode only)                                                                                                                                                                                                                                                                           | 0x0   |
| AddrFmt   | 28    | RW   | The SPI address phase format<br><br>0x0: Address phase is the regular (single) mode<br><br>0x1: The format of the address phase is the same as the data phase (DualQuad).<br><br>(Master mode only)                                                                                                                                                                                                         | 0x0   |
| TransMode | 27:24 | RW   | The transfer mode<br><br>The transfer sequence could be<br><br>0x0: Write and read at the same time<br><br>0x1: Write only<br><br>0x2: Read only<br><br>0x3: Write, Read<br><br>0x4: Read, Write<br><br>0x5: Write, Dummy, Read<br><br>0x6: Read, Dummy, Write<br><br>0x7: None Data (must enable CmdEn or AddrEn in master mode)<br><br>0x8: Dummy, Write<br><br>0x9: Dummy, Read<br><br>0xa~0xf: Reserved | 0x0   |

| Name       | Bit   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset |
|------------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| DualQuad   | 23:22 | RW   | <p>The SPI data phase format</p> <p>ox0: Regular (Single) mode</p> <p>ox1: Dual I/O mode</p> <p>ox2: Quad I/O mode</p> <p>ox3: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ox0   |
| TokenEn    | 21    | RW   | <p>Append an one-byte special token following the address phase for SPI read transfers. The value of the special token should be selected in <a href="#">TokenValue</a>.</p> <p>ox0: Disable the one-byte special token</p> <p>ox1: Enable the one-byte special token</p> <p>(Master mode only)</p>                                                                                                                                                                                                                                                                                           | ox0   |
| WrTranCnt  | 20:12 | RW   | <p>Transfer count for write data</p> <p><a href="#">WrTranCnt</a> indicates the number of units of data to be transmitted to the SPI bus from the Data Register.</p> <p>The actual transfer count is (<a href="#">WrTranCnt</a>+1).</p> <p><a href="#">WrTranCnt</a> only takes effect when <a href="#">TransMode</a> is 0, 1, 3, 4, 5, 6 or 8.</p> <p>The size (bit-width) of a data unit is defined by the <a href="#">DataLen</a> field of the Transfer Format Register.</p> <p>For <a href="#">TransMode</a> 0, <a href="#">WrTranCnt</a> must be equal to <a href="#">RdTranCnt</a>.</p> | ox0   |
| TokenValue | 11    | RW   | <p>The value of the one-byte special token following the address phase for SPI read transfers.</p> <p>ox0: token value = ox00</p> <p>ox1: token value = ox69</p> <p>(Master mode only)</p>                                                                                                                                                                                                                                                                                                                                                                                                    | ox0   |

| Name      | Bit                | Type          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reset                                       |
|-----------|--------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|
| DummyCnt  | 10:9               | RW            | Dummy data count. The actual dummy count is<br>(DummyCnt +1).<br><br>The number of dummy cycles on the SPI interface<br>will be (DummyCnt+1)* ((DataLen+1)/SPI IO width)<br><br>The Data pins are put into the high impedance<br>during the dummy data phase.<br><br>DummyCnt is only used for TransMode 5, 6, 8 and 9,<br>which has dummy data phases.                                                                                                        | ox0                                         |
|           |                    |               | The following table shows dummy cycle settings<br>under some common transfer formats:                                                                                                                                                                                                                                                                                                                                                                          |                                             |
|           |                    |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                             |
|           | Dum<br>myCn<br>t+1 | DataL<br>en+1 | DualQuad                                                                                                                                                                                                                                                                                                                                                                                                                                                       | #Dummy<br>Cycles on<br>the SPI<br>Interface |
|           | 1                  | 8             | Regular/<br>Single                                                                                                                                                                                                                                                                                                                                                                                                                                             | 8                                           |
|           | 1                  | 8             | Dual                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 4                                           |
|           | 1                  | 8             | Quad                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 2                                           |
|           | 2                  | 8             | Quad                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 4                                           |
|           | 3                  | 8             | Quad                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 6                                           |
|           | 1                  | 32            | Quad                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 8                                           |
|           |                    |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                             |
| RdTranCnt | 8:0                | RW            | Transfer count for read data<br><br>RdTranCnt indicates the number of units of data to<br>be received from SPI bus and stored to the Data<br>Register. The actual received count is<br>(RdTranCnt+1).<br><br>RdTranCnt only takes effect when TransMode is<br>0, 2, 3, 4, 5, 6 or 9.<br><br>The size (bit-width) of a data unit is defined by the<br>DataLen field of the Transfer Format Register.<br><br>For TransMode 0, WrTranCnt must equal<br>RdTranCnt. | ox0                                         |

### 34.3.7 SPI Command Register (0x24)

Writing operations on this register will trigger SPI transfers. This register must be written with a dummy value to start a SPI transfer even when the command phase is not enabled. When the ATCSPI200 controller is programmed to the slave mode, the command field of the last received SPI transaction is stored in this SPI Command Register.

Table 34-8 SPI Command Register

| Name     | Bit  | Type | Description | Reset |
|----------|------|------|-------------|-------|
| Reserved | 31:8 | -    | -           | -     |
| CMD      | 7:0  | RW   | SPI Command | 0x0   |

### 34.3.8 SPI Address Register (0x28)

Table 34-9 SPI Address Register

| Name | Bit  | Type | Description                       | Reset |
|------|------|------|-----------------------------------|-------|
| ADDR | 31:0 | RW   | SPI Address<br>(Master mode only) | 0x0   |

### 34.3.9 SPI Data Register (0x2C)

When the controller is in the data merge mode, the byte endian of the SPI Data Register is little endian.

Table 34-10 SPI Data Register

| Name | Bit  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Reset |
|------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| DATA | 31:0 | RW   | <p>Data to transmit or the received data</p> <p>For writes, data is enqueued to the TX FIFO. The least significant byte is always transmitted first. If the TX FIFO is full and the <a href="#">SPIActive</a> bit of the status register is 1, the ready signal <a href="#">hready/pready</a> will be deasserted to insert wait states to the transfer.</p> <p>For reads, data is read and dequeued from the RX FIFO. The least significant byte is the first received byte. If the RX FIFO is empty and the <a href="#">SPIActive</a> bit of the status register is 1, the ready signal <a href="#">hready/pready</a> will be deasserted to insert wait states to the transfer.</p> <p>The FIFOs decouple the speed of the SPI transfers and the software's generation/consumption of data. When the TX FIFO is empty, SPI transfers will hold until more data is written to the TX FIFO; when the RX FIFO is full, SPI transfers will hold until there is more room in the RX FIFO.</p> <p>If more data is written to the TX FIFO than the write transfer count (<a href="#">WrTranCnt</a>), the remaining data will stay in the TX FIFO for the next transfer or until the TX FIFO is reset.</p> | 0x0   |

### 34.3.10 SPI Control Register (0x30)

Table 34-11 SPI Control Register

| Name      | Bit   | Type | Description                                                                                                                                                                                | Reset |
|-----------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved  | 31:21 | -    |                                                                                                                                                                                            | -     |
| TXTHRES   | 20:16 | RW   | Transmit (TX) FIFO Threshold<br><br>The TXFIFOInt interrupt or DMA request would be issued to replenish the TX FIFO when the TX data count is less than or equal to the TX FIFO threshold. | 0x0   |
| Reserved  | 15:13 | -    | -                                                                                                                                                                                          | -     |
| RXTHRES   | 12:8  | RW   | Receive (RX) FIFO Threshold<br><br>The RXFIFOInt interrupt or DMA request would be issued for consuming the RX FIFO when the RX data count is more than or equal to the RX FIFO threshold. | 0x0   |
| Reserved  | 7:5   | -    | -                                                                                                                                                                                          | -     |
| TXDMAEN   | 4     | RW   | TX DMA enable                                                                                                                                                                              | 0x0   |
| RXDMAEN   | 3     | RW   | RX DMA enable                                                                                                                                                                              | 0x0   |
| TXFIFORST | 2     | RW   | Transmit FIFO reset<br><br>Write 1 to reset. It is automatically cleared to 0 after the reset operation completes.                                                                         | 0x0   |
| RXFIFORST | 1     | RW   | Receive FIFO reset<br><br>Write 1 to reset. It is automatically cleared to 0 after the reset operation completes.                                                                          | 0x0   |
| SPIRST    | 0     | RW   | SPI reset<br><br>Write 1 to reset. It is automatically cleared to 0 after the reset operation completes.                                                                                   | 0x0   |

### 34.3.11 SPI Status Register (0x34)

Table 34-12 SPI Status Register

| Name      | Bit   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Reset |
|-----------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved  | 31:24 | -    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -     |
| TXFULL    | 23    | RO   | Transmit FIFO Full flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x0   |
| TXEMPTY   | 22    | RO   | Transmit FIFO Empty flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x1   |
| Reserved  | 21    | -    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -     |
| TXNUM     | 20:16 | RO   | Number of valid entries in the Transmit FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0   |
| RXFULL    | 15    | RO   | Receive FIFO Full flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x0   |
| RXEMPTY   | 14    | RO   | Receive FIFO Empty flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x1   |
| Reserved  | 13    | -    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -     |
| RXNUM     | 12:8  | RO   | Number of valid entries in the Receive FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x0   |
| Reserved  | 7:1   | -    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -     |
| SPIActive | 0     | RO   | SPI register programming is in progress.<br><br>In master mode, <b>SPIActive</b> becomes 1 after the SPI command register is written and becomes 0 after the transfer is finished.<br><br>In slave mode, <b>SPIActive</b> becomes 1 after the SPI CS signal is asserted and becomes 0 after the SPI CS signal is deasserted.<br><br>Note that due to clock synchronization, it may take at most two spi_clock cycles for <b>SPIActive</b> to change when the corresponding condition happens.<br><br>Note this bit stays 0 when Direct IO Control or the memory-mapped interface is used. | 0x0   |

### 34.3.12 SPI Interrupt Enable Register (0x38)

Table 34-13 SPI Interrupt Enable Register

| Name          | Bit  | Type | Description                                                                                                                                                                                      | Reset |
|---------------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved      | 31:6 | -    | -                                                                                                                                                                                                | -     |
| SlvCmdEn      | 5    | RW   | Enable the Slave Command Interrupt.<br>Control whether interrupts are triggered whenever slave commands are received.<br>(Slave mode only)                                                       | ox0   |
| EndIntEn      | 4    | RW   | Enable the End of SPI Transfer interrupt.<br>Control whether interrupts are triggered when SPI transfers end.<br>(In slave mode, end of read status transaction doesn't trigger this interrupt.) | ox0   |
| TXFIFOIntEn   | 3    | RW   | Enable the SPI Transmit FIFO Threshold interrupt.<br>Control whether interrupts are triggered when the valid entries are less than or equal to the TX FIFO threshold.                            | ox0   |
| RXFIFOIntEn   | 2    | RW   | Enable the SPI Receive FIFO Threshold interrupt.<br>Control whether interrupts are triggered when the valid entries are greater than or equal to the RX FIFO threshold.                          | ox0   |
| TXFIFOURIntEn | 1    | RW   | Enable the SPI Transmit FIFO Underrun interrupt.<br>Control whether interrupts are triggered when the Transmit FIFO run out of data.<br>(Slave mode only)                                        | ox0   |
| RXFIFOORIntEn | 0    | RW   | Enable the SPI Receive FIFO Overrun interrupt.<br>Control whether interrupts are triggered when the Receive FIFO overflows.<br>(Slave mode only)                                                 | ox0   |

### 34.3.13 SPI Interrupt Status Register (0x3C)

Table 34-14 SPI Interrupt Status Register

| Name        | Bit  | Type | Description                                                                                                         | Reset |
|-------------|------|------|---------------------------------------------------------------------------------------------------------------------|-------|
| Reserved    | 31:6 | -    |                                                                                                                     | -     |
| SlvCmdInt   | 5    | W1C  | Slave Command Interrupt.<br><br>This bit is set when Slave Command interrupts occur.<br><br>(Slave mode only)       | 0x0   |
| EndInt      | 4    | W1C  | End of SPI Transfer interrupt.<br><br>This bit is set when End of SPI Transfer interrupts occur.                    | 0x0   |
| TXFIFOInt   | 3    | W1C  | TX FIFO Threshold interrupt.<br><br>This bit is set when TX FIFO Threshold interrupts occur.                        | 0x0   |
| RXFIFOInt   | 2    | W1C  | RX FIFO Threshold interrupt.<br><br>This bit is set when RX FIFO Threshold interrupts occur.                        | 0x0   |
| TXFIFOURInt | 1    | W1C  | TX FIFO Underrun interrupt.<br><br>This bit is set when TX FIFO Underrun interrupts occur.<br><br>(Slave mode only) | 0x0   |
| RXFIFOORInt | 0    | W1C  | RX FIFO Overrun interrupt.<br><br>This bit is set when RX FIFO Overrun interrupts occur.<br><br>(Slave mode only)   | 0x0   |

### 34.3.14 SPI Interface Timing Register (0x40)

This register controls the SPI interface timing to satisfy the SPI Slave interface timing requirements. Only the master needs to program this register.

**Table 34-15 SPI Interface Timing Register**

| Name     | Bit   | Type | Description                                                                                                                                                                                                                                                                                                                      | Reset                   |
|----------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| Reserved | 31:14 | -    | -                                                                                                                                                                                                                                                                                                                                | -                       |
| CS2SCLK  | 13:12 | RW   | The minimum time between the edges of SPI CS and the edges of SCLK.<br><br>The actual duration is<br><br>$\frac{\text{SCLK period}}{2} \times (\text{CS2SCLK} + 1)$                                                                                                                                                              | Configuration dependent |
| CSHT     | 11:8  | RW   | The minimum time that SPI CS should stay HIGH.<br><br>The actual duration is<br><br>$\frac{\text{SCLK period}}{2} \times (\text{CSHT} + 1)$                                                                                                                                                                                      | Configuration dependent |
| SCLK_DIV | 7:0   | RW   | The clock frequency ratio between the clock source and SPI interface SCLK.<br><br>$\text{SCLK period} = ((\text{SCLK\_DIV}+1) \times 2) \times (\text{Period of the SPI clock source})$<br><br>The SCLK_DIV value 0xff is a special value which indicates that the SCLK frequency should be the same as the spi_clock frequency. | Configuration dependent |

### 34.3.15 SPI Memory Access Control Register (0x50)

This register defines the SPI command issued for memory-mapped AHB/EILM read accesses.

The memory-mapped AHB/EILM read accesses should not be on-going while programming this register or the SPI Interface Timing Register (0x40). The AHB/EILM accesses could be resumed when the MemCtrlChg bit is cleared.

**Table 34-16 SPI Memory Access Control Register**

| Name       | Bit  | Type | Description                                                                                                                                                                                        | Reset                   |
|------------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| Reserved   | 31:9 | -    | -                                                                                                                                                                                                  | -                       |
| MemCtrlChg | 8    | RO   | This bit is set when this register (0x50) or the SPI Interface Timing Register (0x40) is written; it is automatically cleared when the new programming takes effect.                               | 0                       |
| Reserved   | 7:4  | -    | -                                                                                                                                                                                                  | -                       |
| MemRdCmd   | 3:0  | RW   | Selects the SPI command for serving the memory-mapped reads on the AHB/EILM bus<br><br>The command encoding table is listed in Table 17.<br><br>The latency of each command is listed in Table 18. | Configuration dependent |

**Table 34-17 Supported SPI Read Commands for Memory-Mapped AHB/EILM Reads**

| MemRdCmd | Command  | Address                                  | Dummy                  | Data         |
|----------|----------|------------------------------------------|------------------------|--------------|
| 0        | 0x03     | 3 bytes in Regular mode                  | N/A                    | Regular mode |
| 1        | 0x0B     | 3 bytes in Regular mode                  | 1 byte in Regular mode | Regular mode |
| 2        | 0x3B     | 3 bytes in Regular mode                  | 1 byte in Regular mode | Dual mode    |
| 3        | 0x6B     | 3 bytes in Regular mode                  | 1 byte in Regular mode | Quad mode    |
| 4        | 0xBB     | (3-byte address + 1-byte O) in Dual mode | N/A                    | Dual mode    |
| 5        | 0xEB     | (3-byte address + 1-byte O) in Quad mode | 2 bytes in Quad mode   | Quad mode    |
| 6–7      | Reserved | -                                        | -                      | -            |
| 8        | 0x13     | 4 bytes in Regular mode                  | N/A                    | Regular mode |
| 9        | 0x0C     | 4 bytes in Regular mode                  | 1 byte in Regular mode | Regular mode |
| 10       | 0x3C     | 4 bytes in Regular mode                  | 1 byte in Regular mode | Dual mode    |
| 11       | 0x6C     | 4 bytes in Regular mode                  | 1 byte in Regular mode | Quad mode    |
| 12       | 0xBC     | (4-byte address + 1-byte O) in Dual mode | N/A                    | Dual mode    |
| 13       | 0xEC     | (4-byte address + 1-byte O) in Quad mode | 2 bytes in Quad mode   | Quad mode    |
| 14–15    | Reserved | -                                        | -                      | -            |

**Table 34-18 Latency of a 4 Bytes Data Transfer through the AHB/EILM Memory Read Port**

| Command | Non-sequential                   | Sequential          | Sequential<br>(prefetched*) |
|---------|----------------------------------|---------------------|-----------------------------|
| 0x03    | 8 BUS_CLK + 10 SPI_CLK + 64 SCLK | 3 BUS_CLK + 32 SCLK | 1 BUS_CLK                   |
| 0x0B    | 8 BUS_CLK + 10 SPI_CLK + 72 SCLK | 3 BUS_CLK + 32 SCLK | 1 BUS_CLK                   |
| 0x3B    | 8 BUS_CLK + 10 SPI_CLK + 56 SCLK | 3 BUS_CLK + 16 SCLK | 1 BUS_CLK                   |
| 0x6B    | 8 BUS_CLK + 10 SPI_CLK + 48 SCLK | 3 BUS_CLK + 8 SCLK  | 1 BUS_CLK                   |
| 0xBB    | 8 BUS_CLK + 10 SPI_CLK + 40 SCLK | 3 BUS_CLK + 16 SCLK | 1 BUS_CLK                   |
| 0xEB    | 8 BUS_CLK + 10 SPI_CLK + 28 SCLK | 3 BUS_CLK + 8 SCLK  | 1 BUS_CLK                   |
| 0x13    | 8 BUS_CLK + 10 SPI_CLK + 72 SCLK | 3 BUS_CLK + 32 SCLK | 1 BUS_CLK                   |
| 0x0C    | 8 BUS_CLK + 10 SPI_CLK + 80 SCLK | 3 BUS_CLK + 32 SCLK | 1 BUS_CLK                   |
| 0x3C    | 8 BUS_CLK + 10 SPI_CLK + 64 SCLK | 3 BUS_CLK + 16 SCLK | 1 BUS_CLK                   |
| 0x6C    | 8 BUS_CLK + 10 SPI_CLK + 56 SCLK | 3 BUS_CLK + 8 SCLK  | 1 BUS_CLK                   |
| 0xBC    | 8 BUS_CLK + 10 SPI_CLK + 44 SCLK | 3 BUS_CLK + 16 SCLK | 1 BUS_CLK                   |
| 0xEC    | 8 BUS_CLK + 10 SPI_CLK + 30 SCLK | 3 BUS_CLK + 8 SCLK  | 1 BUS_CLK                   |

BUS\_CLK: bus (AHB or EILM) clock cycle; SPI\_CLK: spi\_clock clock cycle; SCLK: SCLK clock cycle

\* The memory-mapped accesses are prefetched to speed up sequential accesses.

### 34.3.16 SPI Slave Status Register (0x60)

The Slave Status Register keeps slave statuses. An SPI master can get these statuses by issuing status-reading commands.

**Table 34-19 SPI Slave Status Register**

| Name       | Bit   | Type | Description                                                                                                                                                                            | Reset |
|------------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Reserved   | 31:19 | -    | -                                                                                                                                                                                      | -     |
| UnderRun   | 18    | W1C  | Data underrun occurs in the last transaction                                                                                                                                           | 0     |
| OverRun    | 17    | W1C  | Data overrun occurs in the last transaction                                                                                                                                            | 0     |
| Ready      | 16    | RW   | Set this bit to indicate that the ATCSPI200 is ready for data transaction.<br><br>When an SPI transaction other than slave status-reading command ends, this bit will be cleared to 0. | 0     |
| USR_Status | 15:0  | RW   | User defined status flags                                                                                                                                                              | 0     |

### 34.3.17 SPI Slave Data Count Register (0x64)

This register shows the data count of the read/write transactions in the slave mode. Data register is accessed based on the data count information.

**Table 34-20 SPI Slave Data Count Register**

| Name     | Bit   | Type | Description                  | Reset |
|----------|-------|------|------------------------------|-------|
| Reserved | 31:25 | -    | -                            |       |
| WCnt     | 24:16 | RO   | Slave transmitted data count | 0     |
| Reserved | 15:9  | -    | -                            |       |
| RCnt     | 8:0   | RO   | Slave received data count    | 0     |

### 34.3.18 Configuration Register (0x7C)

Table 34-21 Configuration Register

| Name       | Bit   | Type | Description                                                                       | Reset                   |
|------------|-------|------|-----------------------------------------------------------------------------------|-------------------------|
| Reserved   | 31:15 | -    |                                                                                   | -                       |
| Slave      | 14    | RO   | Support for SPI Slave mode                                                        | Configuration dependent |
| EILMMem    | 13    | RO   | Support for memory-mapped access (read-only) through EILM bus                     | Configuration dependent |
| AHBMem     | 12    | RO   | Support for memory-mapped access (read-only) through AHB bus                      | Configuration dependent |
| DirectIO   | 11    | RO   | Support for Direct SPI IO                                                         | Configuration dependent |
| Reserved   | 10    | -    | -                                                                                 | -                       |
| QuadSPI    | 9     | RO   | Support for Quad I/O SPI                                                          | Configuration dependent |
| DualSPI    | 8     | RO   | Support for Dual I/O SPI                                                          | Configuration dependent |
| Reserved   | 7:6   | -    | -                                                                                 | -                       |
| TxFIFOSize | 5:4   | RO   | Depth of TX FIFO<br>ox0: 2 words<br>ox1: 4 words<br>ox2: 8 words<br>ox3: 16 words | Configuration dependent |
| Reserved   | 3:2   | -    | -                                                                                 | -                       |
| RxFIFOSize | 1:0   | RO   | Depth of RX FIFO<br>ox0: 2 words<br>ox1: 4 words<br>ox2: 8 words<br>ox3: 16 words | Configuration dependent |

## 34.4 Hardware Configuration Options

The ATCSPI200 controller provides the following configuration options to select the hardware features. The configuration result can be read from the Configuration Register (0x7C).

### 34.4.1 Address Width

Define the following macro to set the AHB address width to 24-bit.  
Default address width is 32-bit.

```
`define ATCSPI200_ADDR_WIDTH_24
```

### 34.4.2 Dual I/O Mode

Define `ATCSPI200_DUALSPI_SUPPORT` to support the dual I/O mode.

```
`define ATCSPI200_DUALSPI_SUPPORT
```

### 34.4.3 Quad I/O Mode

Define `ATCSPI200_QUADSPI_SUPPORT` to support both dual I/O mode and quad I/O mode.

```
`define ATCSPI200_QUADSPI_SUPPORT
```

### 34.4.4 TX FIFO Depth

Define `ATCSPI200_TXFIFO_DEPTH_nW` to identify the TX FIFO depth, where n could be 2, 4, 8, and, 16. The default depth is 2 words.

For example, define the TX FIFO depth to 4 words by:

```
`define ATCSPI200_TXFIFO_DEPTH_4W
```

### 34.4.5 RX FIFO Depth

Define `ATCSPI200_RXFIFO_DEPTH_nW` to identify the RX FIFO depth, where n could be 2, 4, 8, and, 16. The default depth is 2 words.

For example, define the RX FIFO depth to 4 words by:

```
`define ATCSPI200_RXFIFO_DEPTH_4W
```

### 34.4.6 Direct IO Control

Define `ATCSPI200_DIRECT_IO_SUPPORT` to enable Direct IO control.

```
`define ATCSPI200_DIRECT_IO_SUPPORT
```

### 34.4.7 Memory-Mapped Access Support

The ATCSPI200 provides a memory-mapped access interface. The interface can be either AHB bus or EILM bus.

Define `ATCSPI200_AHB_MEM_SUPPORT` to allow memory-mapped read accesses on the AHB bus.

```
`define ATCSPI200_AHB_MEM_SUPPORT
```

Define `ATCSPI200_EILM_MEM_SUPPORT` to allow memory-mapped read accesses on the EILM bus.

```
`define ATCSPI200_EILM_MEM_SUPPORT
```

### 34.4.8 Slave Mode

Define `ATCSPI200_SLAVE_SUPPORT` to support the SPI Slave mode.

```
`define ATCSPI200_SLAVE_SUPPORT
```

### 34.4.9 AHB Register Port

Define `ATCSPI200_REG_AHB` to change the register file programming port to AHB. The default programming port is APB.

```
`define ATCSPI200_REG_AHB
```

### 34.4.10 Memory-Mapped AHB/EILM Read

Define `ATCSPI200_MEM_RDCMD_DEFAULT` to specify the reset value of the `MemRdCmd` field in the SPI Memory Access Control Register (0x50). For example, define the reset value to 1 by:

```
`define ATCSPI200_MEM_RDCMD_DEFAULT 4'd1
```

### 34.4.11 SPI Interface Timing Parameters

Define following macros to specify the reset values of the `CS2SCLK`, `CSHT`, and `SCLK_DIV` fields in the SPI Interface Timing Register (0x40).

For example:

```
`define ATCSPI200_CS2CLK_DEFAULT 3'h0
```

```
`define ATCSPI200_CSHT_DEFAULT 3'h2
```

```
`define ATCSPI200_SCLKDIV_DEFAULT 8'h10
```

## 34.5 Programming Sequence

This chapter describes the programming sequence to initiate SPI transfers via the register programming. The register programming should not be performed while the memory-mapped reads on the AHB/EILM bus is active. Similarly, the memory-mapped read operation should not be performed when the register programming is in progress.

### 34.5.1 SPI Write with DMA

The following sample programming sequence sets up the controller for

- Transmitting two-byte address and 8-bit data width,
- Total transmission count of 16,
- Merging data from four bytes to one word,
- DMA data transfer with hardware handshaking,
- Triggering interrupts at the end of the SPI transfer,
- SPI SCLK frequency being half of the SPI clock source frequency,
- Issuing the ‘Page-Program’ command (0x02) to the ROM.

#### SPI transfer format setup

1. Read TX/RX FIFO depth in the Configuration Register (0x70).

2. Wait for the previous SPI transfer to finish by waiting for the SPIActive bit of the SPI Status Register (0x34) to become zero.
3. Set the SPI Transfer Format Register (0x10) as follows:
  - AddrLen** = 1 (address length – 1)
  - DataLen** = 7 (data length – 1)
  - DataMerge** = 1
  - Reset values for other fields
4. Set the SPI Transfer Control Register (0x20) as follows:
  - CmdEn** = 1
  - AddrEn** = 1
  - TransMode** = 1 (write only)
  - WrTranCnt** = 15 (total transmission count – 1)
  - Reset values for other fields
5. Set the SPI Control Register (0x30) to enable DMA, reset the TX FIFO, and specify the TX FIFO threshold according to the TX FIFO configuration, e.g., half of the TX FIFO depth.
6. Set the SPI Interrupt Enable Register (0x38) to enable the **EndIntEn** interrupt.
7. Set the SPI Interface Timing Register (0x40) to set **SCLK\_DIV** to 0.

#### SPI transfer execution

8. Set DMA controller to move data from memory to the SPI Data Register (0x2C).
9. Set the SPI Address Register (0x28).
10. Write the ‘Page-Program’ command (0x02) to the SPI Command Register (0x24) to trigger the SPI transfer. The encoding of the command may be different depending on SPI devices.
11. Wait the **EndInt** interrupt by checking the **EndInt** bit of the SPI Interrupt Status Register (0x3C).
12. Write one to clear the **EndInt** bit of the SPI Interrupt Status Register (0x3C).

### 34.5.2 SPI Read with DMA:

The following sample programming sequence sets up the controller for

- Receiving 16 bytes from a two-byte address,
- Merging data from four bytes to one word,
- DMA data transfer with hardware handshaking,
- Triggering interrupts at the end of SPI transfer,
- SPI **SCLK** frequency being half of the SPI clock source frequency,
- Issuing the ‘Read-Data’ command (0x03) to a ROM.

#### SPI transfer format setup

1. Check TX/RX FIFO depth in the Configuration Register (0x70).
2. Wait for the previous SPI transfer to finish by waiting for the **SPIActive** bit of the SPI Status Register (0x34) to become zero.

4. Set the SPI Transfer Format Register (0x10) as follows:  
**AddrLen** = 1 (address length – 1)  
**DataLen** = 7 (data length – 1)  
**DataMerge** = 1  
Reset values for other fields
  5. Set the SPI Transfer Control Register (0x20) as follows:  
**CmdEn** = 1  
**AddrEn** = 1  
**TransMode** = 2 (read only)  
**RdTranCnt** = 15 (total transmission count – 1)  
Reset values for other fields
  6. Set the SPI Control Register (0x30) to enable DMA and specify the RX FIFO threshold.
  7. Set the SPI Interrupt Enable Register (0x38) to enable the **EndIntEn** interrupt.
  8. Set the SPI Interface Timing Register (0x40) to set **SCLK\_DIV** to 0.
- SPI transfer execution**
1. Set DMA controller to move data from the SPI Data Register (0x2C) to memory.
  2. Set the SPI Address Register (0x28).
  3. Write the ‘Read-Data’ command (0x03) to the SPI Command Register (0x24) to trigger the SPI transfer. The encoding of this command may be different depending on SPI devices.
  4. Wait for the **EndInt** interrupt by checking the **EndInt** bit of the SPI Interrupt Status Register (0x3C).
  5. Write one to clear the **EndInt** bit of the SPI Interrupt Status Register (0x3C).

### 34.5.3 Stopping SPI Activities Initiated by the Memory-Mapped

#### Interface

The memory-mapped interface (EILM/AHB) translates bus reads to SPI accesses on the SPI interface. The interface is optimized to speed up sequential accesses. The ATCSPI200 controller always prefetches sequential data words from SPI devices until RX FIFO is full, where it stops the activity by pausing SPI **SCLK** while keeping SPI **CS** still asserted. The data transfer would be resumed without restarting a new SPI request with the command and address phases, if subsequent accesses on the memory interfaces are sequential and the RX FIFO full condition is cleared. Otherwise, the controller will end the current transfer to start a new transfer with the new non-sequential address. The controller also ends the current transfer if there is a new request made through the register programming interface.

To keep SPI **CS** from being asserted for too long without activity, the

following actions can be explicitly performed to deassert SPI **CS** and make the controller leave the active memory-mapped access state when no more memory-mapped accesses will be performed soon. Please note that once the memory-mapped interface is active, the controller protects the FIFOs from being interfered by register programming, so a three-step procedure is required:

1. Read the current value of SPI Memory Access Control Register (0x50).
2. Write back the value to the SPI Memory Access Control Register (0x50).
3. Wait until **MemCtrlChg** becomes 0.

For product ID 0x02002044 or above, the SPI controller will automatically deassert SPI **CS**, clear RX FIFO and return to the idle state if the memory-mapped interface has been quiet for some time. The exact condition is when RX FIFO and the internal serial-to-parallel shift registers are both full and there are no more incoming memory-mapped reads.

After ATCSPI200 is brought back to the idle state either automatically or by the three-step procedure, any normal operation can be performed later. Just follow the recommended flow described herein respectively.

#### 34.5.4 Receiving Data from SPI Masters

Assuming that the SPI transfer format is:

- 8-bit data width,
- quad write command (0x54),
- 20 bytes are transferred.

Since the data merging is enabled by default, this will correspond to 5 data accesses to the Data Register.

1. Reset the RX FIFO by writing one to the **RXFIFORST** bit and wait the **RXFIFORST** bit to be cleared to 0.
2. Set the RX FIFO threshold (**RXTHRES**) in the SPI Control Register (0x30) according to the RX FIFO configuration, e.g., half of the RX FIFO depth.
3. Set the SPI Interrupt Enable Register (0x38) to enable the slave command interrupt (**SlvCmdEn**), receive FIFO threshold interrupt (**RXFIFOIntEn**), and transfer end interrupt (**EndIntEn**).
4. In the interrupt service routine:
  - a) Wait for the Slave Command interrupt by checking the **SlvCmdInt** bit of the SPI Interrupt Status Register (0x3C).
    - i. Prepare to handle the received SPI request as recorded in the SPI Command Register (0x24).
    - ii. Write one to clear the **SlvCmdInt** bit of the SPI Interrupt Status Register (0x3C).
  - b) Wait for the RX FIFO interrupt by checking the **RXFIFOInt** bit of the SPI Interrupt Status Register (0x3C).
    - i. Pop words from the SPI Data Register (0x2C) according to

- the RX FIFO threshold (**RXTHRES**) setup.
- ii. Write one to clear the **RXFIFOInt** bit of the SPI Interrupt Status Register (0x3C).
- c) Wait for transfer end interrupt by checking the **EndInt** bit of the SPI Interrupt Status Register (0x3C).
  - i. Check the RX FIFO entries (**RXNUM**) of the SPI Status Register (0x34).
  - ii. Pop all words from the SPI Data Register (0x2C).
  - iii. Write one to clear the **EndInt** bit of the SPI Interrupt Status Register (0x3C).

### 34.5.5 Transmitting Data to SPI Masters

The SPI master should arrange the slave to make data ready for transmission before submitting read commands. Assuming this is done through a user-defined command to indicate the address offset and data count of the next read transfer.

The user-defined command is followed by the read status command (0x05) to check for the progress of the slave in the processing of the user-defined commands (whether or not the data that the user-defined command asks for is ready).

Finally, the SPI master issues a data read command to initiate the data transfer. Assuming the data transmission format is:

- 8-bit data width,
- quad read command (0x0E),
- the user-defined command ask for 32 bytes of data to be transferred.

Since the data merging is enabled by default, this will correspond to 8 data accesses to the Data Register.

1. When receiving the user-defined command which asks for 32-bytes of data,

Reset the TX FIFO by writing one to the **TXFIFORST** bit and wait the **TXFIFORST** cleared to 0.

Set the TX FIFO threshold (**TXTHRES**) in the SPI Control Register (0x30) according to the TX FIFO configuration, e.g., half of the TX FIFO depth.

Prepare the requested data (8 words = 32 bytes) and fill a number of words larger than the TXTHRES setup into the SPI Data Register (0x2C).

Set the SPI Interrupt Enable Register (0x38) to enable the slave command interrupt (**SlvCmdEn**), transmit FIFO threshold interrupt (**TXFIFOIntEn**), transfer end interrupt (**EndIntEn**).

Set the Ready bit in the SPI Slave Status Register (0x60).

2. In the interrupt service routine:

Wait for the Slave Command interrupt by checking the **SlvCmdInt** bit of the SPI interrupt Status Register (0x3C).

- i. Verify that the received command is a read command by checking the SPI Command Register (0x24).
- ii. Write one to clear the **SlvCmdInt** bit of the SPI Interrupt Status Register 0x3C).

Wait for the TX FIFO interrupt by checking the **TXFIFOInt** bit of the SPI Interrupt Status Register (0x3C).

- i. Fill a number of words larger than the TXTHRES setup into the SPI Data Register (0x2C).
- ii. If the data count of the read transfer has been completely filled into the Data Register, clear the transmit FIFO threshold interrupt (**TXFIFOIntEn**) in the SPI Interrupt Enable Register (0x38) to avoid a redundant interrupt.
- iii. Write one to clear the **TXFIFOInt** bit of the SPI Interrupt Status Register (0x3C).

Wait for transfer end interrupt by checking the **EndInt** bit of the SPI Interrupt Status Register (0x3C).

- i. Write one to clear the **EndInt** bit of the SPI Interrupt Status Register (0x3C).

## 34.6 Integration Guideline

This chapter describes the integration guideline for the ATCSPI200 controller. General integration guidelines are listed in the bullets below and special requirements for the slave mode, clock enable signals, clock gating cell, and DFT considerations are described in the subsections.

General integration guidelines for the ATCSPI200 controller are:

- **eilm\_clk**, **hclk**, and **pclk** must be synchronous;
- **eilm\_clk** frequency  $\geq$  **hclk** frequency  $\geq$  **pclk** frequency;
- In the chip-level environment, **spi\_clk\_in**, **spi\_clk\_out** and **spi\_clk\_oe** must be connected to the I/O pad of **SCLK** as shown in Figure 34-10 SCLK I/O Pad;
- In master mode, the slave device samples/returns data based on the observed clock **SCLK** in the chip-level environment (or **spi\_clk\_out** in the block-level environment). As a result, a generated clock derived from **spi\_clock** is created on **SCLK** (or **spi\_clk\_out**) with PAD delay as the reference clock of **set\_input\_delay/set\_output\_delay** commands. (The **set\_input\_delay/set\_output\_delay** commands of Synopsys DesignCompiler, have the **-reference\_pin** option for this kind of source synchronization design. However, to support Cadence RTL Compiler as well, the traditional generated clock approach is used here.)
- Like the previous step, another generated clock derived from the divided **spi\_clock** is also created to analyze the SCLK DIVIDER path;
- Since **spi\_clk\_in** is looped back from **SCLK** (or **spi\_clk\_out**), **spi\_clk\_in** should be created as a generated clock derived from **SCLK** (or **spi\_clk\_out**) with PAD delay;

- In Figure 34-11 Relation Between SCLK Domain and spi\_clock Domain, the path between `spi_in_r` and the shift register is only valid when SCLK DIVIDER is used. In this case, one `SCLK` period corresponds to  $((SCLK\_DIV+1)*2)$  periods of `spi_clock`. The shift register will only flop data at the correct `spi_clock` edge corresponding to the SCLK cycle. As a result, this path should be set as a  $((SCLK\_DIV\_MIN+1)*2)$  multicycle path where `SCLK_DIV_MIN` represents the smallest possible `SCLK_DIV` value in the system;
- In Figure 34-11 Relation Between SCLK Domain and spi\_clock Domain, `d1_r` is only used when `SCLK_DIV` = 0xff. As a result, the paths from the divided `spi_clock` domain to `d1_r` can be set false paths.
- $(\text{DataLen} + 1)/(\text{SPI IO width})$  must be greater than 1, where the SPI IO width is 2 for the dual mode and 4 for the quad mode;
- The controller cannot be accessed concurrently by register programming and memory-mapped accesses.

Figure 34-10 SCLK I/O Pad



Figure 34-11 Relation Between SCLK Domain and spi\_clock Domain



### 34.6.1 SCLK Frequency

Based on the current design, the frequency of SPI **SCLK** should be smaller than or equal to 1/4 of the **spi\_clock** frequency. As a result, the remote SPI master should drive **SCLK** no faster than 1/4 of the **spi\_clock** frequency:

$$\text{SCLK frequency} \leq \frac{1}{4}(\text{Slave spi_clock frequency})$$

### 34.6.2 Time between the Edges of SPI CS to the First Edge of SCLK

The minimum time between the edges of SPI **CS** and the first edge of **SCLK** should be larger than 2 \* period of **spi\_clock**.

### 34.6.3 Clock Enable Signal

The ATCSPI200 design has several clock enable input signals. A Foo to Bar clock enable signal indicates valid Bar-domain clock cycles to sample and update the Foo clock domain signals when the Bar clock

frequency is a multiple of the Foo clock frequency. The clock enable signal must assert for one Bar clock cycle for each Foo clock cycle. An example is illustrated in Figure 34-12 ATCSPI200 Clock Enable Signal for 4:1 AHB-to-APB Clock Ratio for the case that the AHB frequency is 4 times of the APB frequency. For the special case that AHB clock and APB clock are identical, the clock enable signal must be a constant HIGH.

Figure 34-12 ATCSPI200 Clock Enable Signal for 4:1 AHB-to-APB Clock Ratio



#### 34.6.4 Clock Gating Cell

There is one clock gating cell model in the ATCSPI200 design. The model is located at [\\$NDS\\_HOME/andes\\_ip/macro/hdl/gck.v](#). It is a latch based clock gating cell. The RTL modeling of [gck.v](#) is synthesizable. However, integrated clock gating cells from the standard library is preferred to better control clock skews.

The synthesis script automatically scans the standard cell library for an integrated clock gating cell that matches [gck.v](#)'s behavior. A [gck\\_autogen.v](#) file will be created under the script directory if such a cell is found in the standard library. Please double check the correctness of the cell.

If the heuristic fails, it will fall back to let the synthesizer synthesize the [gck.v](#). One could still modify [gck.v](#) to instantiate a proper integrated clock gating cell if the cell in question cannot be found by the synthesis script.

The synthesis script selects clock gating cells according to the following rule: it scans the library

to find all cells that have attribute [clock\\_gating\\_integrated\\_cell](#) and the value of the attribute is [latch\\_posedge\\_precontrol](#). For example,

```
# .lib file
cell (GCK_VENDOR_CELL) {
...
clock_gating_integrated_cell : "latch_posedge_precontrol";
...
}
```

```
}
```

When there are multiple cells found in the library, the one with the smallest leakage power is selected. The script then connects the pins through these attributes in the library:

`clock_gate_clock_pin`, `clock_gate_enable_pin`, `clock_gate_test_pin` and

`clock_gate_out_pin`.

Figure 34-13 Clock Gating Logic for Simulation and Synthesis shows how the gck module should look like in case the synthesis script fails or you want to generate `gck.v` manually.

Figure 34-13 Clock Gating Logic for Simulation and Synthesis

```
module gck (clk_out, clk_en, clk_in, test_en);
input clk_in;           // clock input
input clk_en;          // gated clock signal
input test_en;         // enable shifting scan data
output clk_out;        // clock output

`ifdef SYNTHESIS
    GCK_VENDOR_CELL gck(
        .Q(clk_out),
        .E(clk_en),
        .TE(test_en),
        .CK(clk_in)
    );
`else
    // gated clock behavior code:
    // FPGA note: this code is synthesizable under
    // FPGA with FixGatedClock support.

    reg latch_out;

    always @(clk_in or clk_en or test_en)
        if (~clk_in)
            latch_out <= clk_en | test_en;

    // clock gating occurs at the negedge of clk_in.
    assign clk_out = clk_in & latch_out;
`endif //SYNTHESIS
endmodule
```

Figure 34-14 Clock Gating Cell Diagram with Waveform further depicts the requirement for the clock gating cell. The internal latch of the clock gating cell should be in the transparent mode when clock is low and in the latch mode when clock is high.

Figure 34-14 Clock Gating Cell Diagram with Waveform



It is recommended that after the manual instantiation of the gck cell, a formal equivalence checking is performed to make sure that the selected cell matches the behavior code. However, unless gck cells with `latch_posedge_precontrol` is used, the equivalence checking will most likely not match.

### 34.6.5 DFT Considerations

The ATCSPI200 design provides `scan_test` and `scan_enable` input pins to control its behavior under ATPG test.

The `scan_test` pin should be asserted (Active-High) during the entire session of the ATPG test mode. There is a loop-back clock path in the ATCSPI200 design as shown in Figure 34-15 ATCSPI200 Design for ATPG Test. The loop-back clock should be controllable under the ATPG test mode to enhance the ATPG coverage. With the `scan_test` pin being HIGH for the entire duration of the ATPG test mode, the flops in the loop-back clock domain will be clocked by `spi_clock` and be immune to the changes of `spi_clk_oe` and `spi_clk_out` pins.

The `scan_enable` pin should only be active high during the ATPG scan/shift phase, such that all clocks are turned on and ATPG test patterns and results can be shifted through the scan chains. The clock gating logic is disabled (clock running freely) when `scan_enable` is active. The `scan_enable` pin is off during ATPG capture phase to allow observabilities for clock gating enable pins.

The DFT tools need to be informed about the usage of these two

signals using the sample commands listed below.

```
set_dft_signal -view existing_dft -port scan_enable -type ScanEnable  
set_dft_signal -view existing_dft -port scan_test -type TestMode
```

Figure 34-15 ATCSPI200 Design for ATPG Test



# 35 ATCUART100

## 35.1 Introduction

AndeShape™ ATCUART100 is a Universal Asynchronous Receiver/Transmitter (UART) controller.

### 35.1.1 Features

- AMBA 2.0 APB interface for registers access
- Hardware configurable 16, 32, 64 and 128 bytes transmit/receive FIFOs
- Over-sampling frequency is programmable (even multiples ranging from 8x to 32x)
- Programming sequence compatible with the 16C550D UART
  - Supports 5 to 8 bits per character
  - Supports 1, 1.5 and 2 STOP bits
  - Supports even, odd and stick parity bits
  - Supports DMA function
  - Supports programmable baud rate
  - Supports modem control interface
  - Supports complete status reporting capabilities
  - Supports line breaks, parity errors, framing errors and data overrun detection

### 35.1.2 Block Diagram

Figure 35-1 ATCUART100 Block Diagram shows the block diagram of ATCUART100:

**Figure 35-1 ATCUART100 Block Diagram**



The ATCUART100 controller is a serial communication controller which provides asynchronous serial interface for a peripheral device or a modem. The controller comprises a transmitter, a receiver, a Baud Rate Generator, a Modem Controller, a Register File and an APB interface, as shown in Figure 34-1.

### 35.1.3 Transmitter

The transmitter comprises a Transmitter FIFO (TX FIFO), a Transmitter Shift Register (TSR), and a Transmitter Controller (TX controller). The TX FIFO holds data to be transferred through the serial interface. The TX FIFO can store up to 128 characters depending on hardware configurations and programming settings. The TSR functions as a parallel-to-serial data converter, converting the outgoing character to serial bit streams. For each character transmission, the TX Controller generates a START bit, an optional parity bit, and some number of STOP bits. The generation of parity bit and STOP bit can be programmed by the Line Control Register. The TX FIFO is by default a one entry buffer called Transmitter Holding Register (THR). It needs to be enabled to work in multi-entry FIFO mode (FIFOE in the FIFO Control Register).

### 35.1.4 Receiver

The receiver comprises a Receiver FIFO (RX FIFO), Receiver Shift Register (RSR), and a Receiver Controller (RX Controller). The RX Controller uses the oversampling clock generated by Baud Rate Generator to perform sampling at the center of each bit transmission. The received bits are shifted into the RSR for serial-to-parallel data conversion and the

received character is stored into the RX FIFO. The RX FIFO is by default a one entry buffer called the Receiver Buffer Register (RBR). It needs to be enabled to work in multi-entry FIFO mode (FIFOE in the FIFO Control Register) with up to 128 characters depending on hardware configurations. The RX controller also detects some error conditions for each data transmission including parity error, framing error, data overrun, or line break.

### 35.1.5 Baud Rate Generator

The Baud Rate Generator takes the UART clock (uclk) as the source clock and divides it by a divisor. The divisor value is 16-bit in size and stored in two separate programming registers, each holding an 8-bit value. The most significant byte (MSB) is held in the Divisor Latch MSB (DLM) register and the least significant byte (LSB) is held in the Divisor Latch LSB (DLL) register.

The ratio of the sampling clock frequency to the baud rate is the oversampling ratio, which is stored in the Over Sample Control Register (OSCR). The default value for OSCR is 16. This is typically good enough and do not need further adjustment.

The formula for the divisor value is as follows:

The divisor value = the frequency of uclk / (desired baud rate × OSCR)

The oversampling clock is used by the RX controller to detect the leading edge of the START bit and to sample the data at the center of each bit transfer. Assume that the oversampling ratio is 16. The RX controller uses the oversampling clock to operate a counter, which starts counting from 1 to 16 after a falling edge of SIN (beginning of a START bit) is detected. The RX controller samples the value of SIN as a data bit when the counter value is 8. The counter will be reset to 1 after its value reaches 16 for sampling the next bit. The process repeats until the STOP bit is received. The oversampling clock is also used by the TX controller to generate its output data stream.

The oversampling technique provides better tolerance of clock variation. Suppose that:

- T is the period of one bit transmission as perceived by the ATCUART100 Rx Controller.
- $T_{\text{transmitter}}$  is the period of one bit transmission of the transmitter.
- N is the bit number for one frame of data – the START bit, data bits, parity bit (if any), and the STOP bit(s).

Then, the clock period tolerance for  $T_{\text{transmitter}}$  is as follows:

$$\frac{(0.5 - \frac{1}{OSCR})}{N} \times T \leqslant T_{\text{transmitter}} \leqslant (NN - 0.5)/(N - 1) \times T$$

Since T is the inverse of the baud rate, the actual baud rate generated by this controller in relation to the actual baud rate of the transmitter (the tolerance factor) can be within the range below:

$$\frac{(0.5 - \frac{1}{OSCR})}{N} \leq \frac{\text{Actual Baud Rate}}{\text{Actual Transmitter Baud Rate}} \leq (N - 0.5)/(N - 1)$$

If the character has one START bit, 8 data bits, one parity bit and one STOP bit, then N is 11 ( $1 + 8 + 1 + 1$ ). The tolerance factor is from 0.9602 to 1.05. The table below shows clock tolerance factors as percentage of the actual Transmitter Baud Rates for typical values of N and OSCR.

**Table 35-1 Clock Variation Tolerance Factor**

| OSCR | N=9              | N=10             | N=11             | N=12             |
|------|------------------|------------------|------------------|------------------|
| 8    | 95.83% - 106.25% | 96.25% - 105.56% | 96.59% - 105.00% | 96.88% - 104.55% |
| 16   | 95.14% - 106.25% | 95.63% - 105.56% | 96.02% - 105.00% | 96.35% - 104.55% |
| 32   | 94.79% - 106.25% | 95.31% - 105.56% | 95.74% - 105.00% | 96.09% - 104.55% |

### 35.1.6 Modem Controller

The Modem Controller provides the modem control function. Furthermore, an auto flow control function is provided to reduce the software management effort.

The flow control of UART can be achieved by the RTS/CTS handshaking. Without the flow control, overrun errors may occur when the data transmission rate exceeds the data consumption rate. The flow control guarantees that the data transmission will not proceed unless the receiver has enough space to accept the data.

The auto flow control function of ATCUART100 comprises auto-RTS and auto-CTS. The former is for the incoming data while the latter is for the outgoing data.

With auto-RTS, the RTS output of the controller should be connected to the CTS input of the other end of the UART connection.

- When the receiver FIFO  $\geq n - 1$ , the RTS is de-asserted.
- When the receiver FIFO  $< n - 1$ , the RTS is automatically asserted to request the other end of the UART connection to send more data.
- n is the depth of the FIFO.

With auto-CTS, the CTS input of the controller is connected to the RTS output of the other end of the UART connection. The UART controller waits for the assertion of CTS before sending the next character. To stop the controller from transmitting the next character, CTS must be de-asserted before the STOP bit of the current character.

### 35.1.7 Loopback Mode

The ATCUART100 provides a loopback mode for diagnostic testing without connecting an external device. When the loopback mode is enabled, the behavior of the controller is as follows:

- The output signals (`uart_sout`, `modem_rtsn`, `modem_dtrn`, `uart_out1n`, `uart_out2n`) are disconnected from the TX Controller and driven HIGH

to avoid confusing the other end of the serial connection in case the connection exists.

- The input signals (`uart_sin`, `modem_ctsn`, `modem_dsrn`, `modem_rin`, `modem_dcsn`) are disconnected from the RX Controller and ignored.
- The TX Controller output values originally intended for the `uart_sout` output signals is routed internally to replace the input signal of `uart_sin` for the RX Controller, so every bit sent by the TX Controller is looped back and received by the RX controller.
- The Modem Controller output values which are intended for the (`modem_rtsn`, `modem_dtrn`, `uart_out1n`, and `uart_out2n`) signals are routed internally to replace the input signals of (`modem_ctsn`, `modem_dsrn`, `modem_rin`, and `modem_dcsn`) for the Modem Controller.

The value written to the Transmitter Holding Register will be internally received by the Receiver Buffer Register and the value written to the Modem Control Register (bit3~bit0) will be routed to the Modem Status Register (bit7~bit4). The entire bit transmission path is exercised in the loopback mode, only the input/output port is isolated from the diagnostic activity. The relationship between the bit fields in the Modem Control Register and those in the Modem Status Register are illustrated in Figure 35-2 Relationship between MCR and MSR in the Loopback Mode.

Figure 35-2 Relationship between MCR and MSR in the Loopback Mode



### 35.1.8 DMA Operation

The ATCUART100 controller provides two pairs of hardware handshake signals to work with a DMA controller (e.g. AndeShape™ ATCDMAC100) for data transfer. One pair is for data reception; the other pair is for data transmission.

When the RX FIFO reaches the threshold set by the Receiver FIFO Trigger Level (RFIFOT) field of the FIFO Control Register, the UART controller will assert `dma_rx_req` to request a data transfer. The DMA controller should then transfer a character1 from the RX FIFO followed by asserting `dma_rx_ack`. Next, the UART controller de-asserts `dma_rx_req` and the DMA controller de-asserts `dma_rx_ack`. The UART controller will assert `dma_rx_req` again unless the RX FIFO is empty.

When the TX FIFO reaches the threshold set by the Transmitter FIFO

Trigger Level (TFIFOT) field of the FIFO Control Register, the UART controller will assert `dma_tx_req` to request a data transfer. The DMA controller should then transfer a character2 to the TX FIFO followed by asserting `dma_tx_ack`. Next, the UART controller de-asserts `dma_tx_req` and the DMA controller de-asserts `dma_tx_ack`. The UART controller will assert `dma_tx_req` again unless the TX FIFO is full.

**Note!**

- For each `dma_rx_req`, the DMA controller should read exactly one character to avoid RX FIFO underflow, i.e., the DMA burst size should be 1.
- For each `dma_tx_req`, the DMA controller should write exactly one character to avoid TX FIFO overflow, i.e., the DMA burst size should be 1.

## 35.2 Signal Description

Table 35-2 Signal Description of ATCUART100 describes the input/output (I/O) signals of ATCUART100.

Table 35-2 Signal Description of ATCUART100

| Name                     | I/O Type | Description                                                                                     |
|--------------------------|----------|-------------------------------------------------------------------------------------------------|
| <b>APB Bus Interface</b> |          |                                                                                                 |
| pclk                     | I        | AMBA APB clock                                                                                  |
| presetn                  | I        | AMBA APB reset signal; active low                                                               |
| psel                     | I        | AMBA APB slave select signal from the APB decoder                                               |
| penable                  | I        | AMBA APB enable signal                                                                          |
|                          |          | AMBA APB transfer direction signal                                                              |
| pwrite                   | I        | This signal indicates a write access when driven HIGH and a read access when driven LOW.        |
| paddr[4:2]               | I        | AMBA APB address bus                                                                            |
| pwdata[31:0]             | I        | AMBA APB write data bus                                                                         |
| prdata[31:0]             | O        | AMBA APB read data bus                                                                          |
| <b>UART Signals</b>      |          |                                                                                                 |
| uclk <sup>3</sup>        | I        | UART clock source                                                                               |
| urstn                    | I        | UART system reset; active low                                                                   |
| uart_sin                 | I        | UART serial input data<br>When there is no communication, the <code>uart_sin</code> stays at 1. |

3 uclk and urstn only exist when ATCUART100\_UCLK\_PCLK\_SAME is not defined. See Dual I/O Mode

| Name       | I/O Type | Description                                                                          |
|------------|----------|--------------------------------------------------------------------------------------|
| uart_sout  | O        | UART serial output data<br>When there is no communication, the uart_sout stays at 1. |
| uart_out1n | O        | UART user-defined output 1; active low                                               |
| uart_out2n | O        | UART user-defined output 2; active low                                               |
| uart_intr  | O        | UART interrupt signal                                                                |

**Modem Signals**

|            |   |                                         |
|------------|---|-----------------------------------------|
| modem_rin  | I | Modem ring indicator; active low        |
| modem_dcdn | I | Modem data carrier detect; active low   |
| modem_dsrn | I | Modem data set ready; active low        |
| modem_ctsn | I | Modem clear to send (CTS); active low   |
| modem_dtrn | O | Modem data terminal ready; active low   |
| modem_rtsn | O | Modem request to send (RTS); active low |

**DMA Signals**

|            |   |                        |
|------------|---|------------------------|
| dma_tx_req | O | DMA TX request         |
| dma_rx_req | O | DMA RX request         |
| dma_tx_ack | I | DMA TX acknowledgement |
| dma_rx_ack | I | DMA RX acknowledgement |

## 35.3 Programming Model

### 35.3.1 Summary of Registers

Table 35-3 Summary of Registers

| Offset      | Name  | Description                                   |
|-------------|-------|-----------------------------------------------|
| +0x00       | IdRev | ID and Revision Register                      |
| +0x04~ 0x0C | -     | Reserved                                      |
| +0x10       | Cfg   | Hardware Configure Register                   |
| +0x14       | OSCR  | Over Sample Control Register                  |
| +0x18~0x1C  | -     | Reserved                                      |
| +0x20       |       | DLAB = 0                                      |
|             | RBR   | Receiver Buffer Register (Read only)          |
|             | THR   | Transmitter Holding Register (Write only)     |
|             |       | DLAB = 1                                      |
|             | DLL   | Divisor Latch LSB                             |
| +0x24       |       | DLAB = 0                                      |
|             | IER   | Interrupt Enable Register                     |
|             |       | DLAB = 1                                      |
|             | DLM   | Divisor Latch MSB                             |
| +0x28       | IIR   | Interrupt Identification Register (Read only) |
|             | FCR   | FIFO Control Register (Write only)            |
| +0x2C       | LCR   | Line Control Register                         |
| +0x30       | MCR   | Modem Control Register                        |
| +0x34       | LSR   | Line Status Register                          |
| +0x38       | MSR   | Modem Status Register                         |
| +0x3C       | SCR   | Scratch Register                              |

The following sections describe ATCUART100 registers in detail. The abbreviations for the Type column are summarized below:

RO: read only

WO: write only

R/W: readable and writable

W1C: write 1 to clear

RC: read clear

### 35.3.2 ID and Revision Register (0x00)

This register holds the ID number and the revision number. The reset values of the two revision fields are revision dependent. This register holds

the ID number and the revision

Table 35-4 ID and Revision Register

| Name  | Bit   | Type | Description              | Reset              |
|-------|-------|------|--------------------------|--------------------|
| ID    | 31:16 | RO   | ID number for ATCUART100 | 0x0201             |
| Major | 15:4  | RO   | Major revision number    | Revision dependent |
| Minor | 3:0   | RO   | Minor revision number    | Revision dependent |

### 35.3.3 Hardware Configure Register (0x10)

Table 35-5 Hardware Configure Register

| Name       | Bit  | Type | Description                                                                                                 | Reset                   |
|------------|------|------|-------------------------------------------------------------------------------------------------------------|-------------------------|
| -          | 31:2 | -    | Reserved                                                                                                    | 0x0                     |
| FIFO_DEPTH | 1:0  | RO   | The depth of RXFIFO and TXFIFO<br>0: 16-byte FIFO<br>1: 32-byte FIFO<br>2: 64-byte FIFO<br>3: 128-byte FIFO | Configuration dependent |

### 35.3.4 Over Sample Control Register (0x14)

The Over Sample Control Register defines the clock ratio between the sampling clock and the baud rate. Please see Transmitter for details.

Table 35-6 Over Sample Control Register

| Name | Bit  | Type | Description                                                                                                                                                                                                                                                                             | Reset |
|------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| -    | 31:5 | -    | Reserved                                                                                                                                                                                                                                                                                | 0x0   |
| OSC  | 4:0  | R/W  | Over-sample control<br>The value must be an even number; any odd value writes to this field will be converted to an even value.<br><b>OSC = 0:</b> The over-sample ratio is 32<br><b>OSC ≤ 8:</b> The over-sample ratio is 8<br><b>8 &lt; OSC &lt; 32:</b> The over sample ratio is OSC | 0x10  |

### 35.3.5 Receiver Buffer Register (when DLAB = 0) (0x20)

The RBR has two modes, the FIFO mode and the BUFFER mode. Bit0 of the FIFO Control Register (FIFOE) controls the selection between these two modes. When FIFOE is 1 (FIFO mode), the RBR is a RXFIFO. The depth of RXFIFO is configurable by the macro ATCUART100\_FIFO\_DEPTH, see The Depth of FIFO for details. When FIFOE is 0 (BUFFER mode), the RBR is just a byte buffer.

**Table 35-7 Receiver Buffer Register (when DLAB = 0)**

| Name | Bit  | Type | Description            | Reset |
|------|------|------|------------------------|-------|
| -    | 31:8 | -    | Reversed               | ox0   |
| RBR  | 7:0  | RO   | Receive data read port | ox0   |

### 35.3.6 Transmitter Holding Register (when DLAB = 0) (0x20)

The THR has two modes, the FIFO mode and the BUFFER mode. FCR bit0 (FIFOE) controls the selection between these two modes. When FIFOE is 1 (FIFO mode), the THR is a TXFIFO. The depth of TXFIFO is configurable by the macro ATCUART100\_FIFO\_DEPTH, see The Depth of FIFO for details. When FIFOE is 0 (BUFFER mode), the THR is a byte buffer.

**Table 35-8 Transmitter Holding Register (when DLAB = 0)**

| Name | Bit  | Type | Description              | Reset |
|------|------|------|--------------------------|-------|
| -    | 31:8 | -    | Reserved                 | ox0   |
| THR  | 7:0  | WO   | Transmit data write port | ox0   |

### 35.3.7 Interrupt Enable Register (when DLAB = 0) (0x24)

The following table describes each field of the Interrupt Enable Register.

**Table 35-9 Interrupt Enable Register (when DLAB = 0)**

| Name  | Bit  | Type | Description                                                                                                                                                                                                                                                                                                                                            | Reset |
|-------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| -     | 31:4 | -    | Reserved                                                                                                                                                                                                                                                                                                                                               | ox0   |
| EMSI  | 3    | R/W  | Enable modem status interrupt<br><br>The interrupt asserts when the status of one of the following occurs:<br><br>The status of modem_rin, modem_dcdn, modem_dsrn or modem_ctsn (If the auto-cts mode is disabled) has been changed.<br><br>If the auto-cts mode is enabled (MCR bit4 (AFE) = 1), modem_ctsn would be used to control the transmitter. | ox0   |
| ELSI  | 2    | R/W  | Enable receiver line status interrupt                                                                                                                                                                                                                                                                                                                  | ox0   |
| ETHEI | 1    | R/W  | Enable transmitter holding register interrupt                                                                                                                                                                                                                                                                                                          | ox0   |
| ERBI  | 0    | R/W  | Enable received data available interrupt and the character timeout interrupt<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                | ox0   |

### 35.3.8 Divisor Latch LSB (when DLAB = 1) (0x20)

The Divisor Latch holds the divisor value for generating the sampling clock from the UART clock source (uclk). The size of the Divisor Latch is 16 bits (two bytes) and this register holds the least significant byte of the Divisor Latch. Please see Baud Rate Generator for details. The valid value of the Divisor Latch should be between 1 and 65535 ( $2^{16}$ -1), inclusive.

Table 35-10 Divisor Latch LSB (when DLAB = 1)

| Name | Bit  | Type | Description                                 | Reset |
|------|------|------|---------------------------------------------|-------|
| -    | 31:8 | -    | Reserved                                    | 0x0   |
| DLL  | 7:0  | R/W  | Least significant byte of the Divisor Latch | 0x1   |

### 35.3.9 Divisor Latch MSB (when DLAB = 1) (0x24)

The Divisor Latch holds the divisor value for generating the sampling clock from the UART clock source (uclk). The size of the Divisor Latch is 16 bits (two bytes) and this register holds the most significant byte of the Divisor Latch. Please see Baud Rate Generator for details. The valid value of the Divisor Latch should be between 1 and 65535 ( $2^{16}$ -1), inclusive.

Table 35-11 Divisor Latch MSB (when DLAB = 1)

| Name | Bit  | Type | Description                                | Reset |
|------|------|------|--------------------------------------------|-------|
| -    | 31:8 | -    | Reserved                                   | 0x0   |
| DLM  | 7:0  | R/W  | Most significant byte of the Divisor Latch | 0x0   |

### 35.3.10 Interrupt Identification Register (0x28)

Table 35-12 Interrupt Identification Register

| Name   | Bit  | Type | Description                                                                                        | Reset |
|--------|------|------|----------------------------------------------------------------------------------------------------|-------|
| -      | 31:8 | -    | Reserved                                                                                           | 0x0   |
| FIFOED | 7:6  | RO   | FIFOs enabled<br>These two bits are 1 when bit 0 of the FIFO Control Register (FIFOE) is set to 1. | 0x0   |
| -      | 5:4  | -    | Reserved                                                                                           | 0x0   |
| INTRID | 3:0  | RO   | Interrupt ID<br>See Table 13 for encodings                                                         | 0x1   |

**Table 35-13 Interrupt Control Table**

| Interrupt Identification Register |      |      |      |                | Interrupt Type               | Interrupt Source Description                                                                                                                                                                                                                                                              | Interrupt Reset Method                                                                            |
|-----------------------------------|------|------|------|----------------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| Bit3                              | Bit2 | Bit1 | Bit0 | Priority Level |                              |                                                                                                                                                                                                                                                                                           |                                                                                                   |
| 0                                 | 0    | 0    | 1    | None           | None                         | None                                                                                                                                                                                                                                                                                      | None                                                                                              |
| 0                                 | 1    | 1    | 0    | 1              | Receiver line status         | Overrun errors, parity errors, framing errors, or line breaks                                                                                                                                                                                                                             | Read the Line Status Register (LSR)                                                               |
| 0                                 | 1    | 0    | 0    | 2              | Received data available      | If FIFOE is disabled, there is one received data available in the RBR. If FIFOE is enabled, the numbers of received data available reach the trigger level (RFIFOT).<br>The interrupt signal will stay active until the number of data available becoming smaller than the trigger level. | Read the Receiver Buffer Register (RBR)                                                           |
| 1                                 | 1    | 0    | 0    | 2              | Character timeout            | When FIFOE is enabled and no character have been removed from or input to receive FIFO and there is at least one character in receive FIFO during the last four character times.                                                                                                          | Read the Receiver Buffer Register (RBR)                                                           |
| 0                                 | 0    | 1    | 0    | 3              | Transmitter Holding Register | If FIFOE is disabled, the 1-byte THR is empty.<br>If FIFOE is enabled, the whole 16-byte transmit FIFO is empty.                                                                                                                                                                          | Write the Transmitter Holding Register (THR) or Read the Interrupt Identification Register (IIR). |
| 0                                 | 0    | 0    | 0    | 4              | Modem status                 | The Modem Status Register (MSR) bit[3:0] is not 0.<br>One of the following events occurred: Clear To Send (CTS), Data Set Ready (DSR), Ring Indicator (RI), or Data Carrier Detect (DCD)                                                                                                  | Read the Modem Status Register (MSR)                                                              |

**Note !**

When multiple events would trigger interrupts at the same time, the priority level determines the value for the INTRID field.

### 35.3.11 FIFO Control Register (0x28)

Table 35-14 FIFO Control Register

| Name     | Bit  | Type | Description                                                                                                                                                                          | Reset |
|----------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| -        | 31:8 |      | Reserved                                                                                                                                                                             | ox0   |
| RFIFOT   | 7:6  | WO   | Receiver FIFO trigger level<br>Please refer to Table 15                                                                                                                              | ox0   |
| TFIFOT   | 5:4  | WO   | Transmitter FIFO trigger level<br>Please refer to Table 16                                                                                                                           | ox0   |
| DMAE     | 3    | WO   | DMA enable<br>0: Disable<br>1: Enable                                                                                                                                                | ox0   |
| TFIFORST | 2    | WO   | Transmitter FIFO reset<br>Write 1 to clear all bytes in the TXFIFO and resets its counter. The Transmitter Shift Register is not cleared.<br>This bit will automatically be cleared. | ox0   |
| RFIFORST | 1    | WO   | Receiver FIFO reset<br>Write 1 to clear all bytes in the RXFIFO and resets its counter. The Receiver Shift Register is not cleared.<br>This bit will automatically be cleared.       | ox0   |
| FIFOE    | 0    | WO   | FIFO enable<br>Write 1 to enable both the transmitter and receiver FIFOs.<br>The FIFOs are reset when the value of this bit toggles.                                                 | ox0   |

Table 35-15 Receive FIFO Trigger Level

| RFIFOT | RXFIFO Trigger Level |                |                |                 |
|--------|----------------------|----------------|----------------|-----------------|
|        | 16-byte RXFIFO       | 32-byte RXFIFO | 64-byte RXFIFO | 128-byte RXFIFO |
| 0      | Not empty            | Not empty      | Not empty      | Not empty       |
| 1      | More than 3          | More than 7    | More than 15   | More than 31    |
| 2      | More than 7          | More than 15   | More than 31   | More than 63    |
| 3      | More than 13         | More than 27   | More than 55   | More than 111   |

**Table 35-16 Transmit FIFO Trigger Level**

| TFIFOT | TXFIFO Trigger Level |                |                |                 |
|--------|----------------------|----------------|----------------|-----------------|
|        | 16-byte TXFIFO       | 32-byte TXFIFO | 64-byte TXFIFO | 128-byte TXFIFO |
| Value  |                      |                |                |                 |
| 0      | Not full             | Not full       | Not full       | Not full        |
| 1      | Less than 12         | Less than 24   | Less than 48   | Less than 96    |
| 2      | Less than 8          | Less than 16   | Less than 32   | Less than 64    |
| 3      | Less than 4          | Less than 8    | Less than 16   | Less than 32    |

### 35.3.12 Line Control Register (0x2C)

Table 35-17 Line Control Register

| Name | Bit  | Type | Description                                                                                                                                                                                                    | Reset |
|------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| -    | 31:8 | -    | Reserved                                                                                                                                                                                                       | oxo   |
| DLAB | 7    | R/W  | Divisor latch access bit                                                                                                                                                                                       | oxo   |
| BC   | 6    | R/W  | Break control                                                                                                                                                                                                  | oxo   |
| SPS  | 5    | R/W  | Stick parity<br><br>1: parity bit is constant 0 or 1, depending on bit4 (EPS).<br>0: disable the sticky bit parity.<br><br>Please refer to Table 18.                                                           | oxo   |
| EPS  | 4    | R/W  | Even parity select<br><br>1: even parity (an even number of logic-1 is in the data and parity bits)<br>0: odd parity.<br><br>Please refer to Table 18.                                                         | oxo   |
| PEN  | 3    | R/W  | Parity enable<br><br>When this bit is set, a parity bit is generated in transmitted data before the first STOP bit and the parity bit would be checked for the received data.<br><br>Please refer to Table 18. | oxo   |
| STB  | 2    | R/W  | Number of STOP bits<br><br>0: 1 bits<br>1: the number of STOP bit is based on the WLS setting<br>When WLS = 0, STOP bit is 1.5 bits<br>When WLS = 1, 2, 3, STOP bit is 2 bits                                  | oxo   |
| WLS  | 1:0  | R/W  | Word length setting<br><br>0: 5 bits<br>1: 6 bits<br>2: 7 bits<br>3: 8 bits                                                                                                                                    | oxo   |

Table 35-18 Parity Bit Selection

| PEN (bit3) | SPS (bit5) | EPS (bit4) | Parity Bit             |
|------------|------------|------------|------------------------|
| 0          | X          | X          | No parity bit          |
| 1          | 0          | 0          | Parity is odd          |
| 1          | 0          | 1          | Parity is even         |
| 1          | 1          | 0          | Parity bit is always 1 |
| 1          | 1          | 1          | Parity bit is always 0 |

### 35.3.13 Modem Control Register (0x30)

This register controls the output of the modem status signals as well as the loopback mode and auto flow control.

Table 35-19 Modem Control Register

| Name | Bit  | Type | Description                                                                                                                                                                           | Reset |
|------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| -    | 31:6 | -    | Reserved                                                                                                                                                                              | 0x0   |
| AFE  | 5    | R/W  | Auto flow control enable<br>0: Disable<br>1: the auto-CTS and auto-RTS setting is based on the RTS bit setting:<br>When RTS = 0, auto-CTS only<br>When RTS = 1, auto-CTS and auto-RTS | 0x0   |
| LOOP | 4    | R/W  | Enable loopback mode<br>0: Disable<br>1: Enable                                                                                                                                       | 0x0   |
| OUT2 | 3    | R/W  | User-defined output 2<br>This bit controls the uart_out2n output.<br>0: the uart_out2n output signal will be driven HIGH<br>1: the uart_out2n output signal will be driven LOW        | 0x0   |
| OUT1 | 2    | R/W  | User-defined output 1<br>This bit controls the uart_out1n output.<br>0: the uart_out1n output signal will be driven HIGH<br>1: the uart_out1n output signal will be driven LOW        | 0x0   |
| RTS  | 1    | R/W  | Request to send<br>This bit controls the modem_rtsn output.<br>0: the modem_rtsn output signal will be driven HIGH<br>1: the modem_rtsn output signal will be driven LOW              | 0x0   |
| DTR  | 0    | R/W  | Data terminal ready                                                                                                                                                                   | 0x0   |

| Name | Bit | Type | Description                                                                                                                                           | Reset |
|------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|      |     |      | This bit controls the modem_dtrn output.<br>0: the modem_dtrn output signal will be driven HIGH<br>1: the modem_dtrn output signal will be driven LOW |       |

### 35.3.14 Line Status Register (0x34)

This register reports the status of the transmitter and the receiver.

Table 35-20 Line Status Register

| Name | Bit  | Type | Description                                                                                                                                                                                                                                                                | Reset |
|------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| -    | 31:8 | -    | Reserved                                                                                                                                                                                                                                                                   | 0x0   |
| ERRF | 7    | RO   | Error in RXFIFO<br><br>In the FIFO mode, this bit is set when there is at least one parity error, framing error, or line break associated with data in the RXFIFO. It is cleared when this register is read and there is no more error for the rest of data in the RXFIFO. | 0x0   |
| TEMT | 6    | RO   | Transmitter empty<br><br>This bit is 1 when the THR (TXFIFO in the FIFO mode) and the Transmitter Shift Register (TSR) are both empty. Otherwise, it is zero.                                                                                                              | 0x1   |
| THRE | 5    | RO   | Transmitter Holding Register empty<br><br>This bit is 1 when the THR (TXFIFO in the FIFO mode) is empty. Otherwise, it is zero.<br><br>If the THRE interrupt is enabled, an interrupt is triggered when THRE becomes 1.                                                    | 0x1   |

| Name   | Bit | Type | Description                                                                                                                                                                                                                                                                                                                                                                              | Reset |
|--------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| LBreak | 4   | RO   | <p>Line break</p> <p>This bit is set when the uart_sin input signal was held LOW for longer than the time for a full-word transmission. A full-word transmission is the transmission of the START, data, parity, and STOP bits. It is cleared when this register is read.</p> <p>In the FIFO mode, this bit indicates the line break for the received data at the top of the RXFIFO.</p> | 0x0   |
| FE     | 3   | RO   | <p>Framing error</p> <p>This bit is set when the received STOP bit is not HIGH. It is cleared when this register is read.</p> <p>In the FIFO mode, this bit indicates the framing error for the received data at the top of the RXFIFO.</p>                                                                                                                                              | 0x0   |
| PE     | 2   | RO   | <p>Parity error</p> <p>This bit is set when the received parity does not match with the parity selected in the LCR[5:4]. It is cleared when this register is read.</p> <p>In the FIFO mode, this bit indicates the parity error for the received data at the top of the RXFIFO.</p>                                                                                                      | 0x0   |
| OE     | 1   | RO   | <p>Overrun error</p> <p>This bit indicates that data in the Receiver Buffer Register (RBR) is overrun.</p>                                                                                                                                                                                                                                                                               | 0x0   |
| DR     | 0   | RO   | <p>Data ready.</p> <p>This bit is set when there are incoming received data in the Receiver Buffer Register (RBR). It is cleared when all of the received data are read.</p>                                                                                                                                                                                                             | 0x0   |

### 35.3.15 Modem Status Register (0x38)

Table 35-21 Modem Status Register (0x38)

| Name | Bit  | Type | Description                                                                                                                                                                       | Reset |
|------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| -    | 31:8 |      | Reserved                                                                                                                                                                          | ox0   |
| DCD  | 7    | RO   | Data carrier detect<br><br>0: the modem_dedn input signal is HIGH.<br>1: the modem_dcdn input signal is LOW.                                                                      | ox0   |
| RI   | 6    | RO   | Ring indicator<br><br>0: The modem_rin input signal is HIGH.<br>1: the modem_rin input signal is LOW.                                                                             | ox0   |
| DSR  | 5    | RO   | Data set ready<br><br>0: The modem_dsrn input signal is HIGH.<br>1: The modem_dsrn input signal is LOW.                                                                           | ox0   |
| CTS  | 4    | RO   | Clear to send<br><br>0: The modem_ctsn input signal is HIGH.<br>1: The modem_ctsn input signal is LOW.                                                                            | ox0   |
| DDCD | 3    | RC   | Delta data carrier detect<br><br>This bit is set when the state of the modem_dedn input signal has been changed since the last time this register is read. Otherwise, it is zero. | ox0   |
| TERI | 2    | RC   | Trailing edge ring indicator<br><br>This bit is set when the state of the modem_rin input signal has been changed from LOW to HIGH since the last time this register is read.     | ox0   |
| DDSR | 1    | RC   | Delta data set ready<br><br>This bit is set when the state of the modem_dsrn input signal has been changed since the last time this register is read.                             | ox0   |
| DCTS | 0    | RC   | Delta clear to send<br><br>This bit is set when the state of the modem_ctsn input signal has been changed since the last time this register is read.                              | ox0   |

### 35.3.16 Scratch Register (0x3C)

Table 35-22 Scratch Register

| Name | Bit  | Type | Description                                                                                                   | Reset |
|------|------|------|---------------------------------------------------------------------------------------------------------------|-------|
| -    | 31:8 | -    | Reserved                                                                                                      | ox0   |
| SCR  | 7:0  | R/W  | An one-byte storage register with no UART related function; available to software with no usage restrictions. | ox0   |

## 35.4 Hardware Configuration Options

### 35.4.1 The Depth of FIFO

Define the depth of TXFIFO and RXFIFO. The depth could be 16, 32, 64 and 128. The following example defines the depth of FIFO to 16-byte.

```
`define ATCUART100_FIFO_DEPTH_16
```

### 35.4.2 The Same Clock Source

If the uclk and the pclk are identical clocks, define this macro to remove the synchronization logic and the extra latencies associated with it. In addition, the uclk input port is omitted such that only the pclk input port remains (since the two clocks are the same one).

```
`define ATCUART100_UCLK_PCLK_SAME
```

## 35.5 Programming Sequence

### 35.5.1 UART Setup

The following programming sequence sets up the UART for:

- Baud rate: 38400
  - Word length: 8-bit
  - Parity: none
  - Number of STOP bits: 1
  - Flow control: none
1. Set baud rate.  
Set the DLAB bit of the Line Control Register to 1.  
Set DLL and DLM registers to select the desired baud rate for the UART.
    - The divisor value = the frequency of uclk / (desired baud rate x OSCR)
    - The default value for OSCR is 16
  2. Set the DLAB bit of the Line Control Register back to 0.
  3. Set the Line Control Register.  
Disable the parity: Set PEN = 0;

Set STOP bits to 1: Set STB = 0;

Set word length to 8-bit: Set WLS = 3.

The following programming sequence transmits data through UART without/with DMA:

### 35.5.2 Data Transfer without DMA

1. Set FIFOE in the FIFO Control Register to enable the FIFO.
2. Wait for FIFO empty by looping until the THRE bit in the Line Status Register becomes 1.
3. Write at most FIFO\_DEPTH bytes of data to THR.
4. If there are more data to send, go to .

### 35.5.3 Data Transfer with DMA

1. Program the FIFO Control Register with the following values:  
Specify the threshold: Set Transmitter FIFO Trigger Level (TFIFOT);  
Enable DMA: Set DMAE = 1;  
Enable FIFO: Set FIFOE = 1.
2. Set a DMA controller to write data to the THR:  
Set THR as the DMA destination.  
Set burst size to 1.  
Set destination data width to one byte.  
Enable hardware handshaking.  
Set DMA terminal count interrupt.  
Set other DMA transfer control registers.
3. The DMA data transfer performs in the background. You will receive a terminal count interrupt from the DMA controller once the data transfer completes.
4. If completion of the data transmission must be guaranteed, wait for the UART TXFIFO empty by checking the THRE bit in the Line Status Register.

### 35.5.4 Receiving Data

The following programming sequence receives data through UART without/with DMA:

### 35.5.5 Data Receive without DMA

1. Set FIFOE in the FIFO Control Register to enable the FIFO.
2. Wait until the Data Ready bit (the DR bit) of the Line Status Register becomes 1.
3. Read one byte of data from the RBR.
4. Go to read more data.

### 35.5.6 Data receive with DMA

1. Program the FIFO Control Register with the following values:

- Specify the threshold: Set Receiver FIFO Trigger Level (RFIFOT);
  - Enable DMA: Set DMAE = 1;
  - Enable FIFO: Set FIFOE = 1.
2. Set a DMA controller to read data from the RBR:
    - Set RBR as the DMA source.
    - Set burst size to 1.
    - Set source data width to one byte.
    - Enable hardware handshaking.
    - Set DMA terminal count interrupt.
    - Set other DMA transfer control registers.
  3. The DMA data transfer performs in the background. You will receive a terminal count interrupt from the DMA controller once the data transfer completes.

